[
    {
        "tags": [
            "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": 1644317269,
                "post_id": 71032520,
                "comment_id": 125568717,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663855167,
                "last_edit_date": 1663855167,
                "creation_date": 1660464999,
                "answer_id": 73350100,
                "question_id": 71032520,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[`jq -c &#39;.[]&#39;`](https://jqplay.org/s/RoG6x-xnlDq) does what you want:\r\n\r\nIn:\r\n\r\n```json\r\n[\r\n {&quot;foo&quot;: 42, &quot;bar&quot;: &quot;less interesting data&quot;},\r\n {&quot;foo&quot;: 42, &quot;bar&quot;: &quot;less interesting data&quot;},\r\n {&quot;foo&quot;: 42, &quot;bar&quot;: &quot;less interesting data&quot;}\r\n]\r\n```\r\n\r\nOut:\r\n\r\n```json\r\n{&quot;foo&quot;:42,&quot;bar&quot;:&quot;less interesting data&quot;}\r\n{&quot;foo&quot;:42,&quot;bar&quot;:&quot;less interesting data&quot;}\r\n{&quot;foo&quot;:42,&quot;bar&quot;:&quot;less interesting data&quot;}\r\n```",
                "title": "jq: remove elements from array and output into a single line each one"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1663855167,
        "creation_date": 1644317105,
        "last_edit_date": 1660464564,
        "question_id": 71032520,
        "body_markdown": "Is there any way to output as &quot;slurp&quot; format and input array?\r\n\r\n```lang-json\r\n[\r\n{ &quot;id&quot;: &quot;id1&quot;, &quot;value&quot;: &quot;value1&quot;},\r\n{ &quot;id&quot;: &quot;id2&quot;, &quot;value&quot;: &quot;value2&quot;}\r\n]\r\n```\r\n\r\nI&#39;d like to get:\r\n\r\n```\r\n{ &quot;id&quot;: &quot;id1&quot;, &quot;value&quot;: &quot;value1&quot;}\r\n{ &quot;id&quot;: &quot;id2&quot;, &quot;value&quot;: &quot;value2&quot;}\r\n```\r\n\r\nEach element outside of array, and each element into a single line.\r\n\r\nI&#39;ve tried with `-c` option. but it generating all array into a single line.\r\n\r\nI mean, `-c` option is generating me:\r\n\r\n```lang-json\r\n[{&quot;id&quot;:&quot;id1&quot;,&quot;value&quot;:&quot;value1&quot;},{&quot;id&quot;:&quot;id2&quot;,&quot;value&quot;:&quot;value2&quot;}]\r\n```",
        "link": "https://stackoverflow.com/questions/71032520/jq-remove-elements-from-array-and-output-into-a-single-line-each-one",
        "title": "jq: remove elements from array and output into a single line each one"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1644334909,
                "post_id": 71036664,
                "comment_id": 125576218,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1644335200,
                "creation_date": 1644335200,
                "answer_id": 71036751,
                "question_id": 71036664,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `strptime` to parse the dates, then `strftime` to format them. `map` can map that filter over your entire list.\r\n\r\n    $ cat tmp.json\r\n    [\r\n      &quot;1934/08/20&quot;,\r\n      &quot;1961/01/10&quot;,\r\n      &quot;1952/01/25&quot;,\r\n      &quot;1967/07/24&quot;\r\n    ]\r\n    $ jq &#39;map(strptime(&quot;%Y/%m/%d&quot;) | strftime(&quot;%F&quot;))&#39; tmp.json\r\n    [\r\n      &quot;1934-08-20&quot;,\r\n      &quot;1961-01-10&quot;,\r\n      &quot;1952-01-25&quot;,\r\n      &quot;1967-07-24&quot;\r\n    ]\r\n\r\n\r\n(`%F` is a shortcut, where available, for `%Y-%m-%d`.)",
                "title": "jq: replache slash by dash chracter"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1644335418,
                "creation_date": 1644335418,
                "answer_id": 71036810,
                "question_id": 71036664,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you want to replace all the `/` with `-`&#39;s, [`gsub`][1] is the way to go:\r\n```\r\njq &#39;map(gsub(&quot;\\/&quot;; &quot;-&quot;))&#39;\r\n```\r\n\r\nWill produce\r\n```json\r\n[\r\n  &quot;1934-08-20&quot;,\r\n  &quot;1961-01-10&quot;,\r\n  &quot;1952-01-25&quot;,\r\n  &quot;1967-07-24&quot;\r\n]\r\n```\r\n\r\nAs you can test in [this online demo](https://jqplay.org/s/4wwrBRMljn)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#gsub(regex;string),gsub(regex;string;flags)",
                "title": "jq: replache slash by dash chracter"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1644335418,
        "creation_date": 1644334847,
        "question_id": 71036664,
        "body_markdown": "I need to replace slash character by `&quot;-&quot;`.\r\n\r\nI mean:\r\n\r\n```lang-json\r\n[\r\n  &quot;1934/08/20&quot;,\r\n  &quot;1961/01/10&quot;,\r\n  &quot;1952/01/25&quot;,\r\n  &quot;1967/07/24&quot;\r\n]\r\n```\r\n\r\nI need:\r\n\r\n```lang-json\r\n[\r\n  &quot;1934-0820&quot;,\r\n  &quot;1961-01-10&quot;,\r\n  &quot;1952-01-25&quot;,\r\n  &quot;1967-07-24&quot;\r\n]\r\n```\r\n\r\nIs there anyway to get it?",
        "link": "https://stackoverflow.com/questions/71036664/jq-replache-slash-by-dash-chracter",
        "title": "jq: replache slash by dash chracter"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1644347527,
                "creation_date": 1644347527,
                "answer_id": 71039594,
                "question_id": 71039547,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the pipe you are changing the context down to an array element, which is what you want for the selection. If you put parentheses around the pipe and the selection, you will keep the assignment and thus the filter&#39;s output on top-level:\r\n~~~sh\r\njq &#39;(.users[] | select(.username == &quot;admin&quot;)).queue += [&quot;dev&quot;]&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;users&quot;: [\r\n    {\r\n      &quot;username&quot;: &quot;karim&quot;,\r\n      &quot;queue&quot;: [\r\n        &quot;default&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;username&quot;: &quot;admin&quot;,\r\n      &quot;queue&quot;: [\r\n        &quot;apps&quot;,\r\n        &quot;prod&quot;,\r\n        &quot;dev&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/WGc_MgUEFW)",
                "title": "jq How to filter array and add element"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1644347527,
        "creation_date": 1644347345,
        "question_id": 71039547,
        "body_markdown": "using jq i&#39;m trying to add data to a specific element in my json below :\r\n\r\n    {\r\n      &quot;users&quot;: [\r\n        {\r\n          &quot;username&quot;: &quot;karim&quot;,\r\n          &quot;queue&quot;: [\r\n            &quot;default&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;username&quot;: &quot;admin&quot;,\r\n          &quot;queue&quot;: [\r\n            &quot;apps&quot;,\r\n            &quot;prod&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nwhat i want to do is to add items in queue[] of user admin like this \r\n\r\n    {\r\n      &quot;users&quot;: [\r\n        {\r\n          &quot;username&quot;: &quot;hive&quot;,\r\n          &quot;queue&quot;: [\r\n            &quot;default&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;username&quot;: &quot;admin&quot;,\r\n          &quot;queue&quot;: [\r\n            &quot;apps&quot;,\r\n            &quot;prod&quot;,\r\n            &quot;dev&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nThis is the command i used\r\n\r\n    jq &#39;.users[] | select(.username == &quot;admin&quot;).queue += [&quot;dev&quot;]&#39; file.json\r\n\r\nBut the result is not as expected\r\n\r\n    {\r\n      &quot;username&quot;: &quot;hive&quot;,\r\n      &quot;queue&quot;: [\r\n        &quot;default&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;username&quot;: &quot;admin&quot;,\r\n      &quot;queue&quot;: [\r\n        &quot;apps&quot;,\r\n        &quot;prod&quot;,\r\n        &quot;dev&quot;\r\n      ]\r\n    }\r\n\r\nWhy users array doesn&#39;t appear ? I need to keep it in the result",
        "link": "https://stackoverflow.com/questions/71039547/jq-how-to-filter-array-and-add-element",
        "title": "jq How to filter array and add element"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1644350321,
                "last_edit_date": 1644350321,
                "creation_date": 1644349655,
                "answer_id": 71040018,
                "question_id": 71039966,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\njq -r &#39;&quot;\\( .apps.name ) \\( .result )&quot;&#39; |\r\nwhile read -r app result; do\r\n   curl -XPOST http://localhost --data-raw &quot;app=$app result=$result&quot;\r\ndone\r\n```\r\n\r\nor\r\n\r\n```sh\r\njq -r &#39;&quot;app=\\( .apps.name ) result=\\( .result )&quot;&#39; |\r\nwhile read -r data; do\r\n   curl -XPOST http://localhost --data-raw &quot;$data&quot;\r\ndone\r\n```\r\n\r\nThe first one assumes the name can&#39;t contain whitespace.\r\n",
                "title": "Pass jq output to curl"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1644350047,
                "creation_date": 1644350047,
                "answer_id": 71040095,
                "question_id": 71039966,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe something like this?\r\n\r\n```\r\njq &lt; data.json &#39;[.apps.name, .result]|@tsv&#39; -r | while read appsName result; do\r\n    curl -XPOST http://localhost --data-raw &quot;$appsName $result&quot;\r\ndone\r\n```",
                "title": "Pass jq output to curl"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1644353921,
                "last_edit_date": 1644353921,
                "creation_date": 1644350160,
                "answer_id": 71040113,
                "question_id": 71039966,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Would this do it?\r\n~~~sh\r\nwhile read -r line; do\r\n  curl -XPOST http://localhost --data-raw &quot;$line&quot;\r\ndone &lt; &lt;(jq -r &#39;&quot;app=\\(.apps.name) result=\\(.result)&quot;&#39; myfile.json)\r\n~~~",
                "title": "Pass jq output to curl"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1644430507,
                "last_edit_date": 1644430507,
                "creation_date": 1644351704,
                "answer_id": 71040391,
                "question_id": 71039966,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think xargs is better than while loops. Maybe just personal preference.\r\n\r\n```bash\r\njq -r &#39;&quot;app=\\( .apps.name ) result=\\( .result )&quot;&#39; \\\r\n  | xargs -r -I{} curl -XPOST http://localhost --data-raw &quot;{}&quot;\r\n```",
                "title": "Pass jq output to curl"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1644430507,
        "creation_date": 1644349408,
        "last_edit_date": 1644350075,
        "question_id": 71039966,
        "body_markdown": "I want to be use a number of values from jq piped to curl. I have json data with a structure that looks something like this\r\n\r\n```\r\n{\r\n  &quot;apps&quot;: {\r\n    &quot;code&quot;: &quot;200&quot;,\r\n    &quot;name&quot;: &quot;app1&quot;,\r\n  },\r\n  &quot;result&quot;: &quot;1&quot;\r\n}\r\n{\r\n  &quot;apps&quot;: {\r\n    &quot;code&quot;: &quot;200&quot;,\r\n    &quot;name&quot;: &quot;app2&quot;,\r\n  },\r\n  &quot;result&quot;: &quot;5&quot;\r\n}\r\n...\r\n...\r\n...\r\n\r\n```\r\n\r\nWhat I want to do is to take the values of every apps.name and result and pass that to curl:\r\n```\r\ncurl -XPOST http://localhost --data-raw &#39;app=$appsName result=$result&#39;\r\n```\r\nThe curl command will then run X amount of times depending on how many objects there are.\r\nIn jq I came up with this but I don&#39;t know how or the best way of passing this to curl in a loop.\r\n\r\n```\r\njq -r &#39;.result as $result | .apps as $apps | $apps.name + &quot; &quot; + $result myfile.json\r\n```",
        "link": "https://stackoverflow.com/questions/71039966/pass-jq-output-to-curl",
        "title": "Pass jq output to curl"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1644350591,
                "creation_date": 1644350591,
                "answer_id": 71040203,
                "question_id": 71040128,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Create an `INDEX` to lookup in, then `map` each element you want to change according to the index.\r\n\r\n~~~sh\r\njq &#39;\r\n  INDEX(.release.services[]; .service) as $index\r\n  | {servers} | .servers[].services[] |= $index[.].URL\r\n&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;servers&quot;: [\r\n    {\r\n      &quot;location&quot;: &quot;server4&quot;,\r\n      &quot;services&quot;: [\r\n        &quot;/srv07_service/v1.19.0&quot;,\r\n        &quot;/srv06_serv/v1.13.0&quot;,\r\n        &quot;/srv01_service/v1.20.0&quot;,\r\n        &quot;/srv04_service/v1.18.0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;server2&quot;,\r\n      &quot;services&quot;: [\r\n        &quot;/srv07_service/v1.19.0&quot;,\r\n        &quot;/srv02_service/v1.14.0&quot;,\r\n        &quot;/srv05_service/v1.14.0&quot;,\r\n        &quot;/srv03_service/v1.15.0&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/clxujSEL6e)",
                "title": "mapping array of keys to array of values for substitution"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1644350591,
        "creation_date": 1644350239,
        "question_id": 71040128,
        "body_markdown": "Given this data, which is two distinct objects, one having an array of keys and the other a dictionary of key value pairs:\r\n\r\n```\r\n{\r\n  &quot;servers&quot;: [\r\n    {\r\n      &quot;location&quot;: &quot;server4&quot;,\r\n      &quot;services&quot;: [\r\n        &quot;srv07&quot;,\r\n        &quot;srv06&quot;,\r\n        &quot;srv01&quot;,\r\n        &quot;srv04&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;server2&quot;,\r\n      &quot;services&quot;: [\r\n        &quot;srv07&quot;,\r\n        &quot;srv02&quot;,\r\n        &quot;srv05&quot;,\r\n        &quot;srv03&quot;\r\n      ]\r\n    }\r\n  ],\r\n  &quot;release&quot;: {\r\n    &quot;id&quot;: &quot;release1&quot;,\r\n    &quot;services&quot;: [\r\n      {\r\n        &quot;service&quot;: &quot;srv01&quot;,\r\n        &quot;URL&quot;: &quot;/srv01_service/v1.20.0&quot;\r\n      },\r\n      {\r\n        &quot;service&quot;: &quot;srv02&quot;,\r\n        &quot;URL&quot;: &quot;/srv02_service/v1.14.0&quot;\r\n      },\r\n      {\r\n        &quot;service&quot;: &quot;srv03&quot;,\r\n        &quot;URL&quot;: &quot;/srv03_service/v1.15.0&quot;\r\n      },\r\n      {\r\n        &quot;service&quot;: &quot;srv04&quot;,\r\n        &quot;URL&quot;: &quot;/srv04_service/v1.18.0&quot;\r\n      },\r\n      {\r\n        &quot;service&quot;: &quot;srv05&quot;,\r\n        &quot;URL&quot;: &quot;/srv05_service/v1.14.0&quot;\r\n      },\r\n      {\r\n        &quot;service&quot;: &quot;srv06&quot;,\r\n        &quot;URL&quot;: &quot;/srv06_serv/v1.13.0&quot;\r\n      },\r\n      {\r\n        &quot;service&quot;: &quot;srv07&quot;,\r\n        &quot;URL&quot;: &quot;/srv07_service/v1.19.0&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nI am trying to produce this, the first object with the keys replaced with the values from the dictionary.  NOTE:  I would be fine with renaming services[] to URLs[] if it makes things easier.\r\n```\r\n{\r\n  &quot;servers&quot;: [\r\n    {\r\n      &quot;location&quot;: &quot;server4&quot;,\r\n      &quot;services&quot;: [\r\n        &quot;/srv07_service/v1.19.0&quot;,\r\n        &quot;/srv06_serv/v1.13.0&quot;,\r\n        &quot;/srv01_service/v1.20.0&quot;,\r\n        &quot;/srv04_service/v1.18.0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;server2&quot;,\r\n      &quot;services&quot;: [\r\n        &quot;/srv07_service/v1.19.0&quot;,\r\n        &quot;/srv02_service/v1.14.0&quot;,\r\n        &quot;/srv05_service/v1.14.0&quot;,\r\n        &quot;/srv03_service/v1.15.0&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nMy latest attempt is close but returns something akin to a Cartesian.\r\n\r\n```\r\n. |  .servers[].services[] = (.servers[] as $s | .release.services[] | select(.service as $v | $s.services[] | index($v)).URL) | {servers}   \r\n```\r\n",
        "link": "https://stackoverflow.com/questions/71040128/mapping-array-of-keys-to-array-of-values-for-substitution",
        "title": "mapping array of keys to array of values for substitution"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644351926,
                "post_id": 71040411,
                "comment_id": 125583194,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1644358980,
                "last_edit_date": 1644358980,
                "creation_date": 1644353371,
                "answer_id": 71040708,
                "question_id": 71040411,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Grab the source value, chop off the last three digits to turn the number into seconds and call `todate` to convert it into a date string (GMT).\r\n\r\n~~~sh\r\njq -c &#39;.birthDate |= (.value.&quot;$date&quot;.&quot;$numberLong&quot;[:-3] | tonumber | todate[:10])&#39;\r\n~~~\r\n~~~json\r\n{&quot;_id&quot;:&quot;ae53d3ec-8fc3-44fc-a7eb-f2f32da4eaae&quot;,&quot;birthDate&quot;:&quot;1955-02-10&quot;}\r\n{&quot;_id&quot;:&quot;ef92c3e4-d5d7-4b81-8a0b-1ab1eac10331&quot;,&quot;birthDate&quot;:&quot;1942-12-01&quot;}\r\n~~~\r\n[Demo](https://jqplay.org/s/kzs7QGawM_)\r\n",
                "title": "jq: convert milliseconds to date"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1644360416,
                "last_edit_date": 1644360416,
                "creation_date": 1644357822,
                "answer_id": 71041432,
                "question_id": 71040411,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\n.birthDate |= (\r\n   .value.&quot;$date&quot;.&quot;$numberLong&quot; |\r\n   tonumber |\r\n   . / 1000 |\r\n   strftime(&quot;%F&quot;)\r\n)\r\n```\r\n\r\nWith `-c`, this produces the desired output exactly.\r\n\r\n```json\r\n{&quot;_id&quot;:&quot;ae53d3ec-8fc3-44fc-a7eb-f2f32da4eaae&quot;,&quot;birthDate&quot;:&quot;1955-02-10&quot;}\r\n{&quot;_id&quot;:&quot;ef92c3e4-d5d7-4b81-8a0b-1ab1eac10331&quot;,&quot;birthDate&quot;:&quot;1942-12-01&quot;}\r\n```\r\n\r\n[Demo](https://jqplay.org/s/vA8nhNBl_Q) on jqplay\r\n\r\n",
                "title": "jq: convert milliseconds to date"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1644360416,
        "creation_date": 1644351824,
        "question_id": 71040411,
        "body_markdown": "I need to convert seconds to date:\r\n\r\nMy input documents are:\r\n\r\n```\r\n{&quot;_id&quot;:&quot;ae53d3ec-8fc3-44fc-a7eb-f2f32da4eaae&quot;,&quot;birthDate&quot;:{&quot;value&quot;:{&quot;$date&quot;:{&quot;$numberLong&quot;:&quot;-469929600000&quot;}}}}\r\n{&quot;_id&quot;:&quot;ef92c3e4-d5d7-4b81-8a0b-1ab1eac10331&quot;,&quot;birthDate&quot;:{&quot;value&quot;:{&quot;$date&quot;:{&quot;$numberLong&quot;:&quot;-854755200000&quot;}}}}\r\n```\r\n\r\nI need to get:\r\n\r\n```\r\n{&quot;_id&quot;:&quot;ae53d3ec-8fc3-44fc-a7eb-f2f32da4eaae&quot;,&quot;birthDate&quot;:&quot;1955-02-10&quot;}\r\n{&quot;_id&quot;:&quot;ef92c3e4-d5d7-4b81-8a0b-1ab1eac10331&quot;,&quot;birthDate&quot;:&quot;1942-12-01&quot;}\r\n```\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/71040411/jq-convert-milliseconds-to-date",
        "title": "jq: convert milliseconds to date"
    },
    {
        "tags": [
            "python",
            "json",
            "jq",
            "nested-lists"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3197460,
                    "reputation": 79011,
                    "user_id": 3620003,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://i.sstatic.net/QnqtZ.jpg?s=256",
                    "display_name": "timgeb",
                    "link": "https://stackoverflow.com/users/3620003/timgeb"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644420357,
                "post_id": 71052248,
                "comment_id": 125602873,
                "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": 0,
                "creation_date": 1644420779,
                "post_id": 71052248,
                "comment_id": 125603047,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7529773,
                    "reputation": 83,
                    "user_id": 8520561,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xLdLT.jpg?s=256",
                    "display_name": "Magic Thighs",
                    "link": "https://stackoverflow.com/users/8520561/magic-thighs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644423047,
                "post_id": 71052248,
                "comment_id": 125604058,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1644422134,
                "last_edit_date": 1644422134,
                "creation_date": 1644421165,
                "answer_id": 71052518,
                "question_id": 71052248,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\ndel( .. | objects | .comment )\r\n```\r\n\r\n[Demo](https://jqplay.org/s/6-7sl0JDto) on jqplay\r\n\r\n---\r\n\r\nIn Python, it would look something like this:\r\n\r\n```python\r\ndef remove_comments(node):\r\n   if isinstance(node, dict):\r\n      if &#39;comment&#39; in node:\r\n         del node[&#39;comment&#39;]\r\n      for child in node.values():\r\n         remove_comments(child)\r\n   elif isinstance(node, list):\r\n      for child in node:\r\n         remove_comments(child)\r\n```\r\n",
                "title": "How to use jq (or python) to remove a particular key(?) in some JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1644422134,
        "creation_date": 1644420130,
        "question_id": 71052248,
        "body_markdown": "Here is the input json. It is a partial JSON dump of a puppet class extracted from Red Hat Satellite.\r\n\r\n```\r\n{\r\n  &quot;Id&quot;: 9999,\r\n  &quot;Match&quot;: &quot;fqdn=server.fqdn.com&quot;,\r\n  &quot;Value&quot;: {\r\n    &quot;user1&quot;: {\r\n      &quot;order&quot;: 90,\r\n      &quot;nofile&quot;: {\r\n        &quot;comment&quot;: &quot;I want to lose this comment&quot;,\r\n        &quot;soft&quot;: &quot;65535&quot;,\r\n        &quot;hard&quot;: &quot;65535&quot;\r\n      },\r\n      &quot;nproc&quot;: {\r\n        &quot;comment&quot;: &quot;I want to lose this also&quot;,\r\n        &quot;soft&quot;: &quot;32768&quot;,\r\n        &quot;hard&quot;: &quot;32768&quot;\r\n      }\r\n      },\r\n    &quot;user2&quot;: {\r\n      &quot;order&quot;: 90,\r\n      &quot;nofile&quot;: {\r\n        &quot;comment&quot;: &quot;I want to lose this comment&quot;,\r\n        &quot;soft&quot;: &quot;65535&quot;,\r\n        &quot;hard&quot;: &quot;65535&quot;\r\n      },\r\n      &quot;nproc&quot;: {\r\n        &quot;comment&quot;: &quot;I want to lose this also&quot;,\r\n        &quot;soft&quot;: &quot;32768&quot;,\r\n        &quot;hard&quot;: &quot;32768&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n```\r\nI want to delete all the &quot;comment&quot;s. I can&#39;t find an example that does this, or an explanation of something that does this in general. Or I am too stupid to understand what I have read so far.\r\n\r\nSo my output would be\r\n\r\n```\r\n{\r\n  &quot;Id&quot;: 9999,\r\n  &quot;Match&quot;: &quot;fqdn=server.fqdn.com&quot;,\r\n  &quot;Value&quot;: {\r\n    &quot;user1&quot;: {\r\n      &quot;order&quot;: 90,\r\n      &quot;nofile&quot;: {\r\n        &quot;soft&quot;: &quot;65535&quot;,\r\n        &quot;hard&quot;: &quot;65535&quot;\r\n      },\r\n      &quot;nproc&quot;: {\r\n        &quot;soft&quot;: &quot;32768&quot;,\r\n        &quot;hard&quot;: &quot;32768&quot;\r\n      }\r\n      },\r\n    &quot;user2&quot;: {\r\n      &quot;order&quot;: 90,\r\n      &quot;nofile&quot;: {\r\n        &quot;soft&quot;: &quot;65535&quot;,\r\n        &quot;hard&quot;: &quot;65535&quot;\r\n      },\r\n      &quot;nproc&quot;: {\r\n        &quot;soft&quot;: &quot;32768&quot;,\r\n        &quot;hard&quot;: &quot;32768&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n```\r\nAny takers?",
        "link": "https://stackoverflow.com/questions/71052248/how-to-use-jq-or-python-to-remove-a-particular-key-in-some-json",
        "title": "How to use jq (or python) to remove a particular key(?) in some JSON?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "string",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644427336,
                "post_id": 71053907,
                "comment_id": 125605925,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4884324,
                    "reputation": 1436,
                    "user_id": 3937208,
                    "user_type": "registered",
                    "accept_rate": 29,
                    "profile_image": "https://www.gravatar.com/avatar/b5ab1bebd8f28171a5a842f379090e5e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Yash",
                    "link": "https://stackoverflow.com/users/3937208/yash"
                },
                "reply_to_user": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644428505,
                "post_id": 71053907,
                "comment_id": 125606370,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644428591,
                "post_id": 71053907,
                "comment_id": 125606402,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4884324,
                    "reputation": 1436,
                    "user_id": 3937208,
                    "user_type": "registered",
                    "accept_rate": 29,
                    "profile_image": "https://www.gravatar.com/avatar/b5ab1bebd8f28171a5a842f379090e5e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Yash",
                    "link": "https://stackoverflow.com/users/3937208/yash"
                },
                "reply_to_user": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644428885,
                "post_id": 71053907,
                "comment_id": 125606516,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644429339,
                "post_id": 71053907,
                "comment_id": 125606700,
                "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": 1644443899,
                "post_id": 71053907,
                "comment_id": 125611856,
                "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": 1644443929,
                "post_id": 71053907,
                "comment_id": 125611864,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4884324,
                    "reputation": 1436,
                    "user_id": 3937208,
                    "user_type": "registered",
                    "accept_rate": 29,
                    "profile_image": "https://www.gravatar.com/avatar/b5ab1bebd8f28171a5a842f379090e5e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Yash",
                    "link": "https://stackoverflow.com/users/3937208/yash"
                },
                "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": 1644921666,
                "post_id": 71053907,
                "comment_id": 125727576,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1644444842,
                "creation_date": 1644444842,
                "answer_id": 71057464,
                "question_id": 71053907,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```bash\r\neval &quot;array=($( jq -r &#39;map( @sh ) | join(&quot; &quot;)&#39; &lt;&lt;&lt;&quot;$json&quot; ))&quot;\r\n```\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "How to parse and convert string list to JSON string array in shell command?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1644453046,
                "last_edit_date": 1644453046,
                "creation_date": 1644452609,
                "answer_id": 71058415,
                "question_id": 71053907,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As `bash` and `jq` are tagged, this solution relies on both (without summoning `eval`). The input string is expected to be in `$string`, the output array is generated into `${array[@]}`. It is robust wrt spaces, newlines, quotes, etc. as it uses `NUL` as delimiter.\r\n~~~sh\r\nmapfile -d &#39;&#39; array &lt; &lt;(jq -j &#39;.[] + &quot;\\u0000&quot;&#39; &lt;&lt;&lt; &quot;$string&quot;)\r\n~~~\r\n\r\n##### Testing\r\n~~~sh\r\nstring=&#39;[&quot;has spaces\\tand tabs&quot;,&quot;has a\\nnewline&quot;,&quot;has \\&quot;quotes\\&quot;&quot;]&#39;\r\nmapfile -d &#39;&#39; array &lt; &lt;(jq -j &#39;.[] + &quot;\\u0000&quot;&#39; &lt;&lt;&lt; &quot;$string&quot;)\r\nprintf &#39;==&gt;%s&lt;==\\n&#39; &quot;${array[@]}&quot;\r\n~~~\r\n~~~\r\n==&gt;has spaces\tand tabs&lt;==\r\n==&gt;has a\r\nnewline&lt;==\r\n==&gt;has &quot;quotes&quot;&lt;==\r\n~~~",
                "title": "How to parse and convert string list to JSON string array in shell command?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -4,
        "last_activity_date": 1644453046,
        "creation_date": 1644426909,
        "question_id": 71053907,
        "body_markdown": "How to parse and convert string list to JSON string array in shell command?\r\n\r\n    &#39;[&quot;test1&quot;,&quot;test2&quot;,&quot;test3&quot;]&#39;\r\nto \r\n\r\n    test1\r\n    test2\r\n    test3\r\n\r\nI tried like below:\r\n\r\n    string=$1\r\n    array=${string#&quot;[&quot;}\r\n    array=${array%&quot;]&quot;}\r\n    \r\n    IFS=&#39;,&#39; read -a array &lt;&lt;&lt; $array; \r\n    \r\n    echo &quot;${array[@]}&quot;\r\n\r\nAny other optimized way?",
        "link": "https://stackoverflow.com/questions/71053907/how-to-parse-and-convert-string-list-to-json-string-array-in-shell-command",
        "title": "How to parse and convert string list to JSON string array in shell command?"
    },
    {
        "tags": [
            "jq",
            "kubectl"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1644450329,
                "creation_date": 1644450329,
                "answer_id": 71058192,
                "question_id": 71058051,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This solution retrieves the active cluster using an `INDEX` construction, then just sets the new field directly without modifying the context:\r\n~~~sh\r\njq &#39;\r\n  INDEX(.contexts[]; .name)[.&quot;current-context&quot;].context.cluster as $cluster\r\n  | (.clusters[] | select(.name == $cluster)).&quot;proxy-url&quot; = &quot;my-url&quot;\r\n&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;clusters&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;cluster1&quot;,\r\n      &quot;field&quot;: &quot;field1&quot;,\r\n      &quot;proxy-url&quot;: &quot;my-url&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;cluster2&quot;,\r\n      &quot;field&quot;: &quot;field2&quot;\r\n    }\r\n  ],\r\n  &quot;contexts&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;context1&quot;,\r\n      &quot;context&quot;: {\r\n        &quot;cluster&quot;: &quot;cluster1&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;context2&quot;,\r\n      &quot;context&quot;: {\r\n        &quot;cluster&quot;: &quot;cluster2&quot;\r\n      }\r\n    }\r\n  ],\r\n  &quot;current-context&quot;: &quot;context1&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/bME9TSA_jD)",
                "title": "Updating an array element identified by other fields in the object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1644450329,
        "creation_date": 1644449110,
        "question_id": 71058051,
        "body_markdown": "# Goal\r\nI&#39;d like to add a `proxy-url` field to the currently active `clusters` entry of my kubeconfig file. The &quot;active&quot; cluster is identified by the &quot;active&quot; context, which is itself identified by a top-level key `current-context`. Simplified, the JSON object looks something like:\r\n\r\n```json\r\n{\r\n  &quot;clusters&quot;:[\r\n    {\r\n      &quot;name&quot;:&quot;cluster1&quot;,\r\n      &quot;field&quot;:&quot;field1&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;:&quot;cluster2&quot;,\r\n      &quot;field&quot;:&quot;field2&quot;\r\n    }\r\n  ],\r\n  &quot;contexts&quot;:[\r\n    {\r\n      &quot;name&quot;:&quot;context1&quot;,\r\n      &quot;context&quot;: {\r\n        &quot;cluster&quot;:&quot;cluster1&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;:&quot;context2&quot;,\r\n      &quot;context&quot;: {\r\n        &quot;cluster&quot;:&quot;cluster2&quot;\r\n      }\r\n    }\r\n  ],\r\n  &quot;current-context&quot;: &quot;context1&quot;\r\n}\r\n```\r\n\r\nAnd I&#39;d like to update the `clusters` entry for `cluster1` from:\r\n```json\r\n{\r\n  &quot;name&quot;:&quot;cluster1&quot;,\r\n  &quot;field&quot;:&quot;field1&quot;\r\n}\r\n```\r\n\r\nto\r\n\r\n```json\r\n{\r\n  &quot;name&quot;:&quot;cluster1&quot;,\r\n  &quot;field&quot;:&quot;field1&quot;,\r\n  &quot;proxy-url&quot;:&quot;my-url&quot;\r\n}\r\n```\r\n\r\n# First attempt\r\n\r\n```bash\r\njq &#39;. as $o\r\n  | $o.&quot;current-context&quot; as $current_context_name\r\n  | $o.contexts[] | select(.name == $current_context_name) as $context\r\n  | $o.clusters[] | select(.name == $context.context.cluster)\r\n  | .proxy_id |= &quot;my-url&quot;&#39;\r\n```\r\ngives me\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;cluster1&quot;,\r\n  &quot;field&quot;: &quot;field1&quot;,\r\n  &quot;proxy_id&quot;: &quot;my-url&quot;\r\n}\r\n```\r\n-- great! But I need the rest of the object too.\r\n\r\n# Parentheses almost work\r\nWith parentheses, I can get the whole object back &amp; add a &quot;proxy-url&quot; field to the active _context_, but I can&#39;t take it one step further to update the active _cluster_. This filter:\r\n\r\n```bash\r\njq &#39;(. as $o\r\n  | $o.&quot;current-context&quot; as $current_context_name\r\n  | $o.contexts[] | select(.name == $current_context_name)\r\n  | .&quot;proxy-url&quot;)\r\n  |= &quot;my-url&quot;&#39;\r\n```\r\n\r\nworks mint:\r\n\r\n```json\r\n{\r\n  &quot;clusters&quot;: [...],  // omitted for brevity, unchanged\r\n  &quot;contexts&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;context1&quot;,\r\n      &quot;context&quot;: {\r\n        &quot;cluster&quot;: &quot;cluster1&quot;\r\n      },\r\n      &quot;proxy-url&quot;: &quot;my-url&quot;  // tada!\r\n    },\r\n    {...}  // omitted for brevity, unchanged\r\n  ],\r\n  &quot;current-context&quot;: &quot;context1&quot;\r\n}\r\n```\r\n\r\nTrying to take it one step further (to update the `cluster` identified by that `context`, instead):\r\n\r\n```bash\r\njq &#39;(. as $o\r\n  | $o.&quot;current-context&quot; as $current_context_name\r\n  | $o.contexts[] | select(.name == $current_context_name) as $context\r\n  | $o.clusters[] | select(.name == $context.context.cluster)\r\n  | .&quot;proxy-url&quot;)\r\n  |= &quot;my-url&quot;&#39;\r\n```\r\n\r\ngives me the following error:\r\n\r\n```bash\r\njq: error (at &lt;stdin&gt;:26): Invalid path expression near attempt to access element &quot;clusters&quot; of {&quot;clusters&quot;:[{&quot;name&quot;:&quot;clus...\r\nexit status 5\r\n```\r\n\r\nHow can I use the `$context.context.cluster` result to update the relevant `clusters` entry? I don&#39;t understand why this approach works for adding something to `contexts` but not to `clusters`.\r\n\r\n# Dirty solution\r\nI can kludge together a new `clusters` entry &amp; merge that with the top-level object:\r\n```bash\r\njq &#39;. as $o\r\n  | $o.&quot;current-context&quot; as $current_context_name\r\n  | $o.contexts[] | select(.name == $current_context_name) as $context\r\n  | $o + {&quot;clusters&quot;: [($o.clusters[] | select(.name == $context.context.cluster).&quot;proxy-url&quot; |= &quot;my-url&quot;)]}\r\n```\r\nbut this feels a bit fragile.",
        "link": "https://stackoverflow.com/questions/71058051/updating-an-array-element-identified-by-other-fields-in-the-object-using-jq",
        "title": "Updating an array element identified by other fields in the object using jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "jtc"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 24151628,
                    "reputation": 79,
                    "user_id": 18116384,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJzdmX7lv-cWCqJqHX1iDjh7s5Nn7-p7M_QisJ6m=k-s256",
                    "display_name": "cbetsworth_echo",
                    "link": "https://stackoverflow.com/users/18116384/cbetsworth-echo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644451660,
                "post_id": 71058266,
                "comment_id": 125613788,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3348672,
                    "reputation": 44978,
                    "user_id": 2813224,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/neWlajPN.png?s=256",
                    "display_name": "zer00ne",
                    "link": "https://stackoverflow.com/users/2813224/zer00ne"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644452468,
                "post_id": 71058266,
                "comment_id": 125613950,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1644451680,
                "creation_date": 1644451680,
                "answer_id": 71058329,
                "question_id": 71058266,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Cancel the fractional seconds and you&#39;re good to go with `fromdate`. To escape within the regex, use double backslashes.\r\n~~~sh\r\njq &#39;map(.time |= (sub(&quot;\\\\.\\\\d+&quot;; &quot;&quot;) | fromdate))&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;time&quot;: 1643392231\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/1DV-wFaIQt)",
                "title": "Need help updating time element with output from jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1644459973,
                "creation_date": 1644459973,
                "answer_id": 71059085,
                "question_id": 71058266,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You mapped all the values in the array but you&#39;re not actually modifying or recreating the array.\r\n\r\nTo modify, use an assignment: (you were almost there)\r\n\r\n```\r\n.[].time |= (sub(&quot;\\\\.\\\\d+Z$&quot;; &quot;Z&quot;) | fromdate)\r\n```\r\n\r\nTo recreate, map it.\r\n\r\n```\r\nmap(.time |= (sub(&quot;\\\\.\\\\d+Z$&quot;; &quot;Z&quot;) | fromdate))\r\n```",
                "title": "Need help updating time element with output from jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1644459973,
        "creation_date": 1644451026,
        "question_id": 71058266,
        "body_markdown": "Current object with proposed format\r\n```\r\n[\r\n  {\r\n    &quot;time&quot;: &quot;2022-01-28T17:50:31.620Z&quot;\r\n  }\r\n]\r\n```\r\nCommand executed to convert from iso8601 to unix\r\n\r\njq &#39;.[].time | sub(&quot;\\\\.[0-9]+Z$&quot;; &quot;Z&quot;) | fromdate&#39; time_test.json\r\n\r\nOutput\r\n1643392231\r\n\r\nI&#39;ve tried varying combinations but how to do I update the time value in the object. I can get the conversion to work but can&#39;t seem to update the value with the output. \r\n\r\nExpected Result - \r\n```\r\n[\r\n  {\r\n    &quot;time&quot;: &quot;1643392231&quot;\r\n  }\r\n]\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/71058266/need-help-updating-time-element-with-output-from-jq",
        "title": "Need help updating time element with output from jq?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1644491614,
                "creation_date": 1644491614,
                "answer_id": 71064085,
                "question_id": 71063945,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This generates your desired output (keys as first, rows as second column),  formatted as CSV with escaping of delimiters used in the data and quotes around the fields:\r\n~~~sh\r\njq -r &#39;.[] | to_entries[] | [.[]] | @csv&#39;\r\n~~~\r\n~~~\r\n&quot;dhcp-libs&quot;,&quot;12:4.2.5-83.el7.centos.1&quot;\r\n&quot;perl-Time-Local&quot;,&quot;1.2300-2.el7&quot;\r\n&quot;kbd-legacy&quot;,&quot;1.15.5-15.el7&quot;\r\n&quot;perl-Scalar-List-Utils&quot;,&quot;1.27-248.el7&quot;\r\n...\r\n~~~\r\n[Demo](https://jqplay.org/s/6mE-c4f_j_)\r\n\r\nIf you don&#39;t want the quotes, you could use `join(&quot;,&quot;)` instead of `@csv` but this wouldn&#39;t do any escaping either:\r\n~~~sh\r\njq -r &#39;.[] | to_entries[] | [.[]] | join(&quot;,&quot;)&#39;\r\n~~~\r\n~~~\r\ndhcp-libs,12:4.2.5-83.el7.centos.1\r\nperl-Time-Local,1.2300-2.el7\r\nkbd-legacy,1.15.5-15.el7\r\nperl-Scalar-List-Utils,1.27-248.el7\r\n...\r\n~~~\r\n[Demo](https://jqplay.org/s/42_4EUwm4g)",
                "title": "jq convert to csv with keys to column rows"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1644491622,
                "creation_date": 1644491622,
                "answer_id": 71064087,
                "question_id": 71063945,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use\r\n```\r\njq -r &#39;.[] | to_entries[] | [ .key, .value ] | join(&quot;,&quot;)&#39;\r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/VTqgX01i76)&lt;/kbd&gt;\r\n\r\nin order to get key-value pairs without quotes",
                "title": "jq convert to csv with keys to column rows"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1652880263,
        "creation_date": 1644490980,
        "last_edit_date": 1652880263,
        "question_id": 71063945,
        "body_markdown": "I have JSON example like this\r\n```\r\n{\r\n  &quot;server1&quot;: {\r\n    &quot;dhcp-libs&quot;: &quot;12:4.2.5-83.el7.centos.1&quot;,\r\n    &quot;perl-Time-Local&quot;: &quot;1.2300-2.el7&quot;,\r\n    &quot;kbd-legacy&quot;: &quot;1.15.5-15.el7&quot;,\r\n    &quot;perl-Scalar-List-Utils&quot;: &quot;1.27-248.el7&quot;,\r\n    &quot;ncurses-base&quot;: &quot;5.9-14.20130511.el7_4&quot;,\r\n    &quot;firewalld&quot;: &quot;0.6.3-13.el7_9&quot;,\r\n    &quot;perl-threads&quot;: &quot;1.87-4.el7&quot;,\r\n    &quot;aic94xx-firmware&quot;: &quot;30-6.el7&quot;,\r\n    &quot;kpartx&quot;: &quot;0.4.9-135.el7_9&quot;,\r\n    &quot;perl-Getopt-Long&quot;: &quot;2.40-3.el7&quot;,\r\n    &quot;basesystem&quot;: &quot;10.0-7.el7.centos&quot;,\r\n    &quot;rsyslog&quot;: &quot;8.24.0-57.el7_9.1&quot;,\r\n    &quot;libtirpc&quot;: &quot;0.2.4-0.16.el7&quot;,\r\n    &quot;python3-libs&quot;: &quot;3.6.8-18.el7&quot;,\r\n    &quot;btrfs-progs&quot;: &quot;4.9.1-1.el7&quot;,\r\n    &quot;ncurses-libs&quot;: &quot;5.9-14.20130511.el7_4&quot;,\r\n    &quot;python36-m2crypto&quot;: &quot;0.35.2-5.el7&quot;\r\n  }\r\n}\r\n{\r\n  &quot;server2&quot;: {\r\n    &quot;perl-Errno&quot;: &quot;1.28-420.el8&quot;,\r\n    &quot;fontpackages-filesystem&quot;: &quot;1.44-22.el8&quot;,\r\n    &quot;python3-hawkey&quot;: &quot;0.63.0-3.el8&quot;,\r\n    &quot;geolite2-city&quot;: &quot;20180605-1.el8&quot;,\r\n    &quot;bind-libs-lite&quot;: &quot;32:9.11.26-6.el8&quot;,\r\n    &quot;samba-client-libs&quot;: &quot;4.14.5-2.el8&quot;,\r\n    &quot;rdma-core&quot;: &quot;35.0-1.el8&quot;,\r\n    &quot;iptables&quot;: &quot;1.8.4-20.el8&quot;,\r\n    &quot;python3-firewall&quot;: &quot;0.9.3-7.el8&quot;,\r\n    &quot;policycoreutils-python-utils&quot;: &quot;2.9-16.el8&quot;,\r\n    &quot;lvm2-libs&quot;: &quot;8:2.03.12-10.el8&quot;,\r\n    &quot;rpm-plugin-selinux&quot;: &quot;4.14.3-19.el8&quot;\r\n  }\r\n}\r\n```\r\n\r\nIs it possible convert JSON usinq jq to CSV in format where keys are first row and values second? Result should be like this\r\n```\r\ndhcp-libs,12:4.2.5-83.el7.centos.1\r\nperl-Time-Local,1.2300-2.el7\r\nkbd-legacy,1.15.5-15.el7\r\nperl-Scalar-List-Utils,1.27-248.el7\r\nncurses-base,5.9-14.20130511.el7_4\r\n....\r\n```\r\n\r\nIs that possible or should I try something else?",
        "link": "https://stackoverflow.com/questions/71063945/jq-convert-to-csv-with-keys-to-column-rows",
        "title": "jq convert to csv with keys to column rows"
    },
    {
        "tags": [
            "linux",
            "shell",
            "curl",
            "cron",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644520346,
                "post_id": 71070808,
                "comment_id": 125635419,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4644649,
                    "reputation": 105,
                    "user_id": 3763392,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/501681245/picture?type=large",
                    "display_name": "DuckCowMooQuack",
                    "link": "https://stackoverflow.com/users/3763392/duckcowmooquack"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644521090,
                "post_id": 71070808,
                "comment_id": 125635675,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644530945,
                "post_id": 71070808,
                "comment_id": 125638742,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4644649,
                    "reputation": 105,
                    "user_id": 3763392,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/501681245/picture?type=large",
                    "display_name": "DuckCowMooQuack",
                    "link": "https://stackoverflow.com/users/3763392/duckcowmooquack"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644616946,
                "post_id": 71070808,
                "comment_id": 125663098,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1644541512,
                "last_edit_date": 1644541512,
                "creation_date": 1644521358,
                "answer_id": 71071169,
                "question_id": 71070808,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Cron runs jobs from a non-ineractive, non-login shell and doesn&#39;t load environment variables from files like `~/.bashrc`, `~/.bash_profile`, `/etc/profile`, and others. You must source these files if you want to include the environment variables defined in them.",
                "title": "Invalid numeric literal when running jq from script via crontab"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1748790369,
        "creation_date": 1644519476,
        "last_edit_date": 1748790369,
        "question_id": 71070808,
        "body_markdown": "I have a shell script that runs fine from the command line but throws a error when it&#39;s run from a cronjob. What could be causing this error?\r\n\r\nThe following includes the cron, the script, and the error I&#39;m getting in /var/spool/mail.\r\n\r\n    [jira-svc ~]$ cat jira_trigger_updater.sh\r\n    #!/usr/bin/sh\r\n    \r\n    tmp_file=/tmp/merge-issues/$(date --iso-8601=minutes).txt\r\n    mkdir -p /tmp/merge-issues\r\n    \r\n    /usr/bin/curl -s -X GET -H &quot;Content-Type: application/json&quot; &quot;https://my url.com/project-management/rest/api/2/search?jql=filter%3D14219&amp;fields=key,status,fixVersions&quot; -u jira-svc:${UPDATE_TRIGGER_PASSWORD} &gt; ${tmp_file}\r\n    /usr/bin/jq -r &#39;.issues[] | [.key , .fields.status.name , .fields.fixVersions[].name] | join(&quot;,&quot;)&#39; ${tmp_file} &gt; /rational/triggers/inputs/jira_merge.csv\r\n    \r\n    /usr/bin/chmod 644 /rational/triggers/inputs/jira_merge.csv\r\n    \r\n    #rm -rf /tmp/merge-issues\r\n    [jira-svc ~]$ crontab -l\r\n    #*/1 * * * * /usr/bin/sh /home/jira-svc/jira_trigger_updater.sh\r\n    [jira-svc@ ~]$ tail -25 /var/spool/mail/jira-svc\r\n    From jira-svc@cc01.localdomain  Tue Feb  8 20:10:02 2022\r\n    Return-Path: &lt;jira-svc@cc01.localdomain&gt;\r\n    X-Original-To: jira-svc\r\n    Delivered-To: jira-svc@cc01.localdomain\r\n    Received: by cc01.localdomain (Postfix, from userid 1001)\r\n            id 9C40168152B5; Tue,  8 Feb 2022 20:10:02 +0000 (UTC)\r\n    From: &quot;(Cron Daemon)&quot; &lt;jira-svc@cc01.localdomain&gt;\r\n    To: jira-svc@cc01.localdomain\r\n    Subject: Cron &lt;jira-svc@cc01&gt; /usr/bin/sh /home/jira-svc/jira_trigger_updater.sh\r\n    Content-Type: text/plain; charset=UTF-8\r\n    Auto-Submitted: auto-generated\r\n    Precedence: bulk\r\n    X-Cron-Env: &lt;XDG_SESSION_ID=2172&gt;\r\n    X-Cron-Env: &lt;XDG_RUNTIME_DIR=/run/user/1001&gt;\r\n    X-Cron-Env: &lt;LANG=en_US.UTF-8&gt;\r\n    X-Cron-Env: &lt;SHELL=/bin/sh&gt;\r\n    X-Cron-Env: &lt;HOME=/home/jira-svc&gt;\r\n    X-Cron-Env: &lt;PATH=/usr/bin:/bin&gt;\r\n    X-Cron-Env: &lt;LOGNAME=jira-svc&gt;\r\n    X-Cron-Env: &lt;USER=jira-svc&gt;\r\n    Message-Id: &lt;20220208201002.9C40168152B5@cc01.localdomain&gt;\r\n    Date: Tue,  8 Feb 2022 20:10:02 +0000 (UTC)\r\n    \r\n    parse error: Invalid numeric literal at line 13, column 0\r\n    \r\n    [jira-svc ~]$",
        "link": "https://stackoverflow.com/questions/71070808/invalid-numeric-literal-when-running-jq-from-script-via-crontab",
        "title": "Invalid numeric literal when running jq from script via crontab"
    },
    {
        "tags": [
            "json",
            "jq",
            "jtc"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 24151628,
                    "reputation": 79,
                    "user_id": 18116384,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJzdmX7lv-cWCqJqHX1iDjh7s5Nn7-p7M_QisJ6m=k-s256",
                    "display_name": "cbetsworth_echo",
                    "link": "https://stackoverflow.com/users/18116384/cbetsworth-echo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644540708,
                "post_id": 71074096,
                "comment_id": 125640926,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1644540998,
                "creation_date": 1644540998,
                "answer_id": 71074149,
                "question_id": 71074096,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the update operator `|=` to preserve the overall structure, and a negative comparison value `-.percentage` to sort in descending order:\r\n~~~sh\r\njq &#39;.[].employee_observations[].bill_rates |= sort_by(-.percentage)&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;employee_observations&quot;: [\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;bill_rates&quot;: [\r\n          {\r\n            &quot;bill_classification&quot;: &quot;Lawn Mowing&quot;,\r\n            &quot;percentage&quot;: 0.672399672399672\r\n          },\r\n          {\r\n            &quot;detection_classification&quot;: &quot;Snow Removal&quot;,\r\n            &quot;percentage&quot;: 0.630630630630631\r\n          },\r\n          {\r\n            &quot;detection_classification&quot;: &quot;Trimming&quot;,\r\n            &quot;percentage&quot;: 0.00163800163800164\r\n          },\r\n          {\r\n            &quot;detection_classification&quot;: &quot;Rock Removal&quot;,\r\n            &quot;percentage&quot;: 0.00163800163800164\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/zhGWnwOvex)",
                "title": "Sort array inside a nested object while maintaining the original json object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1644541271,
        "creation_date": 1644540515,
        "last_edit_date": 1644541271,
        "question_id": 71074096,
        "body_markdown": "The goal is to sort the bill rates array by the percentage while maintaining the original json object. \r\n\r\n```\r\n[{\r\n\t&quot;id&quot;: 2,\r\n\t&quot;employee_observations&quot;: [{\r\n\t\t&quot;id&quot;: 1,\r\n\t\t&quot;bill_rates&quot;: [{\r\n\t\t\t\t&quot;bill_classification&quot;: &quot;Lawn Mowing&quot;,\r\n\t\t\t\t&quot;percentage&quot;: 0.672399672399672\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;bill_classification&quot;: &quot;Trimming&quot;,\r\n\t\t\t\t&quot;percentage&quot;: 0.00163800163800164\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;bill_classification&quot;: &quot;Snow Removal&quot;,\r\n\t\t\t\t&quot;percentage&quot;: 0.630630630630631\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;bill_classification&quot;: &quot;Rock Removal&quot;,\r\n\t\t\t\t&quot;percentage&quot;: 0.00163800163800164\r\n\t\t\t}\r\n\t\t]\r\n\t}]\r\n}]\r\n```\r\n\r\nOutput expected\r\n```\r\n[{\r\n\t&quot;id&quot;: 2,\r\n\t&quot;employee_observations&quot;: [{\r\n\t\t&quot;id&quot;: 1,\r\n\t\t&quot;bill_rates&quot;: [\r\n            {\r\n\t\t\t\t&quot;bill_classification&quot;: &quot;Lawn Mowing&quot;,\r\n\t\t\t\t&quot;percentage&quot;: 0.672399672399672\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;bill_classification&quot;: &quot;Snow Removal&quot;,\r\n\t\t\t\t&quot;percentage&quot;: 0.630630630630631\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;bill_classification&quot;: &quot;Rock Removal&quot;,\r\n\t\t\t\t&quot;percentage&quot;: 0.00163800163800164\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;bill_classification&quot;: &quot;Trimming&quot;,\r\n\t\t\t\t&quot;percentage&quot;: 0.00163800163800164\r\n\t\t\t}\r\n\t\t]\r\n\t}]\r\n}]\r\n```\r\n\r\nIf I break it out by itself I can get to the expected result but haven&#39;t found the right combo to keep the format intact in the nested version above. \r\n\r\n```\r\n[\r\n  {\r\n    &quot;activity_classification&quot;: &quot;Lawn Mowing&quot;,\r\n    &quot;percentage&quot;: 0.672399672399672\r\n  },\r\n  {\r\n    &quot;activity_classification&quot;: &quot;Trimming&quot;,\r\n    &quot;percentage&quot;: 0.00163800163800164\r\n  },\r\n  {\r\n    &quot;activity_classification&quot;: &quot;Snow Removal&quot;,\r\n    &quot;percentage&quot;: 0.630630630630631\r\n  },\r\n  {\r\n    &quot;activity_classification&quot;: &quot;Rock Removal&quot;,\r\n    &quot;percentage&quot;: 0.00163800163800164\r\n  }\r\n]\r\n```\r\njq &#39;sort_by(.activity_percentage) | reverse&#39; - Results\r\n\r\n```\r\n[\r\n  {\r\n    &quot;activity_classification&quot;: &quot;Lawn Mowing&quot;,\r\n    &quot;percentage&quot;: 0.672399672399672\r\n  },\r\n  {\r\n    &quot;activity_classification&quot;: &quot;Snow Removal&quot;,\r\n    &quot;percentage&quot;: 0.630630630630631\r\n  },\r\n  {\r\n    &quot;activity_classification&quot;: &quot;Rock Removal&quot;,\r\n    &quot;percentage&quot;: 0.00163800163800164\r\n  },\r\n  {\r\n    &quot;activity_classification&quot;: &quot;Trimming&quot;,\r\n    &quot;percentage&quot;: 0.00163800163800164\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/71074096/sort-array-inside-a-nested-object-while-maintaining-the-original-json-object",
        "title": "Sort array inside a nested object while maintaining the original json object"
    },
    {
        "tags": [
            "json",
            "jq",
            "jtc"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1644549139,
                "last_edit_date": 1644549139,
                "creation_date": 1644546408,
                "answer_id": 71074684,
                "question_id": 71074641,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The alternative operator `//` retains the first value, unless it is `null`, `false`, or `empty` (i.e. missing), in which case it takes on the second. Combined with the update operator `|=`, this can be contracted to `//=`.\r\n~~~sh\r\njq &#39;.[] |= (.part_description //= .part)&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;part&quot;: &quot;brake-01982&quot;,\r\n    &quot;part_description&quot;: &quot;brake-01982&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/vO_AAh9rqA)\r\n\r\n---\r\nEdit: To strictly update only in the case of `null`, i.e. to keep a value of `false`, and to not create the field if it&#39;s missing, the filter needs to check explicity for `null`:\r\n~~~sh\r\njq &#39;.[] |= ((select(has(&quot;part_description&quot;)).part_description | select(. == null)) = .part)&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;part&quot;: &quot;brake-01982&quot;,\r\n    &quot;part_description&quot;: &quot;brake-01982&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/T66tOtyWp1)",
                "title": "Replace null values from a select command in jq with the value of another field"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1644548773,
                "creation_date": 1644548773,
                "answer_id": 71074883,
                "question_id": 71074641,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n&gt; Goal is to search for null values of part_description ....\r\n\r\nIf this is indeed the goal, then you would need to test for `null` rather than relying on `//` or `//=`.  So you could write:\r\n\r\n    map( if has(&quot;part_description&quot;) and .part_description == null\r\n         then .part_description = .part else . end )\r\n\r\n\r\n",
                "title": "Replace null values from a select command in jq with the value of another field"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1644549139,
        "creation_date": 1644545986,
        "question_id": 71074641,
        "body_markdown": "Goal is to search for null values of part_description and insert in part field value. \r\n\r\n```\r\n[\r\n  {\r\n    &quot;part&quot;: &quot;brake-01982&quot;,\r\n    &quot;part_description&quot;: null,\r\n  }\r\n]\r\n```\r\n\r\nExpected Output\r\n```\r\n[\r\n  {\r\n    &quot;part&quot;: &quot;brake-01982&quot;,\r\n    &quot;part_description&quot;: &quot;brake-01982&quot;,\r\n  }\r\n]\r\n```\r\nCommand: \r\njq &#39;(.[] | select(.part_description==null).part_description) |= .part&#39;\r\n\r\nResults in no change\r\n\r\n\r\nWhat does work is if I try to insert a string value. The double quoted string results in what I would expect. Demo below. How do I pass another fields value into this command vs a quoted string? \r\n\r\nCommand: jq &#39;(.[] | select(.part_description==null).part_description) |= &quot;test&quot;&#39;\r\n\r\n[Demo](https://jqplay.org/s/XkYATvJona)\r\n\r\nOutput \r\n\r\n```\r\n[\r\n  {\r\n    &quot;part&quot;: &quot;brake-01982&quot;,\r\n    &quot;part_description&quot;: &quot;test&quot;\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/71074641/replace-null-values-from-a-select-command-in-jq-with-the-value-of-another-field",
        "title": "Replace null values from a select command in jq with the value of another field"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1644594951,
                "last_edit_date": 1644594951,
                "creation_date": 1644555153,
                "answer_id": 71075491,
                "question_id": 71075281,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.[]` produces the values of the array or object given to it.\r\n\r\nFor example,\r\n\r\n```jq\r\n[ &quot;a&quot;, &quot;b&quot;, &quot;c&quot; ] | .[]\r\n```\r\n\r\nis equivalent to\r\n\r\n```jq\r\n[ &quot;a&quot;, &quot;b&quot;, &quot;c&quot; ] | .[0], .[1], .[2]\r\n```\r\n\r\nand produces three strings: `a`, `b` and `c`.\r\n\r\n---\r\n\r\n```jq\r\nmap( ... )\r\n```\r\n\r\nis equivalent to \r\n\r\n```jq\r\n[ .[] | ... ]\r\n```\r\n\r\nThis means that \r\n\r\n```jq\r\nmap( . )    ≡    [ .[] | . ]    ≡    [ .[] ]\r\n```\r\n\r\nFor an array, that means \r\n\r\n```jq\r\nmap( . )    ≡    [ .[0], .[1], ... ]    ≡    .\r\n```\r\n\r\nFor an object, that means\r\n\r\n```jq\r\nmap( . )    ≡    [ .[&quot;key1&quot;], .[&quot;key2&quot;], ... ]\r\n```\r\n\r\n---\r\n\r\n&gt; The `[]` after `.` strips away the brackets from the input array.\r\n\r\nThere are no brackets. `jq` programs don&#39;t deal with JSON text, but the data structure it represents.\r\n\r\nWhen given an array or object, `.[]` produces the values of the elements of that array or object.\r\n\r\n&gt; Do we have a name for the `[]` operator?\r\n\r\nThe docs call it the *Array/Object Value Iterator*, but it&#39;s really just a specific usage of the indexing operator.\r\n\r\nThe *Array/Object Value Iterator* is ascribed to `.[]` in the docs, but that&#39;s not accurate. It doesn&#39;t have to be `.` before it, but an expression must precede it. This distinguishes it from array construction operator.\r\n\r\nIn technical terms,\r\n\r\n* `[]` as a circumfix operator (`[ EXPR ]`) is the array construction operator, and\r\n* `[]` as a postfix operator (`EXPR [ EXPR? ]`) is the indexing operator, and it&#39;s specifically called the the array/object value iterator when there&#39;s nothing in the brackets.\r\n\r\n&gt; Do we have a name for the resulting thing by appending `[]` to `.`? Obviously it&#39;s not an object. If we do `jq &#39;.[]&#39; fruit.json` we can see that it looks very similar to an array. But apparently it behaves quite differently.\r\n\r\nWe call that a stream.\r\n\r\nI&#39;m not sure what to call the components of the stream. I usually use &quot;value&quot;.\r\n\r\nFor example,\r\n\r\n```jq\r\n&quot;a&quot;, &quot;b&quot;, &quot;c&quot;       // Produces a stream of three values.\r\n&quot;abc&quot; / &quot;&quot; | .[]    // Same\r\n```\r\n\r\nWhen serialized to a file with one value per line (as you would get using `-c`), it&#39;s called [&quot;JSON lines&quot;](https://jsonlines.org/) with a suggested naming convention of `.jsonl`.\r\n\r\n&gt; Why is it the case that the map function seems to go two levels inside instead of one? This is more obvious if we do `jq &#39;.[] | map(. | length)&#39; fruit.json` and see that the . inside the map function refers to the value part of an (object) element of the input array.\r\n\r\nNo, just one.\r\n\r\nIn that example, \r\n\r\n* The `.[]` iterates over the values of the array.\r\n* The `map` iterates over the values of the objects.\r\n",
                "title": "semantics of map on a sequence of objects in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1644594951,
        "creation_date": 1644553036,
        "question_id": 71075281,
        "body_markdown": "Suppose I have a file fruit.json containing the following lines:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;apple&quot;,\r\n        &quot;color&quot;: &quot;red&quot;,\r\n        &quot;price&quot;: 20\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;banana&quot;,\r\n        &quot;color&quot;: &quot;yellow&quot;,\r\n        &quot;price&quot;: 15\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;pineapple&quot;,\r\n        &quot;color&quot;: &quot;orange&quot;,\r\n        &quot;price&quot;: 53\r\n      }\r\n    ]\r\n\r\nIf I do `jq &#39;. | map(.)&#39; fruit.json` then I get the original data. That&#39;s expected. The second `.` refers to an element in the entire array.\r\n\r\nHowever if I do `jq &#39;.[] | map(.)&#39; fruit.json` then I get this: \r\n\r\n    [\r\n      &quot;apple&quot;,\r\n      &quot;red&quot;,\r\n      20\r\n    ]\r\n    [\r\n      &quot;banana&quot;,\r\n      &quot;yellow&quot;,\r\n      15\r\n    ]\r\n    [\r\n      &quot;pineapple&quot;,\r\n      &quot;orange&quot;,\r\n      53\r\n    ]\r\n\r\nCan someone please explain what&#39;s going on? Specifically,\r\n\r\n1. The `[]` after `.` strips away the brackets from the input array. Do\r\n    we have a name for the `[]` operator? The manual seems to treat it as\r\n    something very basic without definition.\r\n2. Do we have a name for the resulting thing by appending `[]` to `.`?\r\n   Obviously it&#39;s not an object. If we do `jq &#39;.[]&#39; fruit.json`\r\n   we can see that it looks very similar to an array.\r\n   But apparently it behaves quite differently.\r\n3. Why is it the case that the `map` function seems to go two\r\n    levels inside instead of one? This is\r\n    more obvious if we do `jq &#39;.[] | map(. | length)&#39; fruit.json`\r\n    and see that the `.` inside the `map`\r\n    function refers to the value part of an (object) element of the input array. \r\n\r\nThank you all in advance!\r\n",
        "link": "https://stackoverflow.com/questions/71075281/semantics-of-map-on-a-sequence-of-objects-in-jq",
        "title": "semantics of map on a sequence of objects in jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644568266,
                "post_id": 71076786,
                "comment_id": 125645788,
                "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": 1644570650,
                "post_id": 71076786,
                "comment_id": 125646626,
                "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": 1644571423,
                "post_id": 71076786,
                "comment_id": 125646905,
                "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": 1644572499,
                "post_id": 71076786,
                "comment_id": 125647270,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1644572362,
                "last_edit_date": 1644572362,
                "creation_date": 1644571236,
                "answer_id": 71077686,
                "question_id": 71076786,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You did not specify why you want `pick_partOf` to achieve.\r\n\r\nIf its output should be\r\n\r\n```json\r\n{\r\n  &quot;identifier-value&quot;: &quot;61&quot;,\r\n  &quot;name&quot;: &quot;name61&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;62&quot;,\r\n  &quot;name&quot;: &quot;name62&quot;,\r\n  &quot;parent-identifier-value&quot;: &quot;61&quot;,\r\n  &quot;partOf&quot;: &quot;be8a02b6-54b9-450f-bf45-f28ab7ebf2dd&quot;\r\n}\r\n```\r\n\r\nthen you can use\r\n\r\n```jq\r\nif .&quot;parent-identifier-value&quot; then\r\n   .partOf = $dict[.&quot;parent-identifier-value&quot;]\r\nelse\r\n   .\r\nend\r\n```\r\n\r\n[Demo](https://jqplay.org/s/7tYNQ8TtA8) on jqplay\r\n\r\nRepeating `.&quot;parent-identifier-value&quot;` was annoying me.\r\n\r\n```jq\r\n.&quot;parent-identifier-value&quot; as $piv |\r\nif $piv then .partOf = $dict[$piv] else . end\r\n```\r\n\r\n[Demo](https://jqplay.org/s/yHHNJWyRLg) on jqplay\r\n",
                "title": "jq: pick value if field exist"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1644572362,
        "creation_date": 1644566267,
        "question_id": 71076786,
        "body_markdown": "This is my script:\r\n\r\n```\r\ndef pick_partOf($uids):\r\n    (reduce $uids[] as $uid (\r\n        {};\r\n        . + ($uid | {(.oid1): .id})\r\n    )) as $dict\r\n    | map(. + { partOf: $dict[.&quot;parent-identifier-value&quot;] } | del(..|nulls));\r\n\r\ndef pick_organization:\r\n    {\r\n        resourceType: &quot;Organization&quot;,\r\n        active: true,\r\n        partOf: .partOf?\r\n    };\r\n\r\npick_partOf($identifiers) | pick_organization\r\n```\r\n\r\nProblem here, is that sometimes some input objects doesn&#39;t contains `.&quot;parent-identifier-value&quot;`, and I&#39;m getting:\r\n\r\n&gt; jq: error (at rsan.json:7): Cannot index object with null\r\n\r\nThose are my input objects:\r\n\r\n```lang-json\r\n{\r\n  &quot;identifier-value&quot;: &quot;61&quot;,\r\n  &quot;name&quot;: &quot;name61&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;62&quot;,\r\n  &quot;name&quot;: &quot;name62&quot;,\r\n  &quot;parent-identifier-value&quot;: &quot;61&quot;\r\n}\r\n```\r\n\r\nCurrently, I&#39;m launching jq using empty array as `$identifiers` arg:\r\n\r\n    jq -s -f build-organization-bundle.jq --argjson identifiers &#39;[]&#39; rsan.json\r\n\r\nHowever, my `identifiers` is an other json files like this:\r\n\r\n```lang-json\r\n{\r\n  &quot;id&quot;: &quot;be8a02b6-54b9-450f-bf45-f28ab7ebf2dd&quot;,\r\n  &quot;oid1&quot;: &quot;61&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;f1652f3a-bca9-433c-a2c4-c924811196f6&quot;,\r\n  &quot;oid1&quot;: &quot;62&quot;\r\n}\r\n```\r\n\r\nI&#39;ve tried with:\r\n\r\n```\r\ndef pick_partOf($uids):\r\n    (reduce $uids[] as $uid (\r\n        {};\r\n        . + ($uid | {(.oid1): .id})\r\n    )) as $dict\r\n    | map(. + (\r\n        if (.|has(&quot;parent-identifier-value&quot;)) then \r\n        { partOf: $dict[.&quot;parent-identifier-value&quot;] }\r\n        else null end\r\n    ))\r\n    | del(..|nulls));\r\n```\r\n\r\nBut here I&#39;m facing with some syntax issue I don&#39;t quite figure out how to fix it.\r\n",
        "link": "https://stackoverflow.com/questions/71076786/jq-pick-value-if-field-exist",
        "title": "jq: pick value if field exist"
    },
    {
        "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": 1644584121,
                "post_id": 71079430,
                "comment_id": 125651447,
                "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": 1,
                "creation_date": 1644591801,
                "post_id": 71079430,
                "comment_id": 125654449,
                "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": 1644592117,
                "post_id": 71079430,
                "comment_id": 125654611,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1644580322,
                "last_edit_date": 1644580322,
                "creation_date": 1644579955,
                "answer_id": 71079578,
                "question_id": 71079430,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can test for existence using `has`\r\n~~~\r\nmap(\r\n  {name} +\r\n  if has(&quot;deceased&quot;)\r\n  then {deceased: (.deceased | strptime(&quot;%Y/%m/%d&quot;) | strftime(&quot;%F&quot;))}\r\n  else {}\r\n  end\r\n)\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;name1&quot;,\r\n    &quot;deceased&quot;: &quot;1982-05-19&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;name2&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/TudrdlDcOg)\r\n\r\n---\r\nIf `.deceased` can only exist as string, then this would be equivalent:\r\n~~~\r\nmap(\r\n  {name, deceased}\r\n  | .deceased |= (strings | strptime(&quot;%Y/%m/%d&quot;) | strftime(&quot;%F&quot;))\r\n)\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;name1&quot;,\r\n    &quot;deceased&quot;: &quot;1982-05-19&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;name2&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/2mckWjHrri)",
                "title": "jq: populate object bedides of field exists"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1644580322,
        "creation_date": 1644579192,
        "question_id": 71079430,
        "body_markdown": "I&#39;m using this filter in:\r\n\r\n```\r\nmap({\r\n    name,\r\n    deceased: (.deceased? // empty | split(&quot; &quot;) | first | strptime(&quot;%Y/%m/%d&quot;) | strftime(&quot;%F&quot;))\r\n})\r\n```\r\n\r\ninput objects are:\r\n\r\n```lang-json\r\n{\r\n    &quot;name&quot;: &quot;name1&quot;,\r\n    &quot;birth&quot;: &quot;1950/05/05&quot;,\r\n    &quot;deceased&quot;: &quot;1982/05/19&quot;\r\n}\r\n{\r\n    &quot;name&quot;: &quot;name2&quot;,\r\n    &quot;birth&quot;: &quot;1982/05/19&quot;\r\n}\r\n```\r\n\r\nI&#39;m getting:\r\n\r\n```lang-json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;name1&quot;,\r\n    &quot;deceased&quot;: &quot;1982-05-19&quot;\r\n  }\r\n]\r\n\r\n```\r\n\r\nI need to get:\r\n\r\n```lang-json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;name1&quot;,\r\n    &quot;deceased&quot;: &quot;1982-05-19&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;name2&quot;\r\n  }\r\n]\r\n```\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/71079430/jq-populate-object-bedides-of-field-exists",
        "title": "jq: populate object bedides of field exists"
    },
    {
        "tags": [
            "json",
            "optimization",
            "cmd",
            "file-io",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1644609938,
                "post_id": 71085709,
                "comment_id": 125661066,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5182392,
                    "reputation": 5881,
                    "user_id": 4182398,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://i.sstatic.net/55DUG.jpg?s=256",
                    "display_name": "Amazon Dies In Darkness",
                    "link": "https://stackoverflow.com/users/4182398/amazon-dies-in-darkness"
                },
                "reply_to_user": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644610685,
                "post_id": 71085709,
                "comment_id": 125661292,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644611915,
                "post_id": 71085709,
                "comment_id": 125661643,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644613180,
                "post_id": 71085709,
                "comment_id": 125661987,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5182392,
                    "reputation": 5881,
                    "user_id": 4182398,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://i.sstatic.net/55DUG.jpg?s=256",
                    "display_name": "Amazon Dies In Darkness",
                    "link": "https://stackoverflow.com/users/4182398/amazon-dies-in-darkness"
                },
                "reply_to_user": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644616773,
                "post_id": 71085709,
                "comment_id": 125663040,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5182392,
                    "reputation": 5881,
                    "user_id": 4182398,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://i.sstatic.net/55DUG.jpg?s=256",
                    "display_name": "Amazon Dies In Darkness",
                    "link": "https://stackoverflow.com/users/4182398/amazon-dies-in-darkness"
                },
                "reply_to_user": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644616811,
                "post_id": 71085709,
                "comment_id": 125663058,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1644614636,
                "last_edit_date": 1644614636,
                "creation_date": 1644613986,
                "answer_id": 71086571,
                "question_id": 71085709,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You want the following:\r\n\r\n```cmd\r\njq . &quot;%1&quot; &gt;&quot;%1&quot;.tmp\r\nif not errorlevel 1 move /y &quot;%1&quot;.tmp &quot;%1&quot; &gt;nul\r\n```\r\n\r\n`jq` has no option to do this for you.\r\n\r\n",
                "title": "jq: Format a JSON file with the output replacing the input file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1644614636,
        "creation_date": 1644608320,
        "last_edit_date": 1644614537,
        "question_id": 71085709,
        "body_markdown": "I want to use `jq` to format a JSON file in Windows.  So far, I haven&#39;t been able to find a way to perform this task using a single `jq` command.\r\n\r\nThus, I wrote this batch file:\r\n```\r\nrem create formatted JSON output file\r\njq-win64.exe . &quot;%1&quot; &gt;&quot;temp.tmp&quot;\r\n\r\nrem replace the unformatted JSON input file with the formatted JSON output file\r\ndel &quot;%1&quot;\r\nren &quot;temp.tmp&quot; &quot;%1&quot;\r\n```\r\n\r\nIs there a way to instruct `jq` to do this without performing these gymnastics?",
        "link": "https://stackoverflow.com/questions/71085709/jq-format-a-json-file-with-the-output-replacing-the-input-file",
        "title": "jq: Format a JSON file with the output replacing the input file"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1644677648,
                "creation_date": 1644677648,
                "answer_id": 71092942,
                "question_id": 71092471,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use:\r\n```\r\nwith_entries(.value |= (with_entries(select(.key | endswith(&quot;_input&quot;))) | to_entries[].value ))\r\n```\r\n\r\nUsing `with_enries` so we can get the desired keys using `endswith(&quot;_input&quot;)`\r\n\r\n\r\n----------\r\n\r\nThe above will generate:\r\n```json\r\n{\r\n  &quot;Core 0&quot;: 52,\r\n  &quot;Core 1&quot;: 53\r\n}\r\n```\r\n\r\nAs you can test in [this online demo](https://jqplay.org/s/JNlUdiA8UO)",
                "title": "Finding json attribute by wildard with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1644678213,
                "creation_date": 1644678213,
                "answer_id": 71093020,
                "question_id": 71092471,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using regular expression :\r\n\r\n```\r\njq &#39;map_values(\r\n        to_entries[] |\r\n        select(.key |\r\n                test(&quot;temp[[:digit:]]+_input&quot;)).value\r\n    )&#39; input.json\r\n```",
                "title": "Finding json attribute by wildard with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1644743360,
        "creation_date": 1644674188,
        "last_edit_date": 1644743360,
        "question_id": 71092471,
        "body_markdown": "I am trying to find a way to extract JSON attributes using wildcard selection with jq. Is there any way to do it? I have the following JSON file.  The fields can be dynamic for each system. I want to map Core with its &quot;input&quot; temperature (tempX_input).\r\n```json\r\n{\r\n  &quot;Core 0&quot;: {\r\n    &quot;temp2_input&quot;: &quot;52.000&quot;,\r\n    &quot;temp2_max&quot;: &quot;100.000&quot;,\r\n    &quot;temp2_crit&quot;: &quot;100.000&quot;,\r\n    &quot;temp2_crit_alarm&quot;: &quot;0.000&quot;\r\n  },\r\n  &quot;Core 1&quot;: {\r\n    &quot;temp3_input&quot;: &quot;53.000&quot;,\r\n    &quot;temp3_max&quot;: &quot;100.000&quot;,\r\n    &quot;temp3_crit&quot;: &quot;100.000&quot;,\r\n    &quot;temp3_crit_alarm&quot;: &quot;0.000&quot;\r\n  }\r\n}\r\n```  \r\n**Result:**\r\n```json\r\n{\r\n  &quot;Core 0&quot;: &quot;52.000&quot;,\r\n  &quot;Core 1&quot;: &quot;53.000&quot;\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/71092471/finding-json-attribute-by-wildard-with-jq",
        "title": "Finding json attribute by wildard with jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "activecampaign"
        ],
        "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": 1644791685,
                "post_id": 71103776,
                "comment_id": 125693832,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1644780204,
                "last_edit_date": 1644780204,
                "creation_date": 1644779799,
                "answer_id": 71104051,
                "question_id": 71103776,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This `split`s the keys at the space character while discarding any items that don&#39;t have one in it. Then it assigns the three fields to their values accordingly, using `reduce` to combine the grouping.\r\n\r\n~~~\r\nto_entries\r\n| map(.key |= split(&quot; &quot;) | select(.key[1]))\r\n| reduce group_by(.key[0])[] as $g ({};\r\n    .[$g[0].key[0]] = (\r\n      INDEX($g[]; .key[1]) | {\r\n        email_address: .Email.value,\r\n        name: .Name.value,\r\n        role: .Name.key[0]\r\n      }\r\n    )\r\n  )\r\n~~~\r\n~~~json\r\n{\r\n  &quot;Approver&quot;: {\r\n    &quot;email_address&quot;: &quot;tim@domain.com&quot;,\r\n    &quot;name&quot;: &quot;Tim&quot;,\r\n    &quot;role&quot;: &quot;Approver&quot;\r\n  },\r\n  &quot;Customer&quot;: {\r\n    &quot;email_address&quot;: &quot;alex@domain.com&quot;,\r\n    &quot;name&quot;: &quot;Alex&quot;,\r\n    &quot;role&quot;: &quot;Customer&quot;\r\n  },\r\n  &quot;Presenter&quot;: {\r\n    &quot;email_address&quot;: &quot;roney@domain.com&quot;,\r\n    &quot;name&quot;: &quot;Roney&quot;,\r\n    &quot;role&quot;: &quot;Presenter&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/DgOQ-xgPv_)",
                "title": "How to get key value pairs of the objects from complex JSON using jq and map? (Active Campaign)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1644792626,
                "last_edit_date": 1644792626,
                "creation_date": 1644790814,
                "answer_id": 71105347,
                "question_id": 71103776,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\n{ &quot;Name&quot;: &quot;name&quot;,  &quot;Email&quot;: &quot;email_address&quot; } as $key_map |\r\nto_entries |\r\nmap (\r\n   ( .key | split(&quot; &quot;) | select( length == 2 ) ) as [ $role, $raw_key ] |\r\n   [ $role, &quot;role&quot;,             $role  ],\r\n   [ $role, $key_map[$raw_key], .value ]\r\n) |\r\nreduce .[] as [ $role, $key, $val ] ( {}; .[ $role ][ $key ] = $val )\r\n```\r\n\r\n[Demo](https://jqplay.org/s/zH98zj6rA0) on jqplay\r\n\r\n---\r\n\r\nIn the above, we start by making the data uniform. Specifically, we start by producing the following:\r\n\r\n```\r\n[\r\n   [ &quot;Presenter&quot;, &quot;role&quot;,          &quot;Presenter&quot;        ],\r\n   [ &quot;Presenter&quot;, &quot;name&quot;,          &quot;Roney&quot;            ],\r\n   [ &quot;Presenter&quot;, &quot;role&quot;,          &quot;Presenter&quot;        ],\r\n   [ &quot;Presenter&quot;, &quot;email_address&quot;, &quot;roney@domain.com&quot; ],\r\n   [ &quot;Approver&quot;,  &quot;role&quot;,          &quot;Approver&quot;         ],\r\n   [ &quot;Approver&quot;,  &quot;name&quot;,          &quot;Tim&quot;              ],\r\n   [ &quot;Approver&quot;,  &quot;role&quot;,          &quot;Approver&quot;         ],\r\n   [ &quot;Approver&quot;,  &quot;email_address&quot;, &quot;tim@domain.com&quot;   ],\r\n   [ &quot;Customer&quot;,  &quot;role&quot;,          &quot;Customer&quot;         ],\r\n   [ &quot;Customer&quot;,  &quot;name&quot;,          &quot;Alex&quot;             ],\r\n   [ &quot;Customer&quot;,  &quot;role&quot;,          &quot;Customer&quot;         ],\r\n   [ &quot;Customer&quot;,  &quot;email_address&quot;, &quot;alex@domain.com&quot;  ]\r\n]\r\n```\r\n\r\nThere&#39;s redundant information, but that doesn&#39;t matter.\r\n\r\nThen, the final simple `reduce` builds the desired structure.\r\n\r\n---\r\n\r\n```jq\r\n.key | split(&quot; &quot;) | select( length == 2 )\r\n```\r\n\r\ncan be replaced with the safer\r\n\r\n```jq\r\n.key | match(&quot;^(.*) (Name|Email)$&quot;) | .captures | map( .string )\r\n```",
                "title": "How to get key value pairs of the objects from complex JSON using jq and map? (Active Campaign)"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1644801143,
                "creation_date": 1644801143,
                "answer_id": 71106218,
                "question_id": 71103776,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another, shorter approach that doesn&#39;t use `group_by`. Instead, this directly iterates over the initial object using `reduce` and imediately sets all the fields accordingly if the key followed the space-separated role-key pattern.\r\n\r\n~~~sh\r\nreduce (to_entries[] | .key /= &quot; &quot;) as {key: [$role, $key], $value} ({};\r\n  if $key then\r\n    .[$role] += {({Email: &quot;email_address&quot;, Name: &quot;name&quot;}[$key]): $value, $role}\r\n  else . end\r\n)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;Presenter&quot;: {\r\n    &quot;name&quot;: &quot;Roney&quot;,\r\n    &quot;role&quot;: &quot;Presenter&quot;,\r\n    &quot;email_address&quot;: &quot;roney@domain.com&quot;\r\n  },\r\n  &quot;Approver&quot;: {\r\n    &quot;name&quot;: &quot;Tim&quot;,\r\n    &quot;role&quot;: &quot;Approver&quot;,\r\n    &quot;email_address&quot;: &quot;tim@domain.com&quot;\r\n  },\r\n  &quot;Customer&quot;: {\r\n    &quot;name&quot;: &quot;Alex&quot;,\r\n    &quot;role&quot;: &quot;Customer&quot;,\r\n    &quot;email_address&quot;: &quot;alex@domain.com&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/nX4YANVgKi)",
                "title": "How to get key value pairs of the objects from complex JSON using jq and map? (Active Campaign)"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1644801143,
        "creation_date": 1644777551,
        "last_edit_date": 1644778483,
        "question_id": 71103776,
        "body_markdown": "I have following JSON. I want to get key-value pair objects based on their role. In this example there are 3 roles(Presenter, Approver, Customer) but there can be more as it is dynamic.\r\n\r\nJSON\r\n```json\r\n{\r\n   &quot;Presenter Name&quot;: &quot;Roney&quot;,\r\n   &quot;Presenter Email&quot;: &quot;roney@domain.com&quot;,\r\n   &quot;Approver Name&quot;: &quot;Tim&quot;,\r\n   &quot;Approver Email&quot;: &quot;tim@domain.com&quot;,\r\n   &quot;Customer Name&quot;: &quot;Alex&quot;,\r\n   &quot;Customer Email&quot;: &quot;alex@domain.com&quot;,   \r\n   &quot;Invoice&quot;: &quot;001&quot;,\r\n   &quot;Date&quot;: &quot;2022-02-14&quot;   \r\n}\r\n```\r\nExpected output using jq, map, \r\n```json\r\n{\r\n\t&quot;Presenter&quot;: {\r\n\t  &quot;email_address&quot;: &quot;roney@domain.com&quot;,\r\n\t  &quot;name&quot;: &quot;Roney&quot;,\r\n\t  &quot;role&quot;: &quot;Presenter&quot;\r\n\t},\r\n\t&quot;Approver&quot;: {\r\n\t  &quot;email_address&quot;: &quot;tim@domain.com&quot;,\r\n\t  &quot;name&quot;: &quot;Tim&quot;,\r\n\t  &quot;role&quot;: &quot;Approver&quot;\r\n\t},\r\n\t&quot;Customer&quot;: {\r\n\t  &quot;email_address&quot;: &quot;alex@domain.com&quot;,\r\n\t  &quot;name&quot;: &quot;Alex&quot;,\r\n\t  &quot;role&quot;: &quot;Customer&quot;\r\n\t}\r\n}\r\n```\r\nI have tried till following but didn&#39;t get what to do next. Please advice.\r\n\r\n `to_entries |map( { (.key): { name: .value, email_address:.value, role: .key} } ) | add`\r\n",
        "link": "https://stackoverflow.com/questions/71103776/how-to-get-key-value-pairs-of-the-objects-from-complex-json-using-jq-and-map-a",
        "title": "How to get key value pairs of the objects from complex JSON using jq and map? (Active Campaign)"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644795462,
                "post_id": 71105669,
                "comment_id": 125694411,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5123562,
                    "reputation": 193,
                    "user_id": 4106434,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://lh6.googleusercontent.com/-7N8GYIFXl50/AAAAAAAAAAI/AAAAAAAAA2g/1dZjJDttHns/s256-rj/photo.jpg",
                    "display_name": "MichaelJS",
                    "link": "https://stackoverflow.com/users/4106434/michaeljs"
                },
                "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": 1644823816,
                "post_id": 71105669,
                "comment_id": 125698612,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5123562,
                    "reputation": 193,
                    "user_id": 4106434,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://lh6.googleusercontent.com/-7N8GYIFXl50/AAAAAAAAAAI/AAAAAAAAA2g/1dZjJDttHns/s256-rj/photo.jpg",
                    "display_name": "MichaelJS",
                    "link": "https://stackoverflow.com/users/4106434/michaeljs"
                },
                "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": 1644824511,
                "post_id": 71105669,
                "comment_id": 125698805,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1644798622,
                "last_edit_date": 1644798622,
                "creation_date": 1644794563,
                "answer_id": 71105740,
                "question_id": 71105669,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you only use `map` then for each element you end up iterating over all arguments again. Instead, you have to align the `.features` array to the `$ARGS.positional` array.\r\n\r\nOne way, which is closer to your attempt, is to expand the `.features` array using `to_entries` to fit the array&#39;s elements  with their keys, which in turn can be used within `map` to reference by index the corresponding item of the `$ARGS.positional` array.\r\n~~~sh\r\njq &#39;\r\n  .features |= (to_entries | map(\r\n    .value * {properties: {NOSW: $ARGS.positional[.key]}}\r\n  ))\r\n&#39; --args &quot;${pushintojson[@]}&quot; &lt; input.json\r\n~~~\r\n\r\nAnother approach would be to use `transpose` to generate an array of aligned items from both initial arrays, and then again just `map` their contents together.\r\n~~~sh\r\njq &#39;\r\n  .features |= ([., $ARGS.positional] | transpose | map(\r\n    .[0] * {properties: {NOSW: .[1]}}\r\n  ))\r\n&#39; --args &quot;${pushintojson[@]}&quot; &lt; input.json\r\n~~~\r\n\r\nBoth produce\r\n~~~json\r\n{\r\n  &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n  &quot;name&quot;: &quot;test&quot;,\r\n  &quot;features&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;OBJECTID&quot;: 3213,\r\n        &quot;USE&quot;: &quot;dem&quot;,\r\n        &quot;tile&quot;: &quot;4045644&quot;,\r\n        &quot;NOSW&quot;: &quot;4045646 NV NV NV&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;OBJECTID&quot;: 3214,\r\n        &quot;USE&quot;: &quot;dem&quot;,\r\n        &quot;tile&quot;: &quot;4045646&quot;,\r\n        &quot;NOSW&quot;: &quot;4045648 NV 4045644 NV&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;OBJECTID&quot;: 3215,\r\n        &quot;USE&quot;: &quot;dem&quot;,\r\n        &quot;tile&quot;: &quot;4045648&quot;,\r\n        &quot;NOSW&quot;: &quot;4045650 NV 4045646 NV&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n~~~",
                "title": "write bash-array to json with jq: one element per object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1644798622,
        "creation_date": 1644793814,
        "question_id": 71105669,
        "body_markdown": "I&#39;m trying to save some values from a bash-array into an existing json. I tried some different approaches, but I didn&#39;t manage to solve the issue. What am I missing here?\r\n\r\ninput.json\r\n```\r\n{\r\n&quot;type&quot;: &quot;FeatureCollection&quot;,\r\n&quot;name&quot;: &quot;test&quot;,\r\n&quot;features&quot;: [\r\n{ &quot;type&quot;: &quot;Feature&quot;, &quot;properties&quot;: { &quot;OBJECTID&quot;: 3213, &quot;USE&quot;: &quot;dem&quot;, &quot;tile&quot;: &quot;4045644&quot;}},\r\n{ &quot;type&quot;: &quot;Feature&quot;, &quot;properties&quot;: { &quot;OBJECTID&quot;: 3214, &quot;USE&quot;: &quot;dem&quot;, &quot;tile&quot;: &quot;4045646&quot;}},\r\n{ &quot;type&quot;: &quot;Feature&quot;, &quot;properties&quot;: { &quot;OBJECTID&quot;: 3215, &quot;USE&quot;: &quot;dem&quot;, &quot;tile&quot;: &quot;4045648&quot;}}\r\n]\r\n}\r\n```\r\nOutput of some calculations in Bash - 100% derived from input.json. So this array length == length of the &quot;features[]&quot;-array in the input.json\r\n```\r\nprintf &#39;%s\\n&#39; &quot;${pushintojson[@]}&quot;\r\n\r\n4045646 NV NV NV \r\n4045648 NV 4045644 NV \r\n4045650 NV 4045646 NV \r\n```\r\n\r\n```\r\njq &#39;.features |= map(.properties +=  {NOSW: $ARGS.positional})&#39; --args &quot;${pushintojson[@]}&quot;  &lt;&lt;&lt; &quot;${input.json}&quot;\r\n```\r\n\r\nSo this produces this (newlines added by me for readability):\r\n```\r\n{\r\n&quot;type&quot;:&quot;FeatureCollection&quot;,\r\n&quot;name&quot;:&quot;test&quot;,\r\n&quot;features&quot;: [\r\n{&quot;type&quot;:&quot;Feature&quot;,&quot;properties&quot;:{&quot;OBJECTID&quot;:3213,&quot;USE&quot;:&quot;dem&quot;,&quot;tile&quot;:&quot;4045644&quot;,\r\n&quot;NOSW&quot;:[\r\n&quot;4045646 NV NV NV&quot;,\r\n&quot;4045648 NV 4045644 NV&quot;,\r\n&quot;4045650 NV 4045646 NV&quot;\r\n]}},\r\n\r\n{&quot;type&quot;:&quot;Feature&quot;,&quot;properties&quot;:{&quot;OBJECTID&quot;:3214,&quot;USE&quot;:&quot;dem&quot;,&quot;tile&quot;:&quot;4045646&quot;,\r\n&quot;NOSW&quot;:[\r\n&quot;4045646 NV NV NV&quot;,\r\n&quot;4045648 NV 4045644 NV&quot;,\r\n&quot;4045650 NV 4045646 NV&quot;\r\n]}},\r\n\r\n{&quot;type&quot;:&quot;Feature&quot;,&quot;properties&quot;:{&quot;OBJECTID&quot;:3215,&quot;USE&quot;:&quot;dem&quot;,&quot;tile&quot;:&quot;4045648&quot;,\r\n&quot;NOSW&quot;:[\r\n&quot;4045646 NV NV NV&quot;,\r\n&quot;4045648 NV 4045644 NV&quot;,\r\n&quot;4045650 NV 4045646 NV&quot;\r\n]}}\r\n]\r\n}\r\n```\r\n\r\nAll values of the bash-array are saved to EVERY element. It&#39;s supposed to be just one value per json-object - actually as an array itself. \r\nSo in pseudo: &quot;pushintojson[0]&quot; needs to be under &quot;features[0]&quot;, pushintojson[1]&quot; to &quot;features[1]&quot;\r\npushintojson[2]&quot; to &quot;features[2]&quot; etc. \r\n\r\n\r\nDESIRED OUTPUT\r\n```\r\n{\r\n&quot;type&quot;:&quot;FeatureCollection&quot;,\r\n&quot;name&quot;:&quot;test&quot;,\r\n&quot;features&quot;: [\r\n{&quot;type&quot;:&quot;Feature&quot;,&quot;properties&quot;:{&quot;OBJECTID&quot;:3213,&quot;USE&quot;:&quot;dem&quot;,&quot;tile&quot;:&quot;4045644&quot;,\r\n&quot;NOSW&quot;:&quot;4045646 NV NV NV&quot;\r\n}},\r\n{&quot;type&quot;:&quot;Feature&quot;,&quot;properties&quot;:{&quot;OBJECTID&quot;:3214,&quot;USE&quot;:&quot;dem&quot;,&quot;tile&quot;:&quot;4045646&quot;,\r\n&quot;NOSW&quot;:&quot;4045648 NV 4045644 NV&quot;\r\n}},\r\n{&quot;type&quot;:&quot;Feature&quot;,&quot;properties&quot;:{&quot;OBJECTID&quot;:3215,&quot;USE&quot;:&quot;dem&quot;,&quot;tile&quot;:&quot;4045648&quot;,\r\n&quot;NOSW&quot;:&quot;4045650 NV 4045646 NV&quot;\r\n}}\r\n]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/71105669/write-bash-array-to-json-with-jq-one-element-per-object",
        "title": "write bash-array to json with jq: one element per object"
    },
    {
        "tags": [
            "jq",
            "strftime"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1644803863,
                "last_edit_date": 1644803863,
                "creation_date": 1644801672,
                "answer_id": 71106261,
                "question_id": 71106182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are using jq v1.6, use `strflocaltime` instead of `strftime` which displays the time in **your** timezone.\r\n~~~sh\r\njq -n &#39;now | strflocaltime(&quot;%Y-%m-%dT%H:%M:%S&quot;)&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/84uwwDuEKJ)\r\n\r\nFrom the [manual](https://stedolan.github.io/jq/manual/v1.6/#Dates):\r\n&gt; The `strftime(fmt)` builtin formats a time (GMT) with the given format. The `strflocaltime` does the same, but using the local timezone setting.\r\n\r\nIf your timezone is different, set the shell&#39;s `TZ` variable accordingly before calling `jq`\r\n~~~sh\r\nTZ=Australia/Sydney jq -n &#39;now | strflocaltime(&quot;%Y-%m-%dT%H:%M:%S&quot;)&#39;\r\n~~~\r\n",
                "title": "Jq strftime() to show time in a specific time zone"
            },
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1644820053,
                "last_edit_date": 1644820053,
                "creation_date": 1644819539,
                "answer_id": 71107835,
                "question_id": 71106182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Both of the following convert to the time zone indicated by the `TZ` environment variable var:\r\n\r\n\r\n```jq\r\nlocaltime | strftime(...)\r\n```\r\n\r\n```jq\r\nstrflocaltime(...)\r\n```\r\n\r\nFor example,\r\n\r\n```none\r\n$ jq -nr &#39;now | strftime(&quot;%FT%T&quot;)&#39;\r\n2022-02-14T06:14:07\r\n\r\n$ jq -nr &#39;now | gmtime | strftime(&quot;%FT%T&quot;)&#39;\r\n2022-02-14T06:14:07\r\n\r\n$ jq -nr &#39;now | localtime | strftime(&quot;%FT%T&quot;)&#39;\r\n2022-02-14T02:14:07\r\n\r\n$ jq -nr &#39;now | strflocaltime(&quot;%FT%T&quot;)&#39;\r\n2022-02-14T02:14:07\r\n```\r\n\r\nThat uses your local time, as determined by `TZ` environment variable. Adjust as needed.\r\n\r\n```none\r\n$ TZ=America/Halifax jq -nr &#39;now | strflocaltime(&quot;%FT%T&quot;)&#39;\r\n2022-02-14T02:14:07\r\n\r\n$ TZ=America/Toronto jq -nr &#39;now | strflocaltime(&quot;%FT%T&quot;)&#39;\r\n2022-02-14T01:14:07\r\n\r\n$ TZ=America/Vancouver jq -nr &#39;now | strflocaltime(&quot;%FT%T&quot;)&#39;\r\n2022-02-14T22:14:07\r\n```\r\n\r\nIf you want to convert to different time zones in a single run of `jq`, you&#39;re out of luck. `jq` doesn&#39;t support converting to/from time zones other than UTC and this time zone.\r\n\r\nTested with both 1.5 and 1.6.\r\n",
                "title": "Jq strftime() to show time in a specific time zone"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1644820053,
        "creation_date": 1644800654,
        "question_id": 71106182,
        "body_markdown": "How to use jq to convert seconds since Unix epoch to a time string in human readable format but adjusted to Sydney, Australia time zone?\r\n\r\nI tried filter:\r\n```\r\nnow | strftime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;)\r\n```\r\nBut I don&#39;t know how to adjust the time format string to convey Sydney, Australia time zone.\r\n\r\nPossibly I need to replace &quot;Z&quot; with the relevant time zone?\r\n",
        "link": "https://stackoverflow.com/questions/71106182/jq-strftime-to-show-time-in-a-specific-time-zone",
        "title": "Jq strftime() to show time in a specific time zone"
    },
    {
        "tags": [
            "docker",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1644809985,
                "last_edit_date": 1644809985,
                "creation_date": 1644805242,
                "answer_id": 71106524,
                "question_id": 71106503,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should use `or` instead of `and` since a field can only have one of those options (if at all), never both.\r\n\r\nAccording to &quot;I only want to keep the amd64 and arm64 architectures&quot;,  instead of deleting you can simply go the keeping route:\r\n~~~sh\r\njq &#39;\r\n  .manifests |= map(select(\r\n    .platform.architecture == &quot;arm64&quot; or .platform.architecture == &quot;amd64&quot;\r\n  ))\r\n&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/CIIXK0gyS2)\r\n\r\nIf you&#39;re using jq 1.6 or later, you can simplify this using the `IN` filter:\r\n~~~sh\r\njq &#39;\r\n  .manifests |= map(select(\r\n    IN(.platform.architecture; &quot;arm64&quot;, &quot;amd64&quot;)\r\n  ))\r\n&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/VmUBUcXkHh)\r\n\r\nOutput\r\n~~~json\r\n{\r\n  &quot;schemaVersion&quot;: 2,\r\n  &quot;mediaType&quot;: &quot;application/vnd.docker.distribution.manifest.list.v2+json&quot;,\r\n  &quot;manifests&quot;: [\r\n    {\r\n      &quot;mediaType&quot;: &quot;application/vnd.docker.distribution.manifest.v2+json&quot;,\r\n      &quot;size&quot;: 1785,\r\n      &quot;digest&quot;: &quot;sha256:34860ea294a018d392e61936f19a7862d5e92039d196cac9176da14b2bbd0fe3&quot;,\r\n      &quot;platform&quot;: {\r\n        &quot;architecture&quot;: &quot;amd64&quot;,\r\n        &quot;os&quot;: &quot;linux&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;mediaType&quot;: &quot;application/vnd.docker.distribution.manifest.v2+json&quot;,\r\n      &quot;size&quot;: 1996,\r\n      &quot;digest&quot;: &quot;sha256:a0000b627744766025f552c4db171a00b055d5d709f22aec8be96b6375b220cf&quot;,\r\n      &quot;platform&quot;: {\r\n        &quot;architecture&quot;: &quot;arm64&quot;,\r\n        &quot;os&quot;: &quot;linux&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n~~~\r\n\r\n",
                "title": "how to using jq command to Delete the specified multi-line field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1644809985,
        "creation_date": 1644804881,
        "question_id": 71106503,
        "body_markdown": "I want to use the jq command to filter out the architecture I want in the manifest file of docker\r\n\r\n    cat manifest.json |jq -r\r\n    {\r\n      &quot;schemaVersion&quot;: 2,\r\n      &quot;mediaType&quot;: &quot;application/vnd.docker.distribution.manifest.list.v2+json&quot;,\r\n      &quot;manifests&quot;: [\r\n        {\r\n          &quot;mediaType&quot;: &quot;application/vnd.docker.distribution.manifest.v2+json&quot;,\r\n          &quot;size&quot;: 1785,\r\n          &quot;digest&quot;: &quot;sha256:34860ea294a018d392e61936f19a7862d5e92039d196cac9176da14b2bbd0fe3&quot;,\r\n          &quot;platform&quot;: {\r\n            &quot;architecture&quot;: &quot;amd64&quot;,\r\n            &quot;os&quot;: &quot;linux&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;mediaType&quot;: &quot;application/vnd.docker.distribution.manifest.v2+json&quot;,\r\n          &quot;size&quot;: 1996,\r\n          &quot;digest&quot;: &quot;sha256:93d5f2293f6faf76fc3f2ff30628cf2100b68e3cf16901f39f01d449e67f67d9&quot;,\r\n          &quot;platform&quot;: {\r\n            &quot;architecture&quot;: &quot;arm&quot;,\r\n            &quot;os&quot;: &quot;linux&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;mediaType&quot;: &quot;application/vnd.docker.distribution.manifest.v2+json&quot;,\r\n          &quot;size&quot;: 1996,\r\n          &quot;digest&quot;: &quot;sha256:a0000b627744766025f552c4db171a00b055d5d709f22aec8be96b6375b220cf&quot;,\r\n          &quot;platform&quot;: {\r\n            &quot;architecture&quot;: &quot;arm64&quot;,\r\n            &quot;os&quot;: &quot;linux&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;mediaType&quot;: &quot;application/vnd.docker.distribution.manifest.v2+json&quot;,\r\n          &quot;size&quot;: 1995,\r\n          &quot;digest&quot;: &quot;sha256:227c06dc0468dacfcfc04cc0aad3f5138a51bb2afa4d8252c6e83ca39beb8c6f&quot;,\r\n          &quot;platform&quot;: {\r\n            &quot;architecture&quot;: &quot;ppc64le&quot;,\r\n            &quot;os&quot;: &quot;linux&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;mediaType&quot;: &quot;application/vnd.docker.distribution.manifest.v2+json&quot;,\r\n          &quot;size&quot;: 1996,\r\n          &quot;digest&quot;: &quot;sha256:e7cfbfe13f7a179277f55a835abc0b01f9c6c21892c1ae1b0007f2e09777bca0&quot;,\r\n          &quot;platform&quot;: {\r\n            &quot;architecture&quot;: &quot;s390x&quot;,\r\n            &quot;os&quot;: &quot;linux&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n\r\n```\r\ncat manifest.json |jq -r &#39;del(.manifests[] |select(.platform.architecture==&quot;arm&quot; and .platform.architecture==&quot;ppc64le&quot;))&#39;\r\n```\r\n\r\nThe above command does not take effect. If I only want to keep the amd64 and arm64 architectures in the manifest file, how should I write this command?\r\n",
        "link": "https://stackoverflow.com/questions/71106503/how-to-using-jq-command-to-delete-the-specified-multi-line-field",
        "title": "how to using jq command to Delete the specified multi-line field"
    },
    {
        "tags": [
            "join",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 19,
                "is_accepted": true,
                "score": 19,
                "last_activity_date": 1644813473,
                "creation_date": 1644813473,
                "answer_id": 71107203,
                "question_id": 71106595,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This function should resemble a `JOIN` clause in `SQL`. It is used to combine rows from two (or more in `SQL`) tables, based on a related column between them.\r\n\r\nLet&#39;s build some &quot;tables&quot;.\r\n\r\nThe first one should be a list of orders with an ID, and ID references to the ordering Customer and the ordered Product:\r\n~~~\r\n[\r\n  {\r\n    &quot;OrderID&quot;: &quot;10&quot;,\r\n    &quot;CustomerIDRef&quot;: &quot;2&quot;,\r\n    &quot;ProductIDRef&quot;: &quot;7&quot;\r\n  },\r\n  {\r\n    &quot;OrderID&quot;: &quot;11&quot;,\r\n    &quot;CustomerIDRef&quot;: &quot;1&quot;,\r\n    &quot;ProductIDRef&quot;: &quot;7&quot;\r\n  },\r\n  {\r\n    &quot;OrderID&quot;: &quot;12&quot;,\r\n    &quot;CustomerIDRef&quot;: &quot;2&quot;,\r\n    &quot;ProductIDRef&quot;: &quot;14&quot;\r\n  },\r\n  {\r\n    &quot;OrderID&quot;: &quot;13&quot;,\r\n    &quot;CustomerIDRef&quot;: &quot;2&quot;,\r\n    &quot;ProductIDRef&quot;: &quot;7&quot;\r\n  }\r\n]\r\nas $orders\r\n~~~\r\n\r\nLet the second one be the list of customers mapped to their name:\r\n~~~\r\n[\r\n  {\r\n    &quot;CustomerID&quot;: &quot;1&quot;,\r\n    &quot;CustomerName&quot;: &quot;Alfred&quot;\r\n  },\r\n  {\r\n    &quot;CustomerID&quot;: &quot;2&quot;,\r\n    &quot;CustomerName&quot;: &quot;Bill&quot;\r\n  },\r\n  {\r\n    &quot;CustomerID&quot;: &quot;3&quot;,\r\n    &quot;CustomerName&quot;: &quot;Caroline&quot;\r\n  }\r\n]\r\nas $customers\r\n~~~\r\n\r\nAs jq&#39;s `JOIN` only handles two tables at once (for more, you need to cascade), let&#39;s ignore the missing Products table.\r\n\r\nBefore we can get to `JOIN` we need to look at `INDEX` first, which turns an array like our tables from above into an object with the table&#39;s &quot;primary keys&quot; as field names. This is reasonable as field names are unique, rendering a lookup to always return not more than one record.\r\n~~~\r\nINDEX($customers[]; .CustomerID)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;1&quot;: {\r\n    &quot;CustomerID&quot;: &quot;1&quot;,\r\n    &quot;CustomerName&quot;: &quot;Alfred&quot;\r\n  },\r\n  &quot;2&quot;: {\r\n    &quot;CustomerID&quot;: &quot;2&quot;,\r\n    &quot;CustomerName&quot;: &quot;Bill&quot;\r\n  },\r\n  &quot;3&quot;: {\r\n    &quot;CustomerID&quot;: &quot;3&quot;,\r\n    &quot;CustomerName&quot;: &quot;Caroline&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/HPPnY8lEpz)\r\n\r\nNow, we can easily perform a `JOIN` operation between Orders (as the &quot;left table&quot;) and their Customers (as the &quot;right table&quot;). Providing the &quot;right table&quot; as an `INDEX`ed object, the &quot;left table&quot; as a stream `.[]`, and the &quot;related column&quot; as field in the left table&#39;s objects that is matched with the right table&#39;s primary key (field name in the lookup object), we get: (let the last parameter be just `.` for now)\r\n~~~\r\nJOIN(INDEX($customers[]; .CustomerID); $orders[]; .CustomerIDRef; .)\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;OrderID&quot;: &quot;10&quot;,\r\n    &quot;CustomerIDRef&quot;: &quot;2&quot;,\r\n    &quot;ProductIDRef&quot;: &quot;7&quot;\r\n  },\r\n  {\r\n    &quot;CustomerID&quot;: &quot;2&quot;,\r\n    &quot;CustomerName&quot;: &quot;Bill&quot;\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;OrderID&quot;: &quot;11&quot;,\r\n    &quot;CustomerIDRef&quot;: &quot;1&quot;,\r\n    &quot;ProductIDRef&quot;: &quot;7&quot;\r\n  },\r\n  {\r\n    &quot;CustomerID&quot;: &quot;1&quot;,\r\n    &quot;CustomerName&quot;: &quot;Alfred&quot;\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;OrderID&quot;: &quot;12&quot;,\r\n    &quot;CustomerIDRef&quot;: &quot;2&quot;,\r\n    &quot;ProductIDRef&quot;: &quot;14&quot;\r\n  },\r\n  {\r\n    &quot;CustomerID&quot;: &quot;2&quot;,\r\n    &quot;CustomerName&quot;: &quot;Bill&quot;\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;OrderID&quot;: &quot;13&quot;,\r\n    &quot;CustomerIDRef&quot;: &quot;2&quot;,\r\n    &quot;ProductIDRef&quot;: &quot;7&quot;\r\n  },\r\n  {\r\n    &quot;CustomerID&quot;: &quot;2&quot;,\r\n    &quot;CustomerName&quot;: &quot;Bill&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/yIROpVyczd)\r\n\r\nAs you can see, we get a stream of arrays, one for each order. Each array has two elements: the record from the left table and the one from the right. An unsuccessful lookup would yield `null` on the right side.\r\n\r\nFinally, the fourth parameter being the &quot;join expression&quot; describes how to join the two matching records, which esentially acts as a `map`.\r\n\r\n~~~\r\nJOIN(INDEX($customers[]; .CustomerID); $orders[]; .CustomerIDRef;\r\n  &quot;\\(.[0].OrderID): \\(.[1].CustomerName) ordered Product #\\(.[0].ProductIDRef).&quot;\r\n)\r\n~~~\r\n~~~json\r\n10: Bill ordered Product #7.\r\n11: Alfred ordered Product #7.\r\n12: Bill ordered Product #14.\r\n13: Bill ordered Product #7.\r\n~~~\r\n[Demo](https://jqplay.org/s/nepV3dNTLQ)\r\n",
                "title": "Understanding jq JOIN()"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 12,
        "last_activity_date": 1658987566,
        "creation_date": 1644806096,
        "question_id": 71106595,
        "body_markdown": "I&#39;m trying to understand `JOIN()` builtin of `jq`.\r\n\r\nFrom the jq manual (https://stedolan.github.io/jq/manual):\r\n```\r\nJOIN($idx; stream; idx_expr; join_expr):\r\n\r\nThis builtin joins the values from the given stream to the given index. \r\nThe index&#39;s keys are computed by applying the given index expression to each value from the given stream. \r\nAn array of the value in the stream and the corresponding value from the index is fed to the given join expression to produce each result.\r\n```\r\n\r\nI find this hard to understand without examples.\r\n\r\nCould you give some examples of its usage demonstrating how it works?",
        "link": "https://stackoverflow.com/questions/71106595/understanding-jq-join",
        "title": "Understanding jq JOIN()"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644839833,
                "post_id": 71111424,
                "comment_id": 125703982,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2234728,
                    "reputation": 57,
                    "user_id": 1971444,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/71bee8358cfc80ef72a214fe21aae3a4?s=256&d=identicon&r=PG",
                    "display_name": "user1971444",
                    "link": "https://stackoverflow.com/users/1971444/user1971444"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644840024,
                "post_id": 71111424,
                "comment_id": 125704051,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644840114,
                "post_id": 71111424,
                "comment_id": 125704081,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2234728,
                    "reputation": 57,
                    "user_id": 1971444,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/71bee8358cfc80ef72a214fe21aae3a4?s=256&d=identicon&r=PG",
                    "display_name": "user1971444",
                    "link": "https://stackoverflow.com/users/1971444/user1971444"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644840219,
                "post_id": 71111424,
                "comment_id": 125704113,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1644841349,
                "last_edit_date": 1644841349,
                "creation_date": 1644840219,
                "answer_id": 71111595,
                "question_id": 71111424,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One option might be using\r\n```\r\njq &#39;.| select( has(&quot;key1&quot;))|to_entries[] | select( .value | length == 0 )&#39; $my_json\r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/go9Uy3DV73)&lt;/kbd&gt;\r\n\r\nEdit(*after question&#39;s edit*): If you need to get the values of the non-empty arrays unlike to the previous one, then just convert the above filter to\r\n```\r\njq -r &#39;.......| length &gt; 0) | &quot;\\(.key):&quot;, &quot;- \\(.value[])&quot;&#39; $my_json\r\n```\r\nthrough use of string interpolation\r\n\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/HZsgfwVxdD)&lt;/kbd&gt;\r\n",
                "title": "How filter json file with jq using bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1644840278,
                "creation_date": 1644840278,
                "answer_id": 71111615,
                "question_id": 71111424,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In jq you can use the `length` filter to get the size of an array.\r\n```shell\r\n$ echo &#39;{&quot;key1&quot;: [], &quot;key2&quot;:[&quot;1&quot;,&quot;2&quot;]}&#39; | jq -r &quot;.key2 | length&quot;\r\n2\r\n$ echo &#39;{&quot;key1&quot;: [], &quot;key2&quot;:[&quot;1&quot;,&quot;2&quot;]}&#39; | jq -r &quot;.key1 | length&quot;\r\n0\r\n\r\n```\r\nAlso, even with that you&#39;ll find a problem iterating the elements of the array stored in `$values`. I think that what you want is this:\r\n```shell\r\nvalues=$(jq -r &quot;.key1[]&quot; &quot;$my_json&quot;)\r\n```",
                "title": "How filter json file with jq using bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1644846768,
                "last_edit_date": 1644846768,
                "creation_date": 1644840437,
                "answer_id": 71111652,
                "question_id": 71111424,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This discards all items with an empty array, and iterates over the rest printing out the key name, then all array items.\r\n\r\n~~~sh\r\njq -r &#39;to_entries[] | select(.value | length &gt; 0) | .key, &quot;- \\(.value[])&quot;&#39;\r\n~~~\r\n~~~\r\nkey2\r\n- first_value\r\n- second_value\r\n~~~\r\n[Demo](https://jqplay.org/s/k86OLyNnsz)",
                "title": "How filter json file with jq using bash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1644848489,
        "creation_date": 1644839594,
        "last_edit_date": 1644848489,
        "question_id": 71111424,
        "body_markdown": "I am trying to filter my json file using bash, which file could be something like:   \r\n\r\n    {\r\n        &quot;key1&quot;: [],\r\n        &quot;key2&quot;:[&quot;first_value&quot;,&quot;second_value&quot;]\r\n    }\r\n\r\nIn case I would like to fetch key1 and key2 I got I can do something like:   \r\n\r\n\r\n    if $(cat $my_json | jq &#39;has(&quot;key1&quot;)&#39;); then\r\n      values=$(jq -r &quot;.key1&quot; &quot;$my_json&quot;)\r\n\r\n      for item in $values\r\n      do\r\n        echo &quot;Item : $item&quot;\r\n      done\r\n    fi\r\n\r\nThe output of the previous is:\r\n\r\n    Output:\r\n    \r\n    Item : []\r\n\r\nThis prevents any issues in the case my file hasn&#39;t such key and I want to verify that.\r\n\r\nHow can I verify that values is empty, referred to my example?   \r\nI want to avoid any iteration on empty values.   \r\nIs there any way to verify the existing key with jq, that should not be empty? \r\n\r\nThe goal I would like to achieve is something like **redirected at the end of a file**\r\n\r\n    key2:\r\n    - first_value\r\n    - second_value\r\n\r\nin case of key, since it is empty I don&#39;t want to have any results",
        "link": "https://stackoverflow.com/questions/71111424/how-filter-json-file-with-jq-using-bash",
        "title": "How filter json file with jq using bash"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1644842845,
                "last_edit_date": 1644842845,
                "creation_date": 1644842460,
                "answer_id": 71112075,
                "question_id": 71112010,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Define them using `--arg`, then set them using `+=`. That way you can always add more subitems.\r\n~~~\r\njq --arg parent_key aiops \\\r\n   --arg child_key catalog_source \\\r\n   --arg child_val abc.com/123 \\\r\n   &#39;.[$parent_key] += {($child_key): $child_val}&#39; input.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;cluster&quot;: &quot;bvt-rtp-123&quot;,\r\n  &quot;state&quot;: &quot;installed&quot;,\r\n  &quot;timestamp&quot;: &quot;2022-02-14T10:23:01Z&quot;,\r\n  &quot;aiops&quot;: {\r\n    &quot;catalog_source&quot;: &quot;abc.com/123&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/EC2TmbcD_3) for the jq filter (simulating argument input with variable declaration)",
                "title": "How to add a new JSON object in an existing JSON file using jq and variable arguments"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1666478875,
        "creation_date": 1644842107,
        "last_edit_date": 1666478875,
        "question_id": 71112010,
        "body_markdown": "I have a json here which looks like: \r\n```json\r\n{\r\n  &quot;cluster&quot;: &quot;bvt-rtp-123&quot;,\r\n  &quot;state&quot;: &quot;installed&quot;,\r\n  &quot;timestamp&quot;: &quot;2022-02-14T10:23:01Z&quot;\r\n}\r\n```\r\nI want to use parameters/environment variables to dynamically add an object to that JSON object using `jq` \r\nThe result should look like:\r\n```json\r\n{\r\n  &quot;cluster&quot;: &quot;bvt-rtp-123&quot;,\r\n  &quot;state&quot;: &quot;installed&quot;,\r\n  &quot;timestamp&quot;: &quot;2022-02-14T10:23:01Z&quot;,\r\n  &quot;aiops&quot;: {\r\n    &quot;catalog_source&quot;: &quot;abc.com/123&quot;,\r\n    &quot;channel&quot;: &quot;dev&quot;\r\n  }\r\n}\r\n```\r\nwherein `aiops`, `catalog_source` and `channel` are parameterized by environment variables in this way:\r\n```env\r\nparent_key=aiops\r\nchild_key=catalog_source\r\nchild_val=abc.com/123\r\n```\r\n\r\nI already tried this method,\r\n`cat test.json | jq --arg parent &quot;$parent_key&quot; --arg child &quot;$child_key&quot; --arg child_val &quot;$payload_val&quot; &#39;.[$key].[$child] = $child_val&#39;`\r\nBut it throws this error:\r\n```\r\njq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.[$key].[$child] = $child_val        \r\njq: 1 compile error\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/71112010/how-to-add-a-new-json-object-in-an-existing-json-file-using-jq-and-variable-argu",
        "title": "How to add a new JSON object in an existing JSON file using jq and variable arguments"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644856007,
                "post_id": 71114895,
                "comment_id": 125710376,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10704094,
                    "reputation": 23,
                    "user_id": 7878462,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8a28d7081932fc7192924c6aeaa13fd3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "rajesh tiwary",
                    "link": "https://stackoverflow.com/users/7878462/rajesh-tiwary"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644856757,
                "post_id": 71114895,
                "comment_id": 125710643,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644857402,
                "post_id": 71114895,
                "comment_id": 125710890,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1644864164,
                "last_edit_date": 1644864164,
                "creation_date": 1644863582,
                "answer_id": 71116670,
                "question_id": 71114895,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should work :\r\n\r\n```\r\n#!/bin/bash\r\n \r\nfor file in &quot;$home&quot;/*; do\r\n  while read -r s; do\r\n       export &quot;$s&quot;\r\n  done &lt; &lt;(jq -r &#39;to_entries|map(&quot;\\(.key)=\\(.value)&quot;)[]&#39; &quot;$file&quot;)\r\ndone\r\n```",
                "title": "read json file key value pair with space in value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1654257408,
        "creation_date": 1644855124,
        "last_edit_date": 1644863236,
        "question_id": 71114895,
        "body_markdown": "getting new line value while parsing json file with space in value from shell script\r\n```json\r\n{\r\n  &quot;KAFKASTORE_SASL_JAAS_CONFIG&quot;: &quot;software.amazon.msk.auth.iam.IAMLoginModule required;&quot;,\r\n  &quot;CLASSPATH&quot;: &quot;/usr/share/java/aws/*&quot;\r\n}\r\n```\r\nwith \r\n```sh\r\ntest.sh script file\r\n#!/bin/sh\r\nfor dir in &quot;$home&quot;/*; do\r\n  for s in $(cat $dir | jq -r &quot;to_entries|map(\\&quot;\\(.key)=\\(.value|tostring)\\&quot;)|.[]&quot; ); do\r\n       export $s\r\n  done\r\ndone\r\n```\r\nerror \r\n\r\n&gt; KAFKASTORE_SASL_JAAS_CONFIG=software.amazon.msk.auth.iam.IAMLoginModule\r\n&gt; required; ./jq.sh: line 20: export: `required;&#39;: not a valid\r\n&gt; identifier\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71114895/read-json-file-key-value-pair-with-space-in-value",
        "title": "read json file key value pair with space in value"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644861513,
                "post_id": 71116214,
                "comment_id": 125712414,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644861592,
                "post_id": 71116214,
                "comment_id": 125712439,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644861625,
                "post_id": 71116214,
                "comment_id": 125712453,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644861686,
                "post_id": 71116214,
                "comment_id": 125712480,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8368447,
                    "reputation": 606,
                    "user_id": 6284287,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d796ff973c6d7a1e989d69bb77774690?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "CClarke",
                    "link": "https://stackoverflow.com/users/6284287/cclarke"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644861717,
                "post_id": 71116214,
                "comment_id": 125712495,
                "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": 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": 2,
                "creation_date": 1644875134,
                "post_id": 71116214,
                "comment_id": 125716694,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1644861685,
                "creation_date": 1644861685,
                "answer_id": 71116280,
                "question_id": 71116214,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you get rid of the comma between the two objects (which is definitely invalid JSON), then just use jq&#39;s `--compact-output` (or `-c`) option and the [identity filter](https://stedolan.github.io/jq/manual/v1.6/#Identity:.) `.`.\r\n~~~sh\r\njq --compact-output &#39;.&#39;\r\n~~~\r\n~~~json\r\n{&quot;user_id&quot;:123,&quot;value&quot;:99}\r\n{&quot;user_id&quot;:122,&quot;value&quot;:100}\r\n~~~\r\n[Demo](https://jqplay.org/s/y7V5u_K2V7)",
                "title": "Convert JSON file to have each set of curly brackets on a single line"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1644862353,
                "creation_date": 1644862353,
                "answer_id": 71116409,
                "question_id": 71116214,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` can be used to wrap the input (as raw text) inside `[...]`, with the result being parsable by its builtin `fromjson` filter. Split the resulting array into separate objects again, and use `-c` to output each object on a single line.\r\n\r\n    $ cat old.txt\r\n    {\r\n      &quot;user_id&quot;: 123,\r\n      &quot;value&quot;: 99\r\n    },\r\n    {\r\n      &quot;user_id&quot;: 122,\r\n      &quot;value&quot;: 100\r\n    } \r\n    $ jq -csR &#39;&quot;[\\(.)]&quot; | fromjson |.[]&#39; old.txt\r\n    {&quot;user_id&quot;:123,&quot;value&quot;:99}\r\n    {&quot;user_id&quot;:122,&quot;value&quot;:100}",
                "title": "Convert JSON file to have each set of curly brackets on a single line"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1644862353,
        "creation_date": 1644861346,
        "question_id": 71116214,
        "body_markdown": "I have a simple JSON file like this:\r\n\r\n    {\r\n      &quot;user_id&quot;: 123,\r\n      &quot;value&quot;: 99\r\n    },\r\n    {\r\n      &quot;user_id&quot;: 122,\r\n      &quot;value&quot;: 100\r\n    }\r\n\r\nbut I need it to look like this:\r\n\r\n    {&quot;user_id&quot;: 123, &quot;value&quot;: 99}\r\n    {&quot;user_id&quot;: 122, &quot;value&quot;: 100}\r\n\r\nBasically every set of curly brackets should be on its own line. I was hoping it would be simple with jq but I&#39;m quite new to it. Thank you in advance.",
        "link": "https://stackoverflow.com/questions/71116214/convert-json-file-to-have-each-set-of-curly-brackets-on-a-single-line",
        "title": "Convert JSON file to have each set of curly brackets on a single line"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1644905874,
                "creation_date": 1644905874,
                "answer_id": 71121858,
                "question_id": 71121734,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The idea is right, but ensure the last update happens without traversing down to the leaf path (at the same level as `xxx`), but relative to the root path by simply wrapping the filter under `(..)`\r\n\r\n```none\r\n( .rules[] | select(.xxx.url | try contains(&quot;google.com&quot;)) | .xxx ) += {&quot;pass&quot;: &quot;abc&quot;}\r\n```\r\n\r\nAlways prefer using _exact_ match conditions instead of a partial match\r\n\r\n```none\r\n( .rules[] | select(.xxx.url == &quot;https://google.com&quot;) | .xxx ) += {&quot;pass&quot;: &quot;abc&quot;}\r\n```",
                "title": "jq: insert{&quot;key&quot;: &quot;value&quot;} pair in the nested structure"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1644942063,
                "last_edit_date": 1644942063,
                "creation_date": 1644908479,
                "answer_id": 71122265,
                "question_id": 71121734,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an even more &quot;dynamic&quot; approach:\r\n\r\n    walk(if type==&quot;object&quot; \r\n            and (.url|type)==&quot;string&quot; \r\n            and (.url|endswith(&quot;google.com&quot;)) \r\n         then .pass = &quot;abc&quot; else . end)\r\n\r\nOf course, depending on the task requirements, a simpler solution such as the following might suffice:\r\n\r\n    .rules.ccc.xxx.pass = &quot;abc&quot;",
                "title": "jq: insert{&quot;key&quot;: &quot;value&quot;} pair in the nested structure"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1644942063,
        "creation_date": 1644904936,
        "last_edit_date": 1644905772,
        "question_id": 71121734,
        "body_markdown": "I just wonder how we can achieve this with simple online `jq`.\r\n\r\n**AS_IS**\r\n```\r\n{\r\n  &quot;rules&quot;: {\r\n    &quot;aaa&quot;: {\r\n      &quot;xxx&quot;: {\r\n        &quot;url&quot;: &quot;https://microsoft.com&quot;\r\n      },\r\n      &quot;xxxx&quot;: {\r\n        &quot;url&quot;: &quot;https://netflix.com&quot;\r\n      }\r\n    },\r\n    &quot;bbb&quot;: {\r\n      &quot;xxx&quot;: {\r\n        &quot;url&quot;: &quot;https://amazon.com&quot;\r\n      }\r\n    },\r\n    &quot;ccc&quot;: {\r\n      &quot;xxx&quot;: {\r\n        &quot;url&quot;: &quot;https://google.com&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n```\r\n\r\n**TO_BE**\r\n```\r\n{\r\n  &quot;rules&quot;: {\r\n    &quot;aaa&quot;: {\r\n      &quot;xxx&quot;: {\r\n        &quot;url&quot;: &quot;https://microsoft.com&quot;\r\n      },\r\n      &quot;xxxx&quot;: {\r\n        &quot;url&quot;: &quot;https://netflix.com&quot;\r\n      }\r\n    },\r\n    &quot;bbb&quot;: {\r\n      &quot;xxx&quot;: {\r\n        &quot;url&quot;: &quot;https://amazon.com&quot;\r\n      }\r\n    },\r\n    &quot;ccc&quot;: {\r\n      &quot;xxx&quot;: {\r\n        &quot;url&quot;: &quot;https://google.com&quot;,\r\n        &quot;pass&quot;: &quot;abc&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nWhat I tried so far is \r\n```\r\n.rules[] | select(.xxx.url | try contains(&quot;google.com&quot;)) | .xxx += {&quot;pass&quot;: &quot;abc&quot;}\r\n```\r\nand the output is below, and I successfully insert `&quot;pass&quot;: &quot;abc&quot;`.\r\n```\r\n{\r\n  &quot;xxx&quot;: {\r\n    &quot;url&quot;: &quot;https://google.com&quot;,\r\n    &quot;pass&quot;: &quot;abc&quot;\r\n  }\r\n}\r\n```\r\nbut I want to get the whole lines of code. (Not a part of it)\r\nref. https://jqplay.org/s/S_UWrrLRl5",
        "link": "https://stackoverflow.com/questions/71121734/jq-insertkey-value-pair-in-the-nested-structure",
        "title": "jq: insert{&quot;key&quot;: &quot;value&quot;} pair in the nested structure"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1644924158,
                "last_edit_date": 1644924158,
                "creation_date": 1644922904,
                "answer_id": 71125298,
                "question_id": 71125191,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re missing a filter in the inner jq call. Insert the [identity filter](https://stedolan.github.io/jq/manual/v1.6/#Identity:.) `.` as in `jq -Rs . file.html`:\r\n\r\n~~~\r\njq --slurpfile texts &lt;(jq -Rs . file.html) &#39;.body=$texts[0]&#39; file.json &gt;newfile.json\r\n~~~\r\n\r\nAdditional notes:\r\n\r\nYou could also use `--argfile` instead of `--slurpfile` which gives you the string itself rather than an array, from which you wouldn&#39;t  have to extract the first element `.[0]` anymore:\r\n~~~\r\njq --argfile texts &lt;(jq -Rs . file.html) &#39;.body=$texts&#39; file.json &gt;newfile.json\r\n~~~\r\n\r\nAlso, if you are using jq 1.6, there&#39;s yet an easier way to do it. Use `--rawfile` instead of `--argfile` or `--slurpfile` and you don&#39;t need the other jq at all anymore:\r\n~~~\r\njq --rawfile texts file.html &#39;.body=$texts&#39; file.json &gt;newfile.json\r\n~~~\r\n",
                "title": "Inserting a long HTML file to a Json file using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1644924158,
        "creation_date": 1644922512,
        "question_id": 71125191,
        "body_markdown": "I&#39;m trying to insert the content of a long html file to my json file using the command I found on this https://stackoverflow.com/questions/51953147/insert-an-html-file-into-a-json-file-value-using-jq\r\n\r\nI&#39;m using this command because the other ones are meant for short argument only, whereas in my usecase, the html content can be quite long.\r\n\r\n```jq --slurpfile texts &lt;(jq -Rs file.html) &#39;.body=$texts[0]&#39; file.json &gt;newfile.json```\r\n\r\nhowever, I&#39;m getting this error\r\n\r\n```\r\njq: error: file/0 is not defined at &lt;top-level&gt;, line 1:\r\nfile.html\r\njq: 1 compile error\r\n```\r\n\r\nthe content of the html file doesn&#39;t seem to matter. I tried using only a simple html file like this\r\n```\r\n&lt;html&gt;\r\n  &lt;body&gt;&lt;/body&gt;\r\n&lt;/html&gt;\r\n```\r\n\r\nAnd still got the same error. \r\n\r\nbtw before I do the jq command I&#39;m using `sed &#39;s/&amp;/\\&amp;amp;/g; s/&quot;/\\\\\\&quot;/g; s/&#39;&quot;&#39;&quot;&#39;/\\\\\\&#39;&quot;&#39;&quot;&#39;/g&#39;` to make the html file an encoded string as described in the same question I linked as well\r\n\r\nWhat exactly am I doing wrong? the error message doesn&#39;t really say anything other than that, so I&#39;m clueless as to what went wrong\r\n\r\nI appreciate any help",
        "link": "https://stackoverflow.com/questions/71125191/inserting-a-long-html-file-to-a-json-file-using-jq",
        "title": "Inserting a long HTML file to a Json file using JQ"
    },
    {
        "tags": [
            "json",
            "linux",
            "base64",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10502687,
                    "reputation": 178,
                    "user_id": 7740944,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/b381654886e2f28d3f10bfeadfa4556e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Guillaume",
                    "link": "https://stackoverflow.com/users/7740944/guillaume"
                },
                "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": 1644938093,
                "post_id": 71128689,
                "comment_id": 125734418,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644940296,
                "post_id": 71128689,
                "comment_id": 125735455,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1644941620,
                "creation_date": 1644941620,
                "answer_id": 71129781,
                "question_id": 71128689,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use jq&#39;s `@base64` builtin, rather than doing the conversion outside because that way you can either convert all or nothing.\r\n~~~sh\r\njq &#39;.data_to_be_encoded |= @base64&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;request_id&quot;: 1234,\r\n  &quot;data_to_be_encoded&quot;: &quot;W3sibWV0YWRhdGEiOnsicHJvamVjdCI6WyJzb21lUHJvamVjdDEiLCJzb21lUHJvamVjdDIiXSwidGFibGVfbmFtZSI6WyJzb21lVGFibGUxIiwic29tZVRhYmxlMiJdLCJzeXNfaW5zZXJ0ZGF0ZXRpbWUiOiJzb21lRGF0ZSIsInN5c19zb3VyY2VzeXN0ZW0iOiJzb21lU291cmNlU3lzdGVtIn0sImRhdGEiOnsiZmllbGQxIjo2MzUzMzcxMiwiZmllbGQyIjoiIiwiZmllbGQzIjoiaGVsbG8iLCJmaWVsZDQiOiJvdGhlciIsImZpZWxkNSI6MjAyMiwiZmllbGQ2IjoiMCIsImZpZWxkNyI6IjAiLCJmaWVsZDgiOiIwIiwiZmllbGQ5IjoiMCIsImZpZWxkMTAiOiIwIiwiZmllbGQxMSI6IjAifX0seyJtZXRhZGF0YSI6eyJwcm9qZWN0IjpbInNvbWVQcm9qZWN0MSIsInNvbWVQcm9qZWN0MiJdLCJ0YWJsZV9uYW1lIjpbInNvbWVUYWJsZTEiLCJzb21lVGFibGUyIl0sInN5c19pbnNlcnRkYXRldGltZSI6InNvbWVEYXRlIiwic3lzX3NvdXJjZXN5c3RlbSI6InNvbWVTb3VyY2VTeXN0ZW0ifSwiZGF0YSI6eyJmaWVsZDEiOjYzNTMzNzEzLCJmaWVsZDIiOiJZMkpqTFRJd01qSXRkekExTFhSeVppMXZabVp5WlhNdGNtVnVabTl5ZEMxamFHVnhkV2xsY2kxM01EVT0iLCJmaWVsZDMiOiJBMEFWQiIsImZpZWxkNCI6Im90aGVyIiwiZmllbGQ1IjoiSEpsYm1admNuUWdZMmhsY1hWcFpYSWdWekExIiwiZmllbGQ2IjoiIiwiZmllbGQ3IjoiMDIvMDIvMjAyMiIsImZpZWxkOCI6IjE0LzAyLzIwMjIiLCJmaWVsZDkiOiJUaWNrZXQifX1d&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/tVJllUdpYx)\r\n\r\nIf you need all in one line, use the `-c` option as before:\r\n~~~sh\r\njq -c &#39;.data_to_be_encoded |= @base64&#39;\r\n~~~\r\n~~~json\r\n{&quot;request_id&quot;:1234,&quot;data_to_be_encoded&quot;:&quot;W3sibWV0YWRhdGEiOnsicHJvamVjdCI6WyJzb21lUHJvamVjdDEiLCJzb21lUHJvamVjdDIiXSwidGFibGVfbmFtZSI6WyJzb21lVGFibGUxIiwic29tZVRhYmxlMiJdLCJzeXNfaW5zZXJ0ZGF0ZXRpbWUiOiJzb21lRGF0ZSIsInN5c19zb3VyY2VzeXN0ZW0iOiJzb21lU291cmNlU3lzdGVtIn0sImRhdGEiOnsiZmllbGQxIjo2MzUzMzcxMiwiZmllbGQyIjoiIiwiZmllbGQzIjoiaGVsbG8iLCJmaWVsZDQiOiJvdGhlciIsImZpZWxkNSI6MjAyMiwiZmllbGQ2IjoiMCIsImZpZWxkNyI6IjAiLCJmaWVsZDgiOiIwIiwiZmllbGQ5IjoiMCIsImZpZWxkMTAiOiIwIiwiZmllbGQxMSI6IjAifX0seyJtZXRhZGF0YSI6eyJwcm9qZWN0IjpbInNvbWVQcm9qZWN0MSIsInNvbWVQcm9qZWN0MiJdLCJ0YWJsZV9uYW1lIjpbInNvbWVUYWJsZTEiLCJzb21lVGFibGUyIl0sInN5c19pbnNlcnRkYXRldGltZSI6InNvbWVEYXRlIiwic3lzX3NvdXJjZXN5c3RlbSI6InNvbWVTb3VyY2VTeXN0ZW0ifSwiZGF0YSI6eyJmaWVsZDEiOjYzNTMzNzEzLCJmaWVsZDIiOiJZMkpqTFRJd01qSXRkekExTFhSeVppMXZabVp5WlhNdGNtVnVabTl5ZEMxamFHVnhkV2xsY2kxM01EVT0iLCJmaWVsZDMiOiJBMEFWQiIsImZpZWxkNCI6Im90aGVyIiwiZmllbGQ1IjoiSEpsYm1admNuUWdZMmhsY1hWcFpYSWdWekExIiwiZmllbGQ2IjoiIiwiZmllbGQ3IjoiMDIvMDIvMjAyMiIsImZpZWxkOCI6IjE0LzAyLzIwMjIiLCJmaWVsZDkiOiJUaWNrZXQifX1d&quot;}\r\n~~~\r\n[Demo](https://jqplay.org/s/hNTxH8v48b)\r\n\r\n",
                "title": "Encode JSON value while disabling line wrapping"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1644945190,
        "creation_date": 1644937305,
        "last_edit_date": 1644945190,
        "question_id": 71128689,
        "body_markdown": "I originally had an issue with a JSON (let&#39;s call it &quot;raw_data.json&quot;) that looked like this:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;metadata&quot;: {\r\n      &quot;project&quot;: [\r\n        &quot;someProject1&quot;,\r\n        &quot;someProject2&quot;\r\n      ],\r\n      &quot;table_name&quot;: [\r\n        &quot;someTable1&quot;,\r\n        &quot;someTable2&quot;\r\n      ],\r\n      &quot;sys_insertdatetime&quot;: &quot;someDate&quot;,\r\n      &quot;sys_sourcesystem&quot;: &quot;someSourceSystem&quot;\r\n    },\r\n    &quot;data&quot;: {\r\n      &quot;field1&quot;: 63533712,\r\n      &quot;field2&quot;: &quot;&quot;,\r\n      &quot;field3&quot;: &quot;hello&quot;,\r\n      &quot;field4&quot;: &quot;other&quot;,\r\n      &quot;field5&quot;: 2022,\r\n      &quot;field6&quot;: &quot;0&quot;,\r\n      &quot;field7&quot;: &quot;0&quot;,\r\n      &quot;field8&quot;: &quot;0&quot;,\r\n      &quot;field9&quot;: &quot;0&quot;,\r\n      &quot;field10&quot;: &quot;0&quot;,\r\n      &quot;field11&quot;: &quot;0&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;metadata&quot;: {\r\n      &quot;project&quot;: [\r\n        &quot;someProject1&quot;,\r\n        &quot;someProject2&quot;\r\n      ],\r\n      &quot;table_name&quot;: [\r\n        &quot;someTable1&quot;,\r\n        &quot;someTable2&quot;\r\n      ],\r\n      &quot;sys_insertdatetime&quot;: &quot;someDate&quot;,\r\n      &quot;sys_sourcesystem&quot;: &quot;someSourceSystem&quot;\r\n    },\r\n    &quot;data&quot;: {\r\n      &quot;field1&quot;: 63533713,\r\n      &quot;field2&quot;: &quot;Y2JjLTIwMjItdzA1LXRyZi1vZmZyZXMtcmVuZm9ydC1jaGVxdWllci13MDU=&quot;,\r\n      &quot;field3&quot;: &quot;A0AVB&quot;,\r\n      &quot;field4&quot;: &quot;other&quot;,\r\n      &quot;field5&quot;: &quot;HJlbmZvcnQgY2hlcXVpZXIgVzA1&quot;,\r\n      &quot;field6&quot;: &quot;&quot;,\r\n      &quot;field7&quot;: &quot;02/02/2022&quot;,\r\n      &quot;field8&quot;: &quot;14/02/2022&quot;,\r\n      &quot;field9&quot;: &quot;Ticket&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nThe dictionaries were pretty big and usually spanned over several lines on my monitor. That was an issue because I needed to encode the whole thing in Base64 and send the result with a HTTP POST method. But the encoding tended to wrap lines by adding newlines characters, which caused my POST method to fail.\r\n\r\nI fortunately found a [question][1] with the following solution:\r\n\r\n    export DATA=$(cat &#39;raw_data.json&#39;)\r\n    export ENCODED_DATA=$(echo &quot;$DATA&quot; | jq -c . | base64 -w 0)\r\n\r\nProblem is, my JSON has now changed to this:\r\n\r\n```json\r\n{\r\n  &quot;request_id&quot;: 1234,\r\n  &quot;data_to_be_encoded&quot;: [\r\n    {\r\n      &quot;metadata&quot;: {\r\n        &quot;project&quot;: [\r\n          &quot;someProject1&quot;,\r\n          &quot;someProject2&quot;\r\n        ],\r\n        &quot;table_name&quot;: [\r\n          &quot;someTable1&quot;,\r\n          &quot;someTable2&quot;\r\n        ],\r\n        &quot;sys_insertdatetime&quot;: &quot;someDate&quot;,\r\n        &quot;sys_sourcesystem&quot;: &quot;someSourceSystem&quot;\r\n      },\r\n      &quot;data&quot;: {\r\n        &quot;field1&quot;: 63533712,\r\n        &quot;field2&quot;: &quot;&quot;,\r\n        &quot;field3&quot;: &quot;hello&quot;,\r\n        &quot;field4&quot;: &quot;other&quot;,\r\n        &quot;field5&quot;: 2022,\r\n        &quot;field6&quot;: &quot;0&quot;,\r\n        &quot;field7&quot;: &quot;0&quot;,\r\n        &quot;field8&quot;: &quot;0&quot;,\r\n        &quot;field9&quot;: &quot;0&quot;,\r\n        &quot;field10&quot;: &quot;0&quot;,\r\n        &quot;field11&quot;: &quot;0&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;metadata&quot;: {\r\n        &quot;project&quot;: [\r\n          &quot;someProject1&quot;,\r\n          &quot;someProject2&quot;\r\n        ],\r\n        &quot;table_name&quot;: [\r\n          &quot;someTable1&quot;,\r\n          &quot;someTable2&quot;\r\n        ],\r\n        &quot;sys_insertdatetime&quot;: &quot;someDate&quot;,\r\n        &quot;sys_sourcesystem&quot;: &quot;someSourceSystem&quot;\r\n      },\r\n      &quot;data&quot;: {\r\n        &quot;field1&quot;: 63533713,\r\n        &quot;field2&quot;: &quot;Y2JjLTIwMjItdzA1LXRyZi1vZmZyZXMtcmVuZm9ydC1jaGVxdWllci13MDU=&quot;,\r\n        &quot;field3&quot;: &quot;A0AVB&quot;,\r\n        &quot;field4&quot;: &quot;other&quot;,\r\n        &quot;field5&quot;: &quot;HJlbmZvcnQgY2hlcXVpZXIgVzA1&quot;,\r\n        &quot;field6&quot;: &quot;&quot;,\r\n        &quot;field7&quot;: &quot;02/02/2022&quot;,\r\n        &quot;field8&quot;: &quot;14/02/2022&quot;,\r\n        &quot;field9&quot;: &quot;Ticket&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\nBasically I needed to keep the *request_id* key-value pair as is, while what was inside the *data_to_be_encoded* key had to be encoded. Again, another [post][2] offered a nice solution:\r\n\r\n    export DATA=$(cat &#39;raw_data.json&#39;)\r\n    export ENCODED_DATA=$(echo &quot;$DATA&quot; | jq &#39;.data_to_be_encoded |= @base64&#39;)\r\n\r\nExcept for the fact that this solution adds line wrapping and I haven&#39;t found a way to disable that feature like I managed to do with the first solution. \r\n\r\nI did try this:\r\n\r\n    export ENCODED_DATA=$(echo &quot;$DATA&quot; | jq -c .data_to_be_encoded | base64 -w 0)\r\n\r\nBut it only returns the value inside the *data_to_be_encoded* key and not the whole JSON. So I&#39;m back to square one.\r\n\r\nHow can I get the best of both worlds? In other words, how can I disable the line wrapping while at the same time encoding a specific part of my JSON?\r\n\r\n  [1]: https://superuser.com/questions/1225134/why-does-the-base64-of-a-string-contain-n\r\n  [2]: https://unix.stackexchange.com/questions/590244/how-to-properly-encode-string-based-on-json-file\r\n",
        "link": "https://stackoverflow.com/questions/71128689/encode-json-value-while-disabling-line-wrapping",
        "title": "Encode JSON value while disabling line wrapping"
    },
    {
        "tags": [
            "json",
            "jq",
            "updates"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1644957455,
                "creation_date": 1644957455,
                "answer_id": 71133081,
                "question_id": 71132774,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following illustrates one approach you could take:\r\n```\r\n&lt; content.json jq --argfile updates updates.json &#39;\r\n    .Network += $updates.Network\r\n&#39;\r\n```\r\n\r\nOr, depending on your precise requirements, you might like to consider:\r\n```\r\n&lt; content.json jq --argfile updates updates.json &#39;\r\n  .Network |= with_entries(select(.value != &quot;unknown&quot;))\r\n  | .Network += $updates.Network\r\n&#39;\r\n```",
                "title": "jq - apply modifications from a file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1644957892,
                "creation_date": 1644957892,
                "answer_id": 71133165,
                "question_id": 71132774,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want the occurrences of &quot;unknown&quot; to determine the updates:\r\n```\r\n&lt; content.json jq --argfile updates updates.json &#39;\r\n  reduce paths(. == &quot;unknown&quot;) as $p (.;\r\n    setpath($p; $updates | getpath($p)) )\r\n&#39;\r\n```",
                "title": "jq - apply modifications from a file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1644958240,
                "creation_date": 1644958240,
                "answer_id": 71133231,
                "question_id": 71132774,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Perhaps the &quot;recursive addition&quot; operator `*` will meet your needs:\r\n```\r\n&lt; contents.json  jq --argfile updates updates.json &#39;\r\n  . * $updates\r\n&#39;\r\n```",
                "title": "jq - apply modifications from a file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1644959715,
                "creation_date": 1644959715,
                "answer_id": 71133485,
                "question_id": 71132774,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A more generic method:\r\n\r\n```\r\njq -s &#39;def multiply:reduce .[] as $i ({}; . * $i);\r\n       multiply&#39; content.json updates.json\r\n```\r\n\r\nSo you can put multiple files.",
                "title": "jq - apply modifications from a file"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1644969318,
        "creation_date": 1644955922,
        "last_edit_date": 1644969318,
        "question_id": 71132774,
        "body_markdown": "I have some json content in a file: *content.json*\r\n```\r\n{\r\n  &quot;Type&quot;: {\r\n    &quot;OS&quot;: &quot;Windows&quot;\r\n  },\r\n  &quot;Network&quot;: {\r\n     &quot;Protocol&quot;: &quot;unknown&quot;,\r\n     &quot;Port&quot;: 80\r\n  }\r\n}\r\n```\r\n\r\nAnd some json updates in a file: *updates.json*\r\n```\r\n{\r\n  &quot;Network&quot;: {\r\n    &quot;Protocol&quot;: &quot;HTTP&quot;\r\n  }\r\n}\r\n```\r\n\r\nHow can I use jq to read *updates.json* and apply its content to *content.json*?&lt;br&gt;&lt;br&gt;\r\nCAVEAT: I cannot predict the what&#39;s in *updates.json*. The jq script must be smart enough to just apply whatever it finds.&lt;br&gt;&lt;br&gt;\r\nThe output should be:\r\n```\r\n{\r\n  &quot;Type&quot;: {\r\n    &quot;OS&quot;: &quot;Windows&quot;\r\n  },\r\n  &quot;Network&quot;: {\r\n     &quot;Protocol&quot;: &quot;HTTP&quot;,\r\n     &quot;Port&quot;: 80\r\n  }\r\n}\r\n```\r\n\r\nThis script does *almost* what I want:&lt;br&gt;\r\n```\r\njq &#39;add&#39; -s content.json updates.json\r\n```\r\nThe results are:\r\n```\r\n{\r\n  &quot;Type&quot;: {\r\n    &quot;OS&quot;: &quot;Windows&quot;\r\n  },\r\n  &quot;Network&quot;: {\r\n    &quot;Protocol&quot;: &quot;HTTP&quot;\r\n  }\r\n}\r\n```\r\nBut as you can see, the &quot;Port&quot; entry is deleted.",
        "link": "https://stackoverflow.com/questions/71132774/jq-apply-modifications-from-a-file",
        "title": "jq - apply modifications from a file"
    },
    {
        "tags": [
            "label",
            "jq",
            "break"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644975401,
                "post_id": 71135312,
                "comment_id": 125746425,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8919214,
                    "reputation": 1037,
                    "user_id": 6656508,
                    "user_type": "registered",
                    "accept_rate": 14,
                    "profile_image": "https://lh5.googleusercontent.com/-Cw00Euo9ls4/AAAAAAAAAAI/AAAAAAAAAD0/AxPxZMOm4qc/s256-rj/photo.jpg",
                    "display_name": "Logan Lee",
                    "link": "https://stackoverflow.com/users/6656508/logan-lee"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644979854,
                "post_id": 71135312,
                "comment_id": 125747114,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644981723,
                "post_id": 71135312,
                "comment_id": 125747400,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1644982123,
                "last_edit_date": 1644982123,
                "creation_date": 1644981725,
                "answer_id": 71136013,
                "question_id": 71135312,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given your input array, `.==1` will never evaluate to true. `$item==3`, `$item==2` and `$item==1`, as well as `.==0`, `.==3` and `.==5`, however, would.\r\n\r\nAnd if it does, it still wouldn&#39;t output `5` because `break` is treated like an error that was caught.\r\n\r\nFrom the [manual]():\r\n&gt; The `break $label_name` expression will cause the program to to act as though the nearest (to the left) `label $label_name` produced `empty`.\r\n\r\nTherefore\r\n~~~\r\nlabel $out | reduce .[] as $item (0;\r\n  if $item==1 then break $out else .+$item end\r\n)\r\n~~~\r\nwill correctly produce `empty`.\r\n\r\nYou can still capture `empty` though, for instance\r\n~~~\r\nlabel $out | reduce .[] as $item (0;\r\n  if $item == 1 then break $out else . + $item end\r\n)? // (.[:index(1)] | add)\r\n~~~\r\n~~~\r\n5\r\n~~~\r\n[Demo](https://jqplay.org/s/soSlN-ttVf)\r\n",
                "title": "Jq label and break to break out of control structure"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1644983114,
                "last_edit_date": 1644983114,
                "creation_date": 1644982094,
                "answer_id": 71136046,
                "question_id": 71135312,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`break` does not work (in the way one might reasonably expect (*) ) with `reduce`.  Whether that is by design or not, I cannot say, but perhaps it&#39;s not surprising as `reduce` is intended for reductions.  \r\n\r\nApart from `reduce`, though, `break` behaves properly elsewhere, notably with `foreach`.\r\n\r\n---\r\n(*) Consider for example:\r\n```\r\n  label $out\r\n  | reduce range(0;10) as $i (0; .+$i | if $i == 4 then ., break $out else . end)\r\n```\r\nOne might reasonably expect the accumulated sum (0+1+2+3+4) to be emitted, but instead the result is `empty`.\r\n\r\nBy contrast, if you replace `reduce` with `foreach`, the result is as expected:\r\n```\r\n0\r\n1\r\n3\r\n6\r\n10\r\n```\r\n\r\nNotice that to achieve the effect that is presumably wanted with `reduce`, one can simply use `last` in conjunction with `foreach`:\r\n```\r\n  last(label $out\r\n       | foreach range(0;10) as $i (0; .+$i | if $i == 4 then ., break $out else . end))\r\n```\r\n",
                "title": "Jq label and break to break out of control structure"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1644983114,
        "creation_date": 1644973987,
        "last_edit_date": 1644981372,
        "question_id": 71135312,
        "body_markdown": "I&#39;m trying to learn jq `label` and `break`.\r\n\r\nHere&#39;s my attempt:\r\nhttps://jqplay.org/s/YHxn1dRlQO\r\n\r\n```\r\nFilter:\r\nlabel $out | reduce .[] as $item (0; if $item==1 then break $out else .+$item end)\r\n\r\nInput:\r\n[3,2,1]\r\n\r\nOutput:\r\nempty\r\n```\r\n\r\nI was expecting output 5.\r\n\r\nI don&#39;t really know how `label` and `break` works.\r\n\r\nCan you explain how to correctly use them with examples?",
        "link": "https://stackoverflow.com/questions/71135312/jq-label-and-break-to-break-out-of-control-structure",
        "title": "Jq label and break to break out of control structure"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1644991332,
                "post_id": 71135417,
                "comment_id": 125748896,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1644975861,
                "creation_date": 1644975861,
                "answer_id": 71135473,
                "question_id": 71135417,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Take `thermostatList` as context and `map`:\r\n~~~sh\r\njq &#39;.thermostatList | {thermostats: map({name, identifier})}&#39; test.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;thermostats&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Thermostat&quot;,\r\n      &quot;identifier&quot;: 123456789\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/mO90Okv9tS)",
                "title": "Select keys within an array then write that out to a config file as an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1644991202,
        "creation_date": 1644975261,
        "last_edit_date": 1644991202,
        "question_id": 71135417,
        "body_markdown": "I&#39;m trying to wrap my head around the following.  I&#39;d like to place the output below into an array that I can save as a list of thermostats (which I currently only have 1, but I&#39;d like to plan on the ability to have 2) \r\n\r\n```json\r\njq &#39;.thermostatList[] | {name, identifier}&#39; test.json\r\n{\r\n  &quot;name&quot;: &quot;Thermostat&quot;,\r\n  &quot;identifier&quot;: &quot;123456789&quot;\r\n}\r\n```\r\n\r\nWhat I&#39;d like\r\n\r\n```json\r\ncat ~/etc/ecobee.thermostats\r\n{\r\n   &quot;thermostats&quot;: [\r\n      {\r\n         &quot;name&quot;: &quot;Thermostat&quot;,\r\n         &quot;identifier&quot;: 123456789\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nIs this possible with jq?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/71135417/select-keys-within-an-array-then-write-that-out-to-a-config-file-as-an-array",
        "title": "Select keys within an array then write that out to a config file as an array"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "where-clause"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1645000066,
                "last_edit_date": 1645000066,
                "creation_date": 1644999714,
                "answer_id": 71138338,
                "question_id": 71138293,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, you have to &quot;navigate&quot; to where you want to make the query. This seems to be an array.\r\n~~~\r\n.data.inventory.list.content\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;item&quot;: {\r\n      &quot;name&quot;: &quot;minivan&quot;\r\n    },\r\n    &quot;owner&quot;: {\r\n      &quot;id&quot;: &quot;12345&quot;,\r\n      &quot;state&quot;: &quot;CA&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;item&quot;: {\r\n      &quot;name&quot;: &quot;sedan&quot;\r\n    },\r\n    &quot;owner&quot;: {\r\n      &quot;id&quot;: &quot;67890&quot;,\r\n      &quot;state&quot;: &quot;AZ&quot;\r\n    }\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/lCIeOQt_3m)\r\n\r\nNext, let&#39;s iterate over that array&#39;s items, which gives us a stream of objects.\r\n~~~\r\n.[]\r\n~~~\r\n~~~json\r\n{\r\n  &quot;item&quot;: {\r\n    &quot;name&quot;: &quot;minivan&quot;\r\n  },\r\n  &quot;owner&quot;: {\r\n    &quot;id&quot;: &quot;12345&quot;,\r\n    &quot;state&quot;: &quot;CA&quot;\r\n  }\r\n}\r\n{\r\n  &quot;item&quot;: {\r\n    &quot;name&quot;: &quot;sedan&quot;\r\n  },\r\n  &quot;owner&quot;: {\r\n    &quot;id&quot;: &quot;67890&quot;,\r\n    &quot;state&quot;: &quot;AZ&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/B6KHJDlxK_)\r\n\r\nFrom these objects we select those that match your criteria.\r\n~~~\r\nselect(.owner.id == &quot;67890&quot;)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;item&quot;: {\r\n    &quot;name&quot;: &quot;sedan&quot;\r\n  },\r\n  &quot;owner&quot;: {\r\n    &quot;id&quot;: &quot;67890&quot;,\r\n    &quot;state&quot;: &quot;AZ&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/vge3rHvFPt)\r\n\r\nFinally, we extract the value you&#39;re interested in.\r\n~~~\r\n.item.name\r\n~~~\r\n~~~\r\n&quot;sedan&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/RvPFrmQPqR)\r\n\r\nEverything combined in a jq call would be:\r\n~~~sh\r\njq &#39;.data.inventory.list.content[] | select(.owner.id == &quot;67890&quot;).item.name&#39;\r\n~~~\r\n~~~\r\n&quot;sedan&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/MqoteTT9oF)\r\n\r\nThis output is still valid JSON document (containing nothing but a JSON string). If you want to process the output as raw text, use the `--raw-output` (or `-r`) option:\r\n~~~sh\r\njq -r &#39;.data.inventory.list.content[] | select(.owner.id == &quot;67890&quot;).item.name&#39;\r\n~~~\r\n~~~\r\nsedan\r\n~~~\r\n[Demo](https://jqplay.org/s/MkvM3U1D7C)\r\n",
                "title": "Using jq to search for a value based on a key located deep in json file"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1645016235,
                "last_edit_date": 1645016235,
                "creation_date": 1645015918,
                "answer_id": 71142224,
                "question_id": 71138293,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that avoids having to &quot;navigate&quot; to the right place, and which is also quite close to your SQL-like query:\r\n\r\n\r\n```\r\n..\r\n| objects \r\n| select(.owner and \r\n         (.owner|type==&quot;object&quot; and .id == &quot;67890&quot;))\r\n  .item.name\r\n```\r\n\r\nor more succinctly:\r\n\r\n```\r\n..|objects|select(.owner.id? == &quot;67890&quot;).item.name\r\n```\r\n",
                "title": "Using jq to search for a value based on a key located deep in json file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1645016313,
        "creation_date": 1644999473,
        "last_edit_date": 1645016313,
        "question_id": 71138293,
        "body_markdown": "I am new to jq and I&#39;m trying to use it to search for a value in a json file based on a key that is located deep in the json structure. Here is a sample of my json file:\r\n\r\n```\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;inventory&quot;: {\r\n      &quot;location&quot;: &quot;remote&quot;,\r\n      &quot;list&quot;: {\r\n        &quot;content&quot;: [\r\n          {\r\n            &quot;item&quot;: {\r\n              &quot;name&quot;: &quot;minivan&quot;\r\n            },\r\n            &quot;owner&quot;: {\r\n              &quot;id&quot;: &quot;12345&quot;,\r\n              &quot;state&quot;: &quot;CA&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;item&quot;: {\r\n              &quot;name&quot;: &quot;sedan&quot;\r\n            },\r\n            &quot;owner&quot;: {\r\n              &quot;id&quot;: &quot;67890&quot;,\r\n              &quot;state&quot;: &quot;AZ&quot;\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n```\r\nAn example of search that I&#39;m trying to do is: \r\n```\r\nselect item.name where owner.id = &quot;67890&quot;\r\n```\r\nand the expected output would be:\r\n```\r\nitem.name = &quot;sedan&quot;\r\n```\r\n\r\nI&#39;m trying to run the following:\r\n\r\n```\r\njq &#39;.[] | select .owner.id = &quot;67890&quot; | .item.name&#39; json\r\n```\r\nand it generates an error:\r\n```\r\njq: error: select/0 is not defined at &lt;top-level&gt;, line 1:\r\n.[] | select .owner.id = &quot;67890&quot; | .item.name      \r\njq: 1 compile error\r\n```\r\n\r\nAny pointers on how to do this in jq would be much appreciated!\r\nThanks!",
        "link": "https://stackoverflow.com/questions/71138293/using-jq-to-search-for-a-value-based-on-a-key-located-deep-in-json-file",
        "title": "Using jq to search for a value based on a key located deep in json file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1645019469,
                "creation_date": 1645019469,
                "answer_id": 71143098,
                "question_id": 71142954,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your sample output is invalid JSON. I assume you want to have one object with one field per input row.\r\n\r\nRead in raw text using `-R`, then split by space using `/`, and reduce all the input to one object by setting the according fields.\r\n\r\n~~~sh\r\njq -Rn &#39;\r\n  [inputs / &quot; &quot;] | reduce .[] as $line ({};\r\n    .[$line[0]] = {exchange: $line[1], replication: $line[2]}\r\n  )\r\n&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;2254003131908096&quot;: {\r\n    &quot;exchange&quot;: &quot;39480500160&quot;,\r\n    &quot;replication&quot;: &quot;39763833120&quot;\r\n  },\r\n  &quot;2296334329577472&quot;: {\r\n    &quot;exchange&quot;: &quot;36713833920&quot;,\r\n    &quot;replication&quot;: &quot;37747166400&quot;\r\n  },\r\n  &quot;2297708719112192&quot;: {\r\n    &quot;exchange&quot;: &quot;39830499360&quot;,\r\n    &quot;replication&quot;: &quot;41430500640&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/mdeFC8wFDm)\r\n",
                "title": "How to create a specific result using JQ (jq parse json)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651042353,
                "creation_date": 1651042353,
                "answer_id": 72024460,
                "question_id": 71142954,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `reduce`.\r\n\r\nFilter\r\n```\r\nreduce (inputs / &quot; &quot; ) as [$k,$e,$r] ({}; .+{($k):{exchange:$e,replication:$r}})\r\n```\r\n\r\nInput\r\n```\r\n2254003131908096 39480500160 39763833120\r\n2296334329577472 36713833920 37747166400\r\n2297708719112192 39830499360 41430500640\r\n```\r\n\r\nOutput\r\n```\r\n{\r\n  &quot;2254003131908096&quot;: {\r\n    &quot;exchange&quot;: &quot;39480500160&quot;,\r\n    &quot;replication&quot;: &quot;39763833120&quot;\r\n  },\r\n  &quot;2296334329577472&quot;: {\r\n    &quot;exchange&quot;: &quot;36713833920&quot;,\r\n    &quot;replication&quot;: &quot;37747166400&quot;\r\n  },\r\n  &quot;2297708719112192&quot;: {\r\n    &quot;exchange&quot;: &quot;39830499360&quot;,\r\n    &quot;replication&quot;: &quot;41430500640&quot;\r\n  }\r\n}\r\n```\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/9uugFhWQtt",
                "title": "How to create a specific result using JQ (jq parse json)"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1651042353,
        "creation_date": 1645018938,
        "question_id": 71142954,
        "body_markdown": "I have massive like this:\r\n\r\n    2254003131908096 39480500160 39763833120\r\n    2296334329577472 36713833920 37747166400\r\n    2297708719112192 39830499360 41430500640\r\n\r\nWhich JQ command should I use to get the result like this:\r\n\r\n    &quot;2254003131908096&quot;: {\r\n      {\r\n        &quot;exchange&quot;: &quot;39480500160&quot;,\r\n        &quot;replication&quot;: &quot;39763833120&quot;\r\n      }\r\n    }\r\n    \t\r\n    &quot;2296334329577472&quot;: {\r\n      {\r\n        &quot;exchange&quot;: &quot;36713833920&quot;,\r\n        &quot;replication&quot;: &quot;39763833120&quot;\r\n      }\r\n    }\r\n      \r\n    &quot;2297708719112192&quot;: {  \r\n      {\r\n        &quot;exchange&quot;: &quot;39830499360&quot;,\r\n        &quot;replication&quot;: &quot;41430500640&quot;\r\n      }\r\n    }\r\n\r\nHelp me please.",
        "link": "https://stackoverflow.com/questions/71142954/how-to-create-a-specific-result-using-jq-jq-parse-json",
        "title": "How to create a specific result using JQ (jq parse json)"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1645031595,
                "last_edit_date": 1645031595,
                "creation_date": 1645031222,
                "answer_id": 71146225,
                "question_id": 71146201,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `--argjson` for JSON parameters. Also, you only need the assignment operator `=` here as the evaluation of the RHS doesn&#39;t rely on the LHS context.\r\n~~~sh\r\njq --argjson new false &#39;.authentication.anonymous.enabled = $new&#39; config.json\r\n~~~\r\n[Demo](https://jqplay.org/s/LLBsIlDymy)\r\n\r\nIf you only wanted to toggle that field, you could do it without parameters and variables:\r\n~~~sh\r\njq &#39;.authentication.anonymous.enabled |= not&#39; config.json\r\n~~~\r\n[Demo](https://jqplay.org/s/8sZWztdBlx)\r\n",
                "title": "jq update boolean value in json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1645031595,
        "creation_date": 1645031124,
        "question_id": 71146201,
        "body_markdown": "I am trying to update a boolean value in a json file using jq.\r\n\r\nMy json file is like this:\r\n```json\r\n{\r\n  &quot;kind&quot;: &quot;KubeletConfiguration&quot;,\r\n  &quot;apiVersion&quot;: &quot;kubelet.config.k8s.io/v1beta1&quot;,\r\n  &quot;address&quot;: &quot;0.0.0.0&quot;,\r\n  &quot;authentication&quot;: {\r\n    &quot;anonymous&quot;: {\r\n      &quot;enabled&quot;: true\r\n    },\r\n    &quot;webhook&quot;: {\r\n      &quot;cacheTTL&quot;: &quot;2m0s&quot;,\r\n      &quot;enabled&quot;: true\r\n    },\r\n    &quot;x509&quot;: {\r\n      &quot;clientCAFile&quot;: &quot;/etc/kubernetes/pki/ca.crt&quot;\r\n    }\r\n  },\r\n  &quot;authorization&quot;: {\r\n    &quot;mode&quot;: &quot;Webhook&quot;,\r\n    &quot;webhook&quot;: {\r\n      &quot;cacheAuthorizedTTL&quot;: &quot;5m0s&quot;,\r\n      &quot;cacheUnauthorizedTTL&quot;: &quot;30s&quot;\r\n    }\r\n  },\r\n....omitted\r\n```\r\n\r\nand I want to update the .authentication.anonymous.enabled value with the boolean _false_\r\n\r\nI have tried the following:\r\n\r\n```bash\r\njq --arg new false &#39;.authentication.anonymous.enabled |= $new&#39; config.json\r\n```\r\n\r\nThis updates the value to _false_ but it does so as a string, rather than a boolean. As below:\r\n\r\n```json\r\n{\r\n  &quot;kind&quot;: &quot;KubeletConfiguration&quot;,\r\n  &quot;apiVersion&quot;: &quot;kubelet.config.k8s.io/v1beta1&quot;,\r\n  &quot;address&quot;: &quot;0.0.0.0&quot;,\r\n  &quot;authentication&quot;: {\r\n    &quot;anonymous&quot;: {\r\n      &quot;enabled&quot;: &quot;false&quot;\r\n    },\r\n    &quot;webhook&quot;: {\r\n      &quot;cacheTTL&quot;: &quot;2m0s&quot;,\r\n      &quot;enabled&quot;: true\r\n    },\r\n    &quot;x509&quot;: {\r\n      &quot;clientCAFile&quot;: &quot;/etc/kubernetes/pki/ca.crt&quot;\r\n    }\r\n  },\r\n  &quot;authorization&quot;: {\r\n    &quot;mode&quot;: &quot;Webhook&quot;,\r\n    &quot;webhook&quot;: {\r\n      &quot;cacheAuthorizedTTL&quot;: &quot;5m0s&quot;,\r\n      &quot;cacheUnauthorizedTTL&quot;: &quot;30s&quot;\r\n    }\r\n  },\r\n....omitted\r\n```\r\nHow do I get this to update as a boolean (no quotes around the value)?",
        "link": "https://stackoverflow.com/questions/71146201/jq-update-boolean-value-in-json-file",
        "title": "jq update boolean value in json file"
    },
    {
        "tags": [
            "json",
            "select",
            "bigdata",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1645211436,
                "last_edit_date": 1645211436,
                "creation_date": 1645038980,
                "answer_id": 71148027,
                "question_id": 71146786,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "(1) If your computer has enough RAM, then the simplest solution would be along the lines of:\r\n```\r\n&lt; very-large-file.json jq &#39;\r\n  .listPoint |= map(select(.ZIPCODE|startswith(&quot;33&quot;)))&#39;\r\n```\r\n\r\n(2) Otherwise, you could use jq&#39;s streaming parser in a two-step solution such as:\r\n```\r\n&lt; very-large-file.json jq -n --stream &#39;\r\n    fromstream(2|truncate_stream(inputs))\r\n    | select(.ZIPCODE|startswith(&quot;33&quot;))&#39; |\r\n  jq -s &#39;{listPoint: .}&#39;\r\n\r\n```\r\n\r\nIn the first step, a stream of the relevant JSON objects is produced; in the second step, these are re-assembled into the desired structure.\r\n\r\n(3) If even the winnowed array is too large to fit into memory, then you could do worse than:\r\n\r\n```\r\necho &#39;{listPoint:&#39;\r\n&lt; very-large-file.json jq -n --stream &#39;\r\n    fromstream(2|truncate_stream(inputs))\r\n    | select(.ZIPCODE|startswith(&quot;33&quot;))&#39; |\r\n  jq -ncr &#39;input, (inputs | &quot;,&quot;, .)&#39;\r\necho &#39;}&#39;\r\n```\r\n\r\n(4) If you want to select zipcodes based on a whitelist, change the selection criterion e.g. to\r\n\r\n    .ZIPCODE|IN($whitelist[])\r\n\r\n\r\n——-\r\n\r\nNote: if your shell is not sufficiently bash-like, you might find it better to use the following invocation format:\r\n\r\n    jq OPTIONS -f program.jq INPUT.json\r\n",
                "title": "How to select specific data in a large json file and save the result with same structure"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1678995355,
                "last_edit_date": 1678995355,
                "creation_date": 1678992732,
                "answer_id": 75760532,
                "question_id": 71146786,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the record, another way to avoid issues with the size of the file would be to use a companion tool such as [jm][1] (a wrapper script for JSON Machine) or [jm.py][1] (a wrapper script for the ijson Python library):\r\n```\r\njm --pointer /listPoint large.json |\r\n  jq -n &#39;[&quot;33410&quot;, &quot;42000&quot;, &quot;75015&quot;] as $ok\r\n         | {listPoint: [inputs | select(.adress.ZIPCODE|IN($ok[]))]} &#39;\r\n```\r\nor\r\n```\r\njm.py -i listPoint.item large.json |\r\n  jq -n &#39;[&quot;33410&quot;, &quot;42000&quot;, &quot;75015&quot;] as $ok\r\n         | {listPoint: [inputs | select(.adress.ZIPCODE|IN($ok[]))]} &#39;\r\n```\r\n\r\nI usually find `jm` to be significantly more economical with both time and space, but it takes a bit of work to install it.\r\n\r\nDisclaimer: I&#39;m the author of these two wrapper scripts, which were created precisely for handling cases such as this. \r\n\r\n\r\n  [1]: https://github.com/pkoppstein/jm",
                "title": "How to select specific data in a large json file and save the result with same structure"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1678995355,
        "creation_date": 1645033569,
        "last_edit_date": 1645205250,
        "question_id": 71146786,
        "body_markdown": "Very large Json file (3Gb) like this:\r\n\r\n  \r\n\r\n      {\r\n    \t&quot;listPoint&quot;: [{\r\n    \t\t\t&quot;Paime&quot;: &quot;RE6845&quot;,\r\n    \t\t\t&quot;rmOi&quot;: &quot;SNO-55&quot;,\r\n    \t\t\t&quot;State&quot;: &quot;OPEN&quot;,\r\n    \t\t\t&quot;dateOpneing&quot;: &quot;2017-12-22&quot;,\r\n    \t\t\t&quot;adress&quot;: {\r\n    \t\t\t\t&quot;ZIPCODE&quot;: &quot;33410&quot;,\r\n    \t\t\t\t&quot;codeRoc&quot;: &quot;33105&quot;\r\n    \t\t\t}\r\n    \t\t},\r\n    \r\n    \t\t{\r\n    \t\t\t&quot;Paime&quot;: &quot;RE6243&quot;,\r\n    \t\t\t&quot;rmOi&quot;: &quot;SNO-65&quot;,\r\n    \t\t\t&quot;State&quot;: &quot;OPEN&quot;,\r\n    \t\t\t&quot;dateOpneing&quot;: &quot;2014-11-12&quot;,\r\n    \t\t\t&quot;adress&quot;: {\r\n    \t\t\t\t&quot;ZIPCODE&quot;: &quot;453410&quot;,\r\n    \t\t\t\t&quot;codeRoc&quot;: &quot;35105&quot;\r\n    \t\t\t}\r\n    \t\t}\r\n    \r\n    \t]\r\n    }\r\n\r\nI&#39;m Trying to filter it to another file with same structure, the condition is that all ZIPCODES must belong to a specific list:\r\n\r\n      [&#39;33410&#39;, &#39;42000&#39;, &#39;75015&#39;....]\r\n\r\nthe result should be like this (the output file must have the same structure as the input):\r\n\r\n   \r\n\r\n     {\r\n            &quot;listPoint&quot;: [{\r\n                    &quot;Paime&quot;: &quot;RE6845&quot;,\r\n                    &quot;rmOi&quot;: &quot;SNO-55&quot;,\r\n                    &quot;State&quot;: &quot;OPEN&quot;,\r\n                    &quot;dateOpneing&quot;: &quot;2017-12-22&quot;,\r\n                   &quot;adress&quot;: {\r\n    \t\t\t\t&quot;ZIPCODE&quot;: &quot;33410&quot;,\r\n    \t\t\t\t&quot;codeRoc&quot;: &quot;35105&quot;\r\n                },\r\n        \r\n                {\r\n                    &quot;Paime&quot;: &quot;RE6243&quot;,\r\n                    &quot;rmOi&quot;: &quot;SNO-65&quot;,\r\n                    &quot;State&quot;: &quot;OPEN&quot;,\r\n                    &quot;dateOpneing&quot;: &quot;2014-11-12&quot;,\r\n                    &quot;ZIPCODE&quot;: &quot;75015&quot;,\r\n                    &quot;codeRoc&quot;: &quot;55115&quot;\r\n                }\r\n            .....\r\n        \r\n            ]\r\n        }\r\n\r\nIve Tried by this but it streams all the file:\r\n\r\n    ./jq-win64.exe -n --stream &#39;fromstream(0|truncate_stream(inputs))&#39; test1.json\r\n\r\nI dont know how to do this  please can you help\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71146786/how-to-select-specific-data-in-a-large-json-file-and-save-the-result-with-same-s",
        "title": "How to select specific data in a large json file and save the result with same structure"
    },
    {
        "tags": [
            "json",
            "swagger",
            "jq",
            "openapi"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1645037395,
                "creation_date": 1645037395,
                "answer_id": 71147666,
                "question_id": 71147392,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Does this fit your needs?\r\n~~~sh\r\njq -r &#39;\r\n  .definitions\r\n  | to_entries[]\r\n  | .key + &quot;:&quot;, &quot;  &quot; + (\r\n    .value\r\n    | (., .allOf[], .anyOf[], .oneOf[] | .properties)? // {}\r\n    | to_entries[].key\r\n  )\r\n&#39;\r\n~~~\r\n~~~none\r\nPet:\r\n  pet_type\r\nDog:\r\n  bark\r\n  breed\r\n~~~\r\n[Demo](https://jqplay.org/s/L-luG8TpNa)\r\n",
                "title": "Extracting objects attributes from Swagger JSON schema using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1645041500,
        "creation_date": 1645036139,
        "last_edit_date": 1645041500,
        "question_id": 71147392,
        "body_markdown": "I want to extract objects name and their attributes (`.properties`) from `.definitions` part of swagger json file, like:\r\n```\r\n{\r\n  &quot;definitions&quot;: {\r\n    &quot;Pet&quot;: {\r\n      &quot;type&quot;: &quot;object&quot;,\r\n      &quot;required&quot;: [&quot;pet_type&quot;],\r\n      &quot;properties&quot;: {\r\n        &quot;pet_type&quot;: {\r\n          &quot;type&quot;: &quot;string&quot;\r\n        }\r\n      },\r\n      &quot;discriminator&quot;: {\r\n        &quot;propertyName&quot;: &quot;pet_type&quot;\r\n      }\r\n    },\r\n    &quot;Dog&quot;: {\r\n      &quot;allOf&quot;: [{\r\n          &quot;$ref&quot;: &quot;#/components/schemas/Pet&quot;\r\n        }, {\r\n          &quot;type&quot;: &quot;object&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;bark&quot;: {\r\n              &quot;type&quot;: &quot;boolean&quot;\r\n            },\r\n            &quot;breed&quot;: {\r\n              &quot;type&quot;: &quot;string&quot;,\r\n              &quot;enum&quot;: [&quot;Dingo&quot;, &quot;Husky&quot;, &quot;Retriever&quot;, &quot;Shepherd&quot;]\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nto:\r\n```\r\nobject_name:\r\n  attribute_name\r\n```\r\nlike:\r\n```\r\nPet:\r\n  pet_type\r\nDog:\r\n  bark\r\n  breed\r\n```\r\n\r\nThe point is `.properties` sometimes come directly after object name and sometimes as part of `allOf`, `anyOf`, or `oneOf`",
        "link": "https://stackoverflow.com/questions/71147392/extracting-objects-attributes-from-swagger-json-schema-using-jq",
        "title": "Extracting objects attributes from Swagger JSON schema using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1645043313,
                "last_edit_date": 1645043313,
                "creation_date": 1645042591,
                "answer_id": 71148728,
                "question_id": 71148657,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `with_entries` which lets you convert the array into an object if you adjust the `.key`s accordingly.\r\n~~~sh\r\njq &#39;.profile |= with_entries(.key = .value.id | .value |= .products)&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/J4L-Tx8hB9)\r\n\r\nOr use `reduce` to build the object by iterating through the array.\r\n~~~sh\r\njq &#39;.profile |= reduce .[] as $p ({}; .[$p.id] = $p.products)&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/OBNQKcbabS)\r\n\r\nOr use `map` to convert each array item into an object, then merge them using `add`.\r\n~~~sh\r\njq &#39;.profile |= (map({(.id): .products}) | add)&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/skKpF1d_RW)\r\n\r\nOutput is:\r\n~~~json\r\n{\r\n  &quot;sunarme&quot;: &quot;foo&quot;,\r\n  &quot;id&quot;: &quot;foo-id&quot;,\r\n  &quot;name&quot;: &quot;Foo bar&quot;,\r\n  &quot;profile&quot;: {\r\n    &quot;test1&quot;: [\r\n      &quot;product1&quot;,\r\n      &quot;product2&quot;\r\n    ],\r\n    &quot;test2&quot;: [\r\n      &quot;product3&quot;,\r\n      &quot;product4&quot;,\r\n      &quot;product5&quot;\r\n    ],\r\n    &quot;test3&quot;: [\r\n      &quot;product6&quot;,\r\n      &quot;product7&quot;,\r\n      &quot;product8&quot;\r\n    ]\r\n  }\r\n}\r\n~~~\r\n",
                "title": "transform json input using jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1645043313,
        "creation_date": 1645042176,
        "question_id": 71148657,
        "body_markdown": "I have the following json input from a internet service:\r\n\r\n```\r\n{\r\n  &quot;sunarme&quot;: &quot;foo&quot;,\r\n  &quot;id&quot;: &quot;foo-id&quot;,\r\n  &quot;name&quot;: &quot;Foo bar&quot;,\r\n  &quot;profile&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;test1&quot;,\r\n      &quot;products&quot;: [\r\n        &quot;product1&quot;,\r\n        &quot;product2&quot;\r\n      ],\r\n      &quot;description&quot;: &quot;test1 description&quot;\r\n     },\r\n     {\r\n      &quot;id&quot;: &quot;test2&quot;,\r\n      &quot;products&quot;: [\r\n        &quot;product3&quot;,\r\n        &quot;product4&quot;,\r\n        &quot;product5&quot;\r\n      ],\r\n      &quot;description&quot;: &quot;test2 description&quot;\r\n     },\r\n     {\r\n      &quot;id&quot;: &quot;test3&quot;,\r\n      &quot;products&quot;: [\r\n        &quot;product6&quot;,\r\n        &quot;product7&quot;,\r\n        &quot;product8&quot;\r\n      ],\r\n      &quot;description&quot;: &quot;test2 description&quot;\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nSo I need to transform profile key from array to json object. This is the desired output:\r\n\r\n\r\n```\r\n{\r\n  &quot;sunarme&quot;: &quot;foo&quot;,\r\n  &quot;id&quot;: &quot;foo-id&quot;,\r\n  &quot;name&quot;: &quot;Foo bar&quot;,\r\n  &quot;profile&quot;: {\r\n      &quot;test1&quot;: [\r\n        &quot;product1&quot;,\r\n        &quot;product2&quot;\r\n      ],\r\n      &quot;test2&quot;: [\r\n        &quot;product3&quot;,\r\n        &quot;product4&quot;,\r\n        &quot;product5&quot;\r\n      ],\r\n      &quot;test3&quot;: [\r\n        &quot;product6&quot;,\r\n        &quot;product7&quot;,\r\n        &quot;product8&quot;\r\n      ]\r\n   }\r\n}\r\n```\r\n\r\nI don&#39;t have any idea how to do it in jq command, please, could you help me?\r\n\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/71148657/transform-json-input-using-jq-command",
        "title": "transform json input using jq command"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1645046640,
                "last_edit_date": 1645046640,
                "creation_date": 1645043778,
                "answer_id": 71148949,
                "question_id": 71148913,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Iterate outside the array which contains the `.name`. That way, another array is generated for each iteration step.\r\n\r\n~~~sh\r\njq -r &#39;.[].system | [.name] + (.interfaces[]? | [.[]]) | @tsv&#39; test_json2\r\n~~~\r\n[Demo](https://jqplay.org/s/1obJ7HB6EX)\r\n\r\nIf the objects in the `.interfaces` array can have more than just those two field, but you only want to output said two fields, name them explicitly.\r\n~~~sh\r\njq -r &#39;.[].system | [.name] + (.interfaces[]? | [.ip, .ent]) | @tsv&#39; test_json2\r\n~~~\r\n[Demo](https://jqplay.org/s/qyF8FMz6KJ)\r\n\r\nOutput is:\r\n~~~\r\nsys1\t1.1.1.1 ent1\r\nsys1\t2.2.2.2 ent0\r\nsys2\t3.3.3.3 ent0\r\n~~~\r\n\r\n",
                "title": "list each specific element with parent name"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649648683,
                "creation_date": 1649648683,
                "answer_id": 71822522,
                "question_id": 71148913,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `array` to group each interface. \r\n\r\n```\r\n.[] | .system | select(.name==&quot;sys1&quot; or .name==&quot;sys2&quot;) | [.name] + (.interfaces[] | [.[]]) | @tsv\r\n```\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/iucSZqkB1r\r\n\r\nNote that `.[]` on an object returns its `values`.",
                "title": "list each specific element with parent name"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1649648683,
        "creation_date": 1645043520,
        "last_edit_date": 1645046474,
        "question_id": 71148913,
        "body_markdown": "I have json with random elements on array:\r\n\r\n    [\r\n      {\r\n        &quot;system&quot;: {\r\n          &quot;name&quot;: &quot;sys1&quot;,\r\n          &quot;interfaces&quot;: [\r\n            {\r\n              &quot;ip&quot;: &quot;1.1.1.1&quot;,\r\n              &quot;ent&quot;: &quot;ent1&quot;\r\n            },\r\n            {\r\n              &quot;ip&quot;: &quot;2.2.2.2&quot;,\r\n              &quot;ent&quot;: &quot;ent0&quot;\r\n            }\r\n          ]\r\n        }\r\n      },\r\n      {\r\n        &quot;system&quot;: {\r\n          &quot;name&quot;: &quot;sys2&quot;,\r\n          &quot;interfaces&quot;: [\r\n            {\r\n              &quot;ip&quot;: &quot;3.3.3.3&quot;,\r\n              &quot;ent&quot;: &quot;ent0&quot;\r\n            }\r\n          ]\r\n        }\r\n      },\r\n      {\r\n        &quot;system&quot;: {\r\n          &quot;name&quot;: &quot;sys3&quot;,\r\n          &quot;interfaces&quot;: null\r\n        }\r\n      },\r\n      {\r\n        &quot;system&quot;: {\r\n          &quot;name&quot;: &quot;sys4&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\n\r\nI need get following output with `jq`:\r\n\r\n    sys1    1.1.1.1 ent1\r\n    sys1    2.2.2.2 ent0\r\n    sys2    3.3.3.3 ent0\r\n\r\nI tried following filter:\r\n\r\n    $ jq -r &#39;.[]|[.system.name, .system.interfaces[].ip, .system.interfaces[].ent]|@tsv&#39; test_json2\r\n    sys1    1.1.1.1 2.2.2.2 ent1    ent0\r\n    sys2    3.3.3.3 ent0\r\n\r\nHow to split line 1 to achieve expected result?\r\n\r\nUpdate: I met new case when array is null and I get now following error using filrer from pmf&#39;s answer:\r\n\r\n    jq: error (at test_json2:34): Cannot iterate over null (null) \r\n\r\n",
        "link": "https://stackoverflow.com/questions/71148913/list-each-specific-element-with-parent-name",
        "title": "list each specific element with parent name"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1645048024,
                "last_edit_date": 1645048024,
                "creation_date": 1645047463,
                "answer_id": 71149594,
                "question_id": 71149572,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `map` instead:\r\n~~~sh\r\njq &#39;map(keys[])&#39; config.json\r\n~~~\r\n~~~json\r\n[\r\n  &quot;N1&quot;,\r\n  &quot;N2&quot;,\r\n  &quot;N3&quot;,\r\n  &quot;N4&quot;\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/PFhrJziEN0)\r\n\r\nNote that `keys` sorts the keys. If you want them unsorted, use `keys_unsorted` instead.\r\n\r\nAlso, if you want to have the output in one line, add the `--compact-output` (or `-c`) option (thx @Cyrus).",
                "title": "How to put jq output multi arrays in single array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1645048024,
        "creation_date": 1645047345,
        "last_edit_date": 1645047579,
        "question_id": 71149572,
        "body_markdown": "While reading data from a json file using jq.\r\nThis command `jq &quot;.[]|keys&quot; config.json` gives following output:\r\n\r\n    [\r\n      &quot;N1&quot;,\r\n      &quot;N2&quot;\r\n    ]\r\n    [\r\n      &quot;N3&quot;,\r\n      &quot;N4&quot;\r\n    ]\r\n\r\nWhat I ideally want is very simple:\r\n\r\n    [&quot;N1&quot;, &quot;N2&quot;, &quot;N3&quot;, &quot;N4&quot;]\r\n\r\nHowever,\r\nHow I cannot find a way to accomplish this.\r\n\r\nConfig file:\r\n\r\n    {\r\n    \t&quot;Test1&quot;:{\r\n    \t\t&quot;N1&quot;:{\r\n    \t\t\t&quot;crn&quot;:&quot;1&quot;,\r\n    \t\t\t&quot;con&quot;:&quot;2&quot;\r\n    \t\t},\r\n    \t\t&quot;N2&quot;:{\r\n    \t\t\t&quot;crn&quot;:&quot;100&quot;,\r\n    \t\t\t&quot;con&quot;:&quot;200&quot;\r\n    \t\t}\r\n    \t\t\r\n    \t},\r\n    \t&quot;test2&quot;:{\r\n    \t\t&quot;N3&quot;:{\r\n    \t\t\t&quot;crn&quot;:&quot;xx&quot;,\r\n    \t\t\t&quot;con&quot;:&quot;2x&quot;\r\n    \t\t},\r\n    \t\t&quot;N4&quot;:{\r\n    \t\t\t&quot;crn&quot;:&quot;xxxx&quot;,\r\n    \t\t\t&quot;con&quot;:&quot;3xx&quot;\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71149572/how-to-put-jq-output-multi-arrays-in-single-array",
        "title": "How to put jq output multi arrays in single array"
    },
    {
        "tags": [
            "json",
            "bash",
            "if-statement",
            "grep",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1645101439,
                "post_id": 71157135,
                "comment_id": 125784456,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1645098207,
                "last_edit_date": 1645098207,
                "creation_date": 1645097179,
                "answer_id": 71157257,
                "question_id": 71157135,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Take the `if` statements to `jq` and have it output whatever you want.\r\n\r\nThe following example prints nothing `&quot;&quot;` if `nonstandard-protocol` is true, or `specialCondition` is neither `matched` nor `unmatched`. Otherwise it&#39;ll print `MATCHED` or `NOTMATCHED`, depending on the content of `specialCondition`:\r\n~~~sh\r\njq --raw-output &#39;\r\n  if .&quot;nonstandard-protocol&quot; then &quot;&quot;\r\n  else if .specialCondition == &quot;matched&quot; then &quot;MATCHED&quot;\r\n    elif .specialCondition == &quot;unmatched&quot; then &quot;NOTMATCHED&quot;\r\n    else &quot;&quot; end\r\n  end\r\n&#39; myjsonfile.json &gt; protocol_result.txt\r\n~~~\r\n[Demo](https://jqplay.org/s/L2rO3KOimC)\r\n\r\nNote: Using `&quot;&quot;` will print nothing as expected, but followed by a newline because it had an output (which essentially is an empty line, then). If you don&#39;t want that, change `&quot;&quot;` to `empty`.",
                "title": "Multiple `if` conditions with `jq` and `grep` incorrectly matches and returns true when it shouldn&#39;t match at all"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1645176801,
                "last_edit_date": 1645176801,
                "creation_date": 1645101720,
                "answer_id": 71158340,
                "question_id": 71157135,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to actually execute your `grep` command, if you need its status code:\r\n\r\n```sh\r\nif jq .specialCondition myjsonfile.json | tee protocol_result.txt | grep -q matched  &amp;&amp;  jq &#39;.&quot;nonstandard-protocol&quot;&#39; myjsonfile.json | tee -a protocol_result.txt | grep -q false \r\nthen \r\n  ..... \r\nfi\r\n```",
                "title": "Multiple `if` conditions with `jq` and `grep` incorrectly matches and returns true when it shouldn&#39;t match at all"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1645176801,
        "creation_date": 1645096642,
        "question_id": 71157135,
        "body_markdown": "I have a `json` file:\r\n\r\n```\r\ncat myjsonfile.json\r\n\r\n{\r\n    &quot;directory&quot;: true,\r\n    &quot;condition&quot;: &quot;&quot;,\r\n    &quot;specialCondition&quot;: &quot;&quot;,\r\n    &quot;dataFiles&quot;: &quot;&quot;,\r\n    &quot;nonstandard-protocol&quot;: true\r\n}\r\n```\r\n\r\n`specialCondition` is standardized and can be empty or have a `matched` or `unmatched` state.\r\n\r\nI simply want to `translate` those conditions to another state when `nonstandard-protocol` is `false`.\r\n\r\nSo I wrote this in my bash script.\r\n\r\n```\r\nif [[  &quot;jq &#39;.specialCondition&#39; myjsonfile.json | grep -q &#39;matched&#39;&quot;  &amp;&amp;  &quot;jq &#39;.&quot;nonstandard-protocol&quot;&#39; myjsonfile.json | grep -q &#39;false&#39;&quot;  ]]; then echo &#39;MATCHED&#39; | cat &gt; protocol_result.txt; fi\r\nif [[  &quot;jq &#39;.specialCondition&#39; myjsonfile.json | grep -q &#39;unmatched&#39;&quot;  &amp;&amp;  &quot;jq &#39;.&quot;nonstandard-protocol&quot;&#39; myjsonfile.json | grep -q &#39;false&#39;&quot;  ]]; then echo &#39;NOTMATCHED&#39; | cat &gt; protocol_result.txt; fi\r\n```\r\n\r\nHowever, this returns incorrect results. When I run the script, I always see that first it writes `MATCHED` to my `protocol_result.txt` and then with the second `if` line it writes `NOTMATCHED` to the file! While it shouldn&#39;t write anything at all... Why is this happening?",
        "link": "https://stackoverflow.com/questions/71157135/multiple-if-conditions-with-jq-and-grep-incorrectly-matches-and-returns-tr",
        "title": "Multiple `if` conditions with `jq` and `grep` incorrectly matches and returns true when it shouldn&#39;t match at all"
    },
    {
        "tags": [
            "curl",
            "jq",
            "ecobee-api"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1645117748,
                "creation_date": 1645117748,
                "answer_id": 71162490,
                "question_id": 71162423,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `curl`, you need to provide each additional header as one string (one argument). Put quotes around them:\r\n~~~\r\n-H &#39;Content-Type: application/json;charset=UTF-8&#39;\r\n-H &#39;Authorization: Bearer MY-ACCESS-TOKEN&#39;\r\n~~~",
                "title": "curl POST request to Ecobee&#39;s API failing with &quot;Update failed due to a communication error.&quot;"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1645230996,
                "creation_date": 1645230996,
                "answer_id": 71181364,
                "question_id": 71162423,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Chalk this up to USER ERROR!\r\n\r\n@pmr. sorry to waste your time on this.  My json query string was off.\r\nIt was\r\n```\r\n{&quot;selection&quot;:{&quot;selectionType&quot;:&quot;thermostats&quot;,&quot;selectionMatch&quot;:123456789,&quot;thermostat&quot;:{&quot;settings&quot;:{&quot;humidity&quot;:45}}}}\r\n```\r\nand should have been:\r\n```\r\n{&quot;selection&quot;:{&quot;selectionType&quot;:&quot;thermostats&quot;,&quot;selectionMatch&quot;:123456789},&quot;thermostat&quot;:{&quot;settings&quot;:{&quot;humidity&quot;:45}}}\r\n```\r\n&#39;thermostat&#39; should have been at the top level instead of under &#39;selection&#39;\r\n\r\nI don&#39;t want to say how much time I spent looking at that until I noticed\r\n\r\n\r\n\r\n",
                "title": "curl POST request to Ecobee&#39;s API failing with &quot;Update failed due to a communication error.&quot;"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1645230996,
        "creation_date": 1645117501,
        "last_edit_date": 1645135350,
        "question_id": 71162423,
        "body_markdown": "So, My retrieving information on the thermostat is working fine, now I&#39;m trying to update a setting on the ecobee and am receiving:\r\n```\r\nstatus.code=3\r\nstatus.message=&quot;Update failed due to a communication error.&quot;\r\n```\r\n\r\nmy query_string looks like:\r\n```\r\n{&quot;selection&quot;:{&quot;selectionType&quot;:&quot;thermostats&quot;,&quot;selectionMatch&quot;:123456789,&quot;thermostat&quot;:{&quot;settings&quot;:{&quot;humidity&quot;:45}}}}\r\n```\r\n\r\nMy curl as follows:\r\n```\r\n-X POST https://api.ecobee.com/1/thermostat?format=json --data %7B%22selection%22%3A%7B%22selectionType%22%3A%22thermostats%22%2C%22selectionMatch%22%3A311081045454%2C%22thermostat%22%3A%7B%22settings%22%3A%7B%22humidity%22%3A45%7D%7D%7D%7D -H Content-Type: application/json;charset=UTF-8 -H Authorization: Bearer MY-ACCESS-TOKEN\r\n```\r\n\r\n`--data - Ran the query-string through the jq &#39;@URI&#39; filter`\r\nalso tried:\r\n`--data-urlencode -Without the &#39;@URI&#39; filter (this is the method shown by the Ecobee API Doc`\r\n\r\nBoth ways return the &quot;Update failed&quot;\r\n\r\nI do have working code from a project on GitHub written in python, but I&#39;m using this as a bash/jq/API learning opportunity (also, I don&#39;t know python)\r\n\r\nHis code shows the following for updating a setting successfully:\r\n```\r\nurl:1/thermostat\r\nheader:{&#39;Content-Type&#39;: &#39;application/json;charset=UTF-8&#39;, &#39;Authorization&#39;: &#39;Bearer MY-ACCESS-TOKEN&#39;}\r\nparameters:{&#39;format&#39;: &#39;json&#39;}\r\nbody:{&quot;thermostat&quot;: {&quot;settings&quot;: {&quot;humidity&quot;: 40}}, &quot;selection&quot;: {&quot;selectionType&quot;: &quot;thermostats&quot;, &quot;selectionMatch&quot;: &quot;123456789&quot;}}\r\n\r\n{&#39;status&#39;: {&#39;code&#39;: 0, &#39;message&#39;: &#39;&#39;}}\r\n```\r\nThis seems to match up to my curl request\r\n\r\nThis is what I&#39;m using to build my curl (which should be maintaining the proper quoting):\r\n```\r\nurl_request=(-X POST &quot;https://api.ecobee.com/1/thermostat?format=json&quot;)\r\nurl_body=(--data &quot;$query_string&quot;)\r\nurl_header=(-H &quot;Content-Type: application/json;charset=UTF-8&quot;\r\n            -H &quot;Authorization: Bearer $access_token&quot;)\r\nurl+=(&quot;${url_request[@]}&quot; &quot;${url_body[@]}&quot; &quot;${url_header[@]}&quot;)\r\n\r\nthermostat=$(curl -s &quot;${url[@]}&quot;)\r\n```\r\n\r\nAnyone see anything obvious?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/71162423/curl-post-request-to-ecobees-api-failing-with-update-failed-due-to-a-communica",
        "title": "curl POST request to Ecobee&#39;s API failing with &quot;Update failed due to a communication error.&quot;"
    },
    {
        "tags": [
            "json",
            "filter",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1645124079,
                "last_edit_date": 1645124079,
                "creation_date": 1645123011,
                "answer_id": 71163658,
                "question_id": 71163527,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `to_entries`, `from_entries` and an index of your choice.\r\n\r\nIn the single-element syntax you need to wrap it in an array\r\n~~~sh\r\njq &#39;[to_entries[0]] | from_entries&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/pn8pKqADfG)\r\n\r\nIn the range-syntax you need to additionally providde the to-index (which is one higher than the from-index if you want just 1 element):\r\n~~~sh\r\njq &#39;to_entries[0:1] | from_entries&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/PVRMmGfKjh)\r\n\r\nOutput:\r\n~~~json\r\n{\r\n  &quot;a&quot;: 1\r\n}\r\n~~~\r\n\r\n",
                "title": "strip all but the first element of an object with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1645127484,
                "last_edit_date": 1645127484,
                "creation_date": 1645125549,
                "answer_id": 71164193,
                "question_id": 71163527,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In a comment you say\r\n&gt; I was just hoping for something more like `.[0]`\r\n\r\nIf you don&#39;t like the piping from the other solutions, then how about using string interpolation:\r\n~~~sh\r\njq &#39;{&quot;\\(keys_unsorted[0])&quot;}&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;a&quot;: 1\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/frKSLMHNbW)\r\n\r\nNote that all of your original attempts used `keys` which provides the keys in **alphabetical order**. For the sample data this makes no difference but I assume you were actually looking for the first key in **representation order**, for which you need to use `keys_unsorted`. \r\nIf I am wrong, then my answer translated to `{&quot;\\(keys[0])&quot;}` should just work fine as well.\r\n\r\n",
                "title": "strip all but the first element of an object with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1645224190,
                "last_edit_date": 1645224190,
                "creation_date": 1645142009,
                "answer_id": 71166829,
                "question_id": 71163527,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use jq&#39;s streaming parser, which might actually make sense if the input object were huge.\r\n```\r\n# counting from 1\r\n# e.g. 2 | nthRun(1,2,2,3; .) #=&gt; 2,2\r\ndef nthRun(s; f):\r\n  . as $n  \r\n  | label $out\r\n  | foreach s as $x (null;\r\n      if . == null then [1, ($x|f)] \r\n      elif .[1] == ($x|f) then . \r\n      else .[0] += 1 | .[1] = ($x|f) \r\n      end;\r\n      if .[0] == $n then $x \r\n      elif .[0] &gt; $n then break $out \r\n      else empty\r\n      end);\r\n\r\nfromstream(1|nthRun(inputs; .[0][0]), [[null]] )\r\n```\r\nInvocation example:\r\n```\r\njq -nc --stream -f program.jq input.json\r\n```\r\n\r\nFor the record, assuming the first key&#39;s value is atomic, you could simply write:\r\n\r\n    jq -nc --stream &#39;fromstream(input, [[null]])&#39;\r\n\r\nThe same `nthRun` can of course also be used to access the n-th key-value pair in the same way.  More generally, it can be used without using the --stream option, e.g.:\r\n```\r\ndef firstKeyValue:\r\n    fromstream(1|nthRun(tostream),[[null]]);\r\n\r\n```\r\n",
                "title": "strip all but the first element of an object with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1645224190,
        "creation_date": 1645122393,
        "last_edit_date": 1645151545,
        "question_id": 71163527,
        "body_markdown": "Assume I have a json structure like:\r\n\r\n    {\r\n      &quot;a&quot; : 1,\r\n      &quot;b&quot; : 2,\r\n      &quot;c&quot; : 3\r\n    }\r\n\r\nI want the same structure, but with only the first element:\r\n\r\n    {\r\n      &quot;a&quot; : 1\r\n    }\r\n\r\nI don&#39;t know or care what the name of the key is. I just want the first one. (Bonus points for being able to grab an arbitrary *n*th one.)\r\n\r\nHow do I do this with `jq`?\r\n\r\n---\r\n\r\nIf I *did* know the name, this would be easy:\r\n\r\n```\r\n% echo &#39;{&quot;a&quot;:1,&quot;b&quot;:2,&quot;c&quot;:3}&#39; | jq &#39;{a}&#39;\r\n{\r\n  &quot;a&quot;: 1\r\n}\r\n```\r\n\r\nWhich is a shortcut for:\r\n\r\n```\r\n% echo &#39;{&quot;a&quot;:1,&quot;b&quot;:2,&quot;c&quot;:3}&#39; | jq &#39;{a: .a}&#39;\r\n{\r\n  &quot;a&quot;: 1\r\n}\r\n```\r\n\r\n## Working, but terrible, solution\r\n\r\nIn trying to come up with a bunch of examples for what I&#39;ve tried that didn&#39;t work, I finally came up with this thing that does work:\r\n\r\n```\r\n% echo &#39;{&quot;a&quot;:1,&quot;b&quot;:2,&quot;c&quot;:3}&#39; | jq &#39;{(keys|first):.[(keys|first)]}&#39;\r\n{\r\n  &quot;a&quot;: 1\r\n}\r\n```\r\n\r\nbut that cannot possibly be the best way to do this.\r\n\r\nNotably, the &quot;shortcut&quot; doesn&#39;t work:\r\n\r\n```\r\n% echo &#39;{&quot;a&quot;:1,&quot;b&quot;:2,&quot;c&quot;:3}&#39; | jq &#39;{(keys|first)}&#39;\r\njq: error: syntax error, unexpected &#39;}&#39;, expecting &#39;:&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n{(keys|first)}\r\njq: 1 compile error\r\n```\r\n\r\nThis also works, but is barely better, if not worse:\r\n\r\n```\r\n% echo &#39;{&quot;a&quot;:1,&quot;b&quot;:2,&quot;c&quot;:3}&#39; | jq &#39;(keys|first) as $i | {($i): .[$i]}&#39;\r\n{\r\n  &quot;a&quot;: 1\r\n}\r\n```\r\n\r\n(The &quot;shortcut&quot; doesn&#39;t work here, either.)\r\n\r\n#### WTF?\r\n\r\nAlso, if I don&#39;t use parens around the `$i` as the key, craziness happens that I don&#39;t understand at all:\r\n\r\n```\r\n% echo &#39;{&quot;a&quot;:1,&quot;b&quot;:2,&quot;c&quot;:3}&#39; | jq &#39;(keys|first) as $i | {$i: .[$i]}&#39;\r\njq: error: syntax error, unexpected &#39;:&#39;, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n(keys|first) as $i | {$i: .[$i]}\r\njq: error: May need parentheses around object key expression at &lt;top-level&gt;, line 1:\r\n(keys|first) as $i | {$i: .[$i]}\r\njq: 2 compile errors\r\n\r\n% echo &#39;{&quot;a&quot;:1,&quot;b&quot;:2,&quot;c&quot;:3}&#39; | jq &#39;(keys|first) as $i | {$i}&#39;\r\n{\r\n  &quot;i&quot;: &quot;a&quot;\r\n}\r\n```\r\n\r\n## Other stuff that doesn&#39;t work\r\n\r\n```\r\n% echo &#39;{&quot;a&quot;:1,&quot;b&quot;:2,&quot;c&quot;:3}&#39; | jq &#39;first&#39;\r\njq: error (at &lt;stdin&gt;:1): Cannot index object with number\r\n\r\n% echo &#39;{&quot;a&quot;:1,&quot;b&quot;:2,&quot;c&quot;:3}&#39; | jq &#39;first(.)&#39;\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: 2,\r\n  &quot;c&quot;: 3\r\n}\r\n\r\n% echo &#39;{&quot;a&quot;:1,&quot;b&quot;:2,&quot;c&quot;:3}&#39; | jq &#39;first(.[])&#39;\r\n1\r\n```",
        "link": "https://stackoverflow.com/questions/71163527/strip-all-but-the-first-element-of-an-object-with-jq",
        "title": "strip all but the first element of an object with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1718801265,
                "last_edit_date": 1718801265,
                "creation_date": 1645212847,
                "answer_id": 71178953,
                "question_id": 71178902,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Identify Ron&#39;s last name: \r\n\r\nExtract the last name of the character named &quot;Ron&quot;.\r\nFilter characters with the same last name: Use the extracted last name to filter other characters.\r\n\r\n    jq &#39;\r\n      # Step 1: Find Ron&#39;s last name\r\n      .characters \r\n      | map(select(.First == &quot;Ron&quot;) | .Last) \r\n      | .[0] as $ronsLastName \r\n      # Step 2: Filter characters with the same last name as Ron\r\n      | .characters \r\n      | map(select(.Last == $ronsLastName))\r\n    &#39; input.json\r\n\r\nFinding Ron&#39;s last name:\r\n\r\n.characters | map(select(.First == &quot;Ron&quot;) | .Last): This part filters the characters array to find the character named &quot;Ron&quot; and then extracts his last name.\r\n.[0] as $ronsLastName: This assigns Ron&#39;s last name to a variable $ronsLastName.\r\nFiltering characters with the same last name:\r\n\r\n.characters | map(select(.Last == $ronsLastName)): This part filters the characters array again to find all characters whose last name matches $ronsLastName.\r\n\r\nAssuming your JSON data is in a file called input.json, you can run the jq command as follows:\r\n\r\n    jq &#39;\r\n      .characters \r\n      | map(select(.First == &quot;Ron&quot;) | .Last) \r\n      | .[0] as $ronsLastName \r\n      | .characters \r\n      | map(select(.Last == $ronsLastName))\r\n    &#39; input.json\r\n\r\n",
                "title": "Searching through an array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1645213634,
                "last_edit_date": 1645213634,
                "creation_date": 1645213456,
                "answer_id": 71179073,
                "question_id": 71178902,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Find the last name you are looking for and save it in a variable, then update the `characters` array accordingly:\r\n~~~sh\r\njq &#39;\r\n  (.characters[] | select(.First == &quot;Ron&quot;).Last) as $last\r\n  | .characters |= map(select(.Last == $last))\r\n&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;characters&quot;: [\r\n    {\r\n      &quot;First&quot;: &quot;Fred&quot;,\r\n      &quot;Last&quot;: &quot;Weasley&quot;\r\n    },\r\n    {\r\n      &quot;First&quot;: &quot;George&quot;,\r\n      &quot;Last&quot;: &quot;Weasley&quot;\r\n    },\r\n    {\r\n      &quot;First&quot;: &quot;Ron&quot;,\r\n      &quot;Last&quot;: &quot;Weasley&quot;\r\n    },\r\n    {\r\n      &quot;First&quot;: &quot;Molly&quot;,\r\n      &quot;Last&quot;: &quot;Weasley&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/geZrHBAd49)\r\n\r\n---\r\nIf you want to make the call with a dynamic first name, provide it using a parameter variable:\r\n~~~sh\r\njq --arg first &quot;Ron&quot; &#39;\r\n  (.characters[] | select(.First == $first).Last) as $last\r\n  | .characters |= map(select(.Last == $last))\r\n&#39;\r\n~~~",
                "title": "Searching through an array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1718801265,
        "creation_date": 1645212512,
        "question_id": 71178902,
        "body_markdown": "Trying to learn how to think in jq script.\r\n\r\nGiven this data:\r\n```\r\n{\r\n   &quot;characters&quot;: [\r\n       { &quot;First&quot;: &quot;Fred&quot;, &quot;Last&quot;: &quot;Weasley&quot; },\r\n       { &quot;First&quot;: &quot;George&quot;, &quot;Last&quot;: &quot;Weasley&quot; },\r\n       { &quot;First&quot;: &quot;Hermione&quot;, &quot;Last&quot;: &quot;Granger&quot; },\r\n       { &quot;First&quot;: &quot;Ron&quot;, &quot;Last&quot;: &quot;Weasley&quot; },\r\n       { &quot;First&quot;: &quot;Hagrid&quot; },\r\n       { &quot;First&quot;: &quot;Draco&quot;, &quot;Last&quot;: &quot;Malfoy&quot; },\r\n       { &quot;First&quot;: &quot;Molly&quot;, &quot;Last&quot;: &quot;Weasley&quot; },\r\n       { &quot;First&quot;: &quot;Voldemort&quot; },\r\n       { &quot;First&quot;: &quot;Lucius&quot;, &quot;Last&quot;: &quot;Malfoy&quot; }\r\n    ]\r\n}\r\n```\r\nFind all characters with the same last name as &quot;Ron&quot;. And no, you don&#39;t already know his last name.",
        "link": "https://stackoverflow.com/questions/71178902/searching-through-an-array",
        "title": "Searching through an array"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "associative-array"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1645381344,
                "last_edit_date": 1645381344,
                "creation_date": 1645378619,
                "answer_id": 71197019,
                "question_id": 71196669,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `@tsv` operator in jq to emit tab-separated output, which a bash `while read` loop can easily parse as input.\r\n\r\nAssuming your input JSON is in the variable `s`:\r\n```\r\ndeclare -A X=( )\r\n\r\nwhile IFS=$&#39;\\t&#39; read -r color id; do\r\n  X[$color]+=&quot;$id &quot;\r\ndone &lt; &lt;(jq -r &#39;.[] | [.color, .id] | @tsv&#39; &lt;&lt;&lt;&quot;$s&quot;)\r\n```\r\n\r\nThe above does take a minor shortcut in that it leaves a trailing space after each item. If that&#39;s unacceptable for some reason, you can always go through the array and clean it up after the fact with a second loop:\r\n\r\n```\r\nfor color in &quot;${!X[@]}&quot;; do\r\n  X[$color]=${X[$color]%&quot; &quot;}\r\ndone\r\n```\r\n\r\nYou can see this running in the sandbox at https://replit.com/@CharlesDuffy2/IndigoRemoteEngineering\r\n\r\n---\r\n\r\nAlternately, using `eval`:\r\n\r\n```\r\n#!/usr/bin/env bash\r\ncase $BASH_VERSION in &#39;&#39;|[0-3].*) echo &quot;ERROR: bash 4.0+ required&quot; &gt;&amp;2; exit 1;; esac\r\ndeclare -A X=( )\r\neval &quot;$(\r\n  jq -r &#39;\r\n    reduce .[] as $item ({}; .[$item.color] += [$item.id])\r\n    | to_entries[]\r\n    | &quot;X[\\(.key | @sh)]=\\(.value | join(&quot; &quot;) | @sh)&quot;\r\n  &#39;\r\n)&quot; &lt;file.json\r\n```",
                "title": "How can I use keys and values from jq to generate a bash associative array?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1645384116,
                "last_edit_date": 1645384116,
                "creation_date": 1645378780,
                "answer_id": 71197041,
                "question_id": 71196669,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Answer:\r\n\r\n    declare -A a\r\n    . &lt;(jq -r &#39;&quot;a[\\(.color)]+=${a[\\(.color)]+ }\\(.id)&quot;&#39; file.json)\r\n    \r\nProvides:\r\n\r\n    $ declare -p a\r\n    $ declare -A a=([red]=&quot;9b058640 0ui9k40&quot; [yellow]=&quot;0u858640 5ty87a&quot; )\r\n    # or\r\n    $ echo &quot;${a[red]}&quot;; echo &quot;${a[yellow]}&quot;\r\n    9b058640 0ui9k40\r\n    0u858640 5ty87a\r\n\r\nExplanation:\r\n\r\n- Construct the following bash code in `jq`:\r\n- `a[color]+=${a[color]+ }id`\r\n- `${a[color]+ }` expands to ` `, only if `a[color]` is empty.\r\n- `&quot;\\(.id)&quot;` is jq string interpolation - its replaced with the value of `.id`\r\n- use `.` and a process sub to source this code\r\n",
                "title": "How can I use keys and values from jq to generate a bash associative array?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1645446668,
                "last_edit_date": 1645446668,
                "creation_date": 1645389445,
                "answer_id": 71198550,
                "question_id": 71196669,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "No need for `.`, `source`, `eval` or even looping in bash. All you need is `declare` and `jq`, which can construct the declaration using [escaping](https://stedolan.github.io/jq/manual/v1.6/#Formatstringsandescaping) with `@sh` and [string interpolation](https://stedolan.github.io/jq/manual/v1.6/#Stringinterpolation-%5C%28foo%29):\r\n\r\n~~~sh\r\ndeclare -A X=&quot;($(\r\n  jq -r &#39;\r\n    (&quot;yellow&quot;, &quot;red&quot;) as $color \r\n    | @sh &quot;[\\($color)]=\\(map(select(.color == $color).id) | join(&quot; &quot;))&quot;\r\n  &#39; input.json\r\n))&quot;\r\n~~~\r\n~~~sh\r\n$ echo &quot;${X[yellow]}&quot;\r\n0u858640 5ty87a\r\n\r\n$ echo &quot;${X[red]}&quot;\r\n9b058640 0ui9k40\r\n~~~\r\n",
                "title": "How can I use keys and values from jq to generate a bash associative array?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1645446668,
        "creation_date": 1645376268,
        "last_edit_date": 1645383745,
        "question_id": 71196669,
        "body_markdown": "From Json structure, I want a specific dictionary. From key&#39;s color yellow or red, I add id value.\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;9b058640&quot;,\r\n    &quot;type&quot;: &quot;db&quot;,\r\n    &quot;color&quot;: &quot;red&quot;,\r\n    &quot;host&quot;: &quot;db1&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;0u858640&quot;,\r\n    &quot;type&quot;: &quot;db&quot;,\r\n    &quot;color&quot;: &quot;yellow&quot;,\r\n    &quot;host&quot;: &quot;db2&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;0ui9k40&quot;,\r\n    &quot;type&quot;: &quot;net&quot;,\r\n    &quot;color&quot;: &quot;red&quot;,\r\n    &quot;host&quot;: &quot;net1&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;5ty87a&quot;,\r\n    &quot;type&quot;: &quot;net&quot;,\r\n    &quot;color&quot;: &quot;yellow&quot;,\r\n    &quot;host&quot;: &quot;net2&quot;\r\n  }\r\n]\r\n```\r\n\r\nSo  I want to get the X dictionary\r\n\r\n    X=(\r\n       [&#39;yellow&#39;]=&quot;9b058640 5ty87a&quot;\r\n       [&#39;red&#39;]=&quot;9b058640 0ui9k40&quot;\r\n     )\r\n\r\n\r\nI could parse by value :  \r\n\r\n    jq -c &#39;.[] | select(.color | contains(&quot;red&quot;))&#39;",
        "link": "https://stackoverflow.com/questions/71196669/how-can-i-use-keys-and-values-from-jq-to-generate-a-bash-associative-array",
        "title": "How can I use keys and values from jq to generate a bash associative array?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1645476935,
                "last_edit_date": 1645476935,
                "creation_date": 1645432114,
                "answer_id": 71203220,
                "question_id": 71202247,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s start with:\r\n\r\n    [[3]] | .[] as [$a] ?// [$b] | {$a,$b}\r\n\r\nwhich is evidently equivalent to\r\n\r\n    [3] as [$a] ?// [$b] | {$a,$b}\r\n\r\nThe first part of this says, in effect: \r\n\r\n* first set $a and $b to null;\r\n* next, try to match [3] with [$a], and if that fails, then try to match [3] with [$b]\r\n\r\nSince [3] can be matched with [$a] by setting $a to 3, $b retains its original value, i.e. `null`.\r\n\r\nThe non-obvious thing here is that `error` triggers backtracking: on backtracking, the assignment of 3 to $a is undone, and $b is assigned the value 3 instead.\r\n\r\nQED\r\n",
                "title": "Simple jq Destructuring Alternative Operator ?// example"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1645452889,
                "last_edit_date": 1645452889,
                "creation_date": 1645437946,
                "answer_id": 71204380,
                "question_id": 71202247,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The [Destructuring Alternative Operator](https://stedolan.github.io/jq/manual/v1.6/#DestructuringAlternativeOperator%3A%3F%2F%2F) `?//` can be used to fall back on interpreting the context according to an alternative **structure** if the first one fails. This can be useful if you cannot be sure if you have to process, say, an array or an object. Checking with something like `type` (again and again if the structure is deep) may be tedious. `?//` provides an easier way using the usual destructuring which has already been introduced with the [Variable Binding Operator](https://stedolan.github.io/jq/manual/v1.6/#Variable%2FSymbolicBindingOperator%3A...as%24identifier%7C...) `as` but with providing alternatives to fall back on.\r\n\r\nFor instance, if you want to capture a value that is either the first item of an array or the value of a field literally called &quot;first&quot; in an object, then you can use `… as [$a] ?// {first: $a}` to capture that value into `$a` regardless which structure (out of the two) was present ([Demo](https://jqplay.org/s/2PCEt6CrIH)). Of course, for more complex structures you can use more variable bindings, which would be set to `null` if they weren&#39;t used in the eventually matching structure.\r\n\r\nThat said, having `… as [$a] ?// [$b]` is quite pointless as it captures the same structure anyway, and only fall back on `$b` if there is an error with `$a` (we&#39;ll come back to that later). Having instead for example `… as [$a] ?// $b` would make a lot more sense as it could fall back on setting `$b` to the original input if it could not be evaluated as an array making the destructuring with `[$a]` fail ([Demo](https://jqplay.org/s/KMmfjcGFzC)).\r\n\r\nTherefore, `.[] as [$a] ?// [$b] | {$a,$b}` from your example, when fed with `[[3]]`, will expectedly produce `{&quot;a&quot;: 3, &quot;b&quot;: null}` and nothing else.\r\n\r\n---\r\n\r\nRegarding your second example combining `,`, `if` and `error`:\r\n\r\nIf `error` is used on its own, execution seemingly fails as expected:\r\n~~~\r\n.[] as [$a] ?// [$b] | error(&quot;failed&quot;)\r\n~~~\r\n~~~json\r\njq: error (at &lt;stdin&gt;:0): failed\r\nexit status 5\r\n~~~\r\n[Demo](https://jqplay.org/s/x5xmRuarpK)\r\n\r\nBut actually, `?//` holds two possible contexts that could be passed on to the next filter. After the first one fails because of the following `error`, the next one is evaluated. After that one fails in the same way, the (second) failure is propagated to the output (while the first one is implicitly caught). However, `debug` can expose that there were indeed two evaluations:\r\n~~~\r\n.[] as [$a] ?// [$b] | debug | error(&quot;failed&quot;)\r\n~~~\r\n~~~json\r\n[&quot;DEBUG:&quot;,[[3]]]\r\n[&quot;DEBUG:&quot;,[[3]]]\r\njq: error (at &lt;stdin&gt;:0): failed\r\nexit status 5\r\n~~~\r\n\r\nTherefore, in an `if` statement using `$a != null` as a condition which evaluates to `true` in the first alternative, but to `false` in the second, while having an `error` in the `then` branch, will by implication eventually reach the `else` branch without actually failing, as the one `error` could be caught and a second was never raised.\r\n~~~\r\n.[] as [$a] ?// [$b] | if $a != null then error(&quot;failed&quot;) else &quot;surprise&quot; end\r\n~~~\r\n~~~json\r\n&quot;surprise&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/r6-tnXub4R)\r\n\r\nAnd showing the variables reveals that infact the second alternative was valid for the `else` branch:\r\n~~~\r\n.[] as [$a] ?// [$b] | if $a != null then error(&quot;failed&quot;) else {$a,$b} end\r\n~~~\r\n~~~json\r\n{\r\n  &quot;a&quot;: null,\r\n  &quot;b&quot;: 3\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/RlyRxLnvo7)\r\n\r\nCombining the above with using a [Comma](https://stedolan.github.io/jq/manual/v1.6/#Comma%3A%2C) turns the output into a [cartesian product](https://en.wikipedia.org/wiki/Cartesian_product).\r\n\r\n~~~\r\n.[] as [$a] ?// [$b]\r\n| {inif: false, $a, $b},\r\n  if $a != null then error(&quot;failed&quot;) else {inif: true, $a, $b} end\r\n~~~\r\n~~~json\r\n{\r\n  &quot;inif&quot;: false,\r\n  &quot;a&quot;: 3,\r\n  &quot;b&quot;: null\r\n}\r\n{\r\n  &quot;inif&quot;: false,\r\n  &quot;a&quot;: null,\r\n  &quot;b&quot;: 3\r\n}\r\n{\r\n  &quot;inif&quot;: true,\r\n  &quot;a&quot;: null,\r\n  &quot;b&quot;: 3\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/BFCY5JH8iY)\r\n\r\nWhile evaluating the first destructuring alternative, the first object (with `inif: false`) is being produced. Then, an error occurs in the `then` branch, and the second destructuring alternative is being evaluated. This produces once again the first object (with `inif: false`) and, as by condition it can now follow the `else` branch of the `if` statement, the other object (with `inif: true`) is being produced as well.\r\n",
                "title": "Simple jq Destructuring Alternative Operator ?// example"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1645569266,
                "last_edit_date": 1645569266,
                "creation_date": 1645505668,
                "answer_id": 71216084,
                "question_id": 71202247,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following follows up on pmf&#39;s example:https://jqplay.org/s/BFCY5JH8iY\r\n\r\nIt aims to shed light on how `,` works like cartesian product.\r\n\r\nThere are two inputs passed to the last filter.\r\n\r\n| input | left of comma | right of comma |\r\n|-------|---------------|----------------|\r\n| $a is 3 and $b is null | {inif: false, a: 3, b: null} | error | \r\n| $b is 3 and $a is null | {inif : false, a: null, b: 3} | {inif: true, a: null, b: 3} |\r\n\r\nFinal output is in this order: `{inif: false, a: 3, b: null} error {inif: false, a: null, b: 3} {inif: true, a: null, b: 3}`(error is suppressed).\r\n\r\nSo the output is:\r\n```\r\n{\r\n  &quot;inif&quot;: false,\r\n  &quot;a&quot;: 3,\r\n  &quot;b&quot;: null\r\n}\r\n{\r\n  &quot;inif&quot;: false,\r\n  &quot;a&quot;: null,\r\n  &quot;b&quot;: 3\r\n}\r\n{\r\n  &quot;inif&quot;: true,\r\n  &quot;a&quot;: null,\r\n  &quot;b&quot;: 3\r\n}\r\n```\r\n\r\nHave a look at this too: https://jqplay.org/s/tC98BzFAzM\r\n\r\nThis time its:\r\n\r\n| input | +10 | +20 |\r\n|-------|-----|-----|\r\n|1|11|21|\r\n|2|12|22|\r\n\r\nAnd output is:\r\n```\r\n11\r\n21\r\n12\r\n22\r\n```\r\n\r\nAm I under right track pmf?\r\n",
                "title": "Simple jq Destructuring Alternative Operator ?// example"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1645543182,
                "creation_date": 1645543182,
                "answer_id": 71223836,
                "question_id": 71202247,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just for the sake of completeness, and because it has been rather neglected so far:\r\n\r\nWhile the other answers explain in depth why your examples behave the way they do, why the errors occur etc., this should focus on how to achieve your &quot;expected output&quot; instead.\r\n\r\nAs a matter of fact, you can also utilize the behaviour of the [comma](https://stedolan.github.io/jq/manual/v1.6/#Comma%3A%2C) here. Set one context to `{a}`, another one to `{b}`, and evaluate `{a,b}` for both.\r\n~~~sh\r\n.[] | {a:.[]}, {b:.[]} | {a,b}\r\n~~~\r\n~~~json\r\n{\r\n  &quot;a&quot;: 3,\r\n  &quot;b&quot;: null\r\n}\r\n{\r\n  &quot;a&quot;: null,\r\n  &quot;b&quot;: 3\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/D8U4aVnTDE)",
                "title": "Simple jq Destructuring Alternative Operator ?// example"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1645570201,
        "creation_date": 1645426394,
        "last_edit_date": 1645570201,
        "question_id": 71202247,
        "body_markdown": "This question is about a simple example using Destructuring Alternative Operator: `?//` of `jq` (https://stedolan.github.io/jq/manual/#Advancedfeatures).\r\n\r\nConsider\r\n```\r\nfilter:\r\n.[] as [$a] ?// [$b] | {$a,$b}\r\n\r\ninput:\r\n[[3]]\r\n\r\noutput:\r\n{\r\n  &quot;a&quot;: 3,\r\n  &quot;b&quot;: null\r\n}\r\n```\r\nhttps://jqplay.org/s/Rik3oc8vgA\r\n\r\nBut I was expecting output:\r\n```\r\n{\r\n  &quot;a&quot;: 3,\r\n  &quot;b&quot;: null\r\n}\r\n{\r\n  &quot;a&quot;: null,\r\n  &quot;b&quot;: 3\r\n}\r\n```\r\nIf I try:\r\n```\r\nfilter:\r\n.[] as [$a] ?// [$b] | {$a,$b}, if $a != null then error(&quot;err: \\($a)&quot;) else {$a,$b} end\r\n\r\ninput:\r\n[[3]]\r\n\r\noutput:\r\n{\r\n  &quot;a&quot;: 3,\r\n  &quot;b&quot;: null\r\n}\r\n{\r\n  &quot;a&quot;: null,\r\n  &quot;b&quot;: 3\r\n}\r\n{\r\n  &quot;a&quot;: null,\r\n  &quot;b&quot;: 3\r\n}\r\n```\r\nhttps://jqplay.org/s/f-jBqB9EdZ\r\n\r\nAs you can see, this time \r\n```\r\n{\r\n  &quot;a&quot;: 3,\r\n  &quot;b&quot;: null\r\n}\r\n{\r\n  &quot;a&quot;: null,\r\n  &quot;b&quot;: 3\r\n}\r\n...\r\n```\r\nis outputted.\r\n\r\nCan you explain what is going on?",
        "link": "https://stackoverflow.com/questions/71202247/simple-jq-destructuring-alternative-operator-example",
        "title": "Simple jq Destructuring Alternative Operator ?// example"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1645437256,
                "creation_date": 1645437256,
                "answer_id": 71204241,
                "question_id": 71204113,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `with_entries` to convert the array into an object with defined keys, and `reduce` to construct the overall object:\r\n~~~sh\r\njq &#39;\r\n  reduce .[] as {$id, $lines} ({};\r\n    . + ($lines | with_entries(.key |= &quot;\\($id)_\\(.)&quot;))\r\n  )\r\n&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;bbb_0&quot;: &quot;bla bla bla&quot;,\r\n  &quot;ccc_0&quot;: &quot;lorem ipsum&quot;,\r\n  &quot;ccc_1&quot;: &quot;sample text&quot;,\r\n  &quot;ddd_0&quot;: &quot;foo&quot;,\r\n  &quot;eee_0&quot;: &quot;some text&quot;,\r\n  &quot;eee_1&quot;: &quot;some more text&quot;,\r\n  &quot;eee_2&quot;: &quot;foobar&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/CtaJXJ5xVw)",
                "title": "In jq, how to convert nested arrays from an array of objects into a single object"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1645437882,
                "creation_date": 1645437882,
                "answer_id": 71204368,
                "question_id": 71204113,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another way of achieving the desired output, using [`map`][1], [`with_entries()`][2] and [`add`][3]:\r\n\r\n```\r\nmap(.id as $id | .lines | with_entries(.key |= &quot;\\($id)_\\(.)&quot;)) | add\r\n```\r\n\r\nProduces\r\n```json\r\n{\r\n  &quot;bbb_0&quot;: &quot;bla bla bla&quot;,\r\n  &quot;ccc_0&quot;: &quot;lorem ipsum&quot;,\r\n  &quot;ccc_1&quot;: &quot;sample text&quot;,\r\n  &quot;ddd_0&quot;: &quot;foo&quot;,\r\n  &quot;eee_0&quot;: &quot;some text&quot;,\r\n  &quot;eee_1&quot;: &quot;some more text&quot;,\r\n  &quot;eee_2&quot;: &quot;foobar&quot;\r\n}\r\n```\r\n\r\nAa you can test in this [online demo](https://jqplay.org/s/OARl5HEuv7)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#map(x),map_values(x)\r\n  [2]: https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries\r\n  [3]: https://stedolan.github.io/jq/manual/#add",
                "title": "In jq, how to convert nested arrays from an array of objects into a single object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1645444593,
        "creation_date": 1645436604,
        "last_edit_date": 1645444593,
        "question_id": 71204113,
        "body_markdown": "I have a JSON document that looks like this\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;bbb&quot;,\r\n    &quot;lines&quot;: [\r\n      &quot;bla bla bla&quot;\r\n    ],\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;ccc&quot;,\r\n    &quot;lines&quot;: [\r\n      &quot;lorem ipsum&quot;,\r\n      &quot;sample text&quot;\r\n    ]\r\n  }\r\n  {\r\n    &quot;id&quot;: &quot;ddd&quot;,\r\n    &quot;lines&quot;: [\r\n      &quot;foo&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;eee&quot;,\r\n    &quot;lines&quot;: [\r\n      &quot;some text&quot;,\r\n      &quot;some more text&quot;,\r\n      &quot;foobar&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI am attempting to use `jq` to modify this document into something that looks like this:\r\n\r\n```\r\n{\r\n  &quot;bbb_0&quot;: &quot;bla bla bla&quot;,\r\n  &quot;ccc_0&quot;: &quot;lorem ipsum&quot;,\r\n  &quot;ccc_1&quot;: &quot;sample text&quot;,\r\n  &quot;ddd_0&quot;: &quot;foo&quot;,\r\n  &quot;eee_0&quot;: &quot;some text&quot;,\r\n  &quot;eee_1&quot;: &quot;some more text&quot;,\r\n  &quot;eee_2&quot;: &quot;foobar&quot;\r\n}\r\n```\r\n\r\nHow would I achieve this? Thanks!",
        "link": "https://stackoverflow.com/questions/71204113/in-jq-how-to-convert-nested-arrays-from-an-array-of-objects-into-a-single-objec",
        "title": "In jq, how to convert nested arrays from an array of objects into a single object"
    },
    {
        "tags": [
            "json",
            "jq",
            "activecampaign"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1645470562,
                "last_edit_date": 1645470562,
                "creation_date": 1645470161,
                "answer_id": 71211683,
                "question_id": 71211622,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `with_entries` to make changes based on keys and values: \r\n~~~sh\r\njq &#39;\r\n  with_entries(\r\n    (.key / &quot;_CC_&quot;) as $key | select($key[1])\r\n    | {key: $key[0], value: {email_address: .value, role: $key[0]}}\r\n  )\r\n&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;Approver&quot;: {\r\n    &quot;email_address&quot;: &quot;tim@domain.com&quot;,\r\n    &quot;role&quot;: &quot;Approver&quot;\r\n  },\r\n  &quot;Customer&quot;: {\r\n    &quot;email_address&quot;: &quot;alex@domain.com&quot;,\r\n    &quot;role&quot;: &quot;Customer&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/-uPNpDR4fX)",
                "title": "How to get object list from key value pairs complex JSON using jq and map? (Active Campaign)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1645514478,
                "creation_date": 1645514478,
                "answer_id": 71217311,
                "question_id": 71211622,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In versions of jq which include `INDEX/2`, it is defined as a simple jq function, so if your jq does not include it, you can simply include its definition yourself:\r\n```\r\ndef INDEX(stream; idx_expr):\r\n  reduce stream as $row ({};\r\n    .[$row|idx_expr|\r\n      if type != &quot;string&quot; then tojson\r\n      else .\r\n      end] |= $row);\r\n```",
                "title": "How to get object list from key value pairs complex JSON using jq and map? (Active Campaign)"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1645514478,
        "creation_date": 1645469845,
        "question_id": 71211622,
        "body_markdown": "I have following JSON. I want to get key-value pair objects based on their CC role. In this example there are 3 roles(Presenter, Approver, Customer). Presenter is of type `TO`. Other 2 are of type `CC`. I want to get of type `CC`. There can be more as it is dynamic.\r\n\r\nJSON\r\n\r\n    {\r\n       &quot;Presenter_TO_Email&quot;: &quot;roney@domain.com&quot;,\r\n       &quot;Approver_CC_Email&quot;: &quot;tim@domain.com&quot;,\r\n       &quot;Customer_CC_Email&quot;: &quot;alex@domain.com&quot;,   \r\n       &quot;Invoice&quot;: &quot;001&quot;,\r\n       &quot;Date&quot;: &quot;2022-02-14&quot;   \r\n    }\r\n\r\nOutput\r\n\r\n    {\r\n        &quot;Approver&quot;: {\r\n          &quot;email_address&quot;: &quot;tim@domain.com&quot;,\r\n          &quot;role&quot;: &quot;Approver&quot;\r\n        },\r\n        &quot;Customer&quot;: {\r\n          &quot;email_address&quot;: &quot;alex@domain.com&quot;,\r\n          &quot;role&quot;: &quot;Customer&quot;\r\n        }\r\n    }\r\n\r\nI can do using INDEX using [this][1] example but as I am using older version of `jq`, it throws error `jq: error: INDEX/2 is not defined at &lt;top-level&gt;, line 1:`\r\n\r\n\r\n  [1]: https://jqplay.org/s/epn55D_OGj",
        "link": "https://stackoverflow.com/questions/71211622/how-to-get-object-list-from-key-value-pairs-complex-json-using-jq-and-map-acti",
        "title": "How to get object list from key value pairs complex JSON using jq and map? (Active Campaign)"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1645557865,
                "last_edit_date": 1645557865,
                "creation_date": 1645547000,
                "answer_id": 71224791,
                "question_id": 71224676,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Drop the quote marker `&quot;` on the numeric type you are trying to search. Quotes should apply only when selecting/matching string types.\r\n\r\nUse `+=` to add the object on the selected entry\r\n\r\n```none\r\n(.thermostats[] | select(.identifier == 111111111111)) += {default: &quot;yes&quot;}\r\n```\r\n\r\njqplay demo - https://jqplay.org/s/k5tForQ9HT\r\n\r\n---\r\n\r\nIf you were to pass the match identifier as an argument, do refer to the answers at [Numeric argument passed with jq --arg not matching data with ==][1], because `--arg` by default defines your argument to be string type, which needs to be modified inside your `select` to numeric type for comparison. So use `$thermoid|tonumber` or pass it as `argjson`\r\n\r\n\r\n  [1]: https://stackoverflow.com/q/41772776/5291015",
                "title": "Adding a record to JSON object after selecting on a condition"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1645700281,
        "creation_date": 1645546599,
        "last_edit_date": 1645700281,
        "question_id": 71224676,
        "body_markdown": "I have the following json:\r\n```\r\n{\r\n   &quot;thermostats&quot;: [\r\n      {\r\n         &quot;name&quot;: &quot;Thermostat1&quot;,\r\n         &quot;identifier&quot;: 111111111111\r\n      },\r\n      {\r\n         &quot;name&quot;: &quot;Thermostat2&quot;,\r\n         &quot;identifier&quot;: 222222222222\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nI&#39;d like to add the following `{default: yes}` to the one that I select.\r\n```\r\n{\r\n   &quot;thermostats&quot;: [\r\n      {\r\n         &quot;name&quot;: &quot;Thermostat1&quot;,\r\n         &quot;identifier&quot;: 111111111111,\r\n         &quot;default&quot;: &quot;yes&quot;\r\n      },\r\n      {\r\n         &quot;name&quot;: &quot;Thermostat2&quot;,\r\n         &quot;identifier&quot;: 222222222222\r\n      }\r\n   ]\r\n}\r\n```\r\nI have the following but haven&#39;t figured out how to add the record\r\n\r\n`q &#39;.thermostats[] | select (.identifier == &quot;1111111111&quot;)`\r\n\r\nI&#39;ve tried `. += {default: yes}` `| . += {default: yes}` `|= . +` but I&#39;m going off the wrong track.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/71224676/adding-a-record-to-json-object-after-selecting-on-a-condition",
        "title": "Adding a record to JSON object after selecting on a condition"
    },
    {
        "tags": [
            "function",
            "variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1645579747,
                "last_edit_date": 1645579747,
                "creation_date": 1645579301,
                "answer_id": 71230305,
                "question_id": 71230251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Function arguments are *filters*, which will take input and produce output when used in the body of the function.\r\n\r\nTo &quot;pass&quot; a value, you &quot;consume&quot; the filter immediately and assign it to a variable\r\n\r\n    def addvalue(f): f as $f | map(. + $f)\r\n\r\nwhich you can write using shorthand\r\n\r\n    def addvalue($f): map(. + $f)\r\n\r\nWithout the variable, the filter `.[0]` is used in the call to `map`\r\n\r\n    map(. + .[0])\r\n\r\nwhere you will now try, for example, to add `[1,2]` and `1` rather than the intended `[1,2] + [1,2]`. That is, the `.[0]` argument is *not* &quot;evaluated&quot; to produce a value to pass to the function; the filter itself is passed as the argument and not actually used until `map` is called.",
                "title": "Why variable is needed sometimes to define a function in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1645582638,
                "last_edit_date": 1645582638,
                "creation_date": 1645579915,
                "answer_id": 71230349,
                "question_id": 71230251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The results are different because `.[0]` has different values depending on the context it is being evaluated in.\r\n\r\n---\r\nIn your first example, the function&#39;s parameter is a filter, and it is called with an argument which also is filter. Therefore, the argument filter is only evaluated when the function&#39;s parameter is. This &quot;late&quot; context is the primary input&#39;s array elements. The overall evaluation is as follows:\r\n~~~\r\n[[1,2], [10,20]] | def addvalue(f): map(. + f); addvalue(.[0])\r\n~~~\r\n~~~\r\n[[1,2], [10,20]] | map(. + .[0])\r\n~~~\r\n~~~\r\n[[1,2] + .[0], [10,20] + .[0]]\r\n~~~\r\n~~~\r\n[[1,2] + 1, [10,20] + 10]\r\n~~~\r\n~~~\r\njq: error (at &lt;stdin&gt;:0): array ([1,2]) and number (1) cannot be added\r\nexit status 5\r\n~~~\r\n\r\n---\r\nIn your second example, the function&#39;s parameter is still a filter, but it is called with an argument which now is a value. Therefore, even if the function&#39;s parameter is evaluated late, it is fed with the unchanged constant value defined on top level. The overall evaluation is as follows:\r\n~~~\r\n[[1,2], [10,20]] | def addvalue(f): map(. + f); addvalue([1,2])\r\n~~~\r\n~~~\r\n[[1,2], [10,20]] | map(. + [1,2])\r\n~~~\r\n~~~\r\n[[1,2] + [1,2], [10,20] + [1,2]]\r\n~~~\r\n~~~\r\n[[1,2,1,2], [10,20,1,2]]\r\n~~~\r\n\r\n---\r\nIn your third example, the function&#39;s parameter is a variable, and it is called with an argument which is a filter. Therefore, to set the function&#39;s parameter variable, the argument filter has to be evaluated immediately. This &quot;early&quot; context is the primary input. The overall evaluation is as follows:\r\n~~~\r\n[[1,2], [10,20]] | def addvalue($f): map(. + $f); addvalue(.[0])\r\n~~~\r\n~~~\r\n[[1,2], [10,20]] | def addvalue($f): map(. + $f); addvalue([1,2])\r\n~~~\r\n~~~\r\n[[1,2], [10,20]] | map(. + [1,2])\r\n~~~\r\n~~~\r\n[[1,2] + [1,2], [10,20] + [1,2]]\r\n~~~\r\n~~~\r\n[[1,2,1,2], [10,20,1,2]]\r\n~~~",
                "title": "Why variable is needed sometimes to define a function in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1645665793,
                "creation_date": 1645665793,
                "answer_id": 71245985,
                "question_id": 71230251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a little clarification of pmf&#39;s excellent answer.\r\n\r\nFor the first example\r\n\r\n```\r\n[[1,2], [10,20]] | def addvalue(f): map(. + f); addvalue(.[0])\r\n\r\n[[1,2], [10,20]] | map(. + .[0])\r\n\r\n[([1,2] | . + .[0]), ([10,20] | . + .[0])]\r\n\r\n[[1,2] + 1, [10,20] + 10]\r\n\r\njq: error (at &lt;stdin&gt;:0): array ([1,2]) and number (1) cannot be added\r\nexit status 5\r\n```\r\nI just clarified the contexts.\r\n",
                "title": "Why variable is needed sometimes to define a function in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1645665793,
        "creation_date": 1645578729,
        "question_id": 71230251,
        "body_markdown": "The following (https://jqplay.org/s/9r9oTh1VFq)\r\n```\r\nfilter:\r\ndef addvalue(f): map(. + f); addvalue(.[0])\r\n\r\ninput:\r\n[[1,2],[10,20]]\r\n```\r\ngives error:\r\n```\r\njq: error (at &lt;stdin&gt;:0): array ([1,2]) and number (1) cannot be added\r\nexit status 5\r\n```\r\n\r\nBut the this (https://jqplay.org/s/X7FDfQWubV)\r\n```\r\nfilter:\r\ndef addvalue(f): map(. + f); addvalue([1,2])\r\n\r\ninput:\r\n[[1,2],[10,20]]\r\n\r\noutput:\r\n[\r\n  [\r\n    1,\r\n    2,\r\n    1,\r\n    2\r\n  ],\r\n  [\r\n    10,\r\n    20,\r\n    1,\r\n    2\r\n  ]\r\n]\r\n```\r\nworks as expected.\r\n\r\nFrom the jq manual, the following (https://jqplay.org/s/npl2nalQyq) works too:\r\n```\r\nfilter:\r\ndef addvalue($f): map(. + $f); addvalue(.[0])\r\n\r\ninput:\r\n[[1,2],[10,20]]\r\n\r\noutput:\r\n[\r\n  [\r\n    1,\r\n    2,\r\n    1,\r\n    2\r\n  ],\r\n  [\r\n    10,\r\n    20,\r\n    1,\r\n    2\r\n  ]\r\n]\r\n```\r\n\r\nIn the jq manual it says:\r\n```\r\nIf you want the value-argument behaviour for defining simple functions, you can just use a variable...\r\n```\r\n\r\nWhy do I need to use the variable `$f` in the function definition for `addvalue(.[0])` to work?\r\n\r\nThanks!\r\n",
        "link": "https://stackoverflow.com/questions/71230251/why-variable-is-needed-sometimes-to-define-a-function-in-jq",
        "title": "Why variable is needed sometimes to define a function in jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1645622828,
                "post_id": 71237635,
                "comment_id": 125920651,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651035407,
                "creation_date": 1651035407,
                "answer_id": 72023463,
                "question_id": 71237635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s my take on this.\r\n\r\nSay we have `superhero.json` like this:\r\n\r\n```\r\n{\r\n  &quot;squadName&quot;: &quot;Super hero squad&quot;,\r\n  &quot;homeTown&quot;: &quot;Metropolia&quot;,\r\n  &quot;formed&quot;: 2013,\r\n  &quot;secretBase&quot;: &quot;Super HQ&quot;,\r\n  &quot;active&quot;: true,\r\n  &quot;members&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Atom Man&quot;,\r\n      &quot;age&quot;: 25,\r\n      &quot;secretIdentity&quot;: &quot;Dan Smith&quot;,\r\n      &quot;powers&quot;: [\r\n        &quot;Radiation resistance&quot;,\r\n        &quot;Radiation blast&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Super Man&quot;,\r\n      &quot;age&quot;: 26,\r\n      &quot;secretIdentity&quot;: &quot;Clark&quot;,\r\n      &quot;powers&quot;: [\r\n        &quot;Flying power&quot;,\r\n        &quot;Super human strength&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Bat Man&quot;,\r\n      &quot;age&quot;: 24,\r\n      &quot;secretIdentity&quot;: &quot;Bruce&quot;,\r\n      &quot;powers&quot;: [\r\n        &quot;Pakour&quot;,\r\n        &quot;Night vision&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nAnd here&#39;s my `run.sh` script:\r\n\r\n```\r\n#!/bin/bash\r\nwhile true\r\ndo\r\njq -r &#39;.members[] | .name&#39; superhero.json #display the hero names for user.\r\n  read -p &quot;Which heroes details do you want to see? Enter &#39;exit&#39; to quit: &quot; HERONAME1\r\n  if [ &quot;$HERONAME1&quot; = &quot;exit&quot; ]\r\n  then\r\n    echo &quot;Quitting...&quot;\r\n    exit\r\n  else\r\n    HERONAME1=$HERONAME1 jq -r &#39;.members[] | select(.name==env.HERONAME1) | {secretIdentity}, {powers}&#39; superhero.json\r\n  fi\r\ndone\r\n```\r\n\r\nHere&#39;s output when I run this script:\r\n\r\n```\r\n$ ./run.sh \r\nAtom Man\r\nSuper Man\r\nBat Man\r\nWhich heroes details do you want to see? Enter &#39;exit&#39; to quit: Bat Man\r\n{\r\n  &quot;secretIdentity&quot;: &quot;Bruce&quot;\r\n}\r\n{\r\n  &quot;powers&quot;: [\r\n    &quot;Pakour&quot;,\r\n    &quot;Night vision&quot;\r\n  ]\r\n}\r\nAtom Man\r\nSuper Man\r\nBat Man\r\nWhich heroes details do you want to see? Enter &#39;exit&#39; to quit: Atom Man\r\n{\r\n  &quot;secretIdentity&quot;: &quot;Dan Smith&quot;\r\n}\r\n{\r\n  &quot;powers&quot;: [\r\n    &quot;Radiation resistance&quot;,\r\n    &quot;Radiation blast&quot;\r\n  ]\r\n}\r\nAtom Man\r\nSuper Man\r\nBat Man\r\nWhich heroes details do you want to see? Enter &#39;exit&#39; to quit: Super Man \r\n{\r\n  &quot;secretIdentity&quot;: &quot;Clark&quot;\r\n}\r\n{\r\n  &quot;powers&quot;: [\r\n    &quot;Flying power&quot;,\r\n    &quot;Super human strength&quot;\r\n  ]\r\n}\r\nAtom Man\r\nSuper Man\r\nBat Man\r\nWhich heroes details do you want to see? Enter &#39;exit&#39; to quit: exit\r\nQuitting...\r\n```\r\n\r\nTry the script. ;)",
                "title": "JQ - Get specific values under a key based on variable filter"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1651035407,
        "creation_date": 1645622142,
        "last_edit_date": 1645636733,
        "question_id": 71237635,
        "body_markdown": "So for class I have to make an shell script (BASH) that uses JQ to display a superheroes secret identity and powers. It has been a pretty fun course.\r\n\r\nThe script prints the hero names to the user, who then specifies which heroes details they want to see.\r\n\r\nHere is a small part of the json file that I have been given.\r\n\r\n```json\r\n{\r\n  &quot;squadName&quot;: &quot;Super hero squad&quot;,\r\n  &quot;homeTown&quot;: &quot;Metropolia&quot;,\r\n  &quot;formed&quot;: 2013,\r\n  &quot;secretBase&quot;: &quot;Super HQ&quot;,\r\n  &quot;active&quot;: true,\r\n  &quot;members&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Atom Man&quot;,\r\n      &quot;age&quot;: 25,\r\n      &quot;secretIdentity&quot;: &quot;Dan Smith&quot;,\r\n      &quot;powers&quot;: [\r\n        &quot;Radiation resistance&quot;,\r\n        &quot;Radiation blast&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nSo if the user enters &quot;Atom Man&quot;, the script should print his secret identity ```(&quot;secretIdentity&quot;: &quot;Dan Smith&quot;)``` and his powers.\r\n```\r\n(&quot;powers&quot;: [\r\n        &quot;Radiation resistance&quot;,\r\n        &quot;Radiation blast&quot;\r\n      ])\r\n```\r\n\r\nAnd here is the partially done script.\r\n\r\n```\r\n#!/bin/bash\r\nwhile [ true ]\r\ndo\r\ncat superhero.json | jq -r &#39;.mem [] | .name&#39; #display the hero names for user.\r\n  read -p &quot;Which heroes details do you want to see? Enter &#39;exit&#39; to quit. :&quot; HERONAME1\r\n  if [ &quot;$HERONAME1&quot; = &quot;exit&quot; ]\r\n  then\r\n    echo &quot;Quitting...&quot;\r\n    exit\r\n  else\r\n    cat superhero.json | jq -r &#39;.member [] | .name [] &#39;\r\n    #or jq &#39;.members[].name&#39; superhero.json&#39;\r\n  fi\r\ndone\r\n```\r\n\r\nNow I am stuck at this part of my script.\r\n\r\n```\r\nelse\r\n    cat superhero.json | jq -r &#39;.member [] | .name [] &#39;\r\n```\r\n\r\nI don&#39;t quite understand how I can filter a certain hero from the json file using the HERONAME1 variable and how to include their powers in the output as well.\r\n\r\n\r\nAny and all pointers are highly appreciated!\r\n\r\n ",
        "link": "https://stackoverflow.com/questions/71237635/jq-get-specific-values-under-a-key-based-on-variable-filter",
        "title": "JQ - Get specific values under a key based on variable filter"
    },
    {
        "tags": [
            "arrays",
            "object",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1645632644,
                "creation_date": 1645632644,
                "answer_id": 71240423,
                "question_id": 71240290,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `select` directly on the list of objects, extract and check the release date inside its argument:\r\n\r\n    jq &#39;.versions[] | select(.userReleaseDate | endswith(&quot;22&quot;))&#39;",
                "title": "JQ get objects from array that has a field ending in string"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1645655186,
                "last_edit_date": 1645655186,
                "creation_date": 1645634175,
                "answer_id": 71240780,
                "question_id": 71240290,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This was so close:\r\n\r\n```sh\r\njq &#39;.versions[].userReleaseDate | endswith(&quot;22&quot;)&#39;\r\n```\r\n\r\nRather than *outputting* whether they end with `22` or not, you want to *select* the values which end with `22`. Fixed:\r\n\r\n```sh\r\njq &#39;.versions[].userReleaseDate | select( endswith(&quot;22&quot;) )&#39;\r\n```\r\n\r\nNow, your question asks for the dates that end with `22`, but the title suggests you want the objects. For that, you&#39;d want something a little different. We want to select from the versions, not from the dates.\r\n\r\n```sh\r\njq &#39;.versions[] | select( .userReleaseDate | endswith(&quot;22&quot;) )&#39;       # As a stream\r\n```\r\n\r\n```sh\r\njq &#39;[ .versions[] | select( .userReleaseDate | endswith(&quot;22&quot;) ) ]&#39;   # As an array\r\n```\r\n\r\n```sh\r\njq &#39;.versions | map( select( .userReleaseDate | endswith(&quot;22&quot;) ) )&#39;  # As an array\r\n```\r\n\r\n---\r\n\r\nThere are a number of issues with `[ .versions[] as $keys | $keys select(endswith(&quot;22&quot;)) ]`.\r\n\r\n* The keys of array element aren&#39;t usually called *keys* but *indexes*. `$indexes` would be a better name.\r\n\r\n* Except `.versions[]` gets the *values* of the array elements, not the *keys*/*indexes*. `$values` would be a better name.\r\n\r\n* Except the variable only takes on a single value at a time. `$value` would be a better name.\r\n\r\n* `$version` would be an even better name.\r\n\r\n* There&#39;s a `|` missing between `$keys` and `select(endswith(&quot;22&quot;))`.\r\n\r\n* There&#39;s no mention of `userReleaseDate` anywhere.\r\n\r\n* The result is placed in an array (because of the `[ ]`). There&#39;s no need or desire for this.\r\n\r\nYou could use\r\n\r\n```jq\r\n.versions[] as $version | $version.userReleaseDate | select(endswith(&quot;22&quot;))\r\n```\r\n\r\nor\r\n\r\n```jq\r\n.versions[].userReleaseDate as $date | $date | select(endswith(&quot;22&quot;))\r\n```\r\n\r\nBut these are just overly-complicated versions of\r\n\r\n```sh\r\njq &#39;.versions[].userReleaseDate | select( endswith(&quot;22&quot;) )&#39;\r\n```",
                "title": "JQ get objects from array that has a field ending in string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1645655186,
        "creation_date": 1645632122,
        "last_edit_date": 1645636645,
        "question_id": 71240290,
        "body_markdown": "I am trying to do what I think should be a fairly simple filter but I keep running into errors. I have this JSON: \r\n```json\r\n{\r\n  &quot;versions&quot;: [\r\n    {\r\n      &quot;archived&quot;: true,\r\n      &quot;description&quot;: &quot;Cod version 3.3/Sprint 8&quot;,\r\n      &quot;id&quot;: &quot;11500&quot;,\r\n      &quot;name&quot;: &quot;v 3.3&quot;,\r\n      &quot;projectId&quot;: 11500,\r\n      &quot;releaseDate&quot;: &quot;2016-03-15&quot;,\r\n      &quot;released&quot;: true,\r\n      &quot;self&quot;: &quot;https://xxxxxxx.atlassian.net/rest/api/2/version/11500&quot;,\r\n      &quot;startDate&quot;: &quot;2016-02-17&quot;,\r\n      &quot;userReleaseDate&quot;: &quot;14/Mar/16&quot;,\r\n      &quot;userStartDate&quot;: &quot;16/Feb/16&quot;\r\n    },\r\n    {\r\n      &quot;archived&quot;: true,\r\n      &quot;description&quot;: &quot;Hot fix&quot;,\r\n      &quot;id&quot;: &quot;12000&quot;,\r\n      &quot;name&quot;: &quot;v3.3.1&quot;,\r\n      &quot;projectId&quot;: 11500,\r\n      &quot;releaseDate&quot;: &quot;2016-03-15&quot;,\r\n      &quot;released&quot;: true,\r\n      &quot;self&quot;: &quot;https://xxxxxxx.atlassian.net/rest/api/2/version/12000&quot;,\r\n      &quot;startDate&quot;: &quot;2016-03-15&quot;,\r\n      &quot;userReleaseDate&quot;: &quot;14/Mar/16&quot;,\r\n      &quot;userStartDate&quot;: &quot;14/Mar/16&quot;\r\n    },\r\n    {\r\n      &quot;archived&quot;: false,\r\n      &quot;id&quot;: &quot;29704&quot;,\r\n      &quot;name&quot;: &quot;Sync-diff v1.0.0&quot;,\r\n      &quot;projectId&quot;: 11500,\r\n      &quot;releaseDate&quot;: &quot;2022-02-16&quot;,\r\n      &quot;released&quot;: true,\r\n      &quot;self&quot;: &quot;https://xxxxxxx.atlassian.net/rest/api/2/version/29704&quot;,\r\n      &quot;startDate&quot;: &quot;2022-02-06&quot;,\r\n      &quot;userReleaseDate&quot;: &quot;15/Feb/22&quot;,\r\n      &quot;userStartDate&quot;: &quot;05/Feb/22&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nI just want to return any userReleaseDate that ends with &#39;22&#39;\r\n\r\nI can get the boolean result by: \r\n```\r\njq &#39;.versions[].userReleaseDate | endswith(&quot;22&quot;)&#39; \r\n```\r\nprints out false, false, true\r\n\r\nBut I am not sure how to retrieve the objects. I tried variations of this: \r\n```\r\n[.versions[] as $keys |  $keys select(endswith(&quot;22&quot;))]\r\n```\r\nand each threw an error. Any help would be appreciated. ",
        "link": "https://stackoverflow.com/questions/71240290/jq-get-objects-from-array-that-has-a-field-ending-in-string",
        "title": "JQ get objects from array that has a field ending in string"
    },
    {
        "tags": [
            "typescript",
            "awk",
            "sed",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1645677566,
                "creation_date": 1645677566,
                "answer_id": 71247179,
                "question_id": 71246584,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I suppose you can apply `jq` by extracting the json string. Let me modify\r\nthe provided TypeScript file to contain a valid json string.\r\n\r\n`file.ts`:\r\n```\r\nexport type Pools = {\r\n  &quot;version&quot;: &quot;0.1.0&quot;,\r\n  &quot;name&quot;: &quot;hydra_liquidity_pools&quot;,\r\n  &quot;accounts&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;poolState&quot;,\r\n      &quot;type&quot;: {\r\n        &quot;kind&quot;: &quot;struct&quot;,\r\n        &quot;fields&quot;: [\r\n          {\r\n            &quot;foo&quot;: &quot;bar&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;reserved&quot;,\r\n            &quot;type&quot;: {\r\n              &quot;defined&quot;: &quot;Reserve&quot;\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\nThen try:\r\n```\r\nlval=$(sed -nE &#39;s/(.*= ).*/\\1/p&#39; &lt; file.ts)             # extract &quot;export type Pools = &quot;\r\necho &quot;$lval&quot; &quot;$(sed &quot;s/$lval//&quot; file.ts | jq &#39;del(.accounts[].type.fields[] | select (.name == &quot;reserved&quot;))&#39;)&quot;\r\n```\r\nOutput:\r\n```\r\nexport type Pools =  {\r\n  &quot;version&quot;: &quot;0.1.0&quot;,\r\n  &quot;name&quot;: &quot;hydra_liquidity_pools&quot;,\r\n  &quot;accounts&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;poolState&quot;,\r\n      &quot;type&quot;: {\r\n        &quot;kind&quot;: &quot;struct&quot;,\r\n        &quot;fields&quot;: [\r\n          {\r\n            &quot;foo&quot;: &quot;bar&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "Parse typescript file on the cli and remove an element"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1645695481,
                "last_edit_date": 1645695481,
                "creation_date": 1645688193,
                "answer_id": 71248545,
                "question_id": 71246584,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could have jq take the whole typscript (using `-Rs`), extract and manipulate the JSON part (using `fromjson` and `tojson`), and write it back (using `-r`). This requires you to know and model the typescript part, and to condone the altered formatting of the JSON part (basically all in one line).\r\n\r\nExample using `capture`:\r\n~~~sh\r\njq -Rsr &#39;\r\n  capture(&quot;(?&lt;ts&gt;export type Pools = )(?&lt;json&gt;.*)&quot;;&quot;m&quot;)\r\n  | .json |= (fromjson | (.) | tojson)\r\n  | .ts + .json\r\n&#39;\r\n~~~\r\n~~~\r\nexport type Pools = {&quot;version&quot;:&quot;0.1.0&quot;,&quot;name&quot;:&quot;hydra_liquidity_pools&quot;,&quot;accounts&quot;:[{&quot;name&quot;:&quot;poolState&quot;,&quot;type&quot;:{&quot;kind&quot;:&quot;struct&quot;,&quot;fields&quot;:[{&quot;name&quot;:&quot;reserved&quot;,&quot;type&quot;:{&quot;defined&quot;:&quot;Reserve&quot;}}]}}]}\r\n~~~\r\n[Demo](https://jqplay.org/s/s4jTp6i3YY)\r\n\r\nAdjust `(?&lt;ts&gt;export type Pools = )` to whatever should be captured as the typescript part using a regex, and change `(.)` to whatever you want to do with the JSON part using jq.",
                "title": "Parse typescript file on the cli and remove an element"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1645695481,
        "creation_date": 1645671986,
        "question_id": 71246584,
        "body_markdown": "Hey peeps I am looking for a way to parse a typescript file and easily remove and element from the embedded json object within a couple of codegen types. \r\n\r\nWould be pretty easy with the likes of `jq` however that doesnt work for a typescript file with an embedded object like this I found. \r\n\r\nFeel like this could be done with sed or awk however I havent had anyluck removing the whole `{..}&#39; element. \r\n \r\n\r\nbefore:\r\n```\r\nexport type Pools = {\r\n  &quot;version&quot;: &quot;0.1.0&quot;,\r\n  &quot;name&quot;: &quot;hydra_liquidity_pools&quot;,\r\n  &quot;accounts&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;poolState&quot;,\r\n      &quot;type&quot;: {\r\n        &quot;kind&quot;: &quot;struct&quot;,\r\n        &quot;fields&quot;: [\r\n          ...  \r\n          {\r\n            &quot;name&quot;: &quot;reserved&quot;,\r\n            &quot;type&quot;: {\r\n              &quot;defined&quot;: &quot;Reserve&quot;\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  ],\r\n...\r\n}\r\n```\r\n\r\nafter:\r\n```\r\nexport type Pools = {\r\n  &quot;version&quot;: &quot;0.1.0&quot;,\r\n  &quot;name&quot;: &quot;hydra_liquidity_pools&quot;,\r\n  &quot;accounts&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;poolState&quot;,\r\n      &quot;type&quot;: {\r\n        &quot;kind&quot;: &quot;struct&quot;,\r\n        &quot;fields&quot;: [\r\n          ...  \r\n        ]\r\n      }\r\n    }\r\n  ],\r\n...\r\n}\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/71246584/parse-typescript-file-on-the-cli-and-remove-an-element",
        "title": "Parse typescript file on the cli and remove an element"
    },
    {
        "tags": [
            "variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1645715190,
                "last_edit_date": 1645715190,
                "creation_date": 1645684639,
                "answer_id": 71248036,
                "question_id": 71246837,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Contrary to what the examples in the *Scoping* section assume, `. * 4 as $times_four | . ` is equivalent to `. * ( 4 as $times_four | . )` and therefore squares its input.\r\n\r\n---\r\n\r\nYou might expect \r\n\r\n```jq\r\n. * 4 as $times_four | .\r\n```\r\n\r\nto be equivalent to\r\n\r\n```jq\r\n( . * 4 ) as $times_four | .\r\n```\r\n\r\nAnd as you point out, some example even suggest this is the case. However, the first snippet is actually equivalent to the following:\r\n\r\n```jq\r\n. * ( 4 as $times_four | . )\r\n```\r\n\r\nAnd since `… as $x` produces its context&lt;sup&gt;[1]&lt;/sup&gt;, that&#39;s the same as\r\n\r\n```jq\r\n. * ( . | . )\r\n```\r\n\r\nor\r\n\r\n```jq\r\n. * .\r\n```\r\n\r\n`jq`&#39;s operator precedence is inconsistent and/or quirky.\r\n\r\n`&quot;def&quot; | &quot;abc&quot;  + &quot;def&quot; | length` means&lt;br&gt;`&quot;def&quot; | ( &quot;abc&quot; + &quot;def&quot; ) | length`, but&lt;br&gt;`&quot;def&quot; | &quot;abc&quot;  + &quot;def&quot; as $x | length` means&lt;br&gt;`&quot;def&quot; | &quot;abc&quot; + ( &quot;def&quot; as $x | length )`.\r\n\r\nThis behaviour suggests that that `as` isn&#39;t a binary operator of the form `X as $Y` as one might expect, but a ternary operator of the form `X as $Y | Z`.\r\n\r\nAnd, in fact, this is how it&#39;s documented:\r\n\r\n&gt; Variable / Symbolic Binding Operator: `... as $identifier | ...`\r\n\r\nThis leads to surprises, especially since it binds a lot more tightly than expected. And it looks like whomever authored the examples in the *Scoping* section fell into the trap.\r\n\r\n---\r\n\r\n1. It might produce it multiple times e.g. `.[] as $x`.\r\n",
                "title": "Jq strange behavior of pipe involving variable on the left hand side"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1645685382,
                "creation_date": 1645685382,
                "answer_id": 71248119,
                "question_id": 71246837,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Indeed, there seems to be a mistake in the manual. In section [Scoping](https://stedolan.github.io/jq/manual/#Scoping) it is contrasting the (faulty) examples\r\n~~~\r\n... | .*3 as $times_three | [. + $times_three] | ...         # faulty!\r\n~~~\r\nand\r\n~~~\r\n... | (.*3 as $times_three | [. + $times_three]) | ...       # faulty!\r\n~~~\r\n\r\nWhile the overall statement stays valid, both examples are missing **additional** parentheses around `.*3`. Thus, it should actually read\r\n~~~\r\n... | (.*3) as $times_three | [. + $times_three] | ...\r\n~~~\r\nand\r\n~~~\r\n... | ((.*3) as $times_three | [. + $times_three]) | ...\r\n~~~\r\nrespectively.\r\n\r\n---\r\nFrom the manual under section [Variable / Symbolic Binding Operator](https://stedolan.github.io/jq/manual/#Variable%2FSymbolicBindingOperator%3A...as%24identifier%7C...):\r\n\r\n&gt; The expression `exp as $x | ...` means: for each value of expression `exp`, run the rest of the pipeline with the entire original input, and with `$x` set to that value. Thus `as` functions as something of a foreach loop.\r\n\r\nThis means that a variable assignment takes the **one** expression left of `as` and assigns its evaluation to the defined variable right of `as` (and this happens as many times as `exp` produces an output). But, as everything in jq is a filter, the assignment itself also is, and as such it needs to have an output itself. If you look closely, the full title of that section\r\n\r\n&gt; Variable / Symbolic Binding Operator: `... as $identifier | ...`\r\n\r\nalso features a pipe symbol next to it, which indicates that it belongs to the assignment&#39;s structure. Try just running `. as $x`. You will get an error because the `| ...` part is missing. Thus, to simply keep the input context as is (apart from maybe duplicating it as many times as the expression left of `as` produced an output), a complete assignment would rather look like `… as $x | .`, or, if the input context is what you wanted to capture in the variable, `. as $x | .`\r\n\r\nThat said, let&#39;s clarify what happens with your examples by putting explicit parentheses around the assignments:\r\n~~~\r\n3 | . * 3 as $times_three | .\r\n3 | . * (3 as $times_three | .)\r\n3 | . * .                           # with $times_three set to 3\r\n3 * 3                               # with $times_three set to 3\r\n9                                   # with $times_three set to 3\r\n~~~\r\n~~~\r\n3 | . * 4 as $times_four | .\r\n3 | . * (4 as $times_four | .)\r\n3 | . * .                           # with $times_four set to 4\r\n3 * 3                               # with $times_four set to 4\r\n9                                   # with $times_four set to 4\r\n~~~\r\n~~~\r\n3 | (. * 3) as $times_three | .\r\n3 | ((. * 3) as $times_three | .)\r\n3 | ((3 * 3) as $times_three | .)\r\n3 | (9 as $times_three | .)\r\n3 | .                               # with $times_three set to 9\r\n3                                   # with $times_three set to 9\r\n~~~\r\n~~~\r\n3 | (. * 4) as $times_four | .\r\n3 | ((. * 4) as $times_four | .)\r\n3 | ((3 * 4) as $times_four | .)\r\n3 | (12 as $times_four | .)\r\n3 | .                               # with $times_four set to 12\r\n3                                   # with $times_four set to 12\r\n~~~",
                "title": "Jq strange behavior of pipe involving variable on the left hand side"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1645715190,
        "creation_date": 1645674095,
        "last_edit_date": 1645674821,
        "question_id": 71246837,
        "body_markdown": "I came across a weird behavior of `jq` involving a variable on the left hand side of a pipe.\r\n\r\nFor your information, this question was inspired by the `jq` manual: under `Scoping` (https://stedolan.github.io/jq/manual/#Advancedfeatures) where it mentions an example filter `... | .*3 as $times_three | [. + $times_three] | ...`. I believe the correct version is `... | (.*3) as $times_three | [. + $times_three] | ...`.\r\n\r\nFirst (https://jqplay.org/s/ffMPsqmsmt)\r\n```\r\nfilter:\r\n. * 3 as $times_three | .\r\ninput:\r\n3\r\noutput:\r\n9\r\n```\r\n\r\nSecond (https://jqplay.org/s/yOFcjRAMLL)\r\n```\r\nfilter:\r\n. * 4 as $times_four | .\r\ninput:\r\n3\r\noutput:\r\n9\r\n```\r\nWhat is happening here?\r\n\r\nBut (https://jqplay.org/s/IKrTNZjKI8)\r\n```\r\nfilter:\r\n(. * 3) as $times_three | .\r\ninput:\r\n3\r\noutput:\r\n3\r\n```\r\nAnd (https://jqplay.org/s/8zoq2-HN1G)\r\n```\r\nfilter:\r\n(. * 4) as $times_four | .\r\ninput:\r\n3\r\noutput:\r\n3\r\n```\r\nSo if parenthesis `(.*3)` or `(.*4)` is used when the variable is declared then filter behaves predictably.\r\n\r\nBut if parenthesis is not used `.*3` or `.*4` then strangely the output is 9 for both.\r\n\r\nCan you explain?",
        "link": "https://stackoverflow.com/questions/71246837/jq-strange-behavior-of-pipe-involving-variable-on-the-left-hand-side",
        "title": "Jq strange behavior of pipe involving variable on the left hand side"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1645694914,
                "last_edit_date": 1645694914,
                "creation_date": 1645691478,
                "answer_id": 71249114,
                "question_id": 71248425,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using all parameters of `JOIN`, you&#39;d do\r\n~~~sh\r\njq --slurpfile fst first.json --slurpfile snd second.json -nc &#39;\r\n  JOIN(INDEX($snd[]; .dvc_ssr); $fst[]; .dvc_ssr; add)\r\n&#39;\r\n~~~\r\n~~~json\r\n{&quot;_time&quot;:&quot;2022-02-20T23&quot;,&quot;csp_name&quot;:&quot;1&quot;,&quot;tool_bf_id&quot;:&quot;1234&quot;,&quot;dvc_ssr&quot;:&quot;aa-1111&quot;,&quot;host&quot;:&quot;hostId1&quot;}\r\n{&quot;_time&quot;:&quot;2022-02-20T23&quot;,&quot;csp_name&quot;:&quot;2&quot;,&quot;tool_bf_id&quot;:&quot;4567&quot;,&quot;dvc_ssr&quot;:&quot;aa-2222&quot;,&quot;host&quot;:&quot;hostId2&quot;}\r\n{&quot;_time&quot;:&quot;2022-02-20T23&quot;,&quot;csp_name&quot;:&quot;3&quot;,&quot;tool_bf_id&quot;:&quot;1357&quot;,&quot;dvc_ssr&quot;:&quot;null&quot;}\r\n{&quot;_time&quot;:&quot;2022-02-20T23&quot;,&quot;csp_name&quot;:&quot;4&quot;,&quot;tool_bf_id&quot;:&quot;2468&quot;,&quot;dvc_ssr&quot;:&quot;aa-1111&quot;,&quot;host&quot;:&quot;hostId1&quot;}\r\n{&quot;_time&quot;:&quot;2022-02-20T23&quot;,&quot;csp_name&quot;:&quot;5&quot;,&quot;tool_bf_id&quot;:&quot;1246&quot;,&quot;dvc_ssr&quot;:&quot;null&quot;}\r\n~~~\r\n\r\nDepending on your application context, you could probably cut off some of them. For instance, JOIN with just two parameters accepts the stream as input and lets you process the joining outside of `JOIN`.\r\n\r\nSame example (notice `-s` instead of `-n`, and `JOIN(…)[]` instead of `JOIN(…)`):\r\n~~~sh\r\njq --slurpfile snd second.json -sc &#39;\r\n  JOIN(INDEX($snd[]; .dvc_ssr); .dvc_ssr)[] | add\r\n&#39; first.json\r\n~~~\r\n",
                "title": "Using JQ - Join 2 json files which do not have the same structure but with a common key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1645694914,
        "creation_date": 1645687351,
        "question_id": 71248425,
        "body_markdown": "I have 2 files that I would like to join based a common key.\r\n\r\nThe first file is an array with:\r\n\r\n```    \r\n{&quot;_time&quot;: &quot;2022-02-20T23&quot;,&quot;csp_name&quot;: &quot;1&quot;,&quot;tool_bf_id&quot;: &quot;1234&quot;, &quot;dvc_ssr&quot;: &quot;aa-1111&quot;}\r\n{&quot;_time&quot;: &quot;2022-02-20T23&quot;,&quot;csp_name&quot;: &quot;2&quot;,&quot;tool_bf_id&quot;: &quot;4567&quot;, &quot;dvc_ssr&quot;: &quot;aa-2222&quot;}\r\n{&quot;_time&quot;: &quot;2022-02-20T23&quot;,&quot;csp_name&quot;: &quot;3&quot;,&quot;tool_bf_id&quot;: &quot;1357&quot;, &quot;dvc_ssr&quot;: &quot;null&quot;}\r\n{&quot;_time&quot;: &quot;2022-02-20T23&quot;,&quot;csp_name&quot;: &quot;4&quot;,&quot;tool_bf_id&quot;: &quot;2468&quot;, &quot;dvc_ssr&quot;: &quot;aa-1111&quot;}\r\n{&quot;_time&quot;: &quot;2022-02-20T23&quot;,&quot;csp_name&quot;: &quot;5&quot;,&quot;tool_bf_id&quot;: &quot;1246&quot;, &quot;dvc_ssr&quot;: &quot;null&quot;}\r\n```\r\n\r\nThe second file is also an array, a complete list of all the different &quot;dvc_ssr&quot; with:\r\n```\r\n{&quot;host&quot;: &quot;hostId1&quot;,&quot;dvc_ssr&quot;: &quot;aa-1111&quot;}\r\n{&quot;host&quot;: &quot;hostId2&quot;,&quot;dvc_ssr&quot;: &quot;aa-2222&quot;}\r\n```    \r\n I am trying to join both files by adding information from the second file into the first one using the dvc_ssr key value.\r\n\r\nI am expecting something like this:\r\n```\r\n{&quot;_time&quot;: &quot;2022-02-20T23&quot;,&quot;csp_name&quot;: &quot;1&quot;,&quot;tool_bf_id&quot;: &quot;1234&quot;, &quot;dvc_ssr&quot;: &quot;aa-1111&quot;,&quot;host&quot;: &quot;hostId1&quot;}\r\n{&quot;_time&quot;: &quot;2022-02-20T23&quot;,&quot;csp_name&quot;: &quot;2&quot;,,&quot;tool_bf_id&quot;: &quot;4567&quot;, &quot;dvc_ssr&quot;: &quot;aa-2222&quot;,&quot;host&quot;: &quot;hostId2&quot;}\r\n{&quot;_time&quot;: &quot;2022-02-20T23&quot;,&quot;csp_name&quot;: &quot;3&quot;,&quot;tool_bf_id&quot;: &quot;1357&quot;, &quot;dvc_ssr&quot;: &quot;null&quot;}\r\n{&quot;_time&quot;: &quot;2022-02-20T23&quot;,&quot;csp_name&quot;: &quot;4&quot;,&quot;tool_bf_id&quot;: &quot;2468&quot;, &quot;dvc_ssr&quot;: &quot;aa-1111&quot;,&quot;host&quot;: &quot;hostId1&quot;}\r\n{&quot;_time&quot;: &quot;2022-02-20T23&quot;,&quot;csp_name&quot;: &quot;5&quot;,&quot;tool_bf_id&quot;: &quot;1246&quot;, &quot;dvc_ssr&quot;: &quot;null&quot;}\r\n\r\n```\r\nAfter some research I found ideas using flatten/group_by/add ..\r\n\r\n`flatten | group_by(.dvc_ssr) | map(reduce .[] as $x ({}; . * $x))`\r\n\r\nor\r\n\r\n`[.[1] + . [0] | group_by(.dvc_ssr) []  | add] `\r\n\r\nBut this is not working out.\r\nThe issue is by grouping them, I am grouping the &quot;null&quot; and also those which have the same &quot;dvc_ssr&quot;. At then end I am losing some records.\r\n\r\nI was able to join the files with jq -s (--slurp) and try to group array\r\n\r\n`jq -s &#39;[.[0] + .[1] | group_by(.dvc_ssr) []]&#39; file1.json file2.json`\r\n\r\nand I can remove then the not used record from the second file, by using:\r\n` |map(select(if ._time!=null then . else empty end))| .[]`\r\n\r\nThe idea is really to do a JOIN like in SQL where &quot;dvc_ssr&quot; are identical.\r\n\r\n   \r\n",
        "link": "https://stackoverflow.com/questions/71248425/using-jq-join-2-json-files-which-do-not-have-the-same-structure-but-with-a-com",
        "title": "Using JQ - Join 2 json files which do not have the same structure but with a common key"
    },
    {
        "tags": [
            "bash",
            "jq",
            "yq"
        ],
        "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": 1645695398,
                "post_id": 71248669,
                "comment_id": 125942115,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1645690477,
                "last_edit_date": 1645690477,
                "creation_date": 1645689993,
                "answer_id": 71248858,
                "question_id": 71248669,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could switch to kislyuk&#39;s [yq](https://github.com/kislyuk/yq) which uses native jq under the hood. Then, you would just need [`to_entries`](https://stedolan.github.io/jq/manual/#to_entries%2Cfrom_entries%2Cwith_entries) to access key and value, [string interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-%5C%28foo%29) in combination with the `-r` flag to produce the output, and [`@sh`](https://stedolan.github.io/jq/manual/#Formatstringsandescaping) to escape for shell compliance:\r\n~~~sh\r\nyq -r &#39;to_entries[] | &quot;export \\(.key)=\\(.value | @sh)&quot;&#39;\r\n~~~\r\n~~~\r\nexport FOO=&#39;somefoo&#39;\r\nexport BAR=&#39;somebar&#39;\r\n~~~\r\n",
                "title": "How to use `yq` to select key-value pairs and format them into &quot;$key=$value&quot; style outputs?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1661072381,
                "last_edit_date": 1661072381,
                "creation_date": 1661071652,
                "answer_id": 73432859,
                "question_id": 71248669,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `key` operator and string concatenation:\r\n\r\n```bash\r\n$ echo &quot;$INPUT&quot; | yq $&#39;.[] | &quot;export &quot; + key + &quot;=\\&#39;&quot; + . + &quot;\\&#39;&quot;&#39;\r\nexport FOO=&#39;somefoo&#39;\r\nexport BAR=&#39;somebar&#39;\r\n```\r\n\r\nTested with `yq` 4.27.2",
                "title": "How to use `yq` to select key-value pairs and format them into &quot;$key=$value&quot; style outputs?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1676892934,
                "last_edit_date": 1676892934,
                "creation_date": 1674041468,
                "answer_id": 75158584,
                "question_id": 71248669,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `@sh` operator has been added in [`yq v4.31.1`][1] (with [my humble contribution][2]). Now you can do it pretty much the same way as in `jq`:\r\n```sh\r\nyq &#39;.[] | &quot;export &quot; + key + &quot;=&quot; + @sh&#39;\r\n```\r\nThe quoting algorithm is a bit different from `jq` as it starts to quote only at characters that need quoting, so the literal output will likely differ, but will be later parsed equally.\r\n```yaml\r\n# input\r\nFOO: somefoo\r\nBAR: somebar and some\r\n```\r\n```sh\r\n# result\r\nexport FOO=somefoo\r\nexport BAR=somebar&#39; and some&#39;\r\n```\r\n---\r\nWith **older `yq` versions** you can still implement a primitive but safe quoting algorithm using other `yq` functions (the quoting is a little lovely nightmare, though):\r\n```bash\r\n# POSIX shell quoting starting &quot;\r\nyq &quot;.[] | \\&quot;export \\&quot; + key + \\&quot;=&#39;\\&quot; + sub(\\&quot;&#39;\\&quot;, \\&quot;&#39;\\&#39;&#39;\\&quot;) + \\&quot;&#39;\\&quot;&quot;\r\n# POSIX shell quoting starting &#39;\r\nyq &#39;.[] | &quot;export &quot; + key + &quot;=&#39;\\&#39;&#39;&quot; + sub(&quot;&#39;\\&#39;&#39;&quot;, &quot;&#39;\\&#39;\\\\\\&#39;\\&#39;&#39;&quot;) + &quot;&#39;\\&#39;&#39;&quot;&#39;\r\n# BASH &quot;dollar&quot; quoting\r\nyq $&#39;.[] | &quot;export &quot; + key + &quot;=\\&#39;&quot; + sub(&quot;\\&#39;&quot;, &quot;\\&#39;\\\\\\&#39;\\&#39;&quot;) + &quot;\\&#39;&quot;&#39;\r\n```\r\nActually this is exactly [what `jq` does][3] with its `@sh`. In all cases this ends up as:\r\n```sh\r\nexport FOO=&#39;somefoo&#39;\r\nexport BAR=&#39;somebar and some&#39;\r\n```\r\n\r\n  [1]: https://github.com/mikefarah/yq/releases/tag/v4.31.1\r\n  [2]: https://github.com/mikefarah/yq/issues/1526\r\n  [3]: https://github.com/stedolan/jq/blob/jq-1.6/src/builtin.c#L617-L619",
                "title": "How to use `yq` to select key-value pairs and format them into &quot;$key=$value&quot; style outputs?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1676892934,
        "creation_date": 1645688904,
        "question_id": 71248669,
        "body_markdown": "Let say I have YAML file that looks like this:\r\n\r\n    FOO: somefoo\r\n    BAR: somebar\r\n\r\nI would like to convert this (using `yq`) into the following so that I can source the contents into environment variables:\r\n\r\n    export BAR=&#39;somebar&#39;\r\n    export FOO=&#39;somefoo&#39;\r\n\r\nI can do it it with `jq` by converting the input to JSON first, but I can&#39;t seem to figure out how to do it with `yq` only. (I am using `yq` 4.x, &lt;4.18). \r\n\r\nSo, concretely, how could I do the following using just `yq`?\r\n\r\n    INPUT=&quot;FOO: somefoo\r\n    BAR: somebar&quot;\r\n    \r\n    echo &quot;$INPUT&quot; | yq e &#39;to_json&#39; - | jq -r &#39;keys[] as $k | &quot;export \\($k)=&#39;\\&#39;&#39;\\(.[$k])&#39;\\&#39;&#39;&quot;&#39;",
        "link": "https://stackoverflow.com/questions/71248669/how-to-use-yq-to-select-key-value-pairs-and-format-them-into-key-value-sty",
        "title": "How to use `yq` to select key-value pairs and format them into &quot;$key=$value&quot; style outputs?"
    },
    {
        "tags": [
            "bash",
            "loops",
            "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": 0,
                "creation_date": 1645712715,
                "post_id": 71253174,
                "comment_id": 125948561,
                "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": 1645717370,
                "post_id": 71253174,
                "comment_id": 125950601,
                "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": 1645728652,
                "post_id": 71253174,
                "comment_id": 125954831,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24365987,
                    "reputation": 3,
                    "user_id": 18299727,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b2d61cf4c14a90fa9b889adbb782a215?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "vikree",
                    "link": "https://stackoverflow.com/users/18299727/vikree"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1645773488,
                "post_id": 71253174,
                "comment_id": 125964435,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1645789908,
                "creation_date": 1645789908,
                "answer_id": 71265460,
                "question_id": 71253174,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Imagine that you have a file `cnames.txt` where each line contains one CNAME domain followed by its value:\r\n\r\n```\r\nfoo.example.com google.com\r\nbar.example.com stackoverflow.com\r\n```\r\n\r\nLet us create that file:\r\n\r\n&lt;!-- language: bash --&gt;\r\n\r\n```\r\ncat &lt;&lt;EOF &gt; cnames.txt\r\nfoo.example.com google.com\r\nbar.example.com stackoverflow.com\r\nEOF\r\n```\r\n\r\nYou can &quot;nest&quot; one `jq` into the other by using `--slurpfile` described in the [jq Manual][1]. The following command should do what you want:\r\n\r\n&lt;!-- language: bash --&gt;\r\n\r\n```\r\ncat cnames.txt | xargs -n2 jq -n &#39;{\r\n    &quot;name&quot;: $ARGS.positional[0],\r\n    &quot;type&quot;: &quot;CNAME&quot;,\r\n    &quot;value&quot;: $ARGS.positional[1],\r\n    &quot;ttl&quot;: 3600\r\n}&#39; --args | jq -n --slurpfile records /dev/stdin &#39;\r\n  {\r\n    &quot;extra_vars&quot;: {\r\n      &quot;oper_tasks&quot;: [ &quot;records&quot; ],\r\n      &quot;zone_info&quot;: [\r\n        {\r\n          &quot;zone&quot;: &quot;example.com&quot;,\r\n          &quot;records&quot;: $records\r\n        }\r\n      ]\r\n    }\r\n  }\r\n&#39;\r\n```\r\n\r\nwhich returns:\r\n\r\n&lt;!-- language: json --&gt;\r\n\r\n```\r\n{\r\n  &quot;extra_vars&quot;: {\r\n    &quot;oper_tasks&quot;: [\r\n      &quot;records&quot;\r\n    ],\r\n    &quot;zone_info&quot;: [\r\n      {\r\n        &quot;zone&quot;: &quot;example.com&quot;,\r\n        &quot;records&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;foo.example.com&quot;,\r\n            &quot;type&quot;: &quot;CNAME&quot;,\r\n            &quot;value&quot;: &quot;google.com&quot;,\r\n            &quot;ttl&quot;: 3600\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;bar.example.com&quot;,\r\n            &quot;type&quot;: &quot;CNAME&quot;,\r\n            &quot;value&quot;: &quot;stackoverflow.com&quot;,\r\n            &quot;ttl&quot;: 3600\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "Need help to create objects inside array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1645789908,
        "creation_date": 1645711302,
        "last_edit_date": 1645759459,
        "question_id": 71253174,
        "body_markdown": "\r\njq query as like this ,\r\n\r\n\r\n\r\n```sh\r\njq -n  --arg cname &quot;$1&quot; --arg dns &quot;$2&quot; &#39;\r\n  {\r\n    &quot;extra_vars&quot;: {\r\n      &quot;oper_tasks&quot;: [ &quot;records&quot; ],\r\n      &quot;zone_info&quot;: [\r\n        {\r\n          &quot;zone&quot;: &quot;exmple.com&quot;,\r\n          &quot;records&quot;: [\r\n            {\r\n              &quot;name&quot;: $cname,\r\n              &quot;type&quot;: &quot;CNAME&quot;,\r\n              &quot;value&quot;: $dns,\r\n              &quot;ttl&quot;: 3600\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  }\r\n&#39;\r\n```\r\n\r\nThe above jq cn produce something like this , cname and dns can be filled with arguments when we execute as script.\r\n\r\n```json\r\n&quot;extra_vars&quot;: {\r\n    &quot;oper_tasks&quot;: [\r\n      &quot;records&quot;\r\n    ],\r\n    &quot;zone_info&quot;: [\r\n      {\r\n        &quot;zone&quot;: &quot;exmple.com&quot;,\r\n        &quot;records&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;&quot;,\r\n            &quot;type&quot;: &quot;CNAME&quot;,\r\n            &quot;value&quot;: &quot;&quot;,\r\n            &quot;ttl&quot;: 3600\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n  \r\n\r\nhow we can create more than one objects like below from an input file.  something like how we do in for loop.\r\n\r\n    &quot;extra_vars&quot;: {\r\n    &quot;oper_tasks&quot;: [\r\n      &quot;records&quot;\r\n    ],\r\n    &quot;zone_info&quot;: [\r\n      {\r\n        &quot;zone&quot;: &quot;exmple.com&quot;,\r\n        &quot;records&quot;: [\r\n          {\r\n            &quot;name&quot;: &lt;cname1 from input file&gt;,\r\n            &quot;type&quot;: &quot;CNAME&quot;,\r\n            &quot;value&quot;: &quot;&quot;,\r\n            &quot;ttl&quot;: 3600\r\n          },\r\n          {\r\n            &quot;name&quot;: &lt;cname2 from input file&gt;,\r\n            &quot;type&quot;: &quot;CNAME&quot;,\r\n            &quot;value&quot;: &quot;&quot;,\r\n            &quot;ttl&quot;: 3600\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71253174/need-help-to-create-objects-inside-array",
        "title": "Need help to create objects inside array"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "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": 1645718789,
                "post_id": 71254853,
                "comment_id": 125951262,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1645719619,
                "last_edit_date": 1645719619,
                "creation_date": 1645719029,
                "answer_id": 71254981,
                "question_id": 71254853,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can check the time within jq, but it handles ISO 8601 dates only without milliseconds. Therefore you have to cut them off for comparison. `now` gives you the current time.\r\n\r\n~~~sh\r\njq &#39;.[] | select(.updated_at | &quot;\\(.[:-5])Z&quot; | fromdate + 900 &gt; now).id&#39;\r\n~~~\r\n\r\nIf you want to have a parameter for minutes, try:\r\n~~~sh\r\njq --argjson min 15 &#39;\r\n  .[] | select(.updated_at | &quot;\\(.[:-5])Z&quot; | fromdate + 60 * $min &gt; now).id\r\n&#39;\r\n~~~\r\n",
                "title": "Get the values which are created in last few minutes from a Json file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1653736257,
                "last_edit_date": 1653736257,
                "creation_date": 1645724604,
                "answer_id": 71256109,
                "question_id": 71254853,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    TIM=`date -u +&quot;%Y-%m-%dT%H:%M:%S.000Z&quot; -d &#39;-15 minutes&#39;`\r\n    jq -r --arg TIMEE &quot;$TIM&quot; &#39;.[]|select((.ref|contains(&quot;dev&quot;)) and (.updated_at &gt;= $TIMEE))|.id&#39; MyJsonFile.json\r\n\r\njust removing the quote around &quot;$TIMEE&quot; will work. It might be taken as a string if you quote it.\r\n\r\n\r\n",
                "title": "Get the values which are created in last few minutes from a Json file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1653736257,
        "creation_date": 1645718487,
        "last_edit_date": 1645729471,
        "question_id": 71254853,
        "body_markdown": "My Json file has the data like below:\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 47,\r\n    &quot;iid&quot;: 12,\r\n    &quot;project_id&quot;: 1,\r\n    &quot;status&quot;: &quot;pending&quot;,\r\n    &quot;source&quot;: &quot;push&quot;,\r\n    &quot;ref&quot;: &quot;new-pipeline&quot;,\r\n    &quot;sha&quot;: &quot;ab23456789d&quot;,\r\n    &quot;web_url&quot;: &quot;https://example.com/project/pipelines/47&quot;,\r\n    &quot;created_at&quot;: &quot;2022-02-24T11:28:34.085Z&quot;,\r\n    &quot;updated_at&quot;: &quot;2016-08-24T15:32:35.169Z&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 48,\r\n    &quot;iid&quot;: 13,\r\n    &quot;project_id&quot;: 1,\r\n    &quot;status&quot;: &quot;pending&quot;,\r\n    &quot;source&quot;: &quot;web&quot;,\r\n    &quot;ref&quot;: &quot;new-pipeline&quot;,\r\n    &quot;sha&quot;: &quot;ab23456789d&quot;,\r\n    &quot;web_url&quot;: &quot;https://example.com/project/pipelines/48&quot;,\r\n    &quot;created_at&quot;: &quot;2022-02-23T11:28:34.085Z&quot;,\r\n    &quot;updated_at&quot;: &quot;2016-08-23T15:32:35.169Z&quot;\r\n  }\r\n]\r\n```\r\nI am trying to fetch the IDs which are created in last 15 minutes. But I couldnt get it. \r\n\r\nI have tried the below way,\r\n\r\n    TIM=`date -u +&quot;%Y-%m-%dT%H:%M:%S.000Z&quot; -d &#39;-15 minutes&#39;`\r\n    jq -r --arg TIMEE &quot;$TIM&quot; &#39;.[]|select((.ref|contains(&quot;dev&quot;)) and (.updated_at &gt;= &quot;$TIMEE&quot;))|.id&#39; MyJsonFile.json\r\n\r\nBut this is not working as expected. I dont see any IDs. But when made the condition to `(.updated_at &gt;= &quot;$TIMEE&quot;)`. I can see all IDs which are created even in last one minute. \r\n\r\nNot sure if I am trying in the right way. Any help is much appreciated.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71254853/get-the-values-which-are-created-in-last-few-minutes-from-a-json-file",
        "title": "Get the values which are created in last few minutes from a Json file"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1645739877,
                "creation_date": 1645739877,
                "answer_id": 71258739,
                "question_id": 71258591,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Without further details wrt conditions, array indices etc, I guess this is what you want:\r\n~~~sh\r\njq -r &#39;\r\n  .CVE_Items[] | select(.cve.CVE_data_meta.ID == &quot;CVE-2020-0597&quot;)\r\n  | .cve.problemtype.problemtype_data[0].description[0].value, \r\n    (.impact.baseMetricV3.cvssV3 | .vectorString, .baseScore)\r\n&#39;\r\n~~~\r\n~~~\r\nCWE-125\r\nCVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H\r\n7.5\r\n~~~\r\n[Demo](https://jqplay.org/s/RA3-u7z1QB)",
                "title": "jq: select only necessary fields if the field n is x"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1645739877,
        "creation_date": 1645738836,
        "question_id": 71258591,
        "body_markdown": "I have the following JSON scheme:\r\n```\r\n{\r\n  &quot;CVE_data_type&quot; : &quot;CVE&quot;,\r\n  &quot;CVE_data_format&quot; : &quot;MITRE&quot;,\r\n  &quot;CVE_data_version&quot; : &quot;4.0&quot;,\r\n  &quot;CVE_data_numberOfCVEs&quot; : &quot;19162&quot;,\r\n  &quot;CVE_data_timestamp&quot; : &quot;2022-02-24T08:00Z&quot;,\r\n  &quot;CVE_Items&quot; : [ {\r\n    &quot;cve&quot; : {\r\n      &quot;data_type&quot; : &quot;CVE&quot;,\r\n      &quot;data_format&quot; : &quot;MITRE&quot;,\r\n      &quot;data_version&quot; : &quot;4.0&quot;,\r\n      &quot;CVE_data_meta&quot; : {\r\n        &quot;ID&quot; : &quot;CVE-2020-0597&quot;,\r\n        &quot;ASSIGNER&quot; : &quot;secure@intel.com&quot;\r\n      },\r\n      &quot;problemtype&quot; : {\r\n        &quot;problemtype_data&quot; : [ {\r\n          &quot;description&quot; : [ {\r\n            &quot;lang&quot; : &quot;en&quot;,\r\n            &quot;value&quot; : &quot;CWE-125&quot;\r\n          } ]\r\n        } ]\r\n      },\r\n      &quot;references&quot; : {\r\n        &quot;reference_data&quot; : [ {\r\n          &quot;url&quot; : &quot;https://www.intel.com/content/www/us/en/security-center/advisory/intel-sa-00295.html&quot;,\r\n          &quot;name&quot; : &quot;https://www.intel.com/content/www/us/en/security-center/advisory/intel-sa-00295.html&quot;,\r\n          &quot;refsource&quot; : &quot;MISC&quot;,\r\n          &quot;tags&quot; : [ &quot;Vendor Advisory&quot; ]\r\n        }, {\r\n          &quot;url&quot; : &quot;https://www.synology.com/security/advisory/Synology_SA_20_15&quot;,\r\n          &quot;name&quot; : &quot;https://www.synology.com/security/advisory/Synology_SA_20_15&quot;,\r\n          &quot;refsource&quot; : &quot;CONFIRM&quot;,\r\n          &quot;tags&quot; : [ &quot;Third Party Advisory&quot; ]\r\n        }, {\r\n          &quot;url&quot; : &quot;https://support.lenovo.com/de/en/product_security/len-30041&quot;,\r\n          &quot;name&quot; : &quot;https://support.lenovo.com/de/en/product_security/len-30041&quot;,\r\n          &quot;refsource&quot; : &quot;MISC&quot;,\r\n          &quot;tags&quot; : [ ]\r\n        }, {\r\n          &quot;url&quot; : &quot;https://security.netapp.com/advisory/ntap-20200611-0007/&quot;,\r\n          &quot;name&quot; : &quot;https://security.netapp.com/advisory/ntap-20200611-0007/&quot;,\r\n          &quot;refsource&quot; : &quot;CONFIRM&quot;,\r\n          &quot;tags&quot; : [ ]\r\n        }, {\r\n          &quot;url&quot; : &quot;https://www.kb.cert.org/vuls/id/257161&quot;,\r\n          &quot;name&quot; : &quot;VU#257161&quot;,\r\n          &quot;refsource&quot; : &quot;CERT-VN&quot;,\r\n          &quot;tags&quot; : [ ]\r\n        } ]\r\n      },\r\n      &quot;description&quot; : {\r\n        &quot;description_data&quot; : [ {\r\n          &quot;lang&quot; : &quot;en&quot;,\r\n          &quot;value&quot; : &quot;Out-of-bounds read in IPv6 subsystem in Intel(R) AMT and Intel(R) ISM versions before 14.0.33 may allow an unauthenticated user to potentially enable denial of service via network access.&quot;\r\n        } ]\r\n      }\r\n    },\r\n    &quot;configurations&quot; : {\r\n      &quot;CVE_data_version&quot; : &quot;4.0&quot;,\r\n      &quot;nodes&quot; : [ {\r\n        &quot;operator&quot; : &quot;OR&quot;,\r\n        &quot;children&quot; : [ ],\r\n        &quot;cpe_match&quot; : [ {\r\n          &quot;vulnerable&quot; : true,\r\n          &quot;cpe23Uri&quot; : &quot;cpe:2.3:a:intel:active_management_technology:*:*:*:*:*:*:*:*&quot;,\r\n          &quot;versionStartIncluding&quot; : &quot;11.0&quot;,\r\n          &quot;versionEndIncluding&quot; : &quot;11.8.76&quot;,\r\n          &quot;cpe_name&quot; : [ ]\r\n        }, {\r\n          &quot;vulnerable&quot; : true,\r\n          &quot;cpe23Uri&quot; : &quot;cpe:2.3:a:intel:active_management_technology:*:*:*:*:*:*:*:*&quot;,\r\n          &quot;versionStartIncluding&quot; : &quot;11.10&quot;,\r\n          &quot;versionEndIncluding&quot; : &quot;11.11.76&quot;,\r\n          &quot;cpe_name&quot; : [ ]\r\n        }, {\r\n          &quot;vulnerable&quot; : true,\r\n          &quot;cpe23Uri&quot; : &quot;cpe:2.3:a:intel:active_management_technology:*:*:*:*:*:*:*:*&quot;,\r\n          &quot;versionStartIncluding&quot; : &quot;11.20&quot;,\r\n          &quot;versionEndIncluding&quot; : &quot;11.22.76&quot;,\r\n          &quot;cpe_name&quot; : [ ]\r\n        }, {\r\n          &quot;vulnerable&quot; : true,\r\n          &quot;cpe23Uri&quot; : &quot;cpe:2.3:a:intel:active_management_technology:*:*:*:*:*:*:*:*&quot;,\r\n          &quot;versionStartIncluding&quot; : &quot;12.0&quot;,\r\n          &quot;versionEndIncluding&quot; : &quot;12.0.63&quot;,\r\n          &quot;cpe_name&quot; : [ ]\r\n        }, {\r\n          &quot;vulnerable&quot; : true,\r\n          &quot;cpe23Uri&quot; : &quot;cpe:2.3:a:intel:active_management_technology:*:*:*:*:*:*:*:*&quot;,\r\n          &quot;versionStartIncluding&quot; : &quot;13.0&quot;,\r\n          &quot;versionEndIncluding&quot; : &quot;13.0.31&quot;,\r\n          &quot;cpe_name&quot; : [ ]\r\n        }, {\r\n          &quot;vulnerable&quot; : true,\r\n          &quot;cpe23Uri&quot; : &quot;cpe:2.3:a:intel:active_management_technology:*:*:*:*:*:*:*:*&quot;,\r\n          &quot;versionStartIncluding&quot; : &quot;14.0&quot;,\r\n          &quot;versionEndIncluding&quot; : &quot;14.0.32&quot;,\r\n          &quot;cpe_name&quot; : [ ]\r\n        }, {\r\n          &quot;vulnerable&quot; : true,\r\n          &quot;cpe23Uri&quot; : &quot;cpe:2.3:a:intel:software_manager:*:*:*:*:*:*:*:*&quot;,\r\n          &quot;versionStartIncluding&quot; : &quot;11.0&quot;,\r\n          &quot;versionEndIncluding&quot; : &quot;11.8.76&quot;,\r\n          &quot;cpe_name&quot; : [ ]\r\n        }, {\r\n          &quot;vulnerable&quot; : true,\r\n          &quot;cpe23Uri&quot; : &quot;cpe:2.3:a:intel:software_manager:*:*:*:*:*:*:*:*&quot;,\r\n          &quot;versionStartIncluding&quot; : &quot;11.10&quot;,\r\n          &quot;versionEndIncluding&quot; : &quot;11.11.76&quot;,\r\n          &quot;cpe_name&quot; : [ ]\r\n        }, {\r\n          &quot;vulnerable&quot; : true,\r\n          &quot;cpe23Uri&quot; : &quot;cpe:2.3:a:intel:software_manager:*:*:*:*:*:*:*:*&quot;,\r\n          &quot;versionStartIncluding&quot; : &quot;11.20&quot;,\r\n          &quot;versionEndIncluding&quot; : &quot;11.22.76&quot;,\r\n          &quot;cpe_name&quot; : [ ]\r\n        }, {\r\n          &quot;vulnerable&quot; : true,\r\n          &quot;cpe23Uri&quot; : &quot;cpe:2.3:a:intel:software_manager:*:*:*:*:*:*:*:*&quot;,\r\n          &quot;versionStartIncluding&quot; : &quot;12.0&quot;,\r\n          &quot;versionEndIncluding&quot; : &quot;12.0.63&quot;,\r\n          &quot;cpe_name&quot; : [ ]\r\n        }, {\r\n          &quot;vulnerable&quot; : true,\r\n          &quot;cpe23Uri&quot; : &quot;cpe:2.3:a:intel:software_manager:*:*:*:*:*:*:*:*&quot;,\r\n          &quot;versionStartIncluding&quot; : &quot;13.0&quot;,\r\n          &quot;versionEndIncluding&quot; : &quot;13.0.31&quot;,\r\n          &quot;cpe_name&quot; : [ ]\r\n        }, {\r\n          &quot;vulnerable&quot; : true,\r\n          &quot;cpe23Uri&quot; : &quot;cpe:2.3:a:intel:software_manager:*:*:*:*:*:*:*:*&quot;,\r\n          &quot;versionStartIncluding&quot; : &quot;14.0&quot;,\r\n          &quot;versionEndIncluding&quot; : &quot;14.0.32&quot;,\r\n          &quot;cpe_name&quot; : [ ]\r\n        } ]\r\n      } ]\r\n    },\r\n    &quot;impact&quot; : {\r\n      &quot;baseMetricV3&quot; : {\r\n        &quot;cvssV3&quot; : {\r\n          &quot;version&quot; : &quot;3.1&quot;,\r\n          &quot;vectorString&quot; : &quot;CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H&quot;,\r\n          &quot;attackVector&quot; : &quot;NETWORK&quot;,\r\n          &quot;attackComplexity&quot; : &quot;LOW&quot;,\r\n          &quot;privilegesRequired&quot; : &quot;NONE&quot;,\r\n          &quot;userInteraction&quot; : &quot;NONE&quot;,\r\n          &quot;scope&quot; : &quot;UNCHANGED&quot;,\r\n          &quot;confidentialityImpact&quot; : &quot;NONE&quot;,\r\n          &quot;integrityImpact&quot; : &quot;NONE&quot;,\r\n          &quot;availabilityImpact&quot; : &quot;HIGH&quot;,\r\n          &quot;baseScore&quot; : 7.5,\r\n          &quot;baseSeverity&quot; : &quot;HIGH&quot;\r\n        },\r\n        &quot;exploitabilityScore&quot; : 3.9,\r\n        &quot;impactScore&quot; : 3.6\r\n      },\r\n      &quot;baseMetricV2&quot; : {\r\n        &quot;cvssV2&quot; : {\r\n          &quot;version&quot; : &quot;2.0&quot;,\r\n          &quot;vectorString&quot; : &quot;AV:N/AC:L/Au:N/C:N/I:N/A:P&quot;,\r\n          &quot;accessVector&quot; : &quot;NETWORK&quot;,\r\n          &quot;accessComplexity&quot; : &quot;LOW&quot;,\r\n          &quot;authentication&quot; : &quot;NONE&quot;,\r\n          &quot;confidentialityImpact&quot; : &quot;NONE&quot;,\r\n          &quot;integrityImpact&quot; : &quot;NONE&quot;,\r\n          &quot;availabilityImpact&quot; : &quot;PARTIAL&quot;,\r\n          &quot;baseScore&quot; : 5.0\r\n        },\r\n        &quot;severity&quot; : &quot;MEDIUM&quot;,\r\n        &quot;exploitabilityScore&quot; : 10.0,\r\n        &quot;impactScore&quot; : 2.9,\r\n        &quot;acInsufInfo&quot; : false,\r\n        &quot;obtainAllPrivilege&quot; : false,\r\n        &quot;obtainUserPrivilege&quot; : false,\r\n        &quot;obtainOtherPrivilege&quot; : false,\r\n        &quot;userInteractionRequired&quot; : false\r\n      }\r\n    },\r\n    &quot;publishedDate&quot; : &quot;2020-06-15T14:15Z&quot;,\r\n    &quot;lastModifiedDate&quot; : &quot;2021-03-18T13:15Z&quot;\r\n }, {\r\n    &quot;cve&quot; : {[...]\r\n```\r\n\r\nI need to get the following values from the schema if the ID value is CVE-2020-0597:\r\n\r\nCWE-125\r\n\r\nCVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H\r\n\r\n7.5\r\n\r\nI&#39;ve never worked with this, so it&#39;s a little hard for me to understand how to do it in this structure. Can somebody show me an example for my case?\r\n",
        "link": "https://stackoverflow.com/questions/71258591/jq-select-only-necessary-fields-if-the-field-n-is-x",
        "title": "jq: select only necessary fields if the field n is x"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1645740870,
                "post_id": 71258849,
                "comment_id": 125958629,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4145996,
                    "reputation": 364,
                    "user_id": 3399702,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/n2ObF.jpg?s=256",
                    "display_name": "Seth",
                    "link": "https://stackoverflow.com/users/3399702/seth"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1645741231,
                "post_id": 71258849,
                "comment_id": 125958706,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1645741295,
                "post_id": 71258849,
                "comment_id": 125958717,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4145996,
                    "reputation": 364,
                    "user_id": 3399702,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/n2ObF.jpg?s=256",
                    "display_name": "Seth",
                    "link": "https://stackoverflow.com/users/3399702/seth"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1645741356,
                "post_id": 71258849,
                "comment_id": 125958726,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4145996,
                    "reputation": 364,
                    "user_id": 3399702,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/n2ObF.jpg?s=256",
                    "display_name": "Seth",
                    "link": "https://stackoverflow.com/users/3399702/seth"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1645741521,
                "post_id": 71258849,
                "comment_id": 125958769,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1645743620,
                "last_edit_date": 1645743620,
                "creation_date": 1645741970,
                "answer_id": 71259021,
                "question_id": 71258849,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are using `join` to concatenate values of different types, which works fine under jq v1.6:\r\n~~~none\r\n.content[] | {seasonTitle, episodeNumber, name} | join(&quot;|&quot;)\r\n~~~\r\n~~~none\r\nTop Master|236|Last Chance / Season 12\r\nTop Master|235|&#201;pisode 8 / Season 12\r\nTop Master|234|&#201;pisode 7 / Season 12\r\n~~~\r\n[Demo](https://jqplay.org/s/rB2UoD2MRr)\r\n\r\nHowever, with jq v1.5 it doesn&#39;t, and you need to convert non-strings to strings using `tostring`. As you are using a shortcut to create an object for `join`, introducing this conversion sacrifices the conciseness of your solution. So either stick with it:\r\n~~~none\r\n.content[] | {seasonTitle, episodeNumber: (.episodeNumber | tostring), name} | join(&quot;|&quot;)\r\n~~~\r\nOr use an array instead, as you are going for the values only anyway:\r\n~~~none\r\n.content[] | [.seasonTitle, (.episodeNumber | tostring), .name] | join(&quot;|&quot;)\r\n~~~\r\n",
                "title": "jq cannot iterate over number with join"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1645743620,
        "creation_date": 1645740724,
        "last_edit_date": 1645741313,
        "question_id": 71258849,
        "body_markdown": "I would like to add some values from json file separated by pipe. It&#39;s working well so far until a value is a number and not a string.\r\n\r\nHere what I&#39;ve done so far: `jq -r &#39;.content[] | {seasonTitle, number, name} | join(&quot;|&quot;)&#39; file.json`\r\n\r\nI&#39;ve tried to convert number to string without any success `jq -r &#39;.content[] | {seasonTitle, &quot;episodeNumber|tostring&quot;, name} | join(&quot;|&quot;)&#39; file.json`\r\n\r\n\r\n**Actual Result:**\r\n```\r\nTop Master||Last Chance / Season 12\r\nTop Master||&#201;pisode 8 / Season 12\r\nTop Master||&#201;pisode 7 / Season 12\r\n```\r\n\r\n**Expected Result:**\r\n```\r\nTop Master|236|Last Chance / Season 12\r\nTop Master|235|&#201;pisode 8 / Season 12\r\nTop Master|234|&#201;pisode 7 / Season 12\r\n```\r\n\r\n**Here the file.json**\r\n\r\n```\r\n{\r\n  &quot;page&quot;: 0,\r\n  &quot;size&quot;: 3,\r\n  &quot;count&quot;: 3,\r\n  &quot;content&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Last Chance / Season 12&quot;,\r\n      &quot;releaseDate&quot;: &quot;2008&quot;,\r\n      &quot;duration&quot;: 2100,\r\n      &quot;episodeNumber&quot;: 236,\r\n      &quot;title&quot;: &quot;Last Chance / Season 12&quot;,\r\n      &quot;seasonTitle&quot;: &quot;Top Master&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;&#201;pisode 8 / Season 12&quot;,\r\n      &quot;releaseDate&quot;: &quot;2008&quot;,\r\n      &quot;duration&quot;: 7320,\r\n      &quot;episodeNumber&quot;: 235,\r\n      &quot;title&quot;: &quot;&#201;pisode 8 / Season 12&quot;,\r\n      &quot;seasonTitle&quot;: &quot;Top Master&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;&#201;pisode 7 / Season 12&quot;,\r\n      &quot;releaseDate&quot;: &quot;2008&quot;,\r\n      &quot;duration&quot;: 7200,\r\n      &quot;episodeNumber&quot;: 234,\r\n      &quot;title&quot;: &quot;&#201;pisode 7 / Season 12&quot;,\r\n      &quot;seasonTitle&quot;: &quot;Top Master&quot;\r\n    }\r\n  ]\r\n}\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/71258849/jq-cannot-iterate-over-number-with-join",
        "title": "jq cannot iterate over number with join"
    },
    {
        "tags": [
            "json",
            "command-line",
            "debian",
            "jq",
            "openmediavault"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1645774536,
                "last_edit_date": 1645774536,
                "creation_date": 1645774366,
                "answer_id": 71262474,
                "question_id": 71262439,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to use [Shell Parameter Expansion](https://www.gnu.org/savannah-checkouts/gnu/bash/manual/bash.html#Shell-Parameter-Expansion) to access variables:\r\n~~~sh\r\nomv-rpc -u admin &#39;ShareMgmt&#39; &#39;set&#39; &quot;${JSON_STRING}&quot;\r\n~~~",
                "title": "Pass a variable containing a JSON as a parameter of a function by command line"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1645774536,
        "creation_date": 1645774121,
        "question_id": 71262439,
        "body_markdown": "I need to enter a value in a **JSON** that requires an **Openmediavault** command. The command in question is this:\r\n\r\n    omv-rpc -u admin &#39;ShareMgmt&#39; &#39;set&#39;  &#39;{&quot;name&quot;:&quot;120GB&quot;,&quot;mntentref&quot;:&quot;71fdbd90-ce16-4726-ad8d-35ba8664b4c6&quot;,&quot;reldirpath&quot;: &quot;/&quot;,&quot;mode&quot;: &quot;775&quot;,&quot;comment&quot;: &quot;&quot;,&quot;uuid&quot;: &quot;fa4b1c66-ef79-11e5-87a0-0002b3a176b4&quot;}&#39;\r\n\r\nBut I need to introduce another **JSON** that I have saved in a variable. I have mounted it like this:\r\n\r\n    JSON_STRING=$( jq -n \\\r\n                      --arg referencia &quot;$code_val&quot; \\\r\n                      &#39;{name:&quot;120GB&quot;,mntentref:$referencia ,reldirpath: &quot;/&quot;,mode: &quot;775&quot;,comment: &quot;&quot;,uuid: &quot;fa4b1c66-ef79-11e5-87a0-0002b3a176b4&quot;}&#39;)\r\n\r\nThe exit **echo $JSON_STRING**:\r\n\r\n    {&quot;name&quot;:&quot;120GB&quot;,&quot;mntentref&quot;:&quot;71fdbd90-ce16-4726-ad8d-35ba8664b4c6&quot;,&quot;reldirpath&quot;: &quot;/&quot;,&quot;mode&quot;: &quot;775&quot;,&quot;comment&quot;: &quot;&quot;,&quot;uuid&quot;: &quot;fa4b1c66-ef79-11e5-87a0-0002b3a176b4&quot;}\r\n\r\nNow I want to build the first function and send the **JSON** that I have created by parameters, but I would not know how to do it, can you give me a hand?\r\n\r\nI tried this way but it gives error. I have little knowledge of **Debian console commands**:\r\n\r\n    omv-rpc -u admin &#39;ShareMgmt&#39; &#39;set&#39; &#39;{&#39;echo $JSON_STRING&#39;}&#39;",
        "link": "https://stackoverflow.com/questions/71262439/pass-a-variable-containing-a-json-as-a-parameter-of-a-function-by-command-line",
        "title": "Pass a variable containing a JSON as a parameter of a function by command line"
    },
    {
        "tags": [
            "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": 1645778002,
                "post_id": 71262461,
                "comment_id": 125965694,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1645779342,
                "creation_date": 1645779342,
                "answer_id": 71263331,
                "question_id": 71262461,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`hosts.jsonl`:\r\n\r\n```json\r\n{ &quot;host&quot;: &quot;hostId1&quot;, &quot;dvc_ssr&quot;: &quot;aa-1111&quot; }\r\n{ &quot;host&quot;: &quot;hostId2&quot;, &quot;dvc_ssr&quot;: &quot;aa-2222&quot; }\r\n{ &quot;host&quot;: &quot;hostId3&quot;, &quot;dvc_ssr&quot;: &quot;aa-3333&quot; }\r\n```\r\n\r\n`records.jsonl`:\r\n\r\n```json\r\n{ &quot;_time&quot;: &quot;2022-02-20T23&quot;, &quot;csp_name&quot;: &quot;1&quot;, &quot;tool_bf_id&quot;: &quot;1234&quot;, &quot;id&quot;:&quot;aa-1111;aa-2222&quot; }\r\n{ &quot;_time&quot;: &quot;2022-02-20T23&quot;, &quot;csp_name&quot;: &quot;3&quot;, &quot;tool_bf_id&quot;: &quot;1357&quot;, &quot;dvc_ssr&quot;: &quot;null&quot; }\r\n{ &quot;_time&quot;: &quot;2022-02-20T23&quot;, &quot;csp_name&quot;: &quot;4&quot;, &quot;tool_bf_id&quot;: &quot;2468&quot;, &quot;dvc_ssr&quot;: &quot;aa-3333&quot; }\r\n```\r\n\r\n```sh\r\njq -n --slurpfile hosts hosts.jsonl &#39;\r\n   INDEX( $hosts[]; .dvc_ssr ) as $host_lkup |\r\n\r\n   inputs |\r\n   .host =\r\n      if has(&quot;dvc_ssr&quot;) then\r\n         $host_lkup[.dvc_ssr].host\r\n      elif has(&quot;id&quot;) then\r\n         .id / &quot;;&quot; | map( $host_lkup[.].host ) | join(&quot;;&quot;)\r\n      else\r\n         null\r\n      end\r\n&#39; records.jsonl\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;_time&quot;: &quot;2022-02-20T23&quot;,\r\n  &quot;csp_name&quot;: &quot;1&quot;,\r\n  &quot;tool_bf_id&quot;: &quot;1234&quot;,\r\n  &quot;id&quot;: &quot;aa-1111;aa-2222&quot;,\r\n  &quot;host&quot;: &quot;hostId1;hostId2&quot;\r\n}\r\n{\r\n  &quot;_time&quot;: &quot;2022-02-20T23&quot;,\r\n  &quot;csp_name&quot;: &quot;3&quot;,\r\n  &quot;tool_bf_id&quot;: &quot;1357&quot;,\r\n  &quot;dvc_ssr&quot;: &quot;null&quot;,\r\n  &quot;host&quot;: null\r\n}\r\n{\r\n  &quot;_time&quot;: &quot;2022-02-20T23&quot;,\r\n  &quot;csp_name&quot;: &quot;4&quot;,\r\n  &quot;tool_bf_id&quot;: &quot;2468&quot;,\r\n  &quot;dvc_ssr&quot;: &quot;aa-3333&quot;,\r\n  &quot;host&quot;: &quot;hostId3&quot;\r\n}\r\n```\r\n\r\n[Demo](https://jqplay.org/s/XMVpNK74vX) on jqplay\r\n",
                "title": "Using JQ - Join records after been split and modified"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1645779342,
        "creation_date": 1645774255,
        "question_id": 71262461,
        "body_markdown": "I have an array where some records need to be duplicated. The id value might be a join of 2 string by &quot;;&quot;, as below\r\n\r\n`{&quot;_time&quot;: &quot;2022-02-20T23&quot;,&quot;csp_name&quot;: &quot;1&quot;,&quot;tool_bf_id&quot;: &quot;1234&quot;, &quot;id&quot;:&quot;aa-1111;aa-2222&quot;}`\r\n\r\nor id value is null or only 1 ref:\r\n```\r\n{&quot;_time&quot;: &quot;2022-02-20T23&quot;,&quot;csp_name&quot;: &quot;3&quot;,&quot;tool_bf_id&quot;: &quot;1357&quot;, &quot;dvc_ssr&quot;: &quot;null&quot;}\r\n{&quot;_time&quot;: &quot;2022-02-20T23&quot;,&quot;csp_name&quot;: &quot;4&quot;,&quot;tool_bf_id&quot;: &quot;2468&quot;, &quot;dvc_ssr&quot;: &quot;aa-3333&quot;}\r\n```\r\n\r\nI am able to duplicate this record and get the following:\r\n\r\n```\r\n{&quot;_time&quot;: &quot;2022-02-20T23&quot;,&quot;csp_name&quot;: &quot;1&quot;,&quot;tool_bf_id&quot;: &quot;1234&quot;, &quot;dvc_ssr&quot;: &quot;aa-1111&quot;,&quot;id&quot;:&quot;aa-1111;aa-2222&quot;},\r\n{&quot;_time&quot;: &quot;2022-02-20T23&quot;,&quot;csp_name&quot;: &quot;1&quot;,&quot;tool_bf_id&quot;: &quot;1234&quot;, &quot;dvc_ssr&quot;: &quot;aa-2222&quot;,&quot;id&quot;:&quot;aa-1111;aa-2222&quot;}\r\n```\r\nThanks to another post: [Join 2 files using a common key][1]\r\n\r\nI modify my records by joining data from another file:\r\n\r\n```\r\n{&quot;_time&quot;:&quot;2022-02-20T23&quot;,&quot;csp_name&quot;:&quot;1&quot;,&quot;tool_bf_id&quot;:&quot;1234&quot;,&quot;id&quot;:&quot;aa-1111;aa-2222&quot;, &quot;dvc_ssr&quot;:&quot;aa-1111&quot;,&quot;host&quot;:&quot;hostId1&quot;}\r\n,{&quot;_time&quot;:&quot;2022-02-20T23&quot;,&quot;csp_name&quot;:&quot;1&quot;,&quot;tool_bf_id&quot;:&quot;1234&quot;,&quot;id&quot;:&quot;aa-1111;aa-2222&quot;,&quot;dvc_ssr&quot;:&quot;aa-2222&quot;,&quot;host&quot;:&quot;hostId2&quot;}\r\n```\r\nNow I need to merge the records back and join the value from the new added fields (which are around 10)\r\n\r\n`{&quot;_time&quot;: &quot;2022-02-20T23&quot;,&quot;csp_name&quot;: &quot;1&quot;,&quot;tool_bf_id&quot;: &quot;1234&quot;, &quot;id&quot;:&quot;aa-1111;aa-2222&quot;, &quot;host&quot;: &quot;hostId1;hostId2&quot;}`\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/71248425/using-jq-join-2-json-files-which-do-not-have-the-same-structure-but-with-a-com/71249114#71249114",
        "link": "https://stackoverflow.com/questions/71262461/using-jq-join-records-after-been-split-and-modified",
        "title": "Using JQ - Join records after been split and modified"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17850928,
                    "reputation": 21,
                    "user_id": 12966702,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/14ab739d2944104add69bbd985e034fe?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jiri Pencak",
                    "link": "https://stackoverflow.com/users/12966702/jiri-pencak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1645778423,
                "post_id": 71263176,
                "comment_id": 125965823,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1645778691,
                "creation_date": 1645778691,
                "answer_id": 71263222,
                "question_id": 71263176,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your actual input file has several superfluous commas. Assuming your JSON file should be a stream of objects, i.e. look like this:\r\n~~~json\r\n{\r\n    &quot;cluster_name&quot;: &quot;k8s-cluster-1&quot;,\r\n    &quot;cluster_env&quot;: &quot;PROD&quot;,\r\n    &quot;cluster_hosts&quot;: [\r\n      {\r\n        &quot;host_type&quot;: &quot;MASTER&quot;,\r\n        &quot;host_hostname&quot;: &quot;aa083&quot;,\r\n        &quot;host_username&quot;: &quot;kubeadm&quot;,\r\n        &quot;host_kubernetes_version&quot;: &quot;&quot;\r\n      },\r\n      {\r\n        &quot;host_type&quot;: &quot;NODE&quot;,\r\n        &quot;host_hostname&quot;: &quot;aa084&quot;,\r\n        &quot;host_username&quot;: &quot;kubeadm&quot;,\r\n        &quot;host_kubernetes_version&quot;: &quot;&quot;\r\n      },\r\n      {\r\n        &quot;host_type&quot;: &quot;NODE&quot;,\r\n        &quot;host_hostname&quot;: &quot;aa085&quot;,\r\n        &quot;host_username&quot;: &quot;kubeadm&quot;,\r\n        &quot;host_kubernetes_version&quot;: &quot;&quot;\r\n      }\r\n    ]\r\n}\r\n{\r\n    &quot;cluster_name&quot;: &quot;k8s-cluster-2&quot;,\r\n    &quot;cluster_env&quot;: &quot;PROD&quot;,\r\n    &quot;cluster_hosts&quot;: [\r\n      {\r\n        &quot;host_type&quot;: &quot;MASTER&quot;,\r\n        &quot;host_hostname&quot;: &quot;ab093&quot;,\r\n        &quot;host_username&quot;: &quot;kubeadm&quot;,\r\n        &quot;host_kubernetes_version&quot;: &quot;&quot;\r\n      },\r\n      {\r\n        &quot;host_type&quot;: &quot;NODE&quot;,\r\n        &quot;host_hostname&quot;: &quot;ab094&quot;,\r\n        &quot;host_username&quot;: &quot;kubeadm&quot;,\r\n        &quot;host_kubernetes_version&quot;: &quot;&quot;\r\n      },\r\n      {\r\n        &quot;host_type&quot;: &quot;NODE&quot;,\r\n        &quot;host_hostname&quot;: &quot;ab095&quot;,\r\n        &quot;host_username&quot;: &quot;kubeadm&quot;,\r\n        &quot;host_kubernetes_version&quot;: &quot;&quot;\r\n      }\r\n    ]\r\n}\r\n~~~\r\nThen you just need to list the fields you are interested in. Use the `-r` flag to output raw text instead of JSON strings (which would be quoted):\r\n~~~sh\r\njq -r &#39;.cluster_name, (.cluster_hosts[] | .host_type, .host_hostname)&#39;\r\n~~~\r\n~~~none\r\nk8s-cluster-1\r\nMASTER\r\naa083\r\nNODE\r\naa084\r\nNODE\r\naa085\r\nk8s-cluster-2\r\nMASTER\r\nab093\r\nNODE\r\nab094\r\nNODE\r\nab095\r\n~~~\r\n[Demo](https://jqplay.org/s/hwfeNkmhUy)\r\n\r\nIf instead your input file is supposed to be an array (in which case the top-level commas were correct but the array brackets `[]` were missing), then simply prepend the filter with `.[] |`.",
                "title": "json filtering in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1645778691,
        "creation_date": 1645778407,
        "question_id": 71263176,
        "body_markdown": "I would like to ask you if you can help me with filtering data in json. I have the following json:\r\n\r\n```\r\n{\r\n    &quot;cluster_name&quot;: &quot;k8s-cluster-1&quot;,\r\n    &quot;cluster_env&quot;: &quot;PROD&quot;,\r\n    &quot;cluster_hosts&quot;: [\r\n      {\r\n        &quot;host_type&quot;: &quot;MASTER&quot;,\r\n        &quot;host_hostname&quot;: &quot;aa083&quot;,\r\n        &quot;host_username&quot;: &quot;kubeadm&quot;,\r\n        &quot;host_kubernetes_version&quot;: &quot;&quot;,\r\n      },\r\n      {\r\n        &quot;host_type&quot;: &quot;NODE&quot;,\r\n        &quot;host_hostname&quot;: &quot;aa084&quot;,\r\n        &quot;host_username&quot;: &quot;kubeadm&quot;,\r\n        &quot;host_kubernetes_version&quot;: &quot;&quot;,\r\n      },\r\n      {\r\n        &quot;host_type&quot;: &quot;NODE&quot;,\r\n        &quot;host_hostname&quot;: &quot;aa085&quot;,\r\n        &quot;host_username&quot;: &quot;kubeadm&quot;,\r\n        &quot;host_kubernetes_version&quot;: &quot;&quot;,\r\n      }\r\n    ],\r\n},\r\n{\r\n    &quot;cluster_name&quot;: &quot;k8s-cluster-2&quot;,\r\n    &quot;cluster_env&quot;: &quot;PROD&quot;,\r\n    &quot;cluster_hosts&quot;: [\r\n      {\r\n        &quot;host_type&quot;: &quot;MASTER&quot;,\r\n        &quot;host_hostname&quot;: &quot;ab093&quot;,\r\n        &quot;host_username&quot;: &quot;kubeadm&quot;,\r\n        &quot;host_kubernetes_version&quot;: &quot;&quot;,\r\n      },\r\n      {\r\n        &quot;host_type&quot;: &quot;NODE&quot;,\r\n        &quot;host_hostname&quot;: &quot;ab094&quot;,\r\n        &quot;host_username&quot;: &quot;kubeadm&quot;,\r\n        &quot;host_kubernetes_version&quot;: &quot;&quot;,\r\n      },\r\n      {\r\n        &quot;host_type&quot;: &quot;NODE&quot;,\r\n        &quot;host_hostname&quot;: &quot;ab095&quot;,\r\n        &quot;host_username&quot;: &quot;kubeadm&quot;,\r\n        &quot;host_kubernetes_version&quot;: &quot;&quot;,\r\n      }\r\n    ],\r\n}\r\n```\r\n\r\nAnd the output should look like this:\r\n```\r\ncluster_name\r\nhost_type\r\nhost_name\r\n.\r\n.\r\n.\r\n```\r\n\r\n```\r\nk8s-cluster-1\r\nMASTER\r\naa083\r\nNODE\r\naa084\r\nNODE\r\naa085\r\nk8s-cluster-2\r\nMASTER\r\nab093\r\nNODE\r\nab094\r\nNODE\r\nab095\r\n```\r\n\r\nI tried this command \r\n\r\n   cat json |jq -c &#39;.[] | .cluster_name,.cluster_hosts[] | {host_type,host_name}&#39;\r\n\r\nbut it shows an error\r\n\r\n   jq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;host_type&quot;\r\n\r\n\r\nI need to do this in bash.\r\n\r\nCould you please help me?\r\n\r\nThank you in advance.\r\n",
        "link": "https://stackoverflow.com/questions/71263176/json-filtering-in-bash",
        "title": "json filtering in bash"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1645790652,
                "creation_date": 1645790652,
                "answer_id": 71265592,
                "question_id": 71265522,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[Alasql][1] lib can load the data file from server, parse it and put the result to array of JSON objects. \r\n\r\n\r\n  [1]: https://github.com/agershun/alasql\r\n\r\nSo, this is some example for you: \r\n\r\n    &lt;script src=&quot;alasql.min.js&quot;&gt;&lt;/script&gt;\r\n    &lt;script&gt;\r\n            alasql(&#39;SELECT * FROM CSV(&quot;FileName.csv&quot;,{headers:true})&#39;,[],function(res){\r\n            var dataResult = {items:res};\r\n            });\r\n    &lt;/script&gt;",
                "title": "JQ - how to convert CSV with headers to JSON array with nested dictionaries"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1645790676,
                "creation_date": 1645790676,
                "answer_id": 71265598,
                "question_id": 71265522,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `-R` to read the input as raw text\r\n~~~sh\r\njq -R &#39;\r\n  (. / &quot;,&quot;) as $keys\r\n  | [ inputs / &quot;,&quot; | [$keys, .]\r\n    | reduce transpose[] as $i (\r\n        {event: &quot;bleep&quot;, sourcetype: &quot;rats&quot;}; .fields[$i[0]] = $i[1])\r\n      ]\r\n&#39; input.csv\r\n~~~\r\n[Demo](https://jqplay.org/s/ZoAb12V6Fi)",
                "title": "JQ - how to convert CSV with headers to JSON array with nested dictionaries"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1645790676,
        "creation_date": 1645790217,
        "question_id": 71265522,
        "body_markdown": "I got the following CSV sample \r\n```\r\nkey1,key2,key3,key4,key5\r\nval1,val2,val3,val4,val5\r\n```\r\nLooking for tips how to convert the above structure into the following JSON structure\r\n```\r\n[\r\n{\r\n&quot;event&quot;: &quot;bleep&quot;,\r\n&quot;sourcetype&quot;: &quot;rats&quot;,\r\n&quot;fields&quot;:  {\r\n&quot;key1&quot;:&quot;val1&quot;,\r\n&quot;key2&quot;:&quot;val2&quot;,\r\n&quot;key3&quot;:&quot;val3&quot;,\r\n&quot;key4&quot;:&quot;val4&quot;,\r\n&quot;key5&quot;:&quot;val5&quot;\r\n }\r\n},\r\n{\r\n&quot;event&quot;: &quot;bleep&quot;,\r\n&quot;sourcetype&quot;: &quot;rats&quot;,\r\n&quot;fields&quot;:  {\r\n&quot;key1&quot;:&quot;val1&quot;,\r\n&quot;key2&quot;:&quot;val2&quot;,\r\n&quot;key3&quot;:&quot;val3&quot;,\r\n&quot;key4&quot;:&quot;val4&quot;,\r\n&quot;key5&quot;:&quot;val5&quot;\r\n }\r\n}\r\n]\r\n```\r\nThanks in advance!",
        "link": "https://stackoverflow.com/questions/71265522/jq-how-to-convert-csv-with-headers-to-json-array-with-nested-dictionaries",
        "title": "JQ - how to convert CSV with headers to JSON array with nested dictionaries"
    },
    {
        "tags": [
            "bash",
            "azure",
            "powershell",
            "terraform",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10275035,
                    "reputation": 121775,
                    "user_id": 7582247,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KPNHoVDG.png?s=256",
                    "display_name": "Ted Lyngmo",
                    "link": "https://stackoverflow.com/users/7582247/ted-lyngmo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1645795644,
                "post_id": 71266384,
                "comment_id": 125971467,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24265932,
                    "reputation": 13,
                    "user_id": 18214839,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GiRT6ru5zTaOSpTGTuhhKsErvrze8-K4TwQGZeSbg=k-s256",
                    "display_name": "yomomsabaddie",
                    "link": "https://stackoverflow.com/users/18214839/yomomsabaddie"
                },
                "reply_to_user": {
                    "account_id": 10275035,
                    "reputation": 121775,
                    "user_id": 7582247,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KPNHoVDG.png?s=256",
                    "display_name": "Ted Lyngmo",
                    "link": "https://stackoverflow.com/users/7582247/ted-lyngmo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1645796469,
                "post_id": 71266384,
                "comment_id": 125971733,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10275035,
                    "reputation": 121775,
                    "user_id": 7582247,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KPNHoVDG.png?s=256",
                    "display_name": "Ted Lyngmo",
                    "link": "https://stackoverflow.com/users/7582247/ted-lyngmo"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1645796943,
                "post_id": 71266384,
                "comment_id": 125971904,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24265932,
                    "reputation": 13,
                    "user_id": 18214839,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GiRT6ru5zTaOSpTGTuhhKsErvrze8-K4TwQGZeSbg=k-s256",
                    "display_name": "yomomsabaddie",
                    "link": "https://stackoverflow.com/users/18214839/yomomsabaddie"
                },
                "reply_to_user": {
                    "account_id": 10275035,
                    "reputation": 121775,
                    "user_id": 7582247,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KPNHoVDG.png?s=256",
                    "display_name": "Ted Lyngmo",
                    "link": "https://stackoverflow.com/users/7582247/ted-lyngmo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1645797433,
                "post_id": 71266384,
                "comment_id": 125972082,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1645805206,
                "creation_date": 1645805206,
                "answer_id": 71268576,
                "question_id": 71266384,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&lt;!-- language-all: sh --&gt;\r\n\r\nHere is the PowerShell equivalent of your `bash` script, using only native PowerShell features; place the code in a `.ps1` file, say `foo.ps1`, and pipe the JSON input of interest to it; e.g.:  \r\n`&#39;{ &quot;group_name&quot;: &quot;foo&quot; }&#39; | .\\foo.ps1`\r\n\r\n```\r\n# Extract the .group_name property value from the JSON input\r\n# provided via the pipeline and save it in variable $GROUP_NAME\r\n$GROUP_NAME = ($Input | ConvertFrom-Json).group_name\r\n\r\n# Call the Azure CLI with the group name as the argument.\r\n$result = az group exists -n $GROUP_NAME\r\n\r\n# Construct a hashtable with an &#39;exists&#39; entry that contains the\r\n# result obtained from Azure and convert it to pretty-printed JSON\r\n# (use -Compress to get single-line, non-pretty-printed output).\r\n# Note: Unlike jq&#39;s output, the text will *not* be colored (syntax-highlighted).\r\n@{ exists = $result } | ConvertTo-Json\r\n```\r\n",
                "title": "How to convert this Bash script to PowerShell"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1645828861,
        "creation_date": 1645794742,
        "last_edit_date": 1645828861,
        "question_id": 71266384,
        "body_markdown": "In Terraform I want to check if a resource group already exists or not. Currently I am using a Bash script to check this but this obviously won&#39;t work on Windows. My plan is to convert this script to ps1. \r\n\r\nI have little to no experience with PowerShell so I have no clue how to convert it to ps1.\r\n\r\nThis is the Bash file:\r\n\r\n```\r\n#!/bin/bash \r\n\r\neval &quot;$(jq -r &#39;@sh &quot;GROUP_NAME=\\(.group_name)&quot;&#39;)&quot;\r\nresult=$(az group exists -n $GROUP_NAME)\r\n\r\njq -n --arg exists &quot;$result&quot; &#39;{&quot;exists&quot;:$exists}&#39;\r\n```\r\n\r\nHow can I make a start on this?\r\n",
        "link": "https://stackoverflow.com/questions/71266384/how-to-convert-this-bash-script-to-powershell",
        "title": "How to convert this Bash script to PowerShell"
    },
    {
        "tags": [
            "json",
            "list",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1645867876,
                "creation_date": 1645867876,
                "answer_id": 71275509,
                "question_id": 71275460,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Read in both files through using `inputs` (which works best if you also add the `--null-input` (or `-n`) option):\r\n~~~\r\njq -n &#39;[inputs[]] &#39; 1.json 2.json \r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;1&quot;,\r\n    &quot;name&quot;: &quot;Product 1&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;2&quot;,\r\n    &quot;name&quot;: &quot;Product 2&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;3&quot;,\r\n    &quot;name&quot;: &quot;Product 3&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;10&quot;,\r\n    &quot;name&quot;: &quot;Product 10&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;11&quot;,\r\n    &quot;name&quot;: &quot;Product 11&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;12&quot;,\r\n    &quot;name&quot;: &quot;Product 12&quot;\r\n  }\r\n]\r\n~~~",
                "title": "Concatenate JSON files"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1645867876,
        "creation_date": 1645867487,
        "question_id": 71275460,
        "body_markdown": "I would like to concatenate all the json files in a specific folder.\r\n\r\nI installed jq tools and tried different things but no success so far. \r\n\r\nThanks for your help!\r\n\r\n\r\nExample : \r\n1.json\r\n\r\n    [{\r\n         &quot;id&quot;: &quot;1&quot;,\r\n         &quot;name&quot;: &quot;Product 1&quot;\r\n    },{\r\n         &quot;id&quot;: &quot;2&quot;,\r\n         &quot;name&quot;: &quot;Product 2&quot;\r\n    },{\r\n         &quot;id&quot;: &quot;3&quot;,\r\n         &quot;name&quot;: &quot;Product 3&quot;\r\n    }]\r\n\r\n2.json\r\n\r\n    [{\r\n         &quot;id&quot;: &quot;10&quot;,\r\n         &quot;name&quot;: &quot;Product 10&quot;\r\n    },{\r\n         &quot;id&quot;: &quot;11&quot;,\r\n         &quot;name&quot;: &quot;Product 11&quot;\r\n    },{\r\n         &quot;id&quot;: &quot;12&quot;,\r\n         &quot;name&quot;: &quot;Product 12&quot;\r\n    }]\r\n\r\noutput.json\r\n\r\n    [{\r\n         &quot;id&quot;: &quot;1&quot;,\r\n         &quot;name&quot;: &quot;Product 1&quot;\r\n    },{\r\n         &quot;id&quot;: &quot;2&quot;,\r\n         &quot;name&quot;: &quot;Product 2&quot;\r\n    },{\r\n         &quot;id&quot;: &quot;3&quot;,\r\n         &quot;name&quot;: &quot;Product 3&quot;\r\n    },{\r\n         &quot;id&quot;: &quot;10&quot;,\r\n         &quot;name&quot;: &quot;Product 10&quot;\r\n    },{\r\n         &quot;id&quot;: &quot;11&quot;,\r\n         &quot;name&quot;: &quot;Product 11&quot;\r\n    },{\r\n         &quot;id&quot;: &quot;12&quot;,\r\n         &quot;name&quot;: &quot;Product 12&quot;\r\n    }]",
        "link": "https://stackoverflow.com/questions/71275460/concatenate-json-files",
        "title": "Concatenate JSON files"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1646037430,
                "post_id": 71290874,
                "comment_id": 126016855,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21249034,
                    "reputation": 9,
                    "user_id": 15631464,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-qnpfnbqJtKU/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnMNO6jpYT8xrG3dJ0tTUioygz-zw/s96-c/s256-rj/photo.jpg",
                    "display_name": "Abhay Darji",
                    "link": "https://stackoverflow.com/users/15631464/abhay-darji"
                },
                "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": 1646126488,
                "post_id": 71290874,
                "comment_id": 126041262,
                "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": 1646130032,
                "post_id": 71290874,
                "comment_id": 126042493,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1646160666,
                "creation_date": 1646160666,
                "answer_id": 71313278,
                "question_id": 71290874,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that first uses [tag:sed] and [tag:hjson] to convert the text to JSON:\r\n```\r\nsed &#39;1s/array =//&#39; array.js |\r\n hjson -j | jq &#39;.[] | select(.Name==&quot;age&quot;).value&#39;\r\n```\r\n\r\n",
                "title": "How to find value from arrays of object in shell script?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1646160666,
        "creation_date": 1646025694,
        "last_edit_date": 1646031679,
        "question_id": 71290874,
        "body_markdown": "I have array of objects as given .\r\n\r\n```\r\narray = [{Name:&#39;firstName&#39;, value: &#39;name&#39;},\r\n         {Name:&#39;lastName&#39;, value: &#39;lname&#39;},\r\n         {Name:&#39;brithDate&#39;, value: &#39;1-1-2000&#39;},\r\n         {Name:&#39;age&#39;, value: 21},]\r\n```\r\n\r\nHow can I get the value of age from the array without for loop?\r\nIn for loop, it takes time and I want it to run in less time because I need to run this for thousands of data. Anyone has solution for it?\r\n",
        "link": "https://stackoverflow.com/questions/71290874/how-to-find-value-from-arrays-of-object-in-shell-script",
        "title": "How to find value from arrays of object in shell script?"
    },
    {
        "tags": [
            "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": 0,
                "creation_date": 1646043776,
                "post_id": 71293398,
                "comment_id": 126018913,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1711099213,
                "last_edit_date": 1711099213,
                "creation_date": 1646043571,
                "answer_id": 71293474,
                "question_id": 71293398,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `max_by` to retrieve the item with the highest predicate value. Alternatively, use `sort_by` to bring the items in order along that predicate, then extract the last item using either `last` or the position `-1`:\r\n~~~sh\r\njq &#39;\r\n  [.nodes[].run_data]\r\n  | max_by(.end_time)\r\n      # or: sort_by(.end_time) | last\r\n      # or: sort_by(.end_time)[-1]\r\n  | {status, end_time}\r\n&#39; test.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;status&quot;: &quot;PASSED&quot;,\r\n  &quot;end_time&quot;: &quot;2022-02-28T09:50:05Z&quot;\r\n}\r\n~~~\r\n---\r\nTo generate a formatted output, replace `{status, end_time}` with an accordingly formatted string, e.g. `&quot;\\(.end_time): Status \\(.status)&quot;`, and set the `-r` flag for a JSON-decoded (raw) output.",
                "title": "jq - Get objects with latest date"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1649988940,
                "last_edit_date": 1649988940,
                "creation_date": 1649988464,
                "answer_id": 71879332,
                "question_id": 71293398,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `transpose` to map each object with its end_time.\r\n\r\nHere I have converted `end_time` to seconds since Unix epoch and outputted the object with largest seconds value (this is the newest).\r\n\r\n```\r\n[\r\n[. | map(.end_time | strptime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;) | mktime), [.[0], .[1]]] \r\n| transpose[] \r\n| .[1] += {secs: .[0]} | .[1]\r\n] \r\n| sort_by(.secs) | last \r\n| {status, end_time}\r\n```\r\n\r\nOutput\r\n```\r\n{\r\n  &quot;status&quot;: &quot;PASSED&quot;,\r\n  &quot;end_time&quot;: &quot;2022-02-28T09:50:05Z&quot;\r\n}\r\n```\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/w1z2n2drc7",
                "title": "jq - Get objects with latest date"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1711099213,
        "creation_date": 1646043233,
        "question_id": 71293398,
        "body_markdown": "Json looks like this:\r\n\r\n    cat test.json |jq -r &quot;.nodes[].run_data&quot;\r\n\r\n      {   \r\n        &quot;id&quot;: &quot;1234&quot;,   \r\n        &quot;status&quot;: &quot;PASSED&quot;,\r\n        &quot;penultimate_status&quot;: &quot;PASSED&quot;,   \r\n        &quot;end_time&quot;:&quot;2022-02-28T09:50:05Z&quot; \r\n      } \r\n      {\r\n        &quot;id&quot;: &quot;4321&quot;,   \r\n        &quot;status&quot;: &quot;PASSED&quot;,  \r\n        &quot;penultimate_status&quot;: &quot;UNKNOWN&quot;,\r\n        &quot;end_time&quot;: &quot;2020-10-14T13:52:57Z&quot;\r\n     }\r\n\r\n\r\nI want to get &quot;status&quot; and &quot;end_time&quot; of the newest run. Unfortunately the order is not fix. Meaning the newest run can be first in the list, but also last or in the middle...",
        "link": "https://stackoverflow.com/questions/71293398/jq-get-objects-with-latest-date",
        "title": "jq - Get objects with latest date"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1646104497,
                "creation_date": 1646104497,
                "answer_id": 71303344,
                "question_id": 71301932,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One solution to the stated problem would be:\r\n```\r\n&lt; test.json jq &#39; \r\n  &quot;time:\\(.time)&quot;,\r\n  [.params[] | select(.key|IN(&quot;state&quot;,&quot;options&quot;))\r\n   | &quot;key:\\(.key)&quot; ,&quot;value:\\(.value)&quot;]\r\n&#39; | sed &#39;/^[][]$/d&#39;\r\n```\r\n\r\nHowever, it would almost certainly be better to modify the requirements slightly so that the output format is less idiosyncratic.  This should also make it easier to formulate a cleaner (e.g. only-jq) solution.\r\n",
                "title": "JQ- print specific key value pair"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651454821,
                "creation_date": 1651454821,
                "answer_id": 72081576,
                "question_id": 71301932,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `@csv` (comma separated values).\r\n\r\nFilter\r\n```\r\n&quot;time:\\(.time)&quot;, \r\n(.params | \r\n[map(select(.key==&quot;state&quot; or .key==&quot;options&quot;))[] \r\n| &quot;key:\\(.key)&quot;, &quot;value:\\(.value)&quot;] \r\n| @csv)\r\n```\r\n\r\nInput\r\n```\r\n{\r\n    &quot;time&quot;: &quot;2022-02-28T22:00:55.196Z&quot;,\r\n    &quot;severity&quot;: &quot;INFO&quot;,\r\n    &quot;params&quot;: [\r\n        {&quot;key&quot;: &quot;state&quot;, &quot;value&quot;: &quot;pending&quot;},\r\n        {&quot;key&quot;: &quot;options&quot;, &quot;value&quot;: &quot;request&quot;},\r\n        {&quot;key&quot;: &quot;description&quot;, &quot;value&quot;: &quot;[FILTERED]&quot;}\r\n    ],\r\n    &quot;content_length&quot;: &quot;231&quot;\r\n}\r\n```\r\n\r\nOutput\r\n```\r\ntime:2022-02-28T22:00:55.196Z\r\n&quot;key:state&quot;,&quot;value:pending&quot;,&quot;key:options&quot;,&quot;value:request&quot;\r\n```\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/F_3QP6-EvK",
                "title": "JQ- print specific key value pair"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1651454821,
        "creation_date": 1646088892,
        "last_edit_date": 1646089223,
        "question_id": 71301932,
        "body_markdown": "I have this JSON:\r\n\r\n```\r\n{\r\n    &quot;time&quot;: &quot;2022-02-28T22:00:55.196Z&quot;,\r\n    &quot;severity&quot;: &quot;INFO&quot;,\r\n    &quot;params&quot;: [\r\n        {&quot;key&quot;: &quot;state&quot;, &quot;value&quot;: &quot;pending&quot;},\r\n        {&quot;key&quot;: &quot;options&quot;, &quot;value&quot;: &quot;request&quot;},\r\n        {&quot;key&quot;: &quot;description&quot;, &quot;value&quot;: &quot;[FILTERED]&quot;}\r\n    ],\r\n    &quot;content_length&quot;: &quot;231&quot;\r\n}\r\n```\r\n\r\nI want to print key value pairs of where the key matches to state and options and also the time and its value. I am able to print the time and all key value pairs by using below command, but not sure how to extract specific key value pairs.\r\n\r\n```\r\njq &#39;&quot;time:\\(.time)&quot; ,[.params[] | &quot;key:\\(.key)&quot; ,&quot;value:\\(.value)&quot;]&#39; test.json\r\n```\r\n\r\nThis gives the output:\r\n\r\n```\r\n&quot;time:2022-02-28T22:00:55.196Z&quot;\r\n[\r\n  &quot;key:state&quot;,\r\n  &quot;value:pending&quot;,\r\n  &quot;key:options&quot;,\r\n  &quot;value:request&quot;,\r\n  &quot;key:description&quot;,\r\n  &quot;value:[FILTERED]&quot;\r\n]\r\n```\r\n\r\nBut my desired output is:\r\n\r\n```\r\n&quot;time:2022-02-28T22:00:55.196Z&quot;\r\n  &quot;key:state&quot;,\r\n  &quot;value:pending&quot;,\r\n  &quot;key:options&quot;,\r\n  &quot;value:request&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/71301932/jq-print-specific-key-value-pair",
        "title": "JQ- print specific key value pair"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1646184668,
                "last_edit_date": 1646184668,
                "creation_date": 1646136896,
                "answer_id": 71308353,
                "question_id": 71308155,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You cannot reference to parent, you have to save the reference in a variable beforehand, and descend with having access to that variable.\r\n\r\n~~~none\r\n.tags[] |= (\r\n  .name as $name\r\n  | # rest of your code using $name\r\n    walk(\r\n      if type == &quot;object&quot; and .setpointA\r\n      then .label = {&quot;bindType&quot;:&quot;Tag&quot;, &quot;value&quot;: &quot;[.]\\($name).Name&quot;}\r\n      else . end\r\n    )\r\n)\r\n~~~\r\n[Demo](https://jqplay.org/s/Oqo-LhO-WG)\r\n\r\nAs you happen to know that the objects are located in the `.alarms` array, you could also just iterate over the items, `select` only those matching the condition and then assign to their `.label` whatever you want (including `$name`) \r\n~~~none\r\n.tags[] |= (\r\n  .name as $name\r\n  | (.alarms[] | select(has(&quot;setpointA&quot;))).label = {\r\n      bindType: &quot;Tag&quot;, value: &quot;[.]\\($name).Name&quot;\r\n    }\r\n)\r\n~~~\r\n[Demo](https://jqplay.org/s/A3Z6LbW4qy)\r\n\r\n---\r\nEdit responding to OP&#39;s follow-up question\r\n&gt; I actually don&#39;t care about the `setpointA` key, I just want to add the `label` key (as well as another `displayPath` key) to each item in all `alarms` arrays.\r\n\r\n~~~none\r\n.tags[] |= (.name as $name | .alarms[] += (\r\n  {bindType: &quot;Tag&quot;, value: &quot;[.]\\($name).&quot;} | {\r\n          label: (.value += &quot;Name&quot;),\r\n    displayPath: (.value += &quot;Documentation&quot;)\r\n  }\r\n))\r\n~~~\r\n[Demo](https://jqplay.org/s/fYtyBICHle)",
                "title": "How to refer to parent object in jq walk?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1646139914,
                "creation_date": 1646139914,
                "answer_id": 71308924,
                "question_id": 71308155,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As jq does not allow you to refer to parent object, you need to work on parent level :\r\n\r\n```\r\njq &#39;walk(if type == &quot;object&quot; and .alarms and ( .alarms | arrays )\r\n         then (.alarms[] | select(.setpointA)).label =\r\n                    { bindType: &quot;Tag&quot;, value: &quot;[.]\\(.name).Name&quot;}\r\n         else . end\r\n    )&#39; data.json\r\n```",
                "title": "How to refer to parent object in jq walk?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1646184668,
        "creation_date": 1646135927,
        "last_edit_date": 1646183224,
        "question_id": 71308155,
        "body_markdown": "I have some json that I want to add to based on a walk. A simple example of the json I have is below:\r\n```\r\n{\r\n  &quot;valueSource&quot;: &quot;memory&quot;,\r\n  &quot;dataType&quot;: &quot;Boolean&quot;,\r\n  &quot;alarms&quot;: [\r\n    {\r\n      &quot;setpointA&quot;: 1.0,\r\n      &quot;name&quot;: &quot;Alarm&quot;,\r\n      &quot;priority&quot;: &quot;Diagnostic&quot;,\r\n      &quot;ackMode&quot;: &quot;Auto&quot;,\r\n    }\r\n  ],\r\n  &quot;name&quot;: &quot;Test Alarm&quot;,\r\n  &quot;value&quot;: false,\r\n  &quot;tagType&quot;: &quot;AtomicTag&quot;\r\n}\r\n```\r\n\r\nI want to add to each object in the &quot;alarms&quot; key&#39;s array the following key:\r\n```\r\n{\r\n   &quot;bindType&quot;: &quot;Tag&quot;,\r\n   &quot;value&quot;: &quot;[.]&lt;parent.name&gt;.Name&quot;\r\n}\r\n```\r\nwhere `&lt;parent.name&gt;` is &quot;Test Alarm&quot; in this example which is the parent-of-the-alarm-array-item&#39;s &quot;name&quot; key.\r\n\r\nI&#39;ve gotten this jq filter so far that adds the object, but the `value` key value is wrong (it&#39;s getting the alarm array item&#39;s name instead of its parent&#39;s name):\r\n```\r\nwalk( if type == &quot;object&quot; and .setpointA then .label = {&quot;bindType&quot;:&quot;Tag&quot;, &quot;value&quot;: &quot;[.]\\(.name).Name&quot;} else . end)\r\n```\r\n\r\n\r\nEssentially I want this:\r\n```\r\n{\r\n  &quot;valueSource&quot;: &quot;memory&quot;,\r\n  &quot;dataType&quot;: &quot;Boolean&quot;,\r\n  &quot;alarms&quot;: [\r\n    {\r\n      &quot;setpointA&quot;: 1.0,\r\n      &quot;name&quot;: &quot;Alarm&quot;,\r\n      &quot;priority&quot;: &quot;Diagnostic&quot;,\r\n      &quot;ackMode&quot;: &quot;Auto&quot;,\r\n      &quot;label&quot;: {\r\n        &quot;bindType&quot;: &quot;Tag&quot;,\r\n        &quot;value&quot;: &quot;[.]Test Alarm.Name&quot;\r\n      }\r\n    }\r\n  ],\r\n  &quot;name&quot;: &quot;Test Alarm&quot;,\r\n  &quot;value&quot;: false,\r\n  &quot;tagType&quot;: &quot;AtomicTag&quot;\r\n}\r\n```\r\n\r\nHere is my jqplay below. It has the final result in the JSON section, where the Result should match this but doesn&#39;t at the moment.\r\n[https://jqplay.org/s/-qHFIWolrD][1]\r\n\r\nFollow up question:\r\nHow would I add this `displayPath` key as well?\r\n[![enter image description here][2]][2]\r\n\r\n\r\n  [1]: https://jqplay.org/s/-qHFIWolrD\r\n  [2]: https://i.sstatic.net/xPpK8.png",
        "link": "https://stackoverflow.com/questions/71308155/how-to-refer-to-parent-object-in-jq-walk",
        "title": "How to refer to parent object in jq walk?"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 19064273,
                    "reputation": 5331,
                    "user_id": 13919668,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/P6CN6.jpg?s=256",
                    "display_name": "dan",
                    "link": "https://stackoverflow.com/users/13919668/dan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646153298,
                "post_id": 71310915,
                "comment_id": 126050959,
                "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": 1646153355,
                "post_id": 71310915,
                "comment_id": 126050977,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19064273,
                    "reputation": 5331,
                    "user_id": 13919668,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/P6CN6.jpg?s=256",
                    "display_name": "dan",
                    "link": "https://stackoverflow.com/users/13919668/dan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646153374,
                "post_id": 71310915,
                "comment_id": 126050982,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24418188,
                    "reputation": 1,
                    "user_id": 18344804,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2b2ace94edf67886e3961f6c94d900a8?s=256&d=identicon&r=PG",
                    "display_name": "dcturbob",
                    "link": "https://stackoverflow.com/users/18344804/dcturbob"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646162666,
                "post_id": 71310915,
                "comment_id": 126054017,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1646215443,
                "creation_date": 1646215443,
                "answer_id": 71320779,
                "question_id": 71310915,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "@dan @ikegami Thank you SO much for the hint --arg.\r\nThis is the better version: \r\n\r\n```\r\n#!/bin/sh\r\nJSONQUERYFILE=&quot;ReportingQueries.json&quot;\r\nJQCOMMAND=&quot;/C/gitBashCmd/jq-win64.exe&quot;\r\n\r\nfor i in $($JQCOMMAND -c -r &#39;.FilterQueries[].Id&#39; $JSONQUERYFILE) \r\n    do  \r\n        forId=$(echo $i | tr -d &#39;\\r&#39;)         #remove weird chars from $i...   \r\n        echo $JQCOMMAND -c -r --arg idToSearch &quot;$forId&quot; &#39;.FilterQueries[] | if .Id == $idToSearch then &quot;YES&quot; else &quot;NOPE&quot; end&#39; $JSONQUERYFILE \r\n        $JQCOMMAND -c -r --arg idToSearch &quot;$forId&quot; &#39;.FilterQueries[] | if .Id == $idToSearch then &quot;YES&quot; else &quot;NOPE&quot; end&#39; $JSONQUERYFILE\r\ndone\r\n```\r\nAnd it produces the following output:\r\n\r\n```\r\n/C/gitBashCmd/jq-win64.exe -c -r --arg idToSearch 274301 .FilterQueries[] | if .Id == $idToSearch then &quot;YES&quot; else &quot;NOPE&quot; end ReportingQueries.json\r\nYES\r\nNOPE\r\nNOPE\r\nNOPE\r\n/C/gitBashCmd/jq-win64.exe -c -r --arg idToSearch 274005 .FilterQueries[] | if .Id == $idToSearch then &quot;YES&quot; else &quot;NOPE&quot; end ReportingQueries.json\r\nNOPE\r\nYES\r\nNOPE\r\nNOPE\r\n/C/gitBashCmd/jq-win64.exe -c -r --arg idToSearch 274004 .FilterQueries[] | if .Id == $idToSearch then &quot;YES&quot; else &quot;NOPE&quot; end ReportingQueries.json\r\nNOPE\r\nNOPE\r\nYES\r\nNOPE\r\n/C/gitBashCmd/jq-win64.exe -c -r --arg idToSearch 274000 .FilterQueries[] | if .Id == $idToSearch then &quot;YES&quot; else &quot;NOPE&quot; end ReportingQueries.json\r\nNOPE\r\nNOPE\r\nNOPE\r\nYES\r\n\r\n```",
                "title": "Executing command string built in shell script"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1646215443,
        "creation_date": 1646148740,
        "question_id": 71310915,
        "body_markdown": "I&#39;m trying to build a command string in a for loop and execute it. \r\nHowever that doesn&#39;t go as planned.  \r\nWhile in fact, running last 2 lines in comment do seem to work.\r\nHow do I get this solved?  How do you build a command string the right way?\r\n\r\nAny help is much appreciated!\r\n```\r\n#!/bin/sh\r\nJSONQUERYFILE=&quot;ReportingQueries.json&quot;\r\nJQCOMMAND=&quot;/C/gitBashCmd/jq-win64.exe&quot;\r\n\r\nfor i in $($JQCOMMAND -c -r &#39;.FilterQueries[].Id&#39; $JSONQUERYFILE) \r\n\tdo\r\n        #remove weird chars from $i...\t\t\r\n\t\tforId=$(echo $i | tr -d &#39;\\r&#39;)\r\n\t\tjqFilterString=&quot;.FilterQueries[] | if .Id == \\&quot;$forId\\&quot; then \\&quot;YES\\&quot; else \\&quot;NOPE\\&quot; end&quot;\r\n\t\techo $jqFilterString \r\n\t\tcommandString=&quot;$JQCOMMAND -c -r &#39;&quot;$jqFilterString&quot;&#39; $JSONQUERYFILE&quot;\r\n\r\n\t\techo $commandString\r\n\t\t$($commandString)\r\n#       echo /C/gitBashCmd/jq-win64.exe -c -r &#39;.FilterQueries[] | if .Id == &quot;274005&quot; then &quot;YES&quot; else &quot;NOPE&quot; end&#39; ReportingQueries.json\r\n#       /C/gitBashCmd/jq-win64.exe -c -r &#39;.FilterQueries[] | if .Id == &quot;274005&quot; then &quot;YES&quot; else &quot;NOPE&quot; end&#39; ReportingQueries.json\r\ndone\r\n```\r\n\r\nThe output of the 2 last lines in comment seems to work fine:  (the jq-win64 command iterates on itself)\r\n```\r\n.FilterQueries[] | if .Id == &quot;274301&quot; then &quot;YES&quot; else &quot;NOPE&quot; end\r\n/C/gitBashCmd/jq-win64.exe -c -r .FilterQueries[] | if .Id == &quot;274005&quot; then &quot;YES&quot; else &quot;NOPE&quot; end ReportingQueries.json\r\nNOPE\r\nYES\r\nNOPE\r\nNOPE\r\n.FilterQueries[] | if .Id == &quot;274005&quot; then &quot;YES&quot; else &quot;NOPE&quot; end\r\n/C/gitBashCmd/jq-win64.exe -c -r .FilterQueries[] | if .Id == &quot;274005&quot; then &quot;YES&quot; else &quot;NOPE&quot; end ReportingQueries.json\r\nNOPE\r\nYES\r\nNOPE\r\nNOPE\r\n.FilterQueries[] | if .Id == &quot;274004&quot; then &quot;YES&quot; else &quot;NOPE&quot; end\r\n/C/gitBashCmd/jq-win64.exe -c -r .FilterQueries[] | if .Id == &quot;274005&quot; then &quot;YES&quot; else &quot;NOPE&quot; end ReportingQueries.json\r\nNOPE\r\nYES\r\nNOPE\r\nNOPE\r\n.FilterQueries[] | if .Id == &quot;274000&quot; then &quot;YES&quot; else &quot;NOPE&quot; end\r\n/C/gitBashCmd/jq-win64.exe -c -r .FilterQueries[] | if .Id == &quot;274005&quot; then &quot;YES&quot; else &quot;NOPE&quot; end ReportingQueries.json\r\nNOPE\r\nYES\r\nNOPE\r\nNOPE\r\n```\r\nWhile if we run the script with the built up command string the output is the following:\r\n```\r\n.FilterQueries[] | if .Id == &quot;274301&quot; then &quot;YES&quot; else &quot;NOPE&quot; end\r\n/C/gitBashCmd/jq-win64.exe -c -r &#39;.FilterQueries[] | if .Id == &quot;274301&quot; then &quot;YES&quot; else &quot;NOPE&quot; end&#39; ReportingQueries.json\r\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&#39;.FilterQueries[]\r\njq: 1 compile error\r\n.FilterQueries[] | if .Id == &quot;274005&quot; then &quot;YES&quot; else &quot;NOPE&quot; end\r\n/C/gitBashCmd/jq-win64.exe -c -r &#39;.FilterQueries[] | if .Id == &quot;274005&quot; then &quot;YES&quot; else &quot;NOPE&quot; end&#39; ReportingQueries.json\r\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&#39;.FilterQueries[]\r\njq: 1 compile error\r\n.FilterQueries[] | if .Id == &quot;274004&quot; then &quot;YES&quot; else &quot;NOPE&quot; end\r\n/C/gitBashCmd/jq-win64.exe -c -r &#39;.FilterQueries[] | if .Id == &quot;274004&quot; then &quot;YES&quot; else &quot;NOPE&quot; end&#39; ReportingQueries.json\r\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&#39;.FilterQueries[]\r\njq: 1 compile error\r\n.FilterQueries[] | if .Id == &quot;274000&quot; then &quot;YES&quot; else &quot;NOPE&quot; end\r\n/C/gitBashCmd/jq-win64.exe -c -r &#39;.FilterQueries[] | if .Id == &quot;274000&quot; then &quot;YES&quot; else &quot;NOPE&quot; end&#39; ReportingQueries.json\r\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&#39;.FilterQueries[]\r\njq: 1 compile error\r\n```",
        "link": "https://stackoverflow.com/questions/71310915/executing-command-string-built-in-shell-script",
        "title": "Executing command string built in shell script"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5880924,
                    "reputation": 4889,
                    "user_id": 4630325,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://www.gravatar.com/avatar/1e076704282eb3a573a289839c349512?s=256&d=identicon&r=PG",
                    "display_name": "Markus AO",
                    "link": "https://stackoverflow.com/users/4630325/markus-ao"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646155685,
                "post_id": 71312313,
                "comment_id": 126051865,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646158796,
                "last_edit_date": 1646158796,
                "creation_date": 1646155878,
                "answer_id": 71312450,
                "question_id": 71312313,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t put commas before closing brackets or curly braces (it&#39;s not valid JSON). Your input should look like this:\r\n~~~json\r\n{\r\n  &quot;results&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;1231&quot;,\r\n      &quot;name&quot;: &quot;AAAA&quot;,\r\n      &quot;div&quot;: {\r\n        &quot;id&quot;: &quot;AAA&quot;,\r\n        &quot;name&quot;: &quot;DDSAA&quot;,\r\n        &quot;selfUri&quot;: &quot;&quot;\r\n      },\r\n      &quot;chat&quot;: {\r\n        &quot;jabberId&quot;: &quot;nn&quot;\r\n      },\r\n      &quot;department&quot;: &quot;Shared Services Organization&quot;,\r\n      &quot;email&quot;: &quot;Test@gmail.com&quot;,\r\n      &quot;primaryContactInfo&quot;: [\r\n        {\r\n          &quot;address&quot;: &quot;Test@gmail.com&quot;,\r\n          &quot;mediaType&quot;: &quot;EMAIL&quot;,\r\n          &quot;type&quot;: &quot;PRIMARY&quot;\r\n        }\r\n      ],\r\n      &quot;addresses&quot;: [],\r\n      &quot;state&quot;: &quot;active&quot;,\r\n      &quot;title&quot;: &quot;AAA&quot;,\r\n      &quot;username&quot;: &quot;Test@gmail.com&quot;,\r\n      &quot;version&quot;: 27,\r\n      &quot;authorization&quot;: {\r\n        &quot;roles&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;01256689-c5ed-43a5-b370-58522402830d&quot;,\r\n            &quot;name&quot;: &quot;AA&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;1e65b009-9f8f-4eef-9844-83944002c095&quot;,\r\n            &quot;name&quot;: &quot;BBB&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;8a19f1ff-40e5-45d2-b758-14550a173323&quot;,\r\n            &quot;name&quot;: &quot;CCC&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;d02250e2-7071-46bf-885b-43edff2d88a6&quot;,\r\n            &quot;name&quot;: &quot;Supervisor&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;1255&quot;,\r\n      &quot;name&quot;: &quot;BBBB&quot;,\r\n      &quot;div&quot;: {\r\n        &quot;id&quot;: &quot;AAA&quot;,\r\n        &quot;name&quot;: &quot;DDSAA&quot;,\r\n        &quot;selfUri&quot;: &quot;&quot;\r\n      },\r\n      &quot;chat&quot;: {\r\n        &quot;jabberId&quot;: &quot;nn&quot;\r\n      },\r\n      &quot;department&quot;: &quot;Shared Services Organization&quot;,\r\n      &quot;email&quot;: &quot;Test@gmail.com&quot;,\r\n      &quot;primaryContactInfo&quot;: [\r\n        {\r\n          &quot;address&quot;: &quot;Test@gmail.com&quot;,\r\n          &quot;mediaType&quot;: &quot;EMAIL&quot;,\r\n          &quot;type&quot;: &quot;PRIMARY&quot;\r\n        }\r\n      ],\r\n      &quot;addresses&quot;: [],\r\n      &quot;state&quot;: &quot;active&quot;,\r\n      &quot;title&quot;: &quot;AAA&quot;,\r\n      &quot;username&quot;: &quot;Test@gmail.com&quot;,\r\n      &quot;version&quot;: 27,\r\n      &quot;authorization&quot;: {\r\n        &quot;roles&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;01256689-c5ed-43a5-b370-58522402830d&quot;,\r\n            &quot;name&quot;: &quot;AA&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;1e65b009-9f8f-4eef-9844-83944002c095&quot;,\r\n            &quot;name&quot;: &quot;BBB&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;8a19f1ff-40e5-45d2-b758-14550a173323&quot;,\r\n            &quot;name&quot;: &quot;CCC&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;d02250e2-7071-46bf-885b-43edff2d88a6&quot;,\r\n            &quot;name&quot;: &quot;Tester&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  ]\r\n}\r\n~~~\r\nThen, you can use `select` to narrow down your target objects (here using `any` to check if at least one of the role names matches your string -- thx @ikegami), then output any part of the resulting object(s):\r\n\r\n~~~sh\r\njq &#39;\r\n  .results[]\r\n  | select(any(.authorization.roles[]; .name == &quot;Supervisor&quot;))\r\n  | {id, name}\r\n&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;id&quot;: &quot;1231&quot;,\r\n  &quot;name&quot;: &quot;AAAA&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/mmj8ykWQzH)\r\n\r\nIf instead of a JSON output you need raw text, use the `-r` (or `--raw-output`) flag, and provide the fields you are interested in:\r\n~~~sh\r\njq -r &#39;\r\n  .results[]\r\n  | select(any(.authorization.roles[]; .name == &quot;Supervisor&quot;))\r\n  | .id, .name\r\n&#39;\r\n~~~\r\n~~~none\r\n1231\r\nAAAA\r\n~~~\r\n[Demo](https://jqplay.org/s/SbfjBfmWa5)\r\n",
                "title": "Need help parsing json output with jq for a complex json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1646158796,
        "creation_date": 1646155138,
        "last_edit_date": 1646155498,
        "question_id": 71312313,
        "body_markdown": "For the below JSON, I need the result.id and result.name output using jq for the ones having \r\n\r\n```\r\nauthorization.roles[].name == &quot;Supervisor&quot; \r\n```\r\n\r\nWhat is the command for jq to to that ?  For the below json we expect 1231 id and name AAAA alone as output as that only has Supervisor as role\r\n\r\n```json\r\n{\r\n\t&quot;results&quot;: [{\r\n\t\t&quot;id&quot;: &quot;1231&quot;,\r\n\t\t&quot;name&quot;: &quot;AAAA&quot;,\r\n\t\t&quot;div&quot;: {\r\n\t\t\t&quot;id&quot;: &quot;AAA&quot;,\r\n\t\t\t&quot;name&quot;: &quot;DDSAA&quot;,\r\n\t\t\t&quot;selfUri&quot;: &quot;&quot;\r\n\t\t},\r\n\t\t&quot;chat&quot;: {\r\n\t\t\t&quot;jabberId&quot;: &quot;nn&quot;\r\n\t\t},\r\n\t\t&quot;department&quot;: &quot;Shared Services Organization&quot;,\r\n\t\t&quot;email&quot;: &quot;Test@gmail.com&quot;,\r\n\t\t&quot;primaryContactInfo&quot;: [{\r\n\t\t\t&quot;address&quot;: &quot;Test@gmail.com&quot;,\r\n\t\t\t&quot;mediaType&quot;: &quot;EMAIL&quot;,\r\n\t\t\t&quot;type&quot;: &quot;PRIMARY&quot;\r\n\t\t}],\r\n\t\t&quot;addresses&quot;: [],\r\n\t\t&quot;state&quot;: &quot;active&quot;,\r\n\t\t&quot;title&quot;: &quot;AAA&quot;,\r\n\t\t&quot;username&quot;: &quot;Test@gmail.com&quot;,\r\n\t\t&quot;version&quot;: 27,\r\n\t\t&quot;authorization&quot;: {\r\n\t\t\t&quot;roles&quot;: [{\r\n\t\t\t\t&quot;id&quot;: &quot;01256689-c5ed-43a5-b370-58522402830d&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;AA&quot;\r\n\t\t\t}, {\r\n\t\t\t\t&quot;id&quot;: &quot;1e65b009-9f8f-4eef-9844-83944002c095&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;BBB&quot;\r\n\t\t\t}, {\r\n\t\t\t\t&quot;id&quot;: &quot;8a19f1ff-40e5-45d2-b758-14550a173323&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;CCC&quot;\r\n\t\t\t}, {\r\n\t\t\t\t&quot;id&quot;: &quot;d02250e2-7071-46bf-885b-43edff2d88a6&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;Supervisor&quot;\r\n\t\t\t}]\r\n\t\t}\r\n\t}, {\r\n\t\t&quot;id&quot;: &quot;1255&quot;,\r\n\t\t&quot;name&quot;: &quot;BBBB&quot;,\r\n\t\t&quot;div&quot;: {\r\n\t\t\t&quot;id&quot;: &quot;AAA&quot;,\r\n\t\t\t&quot;name&quot;: &quot;DDSAA&quot;,\r\n\t\t\t&quot;selfUri&quot;: &quot;&quot;\r\n\t\t},\r\n\t\t&quot;chat&quot;: {\r\n\t\t\t&quot;jabberId&quot;: &quot;nn&quot;\r\n\t\t},\r\n\t\t&quot;department&quot;: &quot;Shared Services Organization&quot;,\r\n\t\t&quot;email&quot;: &quot;Test@gmail.com&quot;,\r\n\t\t&quot;primaryContactInfo&quot;: [{\r\n\t\t\t&quot;address&quot;: &quot;Test@gmail.com&quot;,\r\n\t\t\t&quot;mediaType&quot;: &quot;EMAIL&quot;,\r\n\t\t\t&quot;type&quot;: &quot;PRIMARY&quot;\r\n\t\t}],\r\n\t\t&quot;addresses&quot;: [],\r\n\t\t&quot;state&quot;: &quot;active&quot;,\r\n\t\t&quot;title&quot;: &quot;AAA&quot;,\r\n\t\t&quot;username&quot;: &quot;Test@gmail.com&quot;,\r\n\t\t&quot;version&quot;: 27,\r\n\t\t&quot;authorization&quot;: {\r\n\t\t\t&quot;roles&quot;: [{\r\n\t\t\t\t&quot;id&quot;: &quot;01256689-c5ed-43a5-b370-58522402830d&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;AA&quot;\r\n\t\t\t}, {\r\n\t\t\t\t&quot;id&quot;: &quot;1e65b009-9f8f-4eef-9844-83944002c095&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;BBB&quot;\r\n\t\t\t}, {\r\n\t\t\t\t&quot;id&quot;: &quot;8a19f1ff-40e5-45d2-b758-14550a173323&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;CCC&quot;\r\n\t\t\t}, {\r\n\t\t\t\t&quot;id&quot;: &quot;d02250e2-7071-46bf-885b-43edff2d88a6&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;Tester&quot;\r\n\t\t\t}]\r\n\t\t}\r\n\t}]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/71312313/need-help-parsing-json-output-with-jq-for-a-complex-json",
        "title": "Need help parsing json output with jq for a complex json"
    },
    {
        "tags": [
            "json",
            "key",
            "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": 1646202649,
                "post_id": 71317638,
                "comment_id": 126062234,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646205133,
                "last_edit_date": 1646205133,
                "creation_date": 1646203117,
                "answer_id": 71318384,
                "question_id": 71317638,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Elements of a stream are processed independently. So we have to change the input.\r\n\r\nWe could group the stream elements into an array. For an input stream, this can be achieved using `--slurp`/`-s`.&lt;sup&gt;[1]&lt;/sup&gt;\r\n\r\n```sh\r\njq -s &#39;\r\n   ( .[0].Columns[0] | map_values( tostring ) ) as $map |\r\n   (\r\n      .[0],\r\n      (\r\n         .[1:][] |\r\n         .Users[] |= with_entries(\r\n            .key = $map[ .key ]\r\n         )\r\n      )\r\n   )\r\n&#39;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/Zp5rnziBEC) on jqplay\r\n\r\nAlternatively, we could use `--null-input`/`-n` in conjunction with `input` and/or `inputs` to read the input.\r\n\r\n```sh\r\njq -n &#39;\r\n   input |\r\n   ( .Columns[0] | map_values( tostring ) ) as $map |\r\n   (\r\n      .,\r\n      (\r\n         inputs |\r\n         .Users[] |= with_entries(\r\n            .key = $map[ .key ]\r\n         )\r\n      )\r\n   )\r\n&#39;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/cXWDCrqJMt) on jqplay\r\n\r\nNote that your desired output isn&#39;t valid JSON. Object keys must be strings. So the above produces a slightly different document than requested.\r\n\r\nNote that I assumed that `.Columns` is always an array of one exactly one element. This is a nonsense assumption, but it&#39;s the only way the question makes sense.\r\n\r\n---\r\n\r\n1. For a stream the code generates, you could place the stream generator in an array constructor (`[]`). `reduce` can also be used to collect from a stream. For example, `map( ... )` can be written as `[ .[] | ... ]` and as `reduce .[] as $_ ( []; . + [ $_ | ... ] )`.\r\n",
                "title": "Use JQ to create new object where the key comes from one object and the value comes from another"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1646206674,
                "creation_date": 1646206674,
                "answer_id": 71318992,
                "question_id": 71317638,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following has the merit of simplicity, though it does not sort the keys.\r\nIt assumes jq is invoked with the -n option and of course produces a stream of valid JSON objects:\r\n\r\n```\r\ninput\r\n| . as $Columns\r\n| .Columns[0] as $dict\r\n| input # Users\r\n| .Users[] |= with_entries(.key |= ($dict[.]|tostring))\r\n| $Columns, .\r\n```\r\n\r\nIf having the keys sorted is important, then you could easily add suitable code to do that; alternatively, if you don&#39;t mind having the keys of all objects sorted, you could use the -S command-line option.\r\n\r\n\r\n",
                "title": "Use JQ to create new object where the key comes from one object and the value comes from another"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1646206674,
        "creation_date": 1646196993,
        "last_edit_date": 1646203134,
        "question_id": 71317638,
        "body_markdown": "I have the following input:\r\n\r\n```json\r\n{\r\n  &quot;Columns&quot;: [\r\n    {\r\n      &quot;email&quot;: 123,\r\n      &quot;name&quot;: 456,\r\n      &quot;firstName&quot;: 789,\r\n      &quot;lastName&quot;: 450,\r\n      &quot;admin&quot;: 900,\r\n      &quot;licensedSheetCreator&quot;: 617,\r\n      &quot;groupAdmin&quot;: 354,\r\n      &quot;resourceViewer&quot;: 804,\r\n      &quot;id&quot;: 730,\r\n      &quot;status&quot;: 523,\r\n      &quot;sheetCount&quot;: 298\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;Users&quot;: [\r\n    {\r\n      &quot;email&quot;: &quot;abc@def.com&quot;,\r\n      &quot;name&quot;: &quot;Abc Def&quot;,\r\n      &quot;firstName&quot;: &quot;Abc&quot;,\r\n      &quot;lastName&quot;: &quot;Def&quot;,\r\n      &quot;admin&quot;: false,\r\n      &quot;licensedSheetCreator&quot;: true,\r\n      &quot;groupAdmin&quot;: false,\r\n      &quot;resourceViewer&quot;: true,\r\n      &quot;id&quot;: 521,\r\n      &quot;status&quot;: &quot;ACTIVE&quot;,\r\n      &quot;sheetCount&quot;: 0\r\n    },\r\n    {\r\n      &quot;email&quot;: &quot;aaa@bbb.com&quot;,\r\n      &quot;name&quot;: &quot;Aaa Bob&quot;,\r\n      &quot;firstName&quot;: &quot;Aaa&quot;,\r\n      &quot;lastName&quot;: &quot;Bob&quot;,\r\n      &quot;admin&quot;: false,\r\n      &quot;licensedSheetCreator&quot;: true,\r\n      &quot;groupAdmin&quot;: false,\r\n      &quot;resourceViewer&quot;: false,\r\n      &quot;id&quot;: 352,\r\n      &quot;status&quot;: &quot;ACTIVE&quot;,\r\n      &quot;sheetCount&quot;: 0\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI need to change the key for all key value pairs in users to match the value in Columns, like so:\r\n\r\n```json\r\n{\r\n  &quot;Columns&quot;: [\r\n    {\r\n      &quot;email&quot;: 123,\r\n      &quot;name&quot;: 456,\r\n      &quot;firstName&quot;: 789,\r\n      &quot;lastName&quot;: 450,\r\n      &quot;admin&quot;: 900,\r\n      &quot;licensedSheetCreator&quot;: 617,\r\n      &quot;groupAdmin&quot;: 354,\r\n      &quot;resourceViewer&quot;: 804,\r\n      &quot;id&quot;: 730,\r\n      &quot;status&quot;: 523,\r\n      &quot;sheetCount&quot;: 298\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;Users&quot;: [\r\n    {\r\n      123: &quot;abc@def.com&quot;,\r\n      456: &quot;Abc Def&quot;,\r\n      789: &quot;Abc&quot;,\r\n      450: &quot;Def&quot;,\r\n      900: false,\r\n      617: true,\r\n      354: false,\r\n      804: true,\r\n      730: 521,\r\n      523: &quot;ACTIVE&quot;,\r\n      298: 0\r\n    },\r\n    {\r\n      123: &quot;aaa@bbb.com&quot;,\r\n      456: &quot;Aaa Bob&quot;,\r\n      789: &quot;Aaa&quot;,\r\n      450: &quot;Bob&quot;,\r\n      900: false,\r\n      617: true,\r\n      354: false,\r\n      804: false,\r\n      730: 352,\r\n      523: &quot;ACTIVE&quot;,\r\n      298: 0\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI don&#39;t mind if I update the Users array or create a new array of objects. \r\nI have tried several combinations of with entries, to entries, from entries, trying to search for keys using variables but the more I dive into it, the more confused I get.\r\n",
        "link": "https://stackoverflow.com/questions/71317638/use-jq-to-create-new-object-where-the-key-comes-from-one-object-and-the-value-co",
        "title": "Use JQ to create new object where the key comes from one object and the value comes from another"
    },
    {
        "tags": [
            "arrays",
            "json",
            "command-line",
            "automation",
            "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": 1646202406,
                "post_id": 71318030,
                "comment_id": 126062167,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20854950,
                    "reputation": 67,
                    "user_id": 15318538,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-cVsWP-GxmCo/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuclLw6Bnod2fGBTlCsMa8T2JH3tU7Q/s96-c/s256-rj/photo.jpg",
                    "display_name": "liteyagami",
                    "link": "https://stackoverflow.com/users/15318538/liteyagami"
                },
                "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": 1646237224,
                "post_id": 71318030,
                "comment_id": 126074683,
                "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": 1646244385,
                "post_id": 71318030,
                "comment_id": 126077428,
                "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": 1646244422,
                "post_id": 71318030,
                "comment_id": 126077444,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1646204364,
                "creation_date": 1646204364,
                "answer_id": 71318575,
                "question_id": 71318030,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In both your attempts, the `select` is incorrectly formulated (or in the wrong place, depending on your point of view).  This would work:\r\n```\r\nselect(.type == &quot;dissertation&quot;)\r\n| [.doi,.title, .publication_year, .publication_date, .type]\r\n| @csv\r\n```",
                "title": "Filter keys with specific JSON values in JSON-LD files"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1646204364,
        "creation_date": 1646200452,
        "last_edit_date": 1646202196,
        "question_id": 71318030,
        "body_markdown": "I have a zip file(GZ) which when unzipped contains JSON in each line. Below is one sample JSON line. I am trying to extract specific fields only to CSV file using ```jq```. I want to extract these fields with a condition that the ```type``` key should have the value ```dissertation``` only.\r\n\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;https://openalex.org/W2777209504&quot;,\r\n  &quot;doi&quot;: &quot;https://doi.org/10.24026/1818-1384.1(42).2013.77470&quot;,\r\n  &quot;display_name&quot;: &quot;Hyperandrogenism as a factor of reproductive losses&quot;,\r\n  &quot;title&quot;: &quot;Hyperandrogenism as a factor of reproductive losses&quot;,\r\n  &quot;publication_year&quot;: 2013, \r\n  &quot;publication_date&quot;: &quot;2013-03-27&quot;,\r\n  &quot;ids&quot;: {\r\n    &quot;openalex&quot;: &quot;https://openalex.org/W2777209504&quot;,\r\n    &quot;doi&quot;: &quot;https://doi.org/10.24026/1818-1384.1(42).2013.77470&quot;,\r\n    &quot;mag&quot;: 2777209504\r\n  },\r\n  &quot;type&quot;: &quot;journal-article&quot;,\r\n  &quot;counts_by_year&quot;: [\r\n    {\r\n      &quot;year&quot;: 2019,\r\n      &quot;cited_by_count&quot;: 1\r\n    }\r\n  ],\r\n  &quot;cited_by_api_url&quot;: &quot;https://api.openalex.org/works?filter=cites:W2777209504&quot;,\r\n  &quot;updated_date&quot;: &quot;2021-11-03&quot;,\r\n  &quot;created_date&quot;: &quot;2018-01-05&quot;,\r\n  &quot;abstract_inverted_index&quot;: {}\r\n}\r\n```\r\n\r\nI tried the below two commands and neither of them worked: \\\r\n1. ```gzcat -c sample.gz | jq -rc &#39;[.doi,.title, .publication_year, .publication_date, .type] | select(.type |contains(&quot;dissertation&quot;)) | @csv&#39;&gt;target.csv```\r\n2. ```gzcat -c sample.gz | jq -rc &#39;[.doi,.title, .publication_year, .publication_date, .type] | select(.type==&quot;dissertation&quot;) | @csv&#39;&gt;target.csv```\r\n\r\nThe output received for both of them is: \\\r\n```jq: error (at &lt;stdin&gt;:108753): Cannot index string with string &quot;title&quot;```\r\n\r\nI tried all possibles ways to filter down my JSON-LD file but I am unable to succeed. Any pointers will be of great help. \r\n\r\n",
        "link": "https://stackoverflow.com/questions/71318030/filter-keys-with-specific-json-values-in-json-ld-files",
        "title": "Filter keys with specific JSON values in JSON-LD files"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646216894,
                "last_edit_date": 1646216894,
                "creation_date": 1646216283,
                "answer_id": 71320974,
                "question_id": 71320895,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your approach using `reduce` could be sanitized to\r\n~~~sh\r\njq &#39;group_by(.[&quot;key&quot;]) | .[] |= reduce .[] as $in (\r\n  {value: []}; .key = $in.key | .value += [$in.value]\r\n)&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;value&quot;: [\r\n      &quot;a&quot;,\r\n      &quot;c&quot;\r\n    ],\r\n    &quot;key&quot;: 1\r\n  },\r\n  {\r\n    &quot;value&quot;: [\r\n      &quot;b&quot;\r\n    ],\r\n    &quot;key&quot;: 2\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/WzNfJOE3ZS)\r\n\r\nAnother approach using `map` would be\r\n~~~sh\r\njq &#39;group_by(.key) | map({key: .[0].key, value: map(.value)})&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;key&quot;: 1,\r\n    &quot;value&quot;: [\r\n      &quot;a&quot;,\r\n      &quot;c&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;key&quot;: 2,\r\n    &quot;value&quot;: [\r\n      &quot;b&quot;\r\n    ]\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/iWjjYQmX9s)\r\n",
                "title": "Merging property values of objects with common key with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1646216894,
        "creation_date": 1646215910,
        "question_id": 71320895,
        "body_markdown": "I have an array of objects with 2 properties, say &quot;key&quot; and &quot;value&quot;:\r\n```\r\n[\r\n   {key: 1, value: a}, \r\n   {key: 2, value: b}, \r\n   {key: 1, value: c}\r\n]\r\n```\r\nNow, I would like to merge the values of the &quot;value&quot; properties of objects with the same &quot;key&quot; property value. That is the previous array is transformed into:\r\n```\r\n[\r\n   {key: 1, value: [a, c]}, \r\n   {key: 2, value: [b]}\r\n]\r\n```\r\n\r\nI tried something like:\r\n```\r\n$ echo &#39;[{&quot;key&quot;: &quot;1&quot;, &quot;val&quot;: &quot;a&quot;}, {&quot;key&quot;: &quot;2&quot;, &quot;val&quot;: &quot;b&quot;}, {&quot;key&quot;: &quot;1&quot;, &quot;val&quot;: &quot;c&quot;}]&#39; | jq &#39;. | group_by(.[&quot;key&quot;]) | .[] | reduce .[] as $in ({&quot;val&quot;: []}; {&quot;key&quot;: $in.key, &quot;val&quot;:  [$in.val] + .[&quot;val&quot;]})&#39;\r\n```\r\nBut it triggers a jq syntax error and I have no idea why. I am stuck.\r\n\r\nAny idea ? \r\n\r\nThanks\r\n\r\nB\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71320895/merging-property-values-of-objects-with-common-key-with-jq",
        "title": "Merging property values of objects with common key with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646226294,
                "last_edit_date": 1646226294,
                "creation_date": 1646225008,
                "answer_id": 71322909,
                "question_id": 71322737,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If while the overall structure may be complex, the amount and arrangement of the arrays are not (e.g. no array is itself an item of another array at a position higher than 3, etc), you can simply address &quot;all arrays&quot; and shorten them independently from each other:\r\n~~~none\r\n(.. | arrays) |= .[:3]\r\n~~~\r\n\r\nIf, however, you need to cover those special cases, `walk` would be more appropriate as it descends the document tree in order and therefore will not leave over dangling parts after the trucation:\r\n~~~none\r\nwalk(if type == &quot;array&quot; then .[:3] else . end)\r\n~~~\r\n",
                "title": "jq: limitting all arrays in a complex json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1646226294,
        "creation_date": 1646224233,
        "question_id": 71322737,
        "body_markdown": "Trying the following code:\r\n\r\n    echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;,&quot;e&quot;]&#39; | jq &#39;..|= if type == &quot;array&quot; then [limit(3;.[])] else . end&#39;\r\n    [\r\n      &quot;a&quot;,\r\n      &quot;b&quot;,\r\n      &quot;c&quot;,\r\n      null,\r\n      null\r\n    ]\r\n\r\nExpect it to produce short array:\r\n\r\n    [\r\n      &quot;a&quot;,\r\n      &quot;b&quot;,\r\n      &quot;c&quot;\r\n    ]\r\n\r\nJSONs I work with are big and complex. My goal is to shrink all arrays down to length 3. What I get is arrays of original length with lots of nulls.\r\n\r\nIdeas? ",
        "link": "https://stackoverflow.com/questions/71322737/jq-limitting-all-arrays-in-a-complex-json",
        "title": "jq: limitting all arrays in a complex json"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646229532,
                "post_id": 71323947,
                "comment_id": 126071171,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19061407,
                    "reputation": 511,
                    "user_id": 13917424,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/42d4e6ab5d6c63961d9a7e0829741455?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shahar",
                    "link": "https://stackoverflow.com/users/13917424/shahar"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646229569,
                "post_id": 71323947,
                "comment_id": 126071186,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646230517,
                "last_edit_date": 1646230517,
                "creation_date": 1646229684,
                "answer_id": 71324009,
                "question_id": 71323947,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`any` (see the [manual](https://stedolan.github.io/jq/manual/#any%2Cany%28condition%29%2Cany%28generator%3Bcondition%29)) can return a boolean value if a condition matches with at least one item.\r\n\r\n~~~sh\r\njq &#39;any(.result[]; .host == &quot;Server0001&quot;)&#39;\r\n~~~\r\n~~~json\r\nfalse\r\n~~~\r\n[Demo](https://jqplay.org/s/GJ3KiTMMFz)\r\n\r\n~~~sh\r\njq &#39;any(.result[]; .host == &quot;Server00001&quot;)&#39;\r\n~~~\r\n~~~json\r\ntrue\r\n~~~\r\n[Demo](https://jqplay.org/s/Gnx9FJyKRF)\r\n\r\n---\r\nYou may also want to use the some parameters when invoking `jq` (see the [manual](https://stedolan.github.io/jq/manual/#Invokingjq)): The `--arg`  option, for instance, lets you add a variable which can be initialized from outside the filter string. And with the `-e` (or `--exit-status`) flag  you can have `jq` set the exit status according to the filter&#39;s final result. Together, this enables you to use `jq` like this:\r\n~~~sh\r\nif jq --arg host &quot;Server0001&quot; -e &#39;any(.result[]; .host == $host)&#39;;\r\nthen\r\n  …\r\nelse\r\n  …\r\nfi\r\n~~~",
                "title": "Json use jq to parse, read and return true if entry found"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1731928366,
        "creation_date": 1646229426,
        "last_edit_date": 1731928366,
        "question_id": 71323947,
        "body_markdown": "Apologies if this is basic but the doc for jq is not so good\r\ni have this json:\r\n\r\n```\r\n{\r\n\t&quot;jsonrpc&quot;: &quot;2.0&quot;,\r\n\t&quot;result&quot;: [{\r\n\t\t&quot;hostid&quot;: &quot;10084&quot;,\r\n\t\t&quot;host&quot;: &quot;Zabbix server&quot;,\r\n\t\t&quot;interfaces&quot;: [{\r\n\t\t\t&quot;interfaceid&quot;: &quot;1&quot;,\r\n\t\t\t&quot;ip&quot;: &quot;127.0.0.1&quot;\r\n\t\t}]\r\n\t}, {\r\n\t\t&quot;hostid&quot;: &quot;10336&quot;,\r\n\t\t&quot;host&quot;: &quot;AUTO&quot;,\r\n\t\t&quot;interfaces&quot;: [{\r\n\t\t\t&quot;interfaceid&quot;: &quot;4&quot;,\r\n\t\t\t&quot;ip&quot;: &quot;1.2.3.4&quot;\r\n\t\t}]\r\n\t}, {\r\n\t\t&quot;hostid&quot;: &quot;10337&quot;,\r\n\t\t&quot;host&quot;: &quot;AUTOSERVER&quot;,\r\n\t\t&quot;interfaces&quot;: [{\r\n\t\t\t&quot;interfaceid&quot;: &quot;5&quot;,\r\n\t\t\t&quot;ip&quot;: &quot;4.5.6.7&quot;\r\n\t\t}]\r\n\t}, {\r\n\t\t&quot;hostid&quot;: &quot;10348&quot;,\r\n\t\t&quot;host&quot;: &quot;Server00001&quot;,\r\n\t\t&quot;interfaces&quot;: [{\r\n\t\t\t&quot;interfaceid&quot;: &quot;16&quot;,\r\n\t\t\t&quot;ip&quot;: &quot;4.5.6.7&quot;\r\n\t\t}]\r\n    \r\n\t}],\r\n\t&quot;id&quot;: 2\r\n}\r\n\r\n```\r\n\r\ni need to find a way to use jq to find if &quot;Server0001&quot; exists in one of the hosts\r\ni know i can use grep but i prefer using jq here, like select..\r\nany help or ref toa good doc would be much appriciated\r\n",
        "link": "https://stackoverflow.com/questions/71323947/json-use-jq-to-parse-read-and-return-true-if-entry-found",
        "title": "Json use jq to parse, read and return true if entry found"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 673865,
                    "reputation": 5739,
                    "user_id": 889053,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3e26b08aa9c9bff40d6dab7b98680bf4?s=256&d=identicon&r=PG",
                    "display_name": "Christian Bongiorno",
                    "link": "https://stackoverflow.com/users/889053/christian-bongiorno"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646257848,
                "post_id": 71329446,
                "comment_id": 126081675,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1646259263,
                "last_edit_date": 1646259263,
                "creation_date": 1646257718,
                "answer_id": 71329554,
                "question_id": 71329446,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\njq -j &#39;map(@json) | join(&quot;\\u0000&quot;)&#39; http/customer/us/customers.json |\r\n   xargs -0 -I % curl -X POST http://localhost:3000/customers -d %\r\n```\r\n\r\nSince `@json` never produces any line feeds, the following would also work:\r\n\r\n```sh\r\njq -r &#39;.[] | @json&#39; http/customer/us/customers.json |\r\n   xargs -I % curl -X POST http://localhost:3000/customers -d %\r\n```\r\n\r\n[Demo](https://jqplay.org/s/0z--Al_UbY) on jq play\r\n\r\n* `--join-output`/`-j` prints the string as-is rather that rather than printing a JSON string literal that produces the string. Doesn&#39;t add any line feeds, not even a trailing one.\r\n\r\n* `--raw-output`/`-r` prints the string as-is rather that rather than printing a JSON string literal that produces the string. Adds a line feed after each string.\r\n\r\n* `&quot;\\\\0&quot;` doesn&#39;t produce a NUL. You want `&quot;\\u0000&quot;` for that.\r\n\r\n*  `. |` is useless.\r\n\r\n*  There&#39;s no difference between `&#39;%&#39;` and `%`. They both pass `%` to `xargs`.\r\n\r\n* `-n 1` is useless. `-I` implies `-L 1`, which renders `-n 1` redundant.\r\n\r\n* `{}` is more commonly used as the replacement expression than `%`. But `%` is also fine, so I didn&#39;t change this.\r\n",
                "title": "How to pass individual elements in an array in JQ to xargs"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1646257722,
                "creation_date": 1646257722,
                "answer_id": 71329555,
                "question_id": 71329446,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `--join-output` (or `-j`) option to output raw text with no newlines, and use `\\u0000` to create the `NUL` character:\r\n~~~sh\r\njq -j &#39;map(@json) | join(&quot;\\u0000&quot;)&#39; http/customer/us/customers.json \\\r\n  | xargs -0 -n 1 -I % curl -X POST http://localhost:3000/customers -d &#39;%&#39;\r\n~~~\r\n",
                "title": "How to pass individual elements in an array in JQ to xargs"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1646259263,
        "creation_date": 1646257007,
        "question_id": 71329446,
        "body_markdown": "I have an array like such:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;customer&quot;: {\r\n      &quot;id&quot;: &quot;61ae22891dbcb5200f4af298&quot;,\r\n      &quot;customerId&quot;: &quot;C0001346&quot;,\r\n      &quot;companyName&quot;: &quot;Real Constructions&quot;,\r\n      &quot;displayName&quot;: &quot;Real Constructions&quot;,\r\n      &quot;fullName&quot;: &quot;NiyatiU&quot;,\r\n      &quot;email&quot;: &quot;niyati@curbwaste.com&quot;,\r\n      &quot;phone&quot;: &quot;(987) 654-3209&quot;\r\n    },\r\n    &quot;address&quot;: {\r\n      &quot;streetName&quot;: &quot;NY&quot;,\r\n      &quot;state&quot;: &quot;NY&quot;,\r\n      &quot;city&quot;: &quot;NY&quot;,\r\n      &quot;zipcode&quot;: &quot;39092&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;customer&quot;: {\r\n      &quot;id&quot;: &quot;61ae29f31dbcb5200f4af2b2&quot;,\r\n      &quot;customerId&quot;: &quot;C0001347&quot;,\r\n      &quot;companyName&quot;: &quot;UK Reality&quot;,\r\n      &quot;displayName&quot;: &quot;UK Reality&quot;,\r\n      &quot;fullName&quot;: &quot;VatsalShah&quot;,\r\n      &quot;email&quot;: &quot;vatsal@curbwaste.com&quot;,\r\n      &quot;phone&quot;: &quot;(766) 688-1348&quot;\r\n    },\r\n    &quot;address&quot;: {\r\n      &quot;streetName&quot;: &quot;Queens&quot;,\r\n      &quot;state&quot;: &quot;NY&quot;,\r\n      &quot;city&quot;: &quot;Queens&quot;,\r\n      &quot;zipcode&quot;: &quot;11354&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nand I would like to pass each object as a seperate param to xargs and curl. Psuedo code like\r\n\r\n```bash\r\njq &#39;. | map(@json) | join(&quot;\\\\0&quot;)&#39; http/customer/us/customers.json \\\r\n  | xargs -0 -n 1 -I % curl -X POST http://localhost:3000/customers -d &#39;%&#39;\r\n```\r\n\r\nBut then I get:\r\n\r\n```\r\nxargs: insufficient space for argument\r\n```\r\nbecause the json element is too big, I&#39;d assume. I&#39;d prefer not write a bunch of files.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71329446/how-to-pass-individual-elements-in-an-array-in-jq-to-xargs",
        "title": "How to pass individual elements in an array in JQ to xargs"
    },
    {
        "tags": [
            "json",
            "object",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646263800,
                "last_edit_date": 1646263800,
                "creation_date": 1646262668,
                "answer_id": 71330272,
                "question_id": 71330144,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t know if it&#39;s more efficient but you could shorten the code using `--raw-input` or `-R` without `--slurp` or `-s` to linewise read in a stream of raw text (no need to split by newlines), the `/` operator to do the &quot;column&quot; splitting within a line, and `reduce` to successively build up your final structure, starting with your &quot;static&quot; data.\r\n\r\n~~~sh\r\njq -Rn --argjson extra &quot;$json&quot; &#39;\r\n  reduce (inputs / &quot;|&quot;) as [$object, $type] ($extra; . + [{$object, $type}])\r\n&#39; data.txt\r\n~~~\r\n\r\nIf you want the &quot;static&quot; data at the end, add it afterwards and start with an empty array:\r\n~~~sh\r\njq -Rn --argjson extra &quot;$json&quot; &#39;\r\n  reduce (inputs / &quot;|&quot;) as [$object, $type] ([]; . + [{$object, $type}]) + $extra\r\n&#39; data.txt\r\n~~~\r\n",
                "title": "Merging filter-generated output with static JSON object using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1646269339,
                "creation_date": 1646269339,
                "answer_id": 71330959,
                "question_id": 71330144,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try this :\r\n\r\n```\r\njq -nR --argjson extra &quot;$json&quot; &#39;\r\n    [inputs / &quot;|&quot; | {object:.[0], type:.[1]}] + $extra&#39; data.txt\r\n```",
                "title": "Merging filter-generated output with static JSON object using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649557760,
                "last_edit_date": 1649557760,
                "creation_date": 1649556949,
                "answer_id": 71813280,
                "question_id": 71330144,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n[inputs / &quot;|&quot; | {object: .[0], type: .[1]}]\r\n```\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/XkDdy9-lBq\r\n\r\nOr\r\n\r\n```\r\nreduce (inputs / &quot;|&quot;) as [$obj, $typ] ([]; .+[{$obj, $typ}])\r\n```\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/5N3M-pfJIR",
                "title": "Merging filter-generated output with static JSON object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1649557760,
        "creation_date": 1646261739,
        "last_edit_date": 1646262585,
        "question_id": 71330144,
        "body_markdown": "I&#39;m trying to use `jq` to iterate over some delimited text files, and generate objects from the rows.\r\n\r\nI also want to add some &quot;static&quot; objects (`json` shell variable in the example below) to the generated results.\r\n\r\nI&#39;ve come up with the below solution, which *does* produce the output I want. But, because I&#39;m not very confident in jq, every time I solve a problem with it, it feels like a monkey banging on a typewriter rather than a carefully crafted answer. So, I&#39;m imaginging this could be incorrect.\r\n\r\n**data.txt**\r\n```\r\napple|fruit\r\nTesla|car\r\nsparrow|bird\r\n```\r\n\r\nTest (bash shell):\r\n```bash\r\n$ json=&#39;[\r\n  { &quot;object&quot;: &quot;love&quot;, &quot;type&quot;: &quot;emotion&quot; },\r\n  { &quot;object&quot;: &quot;Ukraine&quot;, &quot;type&quot;: &quot;country&quot; }\r\n]&#39;\r\n\r\n$ jq --slurp --raw-input --argjson extra &quot;$json&quot; &#39;\r\nsplit(&quot;\\n&quot;) |\r\nmap(select(length&gt;0)) |\r\nmap(split(&quot;|&quot;) | {\r\n  object: .[0],\r\n  type: .[1]\r\n}) as $data |\r\n$data + $extra&#39; data.txt\r\n```\r\n\r\nOutput:\r\n```json\r\n[\r\n  {\r\n    &quot;object&quot;: &quot;apple&quot;,\r\n    &quot;type&quot;: &quot;fruit&quot;\r\n  },\r\n  {\r\n    &quot;object&quot;: &quot;Tesla&quot;,\r\n    &quot;type&quot;: &quot;car&quot;\r\n  },\r\n  {\r\n    &quot;object&quot;: &quot;sparrow&quot;,\r\n    &quot;type&quot;: &quot;bird&quot;\r\n  },\r\n  {\r\n    &quot;object&quot;: &quot;love&quot;,\r\n    &quot;type&quot;: &quot;emotion&quot;\r\n  },\r\n  {\r\n    &quot;object&quot;: &quot;Ukraine&quot;,\r\n    &quot;type&quot;: &quot;country&quot;\r\n  }\r\n]\r\n```\r\nIs this efficient?",
        "link": "https://stackoverflow.com/questions/71330144/merging-filter-generated-output-with-static-json-object-using-jq",
        "title": "Merging filter-generated output with static JSON object using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646282107,
                "post_id": 71332069,
                "comment_id": 126086229,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1646283308,
                "last_edit_date": 1646283308,
                "creation_date": 1646282673,
                "answer_id": 71332239,
                "question_id": 71332069,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "At best you could do an object construction directly by naming the key names under `{..}` and apply a further transformation to get only the desired paths\r\n\r\n```none\r\n{foo, bar} | .foo |= {three} | .bar |= [.[1]]\r\n```\r\n\r\n&lt;sup&gt;[jqplay demo][1]&lt;/sup&gt;\r\n\r\n\r\n  [1]: https://jqplay.org/s/Jb10kaAQ_j",
                "title": "Can jq select via a filter while retaining the full input context?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1646297399,
                "creation_date": 1646297399,
                "answer_id": 71334337,
                "question_id": 71332069,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could convert your queries into paths, and the input into a stream, select the pieces matching the query path, and rebuild it to a single output:\r\n~~~none\r\ndef extract(f):\r\n  reduce (\r\n    path(f) as $path | tostream\r\n    | select(length &gt; 1 and (.[0] | index($path) == 0))\r\n  ) as $set (\r\n   null;\r\n   setpath($set[0]; $set[1])\r\n);\r\n~~~\r\n\r\nFirst example using `.foo` and `.baz`:\r\n~~~sh\r\njq &#39;def extract(f): …; extract(.foo, .baz)&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;foo&quot;: {\r\n    &quot;one&quot;: true,\r\n    &quot;two&quot;: false,\r\n    &quot;three&quot;: {\r\n      &quot;hello&quot;: &quot;world&quot;\r\n    },\r\n    &quot;four&quot;: true\r\n  },\r\n  &quot;baz&quot;: true\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/Ll-JoNW1M4)\r\n\r\nAs with sparse arrays though, it&#39;ll fill up the missing items with `null`, as otherwise the index wouldn&#39;t match anymore. Second example using `.foo.three` and `.bar[1]`: \r\n~~~sh\r\njq &#39;def extract(f): …; extract(.foo.three, .bar[1])&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;foo&quot;: {\r\n    &quot;three&quot;: {\r\n      &quot;hello&quot;: &quot;world&quot;\r\n    }\r\n  },\r\n  &quot;bar&quot;: [\r\n    null,\r\n    4\r\n  ]\r\n}\r\n\r\n~~~\r\n[Demo](https://jqplay.org/s/cl2fuvsNwj)\r\n",
                "title": "Can jq select via a filter while retaining the full input context?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646335764,
                "creation_date": 1646335764,
                "answer_id": 71342742,
                "question_id": 71332069,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This would give exactly the result you wanted for `.foo.three,.bar[1]` :\r\n\r\n```\r\njq &#39;def extract(f):\r\n    . as $input |\r\n    reduce path(f) as $path (\r\n    null;\r\n    if ($path | last | type) == &quot;string&quot;\r\n    then setpath($path; $input | getpath($path))\r\n    else setpath(($path|.[:-1]);\r\n                 getpath($path|.[:-1]) +\r\n                [$input | getpath($path)]\r\n                )\r\n    end\r\n    );\r\nextract(.foo.three, .bar[1])&#39; data.json\r\n```",
                "title": "Can jq select via a filter while retaining the full input context?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1646335764,
        "creation_date": 1646280770,
        "question_id": 71332069,
        "body_markdown": "Is there a generic mechanism within jq to select arbitrary elements of a JSON file but return the full structural context of those elements? For example, if I have the following:\r\n\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;one&quot;: true,\r\n        &quot;two&quot;: false,\r\n        &quot;three&quot;: {\r\n          &quot;hello&quot;: &quot;world&quot;\r\n        },\r\n        &quot;four&quot;: true\r\n      },\r\n      &quot;bar&quot;: [\r\n        1,\r\n        4,\r\n        5\r\n      ],\r\n      &quot;baz&quot;: true\r\n    }\r\n\r\nusing the filter `.foo,.baz` would normally result in:\r\n\r\n    {\r\n      &quot;one&quot;: true,\r\n      &quot;two&quot;: false,\r\n      &quot;three&quot;: {\r\n        &quot;hello&quot;: &quot;world&quot;\r\n      },\r\n      &quot;four&quot;: true\r\n    }\r\n    true\r\n\r\nbut what I&#39;d like is to get:\r\n\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;one&quot;: true,\r\n        &quot;two&quot;: false,\r\n        &quot;three&quot;: {\r\n          &quot;hello&quot;: &quot;world&quot;\r\n        },\r\n        &quot;four&quot;: true\r\n      },\r\n      &quot;baz&quot;: true\r\n    }\r\n\r\nI can solve that specifically for the given filter using `select`, but I&#39;d like something generic, to be able to run the same code with a different filter and get the same type of result, e.g. running with the filter `.foo.three,.bar[1]` would result in:\r\n\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;three&quot;: {\r\n          &quot;hello&quot;: &quot;world&quot;\r\n        }\r\n      },\r\n      &quot;bar&quot;: [\r\n        4\r\n      ]\r\n    }\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/71332069/can-jq-select-via-a-filter-while-retaining-the-full-input-context",
        "title": "Can jq select via a filter while retaining the full input context?"
    },
    {
        "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": 1,
                "creation_date": 1646300447,
                "post_id": 71334946,
                "comment_id": 126090810,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646301136,
                "post_id": 71334946,
                "comment_id": 126091085,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1646302560,
                "post_id": 71334946,
                "comment_id": 126091669,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1646302481,
                "creation_date": 1646302481,
                "answer_id": 71335405,
                "question_id": 71334946,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have single quotes around your argument:\r\n\r\n    &#39;$path = $totalArg &#39; \r\n\r\nTherefore variables won&#39;t be expanded by the shell, and `jq` sees the literal string `$path`, which is undefined. If you had used double quotes, both `path` and `totalArg` would be expanded.",
                "title": "Can&#39;t use variable as path - is not defined at &lt;top-level&gt;,"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646306518,
                "creation_date": 1646306518,
                "answer_id": 71336320,
                "question_id": 71334946,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If `$totalRules` is supposed to be a number you should drop the `-r` option when reading it\r\n~~~sh\r\ntotalRules=$(jq &#39;.total&#39; &lt;&lt;&lt; &quot;$rulesResponse&quot;)\r\n~~~\r\nand use `--argjson` when setting it\r\n~~~sh\r\njq --arg key &quot;$rulesTypeKey&quot; --argjson total &quot;$totalRules&quot; \\\r\n  &#39;.rules.active[$key] = $total&#39;\r\n~~~\r\n\r\nIf `$totalRules` may also produce raw text (in edge cases, for instance), and you want to store that value as string, leave the `-r` option when reading it, and use `--arg` when setting it:\r\n~~~sh\r\njq --arg key &quot;$rulesTypeKey&quot; --arg total &quot;$totalRules&quot; \\\r\n  &#39;.rules.active[$key] = $total&#39;\r\n~~~\r\n",
                "title": "Can&#39;t use variable as path - is not defined at &lt;top-level&gt;,"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1646306518,
        "creation_date": 1646300320,
        "last_edit_date": 1646303192,
        "question_id": 71334946,
        "body_markdown": "Here bash script using jq to parse json\r\n\r\n    ruleTypes=( \r\n           [&quot;Bugs&quot;]=0 \r\n           [&quot;Vulnerabilities&quot;]=0 \r\n           [&quot;CodeSmells&quot;]=0\r\n           [&quot;SecurityHotspots&quot;]=0        \r\n         )\r\n    \r\n    for rulesTypeKey in &quot;${!ruleTypes[@]}&quot;; do\r\n      #echo &quot;rules types $rulesTypeKey = ${ruleTypes[$rulesTypeKey]}&quot;\r\n      for currentActivation in ${ACTIVATION_ARRAY[@]}; do\r\n          rulesResponse=$(curl -s -XGET &quot;$RULES_REQUEST_URL_PREFIX&amp;activation=$currentActivation&amp;types=$rulesTypeKey&amp;p=1&amp;ps=1&quot;)\r\n          totalRules=$(jq -r &#39;.total&#39; &lt;&lt;&lt; &quot;$rulesResponse&quot;)\r\n          ruleTypes[$rulesTypeKey]=$totalRules\r\n          jq --argjson totalArg &quot;$totalRules&quot; &#39;.rules.active.Bugs = $totalArg &#39; &lt;&lt;&lt;$RULES_REPORT_INIT_JSON &gt;$FILE_REPORT_RULES      \r\n      done\r\n    done\r\n\r\nThis work fine. Nice. \r\n\r\nNow I want to use variable **$path** for path. I try this:\r\n\r\n    ruleTypes=( \r\n           [&quot;Bugs&quot;]=0 \r\n           [&quot;Vulnerabilities&quot;]=0 \r\n           [&quot;CodeSmells&quot;]=0\r\n           [&quot;SecurityHotspots&quot;]=0        \r\n         )\r\n    \r\n    for rulesTypeKey in &quot;${!ruleTypes[@]}&quot;; do\r\n      #echo &quot;rules types $rulesTypeKey = ${ruleTypes[$rulesTypeKey]}&quot;\r\n      for currentActivation in ${ACTIVATION_ARRAY[@]}; do\r\n          rulesResponse=$(curl -s -XGET &quot;$RULES_REQUEST_URL_PREFIX&amp;activation=$currentActivation&amp;types=$rulesTypeKey&amp;p=1&amp;ps=1&quot;)\r\n          totalRules=$(jq -r &#39;.total&#39; &lt;&lt;&lt; &quot;$rulesResponse&quot;)\r\n          ruleTypes[$rulesTypeKey]=$totalRules\r\n          path=&quot;.rules.active.$rulesTypeKey&quot;\r\n          jq --argjson totalArg &quot;$totalRules&quot; &#39;$path = $totalArg &#39; &lt;&lt;&lt;$RULES_REPORT_INIT_JSON &gt;$FILE_REPORT_RULES      \r\n      done\r\n    done\r\n\r\nBut I get error:\r\n\r\n    jq: error: $path is not defined at &lt;top-level&gt;, line 1:\r\n    $path = $totalArg \r\n    jq: 1 compile error\r\n\r\nP.S \r\n\r\nI try this (double quotes): \r\n\r\n    jq --argjson totalArg &quot;$totalRules&quot; &quot;$path = $totalArg&quot; &lt;&lt;&lt;$RULES_REPORT_INIT_JSON &gt;$FILE_REPORT_RULES . \r\n\r\nBut get error: \r\n\r\n    jq: error: syntax error, unexpected $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1: \r\n\r\n",
        "link": "https://stackoverflow.com/questions/71334946/cant-use-variable-as-path-is-not-defined-at-top-level",
        "title": "Can&#39;t use variable as path - is not defined at &lt;top-level&gt;,"
    },
    {
        "tags": [
            "node.js",
            "json",
            "bash",
            "npm",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646302939,
                "post_id": 71335459,
                "comment_id": 126091801,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8451449,
                    "reputation": 63,
                    "user_id": 6340175,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-mj_HFUncPpY/AAAAAAAAAAI/AAAAAAAAAC4/ce4w0GebazM/s256-rj/photo.jpg",
                    "display_name": "Tony Mack",
                    "link": "https://stackoverflow.com/users/6340175/tony-mack"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646393269,
                "post_id": 71335459,
                "comment_id": 126117461,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1646303654,
                "creation_date": 1646303654,
                "answer_id": 71335673,
                "question_id": 71335459,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your output may have JSON parts and non-JSON parts, you first need to find a way to isolate them in order to tell them apart.\r\n\r\nFor instance, if each item is on its own line (ie. all JSON parts are self-contained within their own line, then read in linewise as raw text using the `--raw-input` (or `-R`) option, check if you can convert them to JSON using the `fromjson` builtin and the error suppression operator `?`, and if not (using the  alternative operator `//`) output the line as is using the `--raw-output` (or `-r` option):\r\n~~~\r\n… | jq --raw-input --raw-output &#39;fromjson? // .&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/zcqMvxTFJ9)\r\n",
                "title": "npm Node output steam to pretty json to terminal"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1646393216,
        "creation_date": 1646302694,
        "last_edit_date": 1646393216,
        "question_id": 71335459,
        "body_markdown": "I want to be able to stream all the output data from when I run `npm run start` into pretty JSON. The issue when using `jq` is that some output is not `JSON` is there any way to pretty-print JSON from an output stream where sometimes its text and sometimes it&#39;s JSON \r\n\r\nExample id like \r\n\r\n    [nodemon] 1.19.4\r\n    [nodemon] to restart at any time, enter `rs`\r\n    [nodemon] watching dir(s): src/**/*\r\n    [nodemon] watching extensions: ts\r\n    [nodemon] starting `ts-node ./src/index.ts index.js`\r\n    helmet deprecated helmet.noCache is deprecated and will be removed in [11:11:55] Found 0 errors. Watching for file changes.\r\n\r\n    [{&quot;caller&quot;: &quot;RESOURCE ACCESS&quot;,&quot;token&quot;: &quot;&quot;,&quot;msg&quot;: &quot;xxx&quot;,&quot;statusCode&quot;: null,&quot;level&quot;: &quot;info&quot;,&quot;time&quot;: &quot;xxx&quot;},{&quot;endpoint&quot;: &quot;some endpoint&quot;,&quot;msg&quot;: &quot;Initial endpoint&quot;,&quot;data&quot;: {&quot;campaign_id&quot;: &quot;xxx&quot;},&quot;level&quot;: &quot;info&quot;,&quot;time&quot;: &quot;xxx&quot;},{&quot;msg&quot;: &quot;Request received&quot;,&quot;endpoint&quot;: &quot;some other endpoint&quot;,&quot;method&quot;: &quot;GET&quot;}]\r\n\r\nTo be formatted in the terminal like \r\n\r\n    [nodemon] 1.19.4\r\n    [nodemon] to restart at any time, enter `rs`\r\n    [nodemon] watching dir(s): src/**/*\r\n    [nodemon] watching extensions: ts\r\n    [nodemon] starting `ts-node ./src/index.ts index.js`\r\n    helmet deprecated helmet.noCache is deprecated and will be removed in [11:11:55] Found 0 errors. Watching for file changes.\r\n\r\n    [\r\n      {\r\n        &quot;caller&quot;: &quot;RESOURCE ACCESS&quot;,\r\n        &quot;token&quot;: &quot;&quot;,\r\n        &quot;msg&quot;: &quot;xxx&quot;,\r\n        &quot;statusCode&quot;: null,\r\n        &quot;level&quot;: &quot;info&quot;,\r\n        &quot;time&quot;: &quot;xxx&quot;\r\n      },\r\n      {\r\n        &quot;endpoint&quot;: &quot;some endpoint&quot;,\r\n        &quot;msg&quot;: &quot;Initial endpoint&quot;,\r\n        &quot;data&quot;: {\r\n          &quot;campaign_id&quot;: &quot;xxx&quot;\r\n        },\r\n        &quot;level&quot;: &quot;info&quot;,\r\n        &quot;time&quot;: &quot;xxx&quot;\r\n      },\r\n      {\r\n        &quot;msg&quot;: &quot;Request received&quot;,\r\n        &quot;endpoint&quot;: &quot;some other endpoint&quot;,\r\n        &quot;method&quot;: &quot;GET&quot;\r\n      }\r\n    ]\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71335459/npm-node-output-steam-to-pretty-json-to-terminal",
        "title": "npm Node output steam to pretty json to terminal"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646309172,
                "last_edit_date": 1646309172,
                "creation_date": 1646308859,
                "answer_id": 71336867,
                "question_id": 71336755,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are sequentially writing to the same file but always using the unaltered input `$RULES_REPORT_INIT_JSON`. This makes you see only the last change.\r\n\r\nInstead of writing to the file on each iteration, you could save the changes to the variable and write to the file just once in the end:\r\n~~~sh\r\nfor …; do\r\n  …\r\n  RULES_REPORT_INIT_JSON=&quot;$(jq … &lt;&lt;&lt;$RULES_REPORT_INIT_JSON)&quot;\r\n  …\r\ndone\r\ncat &lt;&lt;&lt;$RULES_REPORT_INIT_JSON &gt;$FILE_REPORT_RULES\r\n~~~\r\n\r\nOr, if `$RULES_REPORT_INIT_JSON` needs to stay unaltered throughout the loop, use a temporary variable instead\r\n~~~sh\r\ntemp=&quot;$RULES_REPORT_INIT_JSON&quot;\r\nfor …; do\r\n  …\r\n  temp=&quot;$(jq … &lt;&lt;&lt;$temp)&quot;\r\n  …\r\ndone\r\ncat &lt;&lt;&lt;$temp &gt;$FILE_REPORT_RULES\r\n~~~",
                "title": "Set only last variable to file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1646309172,
        "creation_date": 1646308413,
        "question_id": 71336755,
        "body_markdown": "In bash use jq to parse json.\r\n\r\n      for currentActivation in ${ACTIVATION_ARRAY[@]}; do\r\n          rulesResponse=$(curl -s -XGET &quot;$RULES_REQUEST_URL_PREFIX&amp;activation=$currentActivation&amp;types=$rulesTypeKey&amp;p=1&amp;ps=1&quot;)\r\n          typeRuleTotal=$(jq -r &#39;.total&#39; &lt;&lt;&lt; &quot;$rulesResponse&quot;)\r\n          echo &quot;current_rulesTypeKey = $rulesTypeKey, typeRuleTotal = $typeRuleTotal&quot;\r\n          jq --argjson totalArg &quot;$typeRuleTotal&quot; --arg currentType &quot;$rulesTypeKey&quot; &#39;.rules.active[$currentType] = $totalArg &#39; &lt;&lt;&lt;$RULES_REPORT_INIT_JSON &gt;$FILE_REPORT_RULES\r\n      done\r\n\r\nAnd here output:\r\n\r\n    current_rulesTypeKey = CODE_SMELL, typeRuleTotal = 310\r\n    current_rulesTypeKey = SECURITY_HOTSPOT, typeRuleTotal = 1\r\n    current_rulesTypeKey = BUG, typeRuleTotal = 304\r\n    current_rulesTypeKey = VULNERABILITY, typeRuleTotal = 120\r\n\r\nBut on file **$FILE_REPORT_RULES** saved only last value = **120** :\r\n\r\n    {\r\n      &quot;rules&quot;: {\r\n        &quot;totalActive&quot;: 0,\r\n        &quot;totalInactive&quot;: 0,\r\n        &quot;active&quot;: {\r\n          &quot;BUG&quot;: 0,\r\n          &quot;VULNERABILITY&quot;: 120,\r\n          &quot;CODE_SMELL&quot;: 0,\r\n          &quot;SECURITY_HOTSPOT&quot;: 0\r\n        }\r\n      }\r\n    }\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71336755/set-only-last-variable-to-file",
        "title": "Set only last variable to file"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1646309140,
                "creation_date": 1646309140,
                "answer_id": 71336933,
                "question_id": 71336852,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [`map()`][1] to keep the original structure:\r\n```\r\njq --arg temp  &quot;f&quot; &#39;map(select( .key1 == &quot;c&quot;).key2 |= $temp)&#39; test.json\r\n````\r\n\r\n[Online demo](https://jqplay.org/s/6P1-unGR09)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#map(x),map_values(x)",
                "title": "jq .[] removes objects from array when updating value for a key"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1646309564,
                "creation_date": 1646309564,
                "answer_id": 71337036,
                "question_id": 71336852,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could also just use another pair of parentheses around the left hand side of the update assignment in order to retain the context:\r\n\r\nEither way works:\r\n~~~sh\r\njq --arg temp &quot;f&quot; &#39;(.[] | select(.key1 == &quot;c&quot;).key2) |= $temp&#39; test.json\r\n~~~\r\n[Demo](https://jqplay.org/s/OQ7cFnITH4)\r\n~~~sh\r\njq --arg temp &quot;f&quot; &#39;(.[] | select(.key1 == &quot;c&quot;)).key2 |= $temp&#39; test.json\r\n~~~\r\n[Demo](https://jqplay.org/s/yX3H3nAklS)",
                "title": "jq .[] removes objects from array when updating value for a key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1646309564,
        "creation_date": 1646308813,
        "question_id": 71336852,
        "body_markdown": "I am trying to update an value for a key based on a select filter. The list contains dictionaries with same key names, but different values. Based on value, I am filtering to select a dictionary and then update the sibling key in it.\r\n\r\nThe value update works, but the dictionaries move out of list as expected because of .[], but how do I add them back to the list. Or, how can I do it without using .[]?\r\n\r\nInput List: \r\n```\r\n[\r\n    {\r\n        &quot;key1&quot;: &quot;a&quot;,\r\n        &quot;key2&quot;: &quot;b&quot;\r\n    },\r\n    {\r\n        &quot;key1&quot;: &quot;c&quot;,\r\n        &quot;key2&quot;: &quot;d&quot;\r\n    },\r\n    {\r\n        &quot;key1&quot;: &quot;d&quot;,\r\n        &quot;key2&quot;: &quot;e&quot;\r\n    }\r\n]\r\n```\r\nCommand I am running: \r\n`jq --arg temp  &quot;f&quot; &#39;.[] | select( .key1 == &quot;c&quot;).key2 |= $temp&#39; test.json`\r\n\r\noutput:\r\n```\r\n{\r\n  &quot;key1&quot;: &quot;a&quot;,\r\n  &quot;key2&quot;: &quot;b&quot;\r\n}\r\n{\r\n  &quot;key1&quot;: &quot;c&quot;,\r\n  &quot;key2&quot;: &quot;f&quot;\r\n}\r\n{\r\n  &quot;key1&quot;: &quot;d&quot;,\r\n  &quot;key2&quot;: &quot;e&quot;\r\n}\r\n```\r\n\r\nThe objects are not part of list now.\r\nExpected output:\r\n```\r\n[\r\n    {\r\n        &quot;key1&quot;: &quot;a&quot;,\r\n        &quot;key2&quot;: &quot;b&quot;\r\n    },\r\n    {\r\n        &quot;key1&quot;: &quot;c&quot;,\r\n        &quot;key2&quot;: &quot;f&quot;\r\n    },\r\n    {\r\n        &quot;key1&quot;: &quot;d&quot;,\r\n        &quot;key2&quot;: &quot;e&quot;\r\n    }\r\n]\r\n```\r\n\r\nHow can we add the objects back to a list, or do it in-place.",
        "link": "https://stackoverflow.com/questions/71336852/jq-removes-objects-from-array-when-updating-value-for-a-key",
        "title": "jq .[] removes objects from array when updating value for a key"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646313120,
                "creation_date": 1646313120,
                "answer_id": 71337790,
                "question_id": 71337750,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `with_entries(…)`, which is a shortcut to `to_entries | map(…) | from_entries`, which in turn decomposes the object into an array of key/value representations `to_entries`, modifies each item within that array `map`, and converts it back into the original structure `from_entries`.\r\n~~~sh\r\njq &#39;with_entries(select(.key == &quot;google.com&quot; or .key == &quot;bbb.com&quot;))&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;google.com&quot;: {\r\n    &quot;http&quot;: {\r\n      &quot;dest_url&quot;: &quot;http://stackoverflow.com&quot;\r\n    },\r\n    &quot;https&quot;: {\r\n      &quot;dest_url&quot;: &quot;http://github.com&quot;\r\n    }\r\n  },\r\n  &quot;bbb.com&quot;: {\r\n    &quot;https&quot;: {\r\n      &quot;dest_url&quot;: &quot;https://microsoft.com&quot;\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/PHD4Vc5Rrb)",
                "title": "Select objects based on the key in hash using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1646313120,
        "creation_date": 1646312959,
        "question_id": 71337750,
        "body_markdown": "I&#39;d love to select objects based on the key in the hash, but I want the original object format back. How can I achieve this?\r\n\r\n**original**\r\n```\r\n{\r\n  &quot;google.com&quot;: {\r\n    &quot;http&quot;: {\r\n      &quot;dest_url&quot;: &quot;http://stackoverflow.com&quot;\r\n    },\r\n    &quot;https&quot;: {\r\n      &quot;dest_url&quot;: &quot;http://github.com&quot;\r\n    }\r\n  },\r\n  &quot;aaa.com&quot;: {\r\n    &quot;https&quot;: {\r\n      &quot;dest_url&quot;: &quot;https://github.com&quot;\r\n    }\r\n  },\r\n  &quot;bbb.com&quot;: {\r\n    &quot;https&quot;: {\r\n      &quot;dest_url&quot;: &quot;https://microsoft.com&quot;\r\n    }\r\n  },\r\n   &quot;ccc.com&quot;: {\r\n    &quot;https&quot;: {\r\n      &quot;dest_url&quot;: &quot;https://.com&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n**should be**\r\n```\r\n{\r\n  &quot;google.com&quot;: {\r\n    &quot;http&quot;: {\r\n      &quot;dest_url&quot;: &quot;http://stackoverflow.com&quot;\r\n    },\r\n    &quot;https&quot;: {\r\n      &quot;dest_url&quot;: &quot;http://github.com&quot;\r\n    }\r\n  },\r\n  &quot;bbb.com&quot;: {\r\n    &quot;https&quot;: {\r\n      &quot;dest_url&quot;: &quot;https://microsoft.com&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI tried it with `to_entries[] | select (.key == &quot;google.com&quot; or .key == &quot;bbb.com&quot;) | [.key, .value]` but it eneded like this. I&#39;m sure `[.key, .value]` part is wrong but I&#39;m stuck on how I can workaround this.\r\n\r\n```\r\n[\r\n  &quot;google.com&quot;,\r\n  {\r\n    &quot;http&quot;: {\r\n      &quot;dest_url&quot;: &quot;http://stackoverflow.com&quot;\r\n    },\r\n    &quot;https&quot;: {\r\n      &quot;dest_url&quot;: &quot;http://github.com&quot;\r\n    }\r\n  }\r\n]\r\n[\r\n  &quot;bbb.com&quot;,\r\n  {\r\n    &quot;https&quot;: {\r\n      &quot;dest_url&quot;: &quot;https://microsoft.com&quot;\r\n    }\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/71337750/select-objects-based-on-the-key-in-hash-using-jq",
        "title": "Select objects based on the key in hash using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10863515,
                    "reputation": 784,
                    "user_id": 7987708,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Q7nq1.jpg?s=256",
                    "display_name": "Kamil Gw&#243;źdź",
                    "link": "https://stackoverflow.com/users/7987708/kamil-gw%c3%b3%c5%bad%c5%ba"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1646318800,
                "post_id": 71339030,
                "comment_id": 126097649,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1646318845,
                "post_id": 71339030,
                "comment_id": 126097660,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1646318928,
                "creation_date": 1646318928,
                "answer_id": 71339107,
                "question_id": 71339030,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For such keys, you need to quote the key, but the quotes must *also* be quoted so that they aren&#39;t removed by the shell prior to running `jq`.\r\n\r\n    jq -r &#39;.&quot;commit-sha1&quot;&#39;\r\n\r\nThe abbreviated from `.foo` is for &quot;simple, identifier-like keys&quot;, according to the man page.",
                "title": "How to escape dash in jq call"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1646318928,
        "creation_date": 1646318659,
        "question_id": 71339030,
        "body_markdown": "How to escape dash in jq call?\r\n\r\n    cat afile | jq -r .commit-sha1\r\n\r\nSo the dash is being interpreted in some way. How to escape it? I tried wrap with &quot;",
        "link": "https://stackoverflow.com/questions/71339030/how-to-escape-dash-in-jq-call",
        "title": "How to escape dash in jq call"
    },
    {
        "tags": [
            "json",
            "windows",
            "powershell",
            "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": 0,
                "creation_date": 1646323565,
                "post_id": 71340156,
                "comment_id": 126099804,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5462974,
                    "reputation": 3,
                    "user_id": 8742375,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-ox1L-JU6Ss4/AAAAAAAAAAI/AAAAAAAAAAA/H28y7xn3fXY/s256-rj/photo.jpg",
                    "display_name": "BruceR",
                    "link": "https://stackoverflow.com/users/8742375/brucer"
                },
                "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": 1646340814,
                "post_id": 71340156,
                "comment_id": 126105821,
                "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": 1646342134,
                "post_id": 71340156,
                "comment_id": 126106201,
                "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": 1646342538,
                "post_id": 71340156,
                "comment_id": 126106312,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1646417866,
                "last_edit_date": 1646417866,
                "creation_date": 1646342723,
                "answer_id": 71343984,
                "question_id": 71340156,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The correct jq program is\r\n\r\n```jq\r\n.Vpcs[] | [.VpcId, .CidrBlock, ( .Tags[] | select( .Key == &quot;Name&quot; ) | .Value ) ]\r\n```\r\n\r\nYou didn&#39;t show the command you used, but you provided the following to `jq`:\r\n\r\n```jq\r\n.Vpcs[] | [.VpcId, .CidrBlock, ( .Tags[] | select( .Key == Name ) | .Value ) ]\r\n```\r\n\r\nThat&#39;s incorrect. (Notice the missing quotes.)\r\n\r\nNot only did you not provide what command you used, you didn&#39;t specify whether it was being provided to the Windows API (`CreateProcess`), Windows Shell (`cmd`) or Power Shell. \r\n\r\nI&#39;m guessing `cmd`. In order to provide the above program to `jq`, you can use the following `cmd` command:\r\n\r\n```cmd\r\njq &quot;.Vpcs[] | [.VpcId, .CidrBlock, ( .Tags[] | select( .Key == \\&quot;Name\\&quot; ) | .Value ) ]&quot; file.json\r\n```\r\n",
                "title": "Windows version fails where jqplay.org works"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1646363255,
                "creation_date": 1646363255,
                "answer_id": 71346198,
                "question_id": 71340156,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not agreeing to ikegami about the CMD command that [he/she?] provided because the character used for CMD escaping is `^`, not `\\` like Assembly/C/C++. I hope this will work (I don&#39;t want to test this on my potato thing):\r\n```batch\r\njq .Vpcs[] | [.VpcId, .CidrBlock, ( .Tags[] | select( .Key == &quot;Name&quot; ) | .Value ) ] file.json\r\n```\r\nor this:\r\n```batch\r\njq .Vpcs[] | [.VpcId, .CidrBlock, ( .Tags[] | select( .Key == ^&quot;Name^&quot; ) | .Value ) ] file.json\r\n```",
                "title": "Windows version fails where jqplay.org works"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1646417878,
        "creation_date": 1646323372,
        "last_edit_date": 1646417878,
        "question_id": 71340156,
        "body_markdown": "I&#39;ve been using jq to parse the output from AWS cli. \r\n\r\nThe output looks something like this..\r\n\r\n    {\r\n    &quot;Vpcs&quot;: [\r\n        {\r\n            &quot;CidrBlock&quot;: &quot;10.29.19.64/26&quot;,\r\n            &quot;State&quot;: &quot;available&quot;,\r\n            &quot;VpcId&quot;: &quot;vpc-0ba51bd29c41d41&quot;,\r\n            &quot;IsDefault&quot;: false,\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Key&quot;: &quot;Name&quot;,\r\n                    &quot;Value&quot;: &quot;CloudEndure-Europe-Development&quot;\r\n                }\r\n            ]\r\n        }\r\n    ]}\r\n\r\nand the script I am using looks like this..\r\n\r\n    .Vpcs[] | [.VpcId, .CidrBlock,   (.Tags[]|select(.Key==&quot;Name&quot;)|.Value)]\r\n\r\nIf I run it under Windows it fails like this. \r\n\r\n&gt; jq: error: Name/0 is not defined at &lt;top-level&gt;, line 1:\r\n.Vpcs[] | [.VpcId, .CidrBlock, (.Tags[]|select(.Key==Name)|.Value)]\r\njq: 1 compile error\r\n\r\nBut it works fine in jqplay.org. \r\n\r\nAny ideas, on Windows Im using jq-1.6.\r\n\r\nThanks\r\n\r\nBruce.",
        "link": "https://stackoverflow.com/questions/71340156/windows-version-fails-where-jqplay-org-works",
        "title": "Windows version fails where jqplay.org works"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646376339,
                "last_edit_date": 1646376339,
                "creation_date": 1646372710,
                "answer_id": 71347084,
                "question_id": 71346971,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The filter is practically as good as it can get. If you really wanted to, you could still change\r\n- `del(.associatedMacs)` to `{userName}` for a positive definition, and\r\n- `(…) + {…}` to `{userName: …, associatedMacs: …}` to avoid the addition,\r\n\r\nresulting in\r\n~~~none\r\n… | map({userName: (.[0].userName), associatedMacs: (map(.associatedMacs[]) | unique)})\r\n~~~\r\n[Demo](https://jqplay.org/s/84JcMALOVN)\r\n\r\n---\r\nAs for the second question, if you treated the input as an `INDEX` on the IPs, you could mostly reuse the code from earlier (of course, the `unique` part wouldn&#39;t be necessary anymore)\r\n\r\n~~~none\r\n[INDEX(…; .associatedMacs[])[]] | group_by(.userName) | map(…)\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;userName&quot;: &quot;1&quot;,\r\n    &quot;associatedMacs&quot;: [\r\n      &quot;3:3:3:3:3:3&quot;,\r\n      &quot;5:5:5:5:5:5&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;userName&quot;: &quot;10&quot;,\r\n    &quot;associatedMacs&quot;: [\r\n      &quot;4:4:4:4:4:4&quot;,\r\n      &quot;6:6:6:6:6:6&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;userName&quot;: &quot;2&quot;,\r\n    &quot;associatedMacs&quot;: [\r\n      &quot;1:1:1:1:1:1&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;userName&quot;: &quot;3&quot;,\r\n    &quot;associatedMacs&quot;: [\r\n      &quot;2:2:2:2:2:2&quot;\r\n    ]\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/OHr4K5mFIh)",
                "title": "Group by and remove duplicates across arrays objects using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1646376339,
        "creation_date": 1646371700,
        "last_edit_date": 1646374846,
        "question_id": 71346971,
        "body_markdown": "Given the [json][1], I need to group by key `userName` the object `userClientDetailDTOList` across all sites-&gt;buildings-&gt;floors and remove any duplicate mac addresses.\r\n\r\nI have been able to do it using jq expression -\r\n\r\n`[.billingDetailPerSiteDTOList[].billingDetailPerBuildingDTOList[].billingDetailsPerFloorDTOList[].userClientDetailDTOList[] ] | group_by(.userName) | map((.[0]|del(.associatedMacs)) + { associatedMacs: (map(.associatedMacs[]) | unique) })`\r\n\r\nThis groups by `userName` and also removes duplicate `macs` belonging to particular user. This results in a list as \r\n\r\n    [\r\n      {\r\n        &quot;userName&quot;: &quot;1&quot;,\r\n        &quot;associatedMacs&quot;: [\r\n          &quot;3:3:3:3:3:3&quot;,\r\n          &quot;5:5:5:5:5:5&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;userName&quot;: &quot;10&quot;,\r\n        &quot;associatedMacs&quot;: [\r\n          &quot;4:4:4:4:4:4&quot;,\r\n          &quot;6:6:6:6:6:6&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;userName&quot;: &quot;2&quot;,\r\n        &quot;associatedMacs&quot;: [\r\n          &quot;1:1:1:1:1:1&quot;,\r\n          &quot;2:2:2:2:2:2&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;userName&quot;: &quot;3&quot;,\r\n        &quot;associatedMacs&quot;: [\r\n          &quot;2:2:2:2:2:2&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\n\r\n[Live example][2]\r\n\r\nQuestions:\r\n\r\n1. Can the expression be simplified?\r\n2. How do I remove duplicate mac addresses across all users? The mac address `2:2:2:2:2:2` is repeated for users `2` and `3`\r\n\r\n\r\n  [1]: https://api.jsonbin.io/b/6221a05d7caf5d67835ef7bd\r\n  [2]: https://jqplay.org/s/0VHtRibfUN",
        "link": "https://stackoverflow.com/questions/71346971/group-by-and-remove-duplicates-across-arrays-objects-using-jq",
        "title": "Group by and remove duplicates across arrays objects using JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1646393315,
                "creation_date": 1646393315,
                "answer_id": 71350781,
                "question_id": 71350766,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Enclose the `select` with a `map`, as you want to apply the filter to each array item individually while retaining the surrounding array structure.\r\n~~~sh\r\njq &#39;.items | map(select(.website == &quot;google&quot;))&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;name1&quot;,\r\n    &quot;id&quot;: &quot;1&quot;,\r\n    &quot;website&quot;: &quot;google&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;name1&quot;,\r\n    &quot;id&quot;: &quot;1&quot;,\r\n    &quot;website&quot;: &quot;google&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/CdWcpiRc8D)",
                "title": "Using jq to get arrays where a key within the array is equal to a specific value?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1646495451,
        "creation_date": 1646393224,
        "last_edit_date": 1646495451,
        "question_id": 71350766,
        "body_markdown": "I have been practicing with jq play to try to get all the arrays in a list where website is == &quot;google&quot; and create another json list from that. \r\n\r\nhttps://jqplay.org/s/DKNC2mhOLq\r\n\r\njq: error (at &lt;stdin&gt;:18): Cannot index array with string &quot;website&quot;\r\nexit status 5\r\n\r\n\r\n    {\r\n        &quot;items&quot;: [\r\n        {\r\n         &quot;name&quot;:&quot;name1&quot;,\r\n         &quot;id&quot;:&quot;1&quot;,\r\n         &quot;website&quot;:&quot;google&quot;\r\n        },\r\n        {\r\n         &quot;name&quot;:&quot;name1&quot;,\r\n         &quot;id&quot;:&quot;1&quot;,\r\n         &quot;website&quot;:&quot;google&quot;\r\n        },\r\n        {\r\n         &quot;name&quot;:&quot;name1&quot;,\r\n         &quot;id&quot;:&quot;2&quot;,\r\n         &quot;website&quot;:&quot;jingle&quot;\r\n        }\r\n        ]\r\n\r\nDesired output:\r\n       \r\n       [\r\n        {\r\n         &quot;name&quot;:&quot;name1&quot;,\r\n         &quot;id&quot;:&quot;1&quot;,\r\n         &quot;website&quot;:&quot;google&quot;\r\n         },\r\n        {\r\n         &quot;name&quot;:&quot;name1&quot;,\r\n         &quot;id&quot;:&quot;1&quot;,\r\n         &quot;website&quot;:&quot;google&quot;\r\n         }\r\n       ]\r\n\r\n\r\nhow can I loop through arrays in a list and look for specific values for specific keys? Thanks for any help or ideas you can provide. I am a begginer with JSON and jq.",
        "link": "https://stackoverflow.com/questions/71350766/using-jq-to-get-arrays-where-a-key-within-the-array-is-equal-to-a-specific-value",
        "title": "Using jq to get arrays where a key within the array is equal to a specific value?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646400681,
                "last_edit_date": 1646400681,
                "creation_date": 1646400189,
                "answer_id": 71352092,
                "question_id": 71352016,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you separate accessing `.key` and the iteration over `.value[]`, you&#39;ll get the cartesian product:\r\n~~~sh\r\njq &#39;to_entries[] | [.key] + (.value[] | [.dest_url])&#39;\r\n~~~\r\n~~~json\r\n[\r\n  &quot;google.com&quot;,\r\n  &quot;http://aaa.com&quot;\r\n]\r\n[\r\n  &quot;microsoft.com&quot;,\r\n  &quot;http://bbb.com&quot;\r\n]\r\n[\r\n  &quot;microsoft.com&quot;,\r\n  &quot;http://ccc.com&quot;\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/P-yH7TK9g6)\r\n\r\n---\r\n\r\nTo include the nested keys, it&#39;s easier to save the outer `.key` before descending with the inner `to_entries`:\r\n~~~sh\r\njq &#39;to_entries[] | .key as $key | .value | to_entries[] | [.key + &quot;://&quot; + $key, .value.dest_url]&#39;\r\n~~~\r\n~~~json\r\n[\r\n  &quot;https://google.com&quot;,\r\n  &quot;http://aaa.com&quot;\r\n]\r\n[\r\n  &quot;http://microsoft.com&quot;,\r\n  &quot;http://bbb.com&quot;\r\n]\r\n[\r\n  &quot;https://microsoft.com&quot;,\r\n  &quot;http://ccc.com&quot;\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/UIn9Fg48rL)",
                "title": "Reuse the hash-key and generate csv ready format"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1646400982,
        "creation_date": 1646399802,
        "last_edit_date": 1646400982,
        "question_id": 71352016,
        "body_markdown": "I&#39;m trying to create an csv ready output with jq, and want to reuse the nested hash key on the way.\r\n\r\nIn this example http, https should be reused to generate csv ready format `([][]...)`.\r\n\r\n**Original**\r\n```\r\n{\r\n   &quot;google.com&quot;:{\r\n      &quot;https&quot;:{\r\n         &quot;dest_url&quot;:&quot;http://aaa.com&quot;\r\n      }\r\n   },\r\n   &quot;microsoft.com&quot;:{\r\n      &quot;http&quot;:{\r\n         &quot;dest_url&quot;:&quot;http://bbb.com&quot;\r\n      },\r\n      &quot;https&quot;:{\r\n         &quot;dest_url&quot;:&quot;http://ccc.com&quot;\r\n      }\r\n   }\r\n}\r\n```\r\n\r\n**Expected**\r\n```\r\n[\r\n  &quot;https://google.com&quot;,\r\n  &quot;http://aaa.com&quot;\r\n]\r\n[\r\n  &quot;http://microsoft.com&quot;,\r\n  &quot;http://bbb.com&quot;,\r\n]\r\n[\r\n  &quot;https://microsoft.com&quot;,\r\n  &quot;http://ccc.com&quot;\r\n]\r\n```\r\n\r\n**What I tried**\r\n\r\n```\r\nto_entries[] | [.key, .value[].dest_url]\r\n```\r\n\r\n```\r\n[\r\n  &quot;google.com&quot;,\r\n  &quot;http://aaa.com&quot;\r\n]\r\n[\r\n  &quot;microsoft.com&quot;,\r\n  &quot;http://bbb.com&quot;,\r\n  &quot;http://ccc.com&quot;\r\n]\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/71352016/reuse-the-hash-key-and-generate-csv-ready-format",
        "title": "Reuse the hash-key and generate csv ready format"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646415471,
                "creation_date": 1646415471,
                "answer_id": 71355225,
                "question_id": 71355129,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Is the field called `domain_records` or just `records`?\r\n\r\nUse `select` to match your criteria\r\n~~~sh\r\njq -r &#39;.records[] | select(.type == &quot;A&quot;).data&#39;\r\n~~~\r\n~~~none\r\ntest.com\r\n~~~\r\n[Demo](https://jqplay.org/s/lqeL3WK1Vn)\r\n",
                "title": "Linux JQ. How to extract data from specific ID Entry"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1646415972,
        "creation_date": 1646415037,
        "last_edit_date": 1646415972,
        "question_id": 71355129,
        "body_markdown": "Guy, long term looking at this board and learning a lot but now stuck with little issue. Im working with Linux shell script that reads json (no problem here). What Im trying to do is get value from entry that has specific Type.\r\n\r\nBy parsing a json with just `jq -r &#39;.&#39;`, I get \r\n\r\n    {\r\n      &quot;records&quot;: [\r\n      {\r\n        &quot;id&quot;: 01,\r\n        &quot;type&quot;: &quot;SOA&quot;,\r\n        &quot;name&quot;: &quot;@&quot;,\r\n        &quot;data&quot;: &quot;1800&quot;,\r\n        &quot;priority&quot;: null,\r\n        &quot;port&quot;: null,\r\n        &quot;ttl&quot;: 1800,\r\n        &quot;weight&quot;: null,\r\n        &quot;flags&quot;: null,\r\n        &quot;tag&quot;: null\r\n      },\r\n      {\r\n        &quot;id&quot;: 02,\r\n        &quot;type&quot;: &quot;A&quot;,\r\n        &quot;name&quot;: &quot;@&quot;,\r\n        &quot;data&quot;: &quot;test.com&quot;,\r\n        &quot;priority&quot;: null,\r\n        &quot;port&quot;: null,\r\n        &quot;ttl&quot;: 1800,\r\n        &quot;weight&quot;: null,\r\n        &quot;flags&quot;: null,\r\n        &quot;tag&quot;: null\r\n      }\r\n      ],\r\n      &quot;links&quot;: {},\r\n      &quot;meta&quot;: {\r\n        &quot;total&quot;: 2\r\n      }\r\n    }\r\n\r\n\r\nThen, I use  `&quot;jq -r &#39;.records&#39; &quot;` and get:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 01,\r\n        &quot;type&quot;: &quot;SOA&quot;,\r\n        &quot;name&quot;: &quot;@&quot;,\r\n        &quot;data&quot;: &quot;1800&quot;,\r\n        &quot;priority&quot;: null,\r\n        &quot;port&quot;: null,\r\n        &quot;ttl&quot;: 1800,\r\n        &quot;weight&quot;: null,\r\n        &quot;flags&quot;: null,\r\n        &quot;tag&quot;: null\r\n      },\r\n      {\r\n        &quot;id&quot;: 02,\r\n        &quot;type&quot;: &quot;A&quot;,\r\n        &quot;name&quot;: &quot;@&quot;,\r\n        &quot;data&quot;: &quot;test.com&quot;,\r\n        &quot;priority&quot;: null,\r\n        &quot;port&quot;: null,\r\n        &quot;ttl&quot;: 1800,\r\n        &quot;weight&quot;: null,\r\n        &quot;flags&quot;: null,\r\n        &quot;tag&quot;: null\r\n      }\r\n    ]\r\n\r\n\r\nWhat I need to do is get data value of the type A. Currently, we have type SOA and A, but I need to only get data from A. \r\n\r\nI can use dummy way of `&quot;jq -r &#39;.records[1].data&#39;&quot;` and it gives me correct response of `test.com`, but I want a more dynamic way of searching for specific type (in this case &quot;A&quot;) and then giving the data value.\r\n\r\nThanks guys!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/71355129/linux-jq-how-to-extract-data-from-specific-id-entry",
        "title": "Linux JQ. How to extract data from specific ID Entry"
    },
    {
        "tags": [
            "arrays",
            "json",
            "random",
            "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": 1646420484,
                "post_id": 71356034,
                "comment_id": 126126992,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646420612,
                "post_id": 71356034,
                "comment_id": 126127032,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 673865,
                    "reputation": 5739,
                    "user_id": 889053,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3e26b08aa9c9bff40d6dab7b98680bf4?s=256&d=identicon&r=PG",
                    "display_name": "Christian Bongiorno",
                    "link": "https://stackoverflow.com/users/889053/christian-bongiorno"
                },
                "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": 1646421251,
                "post_id": 71356034,
                "comment_id": 126127221,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 673865,
                    "reputation": 5739,
                    "user_id": 889053,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3e26b08aa9c9bff40d6dab7b98680bf4?s=256&d=identicon&r=PG",
                    "display_name": "Christian Bongiorno",
                    "link": "https://stackoverflow.com/users/889053/christian-bongiorno"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646421736,
                "post_id": 71356034,
                "comment_id": 126127367,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646421979,
                "post_id": 71356034,
                "comment_id": 126127445,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 673865,
                    "reputation": 5739,
                    "user_id": 889053,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3e26b08aa9c9bff40d6dab7b98680bf4?s=256&d=identicon&r=PG",
                    "display_name": "Christian Bongiorno",
                    "link": "https://stackoverflow.com/users/889053/christian-bongiorno"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646422449,
                "post_id": 71356034,
                "comment_id": 126127570,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646422564,
                "post_id": 71356034,
                "comment_id": 126127611,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 673865,
                    "reputation": 5739,
                    "user_id": 889053,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3e26b08aa9c9bff40d6dab7b98680bf4?s=256&d=identicon&r=PG",
                    "display_name": "Christian Bongiorno",
                    "link": "https://stackoverflow.com/users/889053/christian-bongiorno"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646423172,
                "post_id": 71356034,
                "comment_id": 126127786,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 673865,
                    "reputation": 5739,
                    "user_id": 889053,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3e26b08aa9c9bff40d6dab7b98680bf4?s=256&d=identicon&r=PG",
                    "display_name": "Christian Bongiorno",
                    "link": "https://stackoverflow.com/users/889053/christian-bongiorno"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646425133,
                "post_id": 71356034,
                "comment_id": 126128344,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 673865,
                    "reputation": 5739,
                    "user_id": 889053,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3e26b08aa9c9bff40d6dab7b98680bf4?s=256&d=identicon&r=PG",
                    "display_name": "Christian Bongiorno",
                    "link": "https://stackoverflow.com/users/889053/christian-bongiorno"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646425997,
                "post_id": 71356034,
                "comment_id": 126128565,
                "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": 1683125997,
                "post_id": 71356034,
                "comment_id": 134319226,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1646436773,
                "last_edit_date": 1646436773,
                "creation_date": 1646424460,
                "answer_id": 71356728,
                "question_id": 71356034,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This shows how to select elements at random from an array, assuming a bash or sufficiently bash-like environment:\r\n```\r\n#!/bin/bash\r\n\r\n&lt; /dev/urandom tr -cd &#39;0-9&#39; | fold -w 1 | jq -MRnc &#39;\r\n\r\n# Output: a prn in range(0;$n) where $n is `.`\r\ndef prn:\r\n  if . == 1 then 0\r\n  else . as $n\r\n  | ([1, (($n-1)|tostring|length)]|max) as $w\r\n  | [limit($w; inputs)] | join(&quot;&quot;) | tonumber\r\n  | if . &lt; $n then . else ($n | prn) end\r\n  end;\r\n\r\n# Input: an array\r\n# Output: an array, being a selection of $k elements from . chosen at random without replacement\r\ndef prns($k):\r\n  if $k &lt;= 0 then []\r\n  else . as $in\r\n  | length as $n\r\n  | if $k &gt; $n then &quot;no can do&quot; | error\r\n    else ($n|prn) as $ix\r\n    | [$in[$ix]] + (($in[0:$ix] + $in[$ix+1:])|prns($k-1))\r\n    end\r\n  end;\r\n\r\n\r\n# Two illustrations\r\n# Three from range(0,10) (with replacement):\r\n[range(0;10) | ( [&quot;a&quot;, &quot;b&quot;, &quot;c&quot;] | .[length|prn]) ],\r\n\r\n# Three from an array, without replacement:\r\n([range(0;10)] | prns(3))\r\n\r\n&#39;\r\n```",
                "title": "Select random id from list in jq and update value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1646427107,
                "last_edit_date": 1646427107,
                "creation_date": 1646424557,
                "answer_id": 71356746,
                "question_id": 71356034,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I understood correctly, you want to replace each `id` field (spelling may differ, sometimes it&#39;s `Id`) with a randomly generated id string.\r\n\r\nThis solution first extracts the paths of all such id fields (in various spellings) using `jq`, then iterates over the result in the shell, using `uuidgen` to generate an id for each, which is fed into another `jq` call which uses `setpath` to change the value at the paths saved to the ids generated:\r\n\r\n~~~sh\r\nfile=&quot;input.json&quot;\r\n\r\njq -c &#39;\r\n  paths(.. | scalars) | select(.[-1] == (&quot;id&quot;, &quot;Id&quot;, &quot;ID&quot;)) | tojson\r\n&#39; &quot;$file&quot; |\r\nwhile read -r json; do printf &#39;[&quot;%s&quot;,%s]\\n&#39; &quot;$(uuidgen)&quot; &quot;$json&quot;; done |\r\njq -n --argfile file &quot;$file&quot; &#39;\r\n  reduce inputs as [$id,$json] ($file; setpath($json | fromjson; $id))\r\n&#39;\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;Id&quot;: &quot;10162eb7-29ba-4b60-ad20-e5b1133eca63&quot;,\r\n    &quot;Line&quot;: [\r\n      {\r\n        &quot;Amount&quot;: 100,\r\n        &quot;Description&quot;: &quot;Weekly Gardening Service&quot;,\r\n        &quot;DetailType&quot;: &quot;SalesItemLineDetail&quot;,\r\n        &quot;Id&quot;: &quot;272832df-a8f5-4877-92de-1545150afc33&quot;,\r\n        &quot;LineNum&quot;: 1,\r\n        &quot;SalesItemLineDetail&quot;: {\r\n          &quot;ItemAccountRef&quot;: {\r\n            &quot;name&quot;: &quot;Landscaping Services&quot;,\r\n            &quot;value&quot;: &quot;45&quot;\r\n          },\r\n          &quot;ItemRef&quot;: {\r\n            &quot;name&quot;: &quot;Gardening&quot;,\r\n            &quot;value&quot;: &quot;6&quot;\r\n          },\r\n          &quot;Qty&quot;: 4,\r\n          &quot;TaxCodeRef&quot;: {\r\n            &quot;value&quot;: &quot;TAX&quot;\r\n          },\r\n          &quot;UnitPrice&quot;: 25\r\n        }\r\n      },\r\n      {\r\n        &quot;Amount&quot;: 100,\r\n        &quot;DetailType&quot;: &quot;SubTotalLineDetail&quot;,\r\n        &quot;SubTotalLineDetail&quot;: {}\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;Id&quot;: &quot;190b0e50-e007-46a4-b1ca-c3efb762629c&quot;,\r\n    &quot;Line&quot;: [\r\n      {\r\n        &quot;Amount&quot;: 140,\r\n        &quot;Description&quot;: &quot;Weekly Gardening Service&quot;,\r\n        &quot;DetailType&quot;: &quot;SalesItemLineDetail&quot;,\r\n        &quot;Id&quot;: &quot;f7067227-56d4-4849-873a-3ee5c336999e&quot;,\r\n        &quot;LineNum&quot;: 1,\r\n        &quot;SalesItemLineDetail&quot;: {\r\n          &quot;ItemAccountRef&quot;: {\r\n            &quot;name&quot;: &quot;Landscaping Services&quot;,\r\n            &quot;value&quot;: &quot;45&quot;\r\n          },\r\n          &quot;ItemRef&quot;: {\r\n            &quot;name&quot;: &quot;Gardening&quot;,\r\n            &quot;value&quot;: &quot;6&quot;\r\n          },\r\n          &quot;Qty&quot;: 4,\r\n          &quot;TaxCodeRef&quot;: {\r\n            &quot;value&quot;: &quot;NON&quot;\r\n          },\r\n          &quot;UnitPrice&quot;: 35\r\n        }\r\n      },\r\n      {\r\n        &quot;Amount&quot;: 35,\r\n        &quot;Description&quot;: &quot;Pest Control Services&quot;,\r\n        &quot;DetailType&quot;: &quot;SalesItemLineDetail&quot;,\r\n        &quot;Id&quot;: &quot;181d7c6b-0afa-4f44-a568-2c482fc5c285&quot;,\r\n        &quot;LineNum&quot;: 2,\r\n        &quot;SalesItemLineDetail&quot;: {\r\n          &quot;ItemAccountRef&quot;: {\r\n            &quot;name&quot;: &quot;Pest Control Services&quot;,\r\n            &quot;value&quot;: &quot;54&quot;\r\n          },\r\n          &quot;ItemRef&quot;: {\r\n            &quot;name&quot;: &quot;Pest Control&quot;,\r\n            &quot;value&quot;: &quot;10&quot;\r\n          },\r\n          &quot;Qty&quot;: 1,\r\n          &quot;TaxCodeRef&quot;: {\r\n            &quot;value&quot;: &quot;NON&quot;\r\n          },\r\n          &quot;UnitPrice&quot;: 35\r\n        }\r\n      },\r\n      {\r\n        &quot;Amount&quot;: 175,\r\n        &quot;DetailType&quot;: &quot;SubTotalLineDetail&quot;,\r\n        &quot;SubTotalLineDetail&quot;: {}\r\n      }\r\n    ]\r\n  }\r\n]\r\n~~~",
                "title": "Select random id from list in jq and update value"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1683123728,
                "creation_date": 1683123728,
                "answer_id": 76164963,
                "question_id": 71356034,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a snippet I use for creating random date strings using &#39;now&#39; as a source for random. It should be simple to adapt it to generate indices in the array (map) of ids using the array length as an upper limit:\r\n\r\n````\r\n#!/bin/sh\r\necho &quot;{}&quot; | jq &#39;\r\n    (now * 1000000) as $random |\r\n    (($random * 3) % 10 + 2015 | tostring) as $year |\r\n    (($random * 5) % 12 + 1 | tostring | (&quot;0&quot; + .) | .[0:2]) as $month |\r\n    (($random * 7) % 28 + 1 | tostring | (&quot;0&quot; + .) | .[0:2]) as $day |\r\n    ($year + &quot;-&quot; + $month + &quot;-&quot; + $day) as $randomDate |\r\n    {randomDate: $randomDate}\r\n&#39;\r\n````",
                "title": "Select random id from list in jq and update value"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1683123728,
        "creation_date": 1646420049,
        "last_edit_date": 1646555995,
        "question_id": 71356034,
        "body_markdown": "I have some sample payload that I am going to be receiving, it looks like this:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;Id&quot;: &quot;9&quot;,\r\n    &quot;Line&quot;: [\r\n      {\r\n        &quot;Amount&quot;: 100,\r\n        &quot;Description&quot;: &quot;Weekly Gardening Service&quot;,\r\n        &quot;DetailType&quot;: &quot;SalesItemLineDetail&quot;,\r\n        &quot;Id&quot;: &quot;1&quot;,\r\n        &quot;LineNum&quot;: 1,\r\n        &quot;SalesItemLineDetail&quot;: {\r\n          &quot;ItemAccountRef&quot;: {\r\n            &quot;name&quot;: &quot;Landscaping Services&quot;,\r\n            &quot;value&quot;: &quot;45&quot;\r\n          },\r\n          &quot;ItemRef&quot;: {\r\n            &quot;name&quot;: &quot;Gardening&quot;,\r\n            &quot;value&quot;: &quot;6&quot;\r\n          },\r\n          &quot;Qty&quot;: 4,\r\n          &quot;TaxCodeRef&quot;: {\r\n            &quot;value&quot;: &quot;TAX&quot;\r\n          },\r\n          &quot;UnitPrice&quot;: 25\r\n        }\r\n      },\r\n      {\r\n        &quot;Amount&quot;: 100,\r\n        &quot;DetailType&quot;: &quot;SubTotalLineDetail&quot;,\r\n        &quot;SubTotalLineDetail&quot;: {}\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;Id&quot;: &quot;10&quot;,\r\n    &quot;Line&quot;: [\r\n      {\r\n        &quot;Amount&quot;: 140,\r\n        &quot;Description&quot;: &quot;Weekly Gardening Service&quot;,\r\n        &quot;DetailType&quot;: &quot;SalesItemLineDetail&quot;,\r\n        &quot;Id&quot;: &quot;1&quot;,\r\n        &quot;LineNum&quot;: 1,\r\n        &quot;SalesItemLineDetail&quot;: {\r\n          &quot;ItemAccountRef&quot;: {\r\n            &quot;name&quot;: &quot;Landscaping Services&quot;,\r\n            &quot;value&quot;: &quot;45&quot;\r\n          },\r\n          &quot;ItemRef&quot;: {\r\n            &quot;name&quot;: &quot;Gardening&quot;,\r\n            &quot;value&quot;: &quot;6&quot;\r\n          },\r\n          &quot;Qty&quot;: 4,\r\n          &quot;TaxCodeRef&quot;: {\r\n            &quot;value&quot;: &quot;NON&quot;\r\n          },\r\n          &quot;UnitPrice&quot;: 35\r\n        }\r\n      },\r\n      {\r\n        &quot;Amount&quot;: 35,\r\n        &quot;Description&quot;: &quot;Pest Control Services&quot;,\r\n        &quot;DetailType&quot;: &quot;SalesItemLineDetail&quot;,\r\n        &quot;Id&quot;: &quot;2&quot;,\r\n        &quot;LineNum&quot;: 2,\r\n        &quot;SalesItemLineDetail&quot;: {\r\n          &quot;ItemAccountRef&quot;: {\r\n            &quot;name&quot;: &quot;Pest Control Services&quot;,\r\n            &quot;value&quot;: &quot;54&quot;\r\n          },\r\n          &quot;ItemRef&quot;: {\r\n            &quot;name&quot;: &quot;Pest Control&quot;,\r\n            &quot;value&quot;: &quot;10&quot;\r\n          },\r\n          &quot;Qty&quot;: 1,\r\n          &quot;TaxCodeRef&quot;: {\r\n            &quot;value&quot;: &quot;NON&quot;\r\n          },\r\n          &quot;UnitPrice&quot;: 35\r\n        }\r\n      },\r\n      {\r\n        &quot;Amount&quot;: 175,\r\n        &quot;DetailType&quot;: &quot;SubTotalLineDetail&quot;,\r\n        &quot;SubTotalLineDetail&quot;: {}\r\n      }\r\n    ]\r\n  }\r\n]\r\n\r\n```\r\n\r\nThese I know are valid and I need to cross reference them, by id, in another payload I am receiving. But, the data I am receiving I can&#39;t assume to have valid ID&#39;s. \r\n\r\nSo, I want to take all the valid `Id`s from above, and shove them, randomly, into the sample data I have, that looks like this `($.invoices[].qbId)`:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;fb2430c5-5970-46b0-9947-aaa0b9f177bb&quot;,\r\n    &quot;invoices&quot;: [\r\n      {\r\n        &quot;description&quot;: &quot;2022-02-03 - 179&quot;,\r\n        &quot;dueDate&quot;: &quot;2022-02-03T22:51:10.206Z&quot;,\r\n        &quot;id&quot;: &quot;6f904b18-71c6-4fec-a016-7452f6a6b1dc&quot;,\r\n        &quot;invoiceDate&quot;: &quot;2022-02-03T22:51:10.347Z&quot;,\r\n        &quot;openBalance&quot;: 200,\r\n        &quot;paidAmount&quot;: 200,\r\n        &quot;qbId&quot;: &quot;1&quot;,\r\n        &quot;totalAmount&quot;: 212\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;fa5b77b5-bfd4-4178-ac31-386ec83f530c&quot;,\r\n    &quot;invoices&quot;: [\r\n      {\r\n        &quot;description&quot;: &quot;2022-01-12 - 95&quot;,\r\n        &quot;dueDate&quot;: &quot;2022-01-12T14:08:26.219Z&quot;,\r\n        &quot;id&quot;: &quot;05a58be3-4396-4c15-b9c2-ece68cb2b3fb&quot;,\r\n        &quot;invoiceDate&quot;: &quot;2022-01-12T14:08:26.399Z&quot;,\r\n        &quot;openBalance&quot;: 7.33,\r\n        &quot;paidAmount&quot;: 7.33,\r\n        &quot;qbId&quot;: &quot;&quot;,\r\n        &quot;totalAmount&quot;: 7.33\r\n      },\r\n      {\r\n        &quot;description&quot;: &quot;2022-01-12 - 95&quot;,\r\n        &quot;dueDate&quot;: &quot;2022-01-12T14:08:26.219Z&quot;,\r\n        &quot;id&quot;: &quot;91f5ecd0-e18d-4029-8745-143323e02007&quot;,\r\n        &quot;invoiceDate&quot;: &quot;2022-01-12T14:08:26.580Z&quot;,\r\n        &quot;openBalance&quot;: 53.13,\r\n        &quot;paidAmount&quot;: 53.13,\r\n        &quot;qbId&quot;: &quot;&quot;,\r\n        &quot;totalAmount&quot;: 53.13\r\n      }\r\n    ]\r\n  }\r\n]\r\n\r\n```\r\n\r\nthis jq will get me my ids `jq &#39;.QueryResponse.Invoice | map(.Id)&#39;` which can be readily consumed by jq. The question now is (and this is what I don&#39;t know) how to randomly choose from this array and update the sample payload: \r\n```\r\njq &#39;map(. + {\r\n   invoices : .invoices | map(. + {qbId: ??random here })\r\n   })\r\n&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/71356034/select-random-id-from-list-in-jq-and-update-value",
        "title": "Select random id from list in jq and update value"
    },
    {
        "tags": [
            "json",
            "key",
            "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": 1646434964,
                "post_id": 71358075,
                "comment_id": 126130574,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1646436380,
                "creation_date": 1646436380,
                "answer_id": 71358256,
                "question_id": 71358075,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One of many possibilities would be to use `try`:\r\n```\r\n.name as $n | .hobby | try to_entries[] | [ $n, .value]\r\n```\r\n\r\n`try EXP` is equivalent to `try EXP catch empty`.",
                "title": "Skip or Ignore non-existing key with to_entries in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1650113283,
                "creation_date": 1650113283,
                "answer_id": 71893999,
                "question_id": 71358075,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nEnter the following:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;bob&quot;,\r\n      &quot;hobby&quot;: [\r\n        &quot;baseball&quot;,\r\n        &quot;baseketball&quot;\r\n      ]\r\n    }\r\n\r\n    $ cat file | jq -c &quot;{name,hobby:.hobby[]}|[.[]]&quot;\r\n\r\n    [&quot;bob&quot;,&quot;baseball&quot;]\r\n    [&quot;bob&quot;,&quot;baseketball&quot;]\r\n\r\n\r\n",
                "title": "Skip or Ignore non-existing key with to_entries in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1650113283,
        "creation_date": 1646434518,
        "last_edit_date": 1646564553,
        "question_id": 71358075,
        "body_markdown": "I&#39;m trying to create a massive CSV file converted from each `*.json` file. This snippet works until it faces the file that doesn&#39;t have the key (`hobby`).\r\n\r\n**Original**\r\n```\r\n{\r\n  &quot;name&quot;: &quot;bob&quot;,\r\n  &quot;hobby&quot;: [\r\n    &quot;baseball&quot;,\r\n    &quot;baseketball&quot;\r\n   ]\r\n}\r\n\r\n```\r\n\r\n**jq snippet**\r\n```\r\ncat *.json | jq &#39;.name as $n | .hobby | to_entries[] | [ $n, .value]&#39;\r\n```\r\n\r\n**It works**\r\n\r\n`[][]...` is a pre-format when creating CSV with jq\r\n```\r\n[\r\n  &quot;bob&quot;,\r\n  &quot;baseball&quot;\r\n]\r\n[\r\n  &quot;bob&quot;,\r\n  &quot;baseketball&quot;\r\n]\r\n```\r\nhttps://jqplay.org/s/L-SmqiN-jw\r\n\r\n**However** if the `.hobby` key doesn&#39;t exist it fails miserably.\r\n```\r\njq: error (at &lt;stdin&gt;:6): null (null) has no keys\r\nexit status 5\r\n```\r\n\r\nhttps://jqplay.org/s/gapUv1Tpmb\r\n\r\nI tried to use if block but it seems not correct. How can we do such a thing either\r\n- return `[]` (empty array)\r\n- skip jq excution for the current working file with this problem and go to the next",
        "link": "https://stackoverflow.com/questions/71358075/skip-or-ignore-non-existing-key-with-to-entries-in-jq",
        "title": "Skip or Ignore non-existing key with to_entries 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": 1,
                "creation_date": 1646555922,
                "post_id": 71367415,
                "comment_id": 126148925,
                "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": 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": 1646559743,
                "post_id": 71367415,
                "comment_id": 126149512,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1646538411,
                "last_edit_date": 1646538411,
                "creation_date": 1646536995,
                "answer_id": 71367467,
                "question_id": 71367415,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To query specific tags in `instance.json` based on ids shared with `state.json`, you can iterate over the targets by comparing their common ids using a variable and the `select` function.\r\n~~~sh\r\njq -r --argfile state state.json --arg tag &quot;Name&quot; &#39;\r\n  $state.StoppingInstances[].InstanceId as $id\r\n  | .Reservations[].Instances[]\r\n  | select(.InstanceId == $id).Tags[]\r\n  | select(.Key == $tag).Value\r\n&#39; instance.json\r\n~~~\r\n~~~none\r\nhostname1\r\nhostname2\r\nhostname3\r\n~~~\r\n\r\n---\r\nTo join records from `instance.json` with items in `state.json`, you could use the `INDEX` and `JOIN` builtins:\r\n~~~sh\r\njq --argfile instance instance.json &#39;\r\n  .StoppingInstances |= JOIN(\r\n    INDEX($instance.Reservations[].Instances[]; .InstanceId); .InstanceId\r\n  )\r\n&#39; state.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;StoppingInstances&quot;: [\r\n    [\r\n      {&quot;CurrentState&quot;:{&quot;Code&quot;:80,&quot;Name&quot;:&quot;stopped&quot;},&quot;InstanceId&quot;:&quot;i-1&quot;,&quot;PreviousState&quot;:{&quot;Code&quot;:80,&quot;Name&quot;:&quot;stopped&quot;}},\r\n      {&quot;InstanceId&quot;:&quot;i-1&quot;,&quot;Tags&quot;:[{&quot;Value&quot;:&quot;hostname1&quot;,&quot;Key&quot;:&quot;Name&quot;}],&quot;AmiLaunchIndex&quot;:0}\r\n    ],\r\n    [\r\n      {&quot;CurrentState&quot;:{&quot;Code&quot;:80,&quot;Name&quot;:&quot;stopped&quot;},&quot;InstanceId&quot;:&quot;i-2&quot;,&quot;PreviousState&quot;:{&quot;Code&quot;:80,&quot;Name&quot;:&quot;stopped&quot;}},\r\n      {&quot;InstanceId&quot;:&quot;i-2&quot;,&quot;Tags&quot;:[{&quot;Value&quot;:&quot;hostname2&quot;,&quot;Key&quot;:&quot;Name&quot;}],&quot;AmiLaunchIndex&quot;:0}\r\n    ],\r\n    [\r\n      {&quot;CurrentState&quot;:{&quot;Code&quot;:80,&quot;Name&quot;:&quot;stopped&quot;},&quot;InstanceId&quot;:&quot;i-3&quot;,&quot;PreviousState&quot;:{&quot;Code&quot;:80,&quot;Name&quot;:&quot;stopped&quot;}},\r\n      {&quot;InstanceId&quot;:&quot;i-3&quot;,&quot;Tags&quot;:[{&quot;Value&quot;:&quot;hostname3&quot;,&quot;Key&quot;:&quot;Name&quot;}],&quot;AmiLaunchIndex&quot;:0}\r\n    ]\r\n  ]\r\n}\r\n~~~",
                "title": "Retrieve one key value from another file at another depth"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646563843,
                "last_edit_date": 1646563843,
                "creation_date": 1646563180,
                "answer_id": 71369513,
                "question_id": 71367415,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward approach that just uses `INDEX`.  It assumes an invocation of the following form, though different variations are of course possible:\r\n\r\n    jq -n --argfile state state.json --argfile instance instance.json -f program.jq\r\n\r\nwhere program.jq contains:\r\n```\r\nINDEX($instance.Reservations[].Instances[]; .InstanceId)\r\n| map_values(.Tags|from_entries.Name) as $dict\r\n| $state\r\n| .StoppingInstances |= map(. + {Hostname: $dict[.InstanceId]})\r\n```\r\n\r\nIf you&#39;re not sure where .InstanceId is located in instance.json, you could modify the above as follows:\r\n```\r\nINDEX($instance | .. | objects | select(has(&quot;Instances&quot;)) | .Instances[]; \r\n      .InstanceId)\r\n| map_values(.Tags|from_entries.Name) as $dict\r\n| $state\r\n| .StoppingInstances |= map(. + {Hostname: $dict[.InstanceId]})\r\n```",
                "title": "Retrieve one key value from another file at another depth"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1646563843,
        "creation_date": 1646536398,
        "last_edit_date": 1646559713,
        "question_id": 71367415,
        "body_markdown": "I have two json files (these are from AWS). One is returned from amazon following a server state change (state.json), the other has details of the instance including a specific tag (The tag is called &quot;Name&quot; and the value has the hostname of the server) - file is called instance.json in my example. I&#39;m trying to write some jq which uses the instanceID retrieved from the state to query the instance details document (with the same instanceID key). I think if I could get the hostname tag added to the state document in the right place, that would be ideal...\r\n\r\nThis would normally be something I&#39;d possibly be capable of, but the keys are at different depths in the json and I can&#39;t figure out how to retrieve different depth/matching keys. (If you&#39;re familiar with aws you&#39;ll know the server state is *also* in the instance, however I&#39;m changing the state and don&#39;t wish to make 3 amazon calls).\r\n\r\nSome sample json below:\r\n\r\ninstance.json (this is a huge file, I&#39;ve edited out all the useless bits and maintained the structure):\r\n\r\n```\r\n{\r\n  &quot;Reservations&quot;: [\r\n    {\r\n      &quot;Instances&quot;: [\r\n        {\r\n          &quot;InstanceId&quot;: &quot;i-1&quot;,\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Value&quot;: &quot;hostname1&quot;,\r\n              &quot;Key&quot;: &quot;Name&quot;\r\n            }\r\n          ],\r\n          &quot;AmiLaunchIndex&quot;: 0\r\n        }\r\n      ],\r\n      &quot;ReservationId&quot;: &quot;r-1&quot;,\r\n      &quot;Groups&quot;: []\r\n    },\r\n    {\r\n      &quot;Instances&quot;: [\r\n        {\r\n          &quot;InstanceId&quot;: &quot;i-2&quot;,\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Value&quot;: &quot;hostname2&quot;,\r\n              &quot;Key&quot;: &quot;Name&quot;\r\n            }\r\n          ],\r\n          &quot;AmiLaunchIndex&quot;: 0\r\n        }\r\n      ],\r\n      &quot;ReservationId&quot;: &quot;r-1&quot;,\r\n      &quot;Groups&quot;: []\r\n    },\r\n    {\r\n      &quot;Instances&quot;: [\r\n        {\r\n          &quot;InstanceId&quot;: &quot;i-3&quot;,\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Value&quot;: &quot;hostname3&quot;,\r\n              &quot;Key&quot;: &quot;Name&quot;\r\n            }\r\n          ],\r\n          &quot;AmiLaunchIndex&quot;: 0\r\n        }\r\n      ],\r\n      &quot;ReservationId&quot;: &quot;r-1&quot;,\r\n      &quot;Groups&quot;: []\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nstate.json:\r\n```\r\n{\r\n    &quot;StoppingInstances&quot;: [\r\n        {\r\n            &quot;CurrentState&quot;: {\r\n                &quot;Code&quot;: 80,\r\n                &quot;Name&quot;: &quot;stopped&quot;\r\n            },\r\n            &quot;InstanceId&quot;: &quot;i-1&quot;,\r\n            &quot;PreviousState&quot;: {\r\n                &quot;Code&quot;: 80,\r\n                &quot;Name&quot;: &quot;stopped&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;CurrentState&quot;: {\r\n                &quot;Code&quot;: 80,\r\n                &quot;Name&quot;: &quot;stopped&quot;\r\n            },\r\n            &quot;InstanceId&quot;: &quot;i-2&quot;,\r\n            &quot;PreviousState&quot;: {\r\n                &quot;Code&quot;: 80,\r\n                &quot;Name&quot;: &quot;stopped&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;CurrentState&quot;: {\r\n                &quot;Code&quot;: 80,\r\n                &quot;Name&quot;: &quot;stopped&quot;\r\n            },\r\n            &quot;InstanceId&quot;: &quot;i-3&quot;,\r\n            &quot;PreviousState&quot;: {\r\n                &quot;Code&quot;: 80,\r\n                &quot;Name&quot;: &quot;stopped&quot;\r\n            }\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nDesirable output (if possible):\r\n```\r\n{\r\n  &quot;StoppingInstances&quot;: [\r\n      {\r\n          &quot;CurrentState&quot;: {\r\n              &quot;Code&quot;: 80,\r\n              &quot;Name&quot;: &quot;stopped&quot;\r\n          },\r\n          &quot;InstanceId&quot;: &quot;i-1&quot;,\r\n          &quot;Hostname&quot;: &quot;hostname1&quot;,\r\n          &quot;PreviousState&quot;: {\r\n              &quot;Code&quot;: 80,\r\n              &quot;Name&quot;: &quot;stopped&quot;\r\n          }\r\n      },\r\n      {\r\n          &quot;CurrentState&quot;: {\r\n              &quot;Code&quot;: 80,\r\n              &quot;Name&quot;: &quot;stopped&quot;\r\n          },\r\n          &quot;InstanceId&quot;: &quot;i-2&quot;,\r\n          &quot;Hostname&quot;: &quot;hostname2&quot;,\r\n          &quot;PreviousState&quot;: {\r\n              &quot;Code&quot;: 80,\r\n              &quot;Name&quot;: &quot;stopped&quot;\r\n          }\r\n      },\r\n      {\r\n          &quot;CurrentState&quot;: {\r\n              &quot;Code&quot;: 80,\r\n              &quot;Name&quot;: &quot;stopped&quot;\r\n          },\r\n          &quot;InstanceId&quot;: &quot;i-3&quot;,\r\n          &quot;Hostname&quot;: &quot;hostname3&quot;,\r\n          &quot;PreviousState&quot;: {\r\n              &quot;Code&quot;: 80,\r\n              &quot;Name&quot;: &quot;stopped&quot;\r\n          }\r\n      }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/71367415/retrieve-one-key-value-from-another-file-at-another-depth",
        "title": "Retrieve one key value from another file at another depth"
    },
    {
        "tags": [
            "arrays",
            "json",
            "shell",
            "unix",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1646547785,
                "creation_date": 1646547785,
                "answer_id": 71368109,
                "question_id": 71368074,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As `jq` is tagged, how about the `reverse` function applied to the sublist containing the first two elements\r\n~~~sh\r\njq &#39;.[:2] |= reverse&#39;\r\n~~~\r\n~~~json\r\n[&quot;2&quot;,&quot;1&quot;,&quot;3&quot;]\r\n~~~\r\n[Demo](https://jqplay.org/s/-PeuwWsybN)",
                "title": "Swap first and second item from json array?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1646668217,
                "creation_date": 1646668217,
                "answer_id": 71383729,
                "question_id": 71368074,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "More generically, if more prosaically:\r\n\r\n    def swap(i;j): .[i] as $t | .[i]=.[j]|.[j]=$t; \r\n    swap(0;1)",
                "title": "Swap first and second item from json array?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1646668217,
        "creation_date": 1646547246,
        "last_edit_date": 1646570589,
        "question_id": 71368074,
        "body_markdown": "Suppose I have an array : `[&quot;1&quot;,&quot;2&quot;,&quot;3&quot;]`. How can I swap the first element `1` with the later one which is `2` ?\r\n\r\nThat is the end result to be `[&quot;2&quot;,&quot;1&quot;,&quot;3&quot;]`\r\n",
        "link": "https://stackoverflow.com/questions/71368074/swap-first-and-second-item-from-json-array",
        "title": "Swap first and second item from json array?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1646585283,
                "last_edit_date": 1646585283,
                "creation_date": 1646576972,
                "answer_id": 71371163,
                "question_id": 71370136,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming `.domain` is unique to the updating objects in `2.json` (change if this holds true for another key instead; even spannig over multiple keys is possible using an array, e.g. `[.name, .ip_address]`), you could use `JOIN` based on the unique `INDEX` to match corresponding pairs of objects.\r\n\r\nFurthermore, to combine a match, you could simply `add` up the pair&#39;s members, as nothing from `2.json` can effectively overwrite anything (else) in `1.json`, assuming your sample is representative to this regard. If this ish&#39;t the case, use a more fine-grained combination method instead, e.g. `first + (last | {ping_latency} | select(.[]) // {})` or similar.\r\n\r\nLastly, backed by your description\r\n&gt; Object with mark &quot;REMOVED&quot; should not appear in result. Because it is not in 1.json.\r\n\r\nit is further assumed that there is generally no object in `2.json` which should **newly** be added to `1.json`. As `JOIN` behaves exactly that way, checking for `&quot;REMOVED&quot;` is believed to not be necessary.\r\n\r\nHaving the first file as input while reading the second file into a variable using `--argfile`:\r\n~~~sh\r\njq --argfile a 2.json &#39;[JOIN(INDEX($a[]; .domain); .[]; .domain; add)]&#39; 1.json\r\n~~~\r\nOr, equivalently, reading in both files into one array using `--slurp`:\r\n~~~sh\r\njq -s &#39;[JOIN(INDEX(last[]; .domain); first[]; .domain; add)]&#39; 1.json 2.json\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;domain&quot;: &quot;ca944.nordvpn.com&quot;,\r\n    &quot;name&quot;: &quot;Canada #944&quot;,\r\n    &quot;ip_address&quot;: &quot;172.83.40.219&quot;,\r\n    &quot;ping_latency&quot;: 123\r\n  },\r\n  {\r\n    &quot;domain&quot;: &quot;pl128.nordvpn.com&quot;,\r\n    &quot;name&quot;: &quot;Poland #128&quot;,\r\n    &quot;ip_address&quot;: &quot;194.99.105.100&quot;\r\n  },\r\n  {\r\n    &quot;domain&quot;: &quot;dk151.nordvpn.com&quot;,\r\n    &quot;name&quot;: &quot;Denmark #151&quot;,\r\n    &quot;ip_address&quot;: &quot;82.102.20.236&quot;,\r\n    &quot;ping_latency&quot;: 13\r\n  },\r\n  {\r\n    &quot;domain&quot;: &quot;be148.nordvpn.com&quot;,\r\n    &quot;name&quot;: &quot;Belgium #148&quot;,\r\n    &quot;ip_address&quot;: &quot;82.102.19.137&quot;,\r\n    &quot;ping_latency&quot;: 67\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/WUNqbQFC_q)",
                "title": "With JQ update JSON array with values from another one, namely JOIN"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1646587218,
        "creation_date": 1646568633,
        "last_edit_date": 1646587218,
        "question_id": 71370136,
        "body_markdown": "Given two files `1.json` and `2.json`. They are both arrays of objects. Need to update field `ping_latency` to 1.json from 2.json\r\n\r\n`1.json`\r\n```json\r\n[\r\n    {\r\n      &quot;domain&quot;: &quot;ca944.nordvpn.com&quot;,\r\n      &quot;name&quot;: &quot;Canada #944&quot;,\r\n      &quot;ip_address&quot;: &quot;172.83.40.219&quot;\r\n    },\r\n    {\r\n      &quot;domain&quot;: &quot;pl128.nordvpn.com&quot;,\r\n      &quot;name&quot;: &quot;Poland #128&quot;,\r\n      &quot;ip_address&quot;: &quot;194.99.105.100&quot;\r\n    },\r\n    {\r\n      &quot;domain&quot;: &quot;dk151.nordvpn.com&quot;,\r\n      &quot;name&quot;: &quot;Denmark #151&quot;,\r\n      &quot;ip_address&quot;: &quot;82.102.20.236&quot;\r\n    },\r\n    {\r\n      &quot;domain&quot;: &quot;be148.nordvpn.com&quot;,\r\n      &quot;name&quot;: &quot;Belgium #148&quot;,\r\n      &quot;ip_address&quot;: &quot;82.102.19.137&quot;,\r\n      &quot;ping_latency&quot;: 334\r\n    }\r\n]\r\n```\r\n`2.json`\r\n```json\r\n[\r\n    {\r\n      &quot;domain&quot;: &quot;ca944.nordvpn.com&quot;,\r\n      &quot;name&quot;: &quot;Canada #944&quot;,\r\n      &quot;ip_address&quot;: &quot;172.83.40.219&quot;,\r\n      &quot;ping_latency&quot;: 123\r\n    },\r\n    {\r\n      &quot;domain&quot;: &quot;pl27.nordvpn.com&quot;,\r\n      &quot;name&quot;: &quot;Poland #27&quot;,\r\n      &quot;ip_address&quot;: &quot;194.99.105.27&quot;,\r\n      &quot;ping_latency&quot;: &quot;REMOVED&quot;\r\n    },\r\n    {\r\n      &quot;domain&quot;: &quot;dk151.nordvpn.com&quot;,\r\n      &quot;name&quot;: &quot;Denmark #151&quot;,\r\n      &quot;ip_address&quot;: &quot;82.102.20.236&quot;,\r\n      &quot;ping_latency&quot;: 13\r\n    },\r\n    {\r\n      &quot;domain&quot;: &quot;be148.nordvpn.com&quot;,\r\n      &quot;name&quot;: &quot;Belgium #148&quot;,\r\n      &quot;ip_address&quot;: &quot;82.102.19.137&quot;,\r\n      &quot;ping_latency&quot;: 67\r\n    }\r\n]\r\n```\r\nObject with mark &quot;REMOVED&quot; should not appear in result. Because it is not in 1.json.\r\n\r\nPS &lt;sub&gt;I do not work for NordVPN - this is just an example.&lt;/sub&gt;\r\n\r\n-----\r\nI tried to merge arrays with operator `+` or `*`. But it always adds &quot;REMOVED&quot; domain.\r\n\r\n\r\n```\r\njq -s &#39;map(INDEX(.domain)) | add | [.[]]&#39; {1,2}.json\r\n```\r\nand\r\n```\r\njq -s &#39;(.[0]|INDEX(.domain)) as $x | (.[1]|INDEX(.domain)) as $y | $x *$y&#39; {1,2}.json\r\n```\r\nBoth adds &quot;REMOVED&quot; node from 2.json.\r\n```json\r\n[\r\n  {\r\n    &quot;domain&quot;: &quot;ca944.nordvpn.com&quot;,\r\n    &quot;name&quot;: &quot;Canada #944&quot;,\r\n    &quot;ip_address&quot;: &quot;172.83.40.219&quot;,\r\n    &quot;ping_latency&quot;: 123\r\n  },\r\n  {\r\n    &quot;domain&quot;: &quot;pl128.nordvpn.com&quot;,\r\n    &quot;name&quot;: &quot;Poland #128&quot;,\r\n    &quot;ip_address&quot;: &quot;194.99.105.100&quot;\r\n  },\r\n  {\r\n    &quot;domain&quot;: &quot;dk151.nordvpn.com&quot;,\r\n    &quot;name&quot;: &quot;Denmark #151&quot;,\r\n    &quot;ip_address&quot;: &quot;82.102.20.236&quot;,\r\n    &quot;ping_latency&quot;: 13\r\n  },\r\n  {\r\n    &quot;domain&quot;: &quot;be148.nordvpn.com&quot;,\r\n    &quot;name&quot;: &quot;Belgium #148&quot;,\r\n    &quot;ip_address&quot;: &quot;82.102.19.137&quot;,\r\n    &quot;ping_latency&quot;: 67\r\n  },\r\n  {\r\n    &quot;domain&quot;: &quot;pl27.nordvpn.com&quot;,\r\n    &quot;name&quot;: &quot;Poland #27&quot;,\r\n    &quot;ip_address&quot;: &quot;194.99.105.27&quot;,\r\n    &quot;ping_latency&quot;: &quot;REMOVED&quot;\r\n  }\r\n]\r\n```\r\n\r\nHow to manage it?\r\n\r\n\r\n----------\r\n\r\nUpdate. After some mental fight I found a way and managed to do that in JQ\r\n```\r\njq &#39;INDEX(.domain) as $u | \r\n     reduce ($full[][] | {domain,ip_address,name}) as $i (\r\n     []; . + [ $i | .ping_latency=( $u[$i.domain].ping_latency//98767 )]\r\n    )&#39; --slurpfile full 1.json &lt;2.json\r\n```\r\n\r\nBut comparing to operator `*` my approach is about 100 times slower and takes up to 2 second on Intel Core i7-11xxx with array length of 5474 objects\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;domain&quot;: &quot;ca944.nordvpn.com&quot;,\r\n    &quot;ip_address&quot;: &quot;172.83.40.219&quot;,\r\n    &quot;name&quot;: &quot;Canada #944&quot;,\r\n    &quot;ping_latency&quot;: 123\r\n  },\r\n  {\r\n    &quot;domain&quot;: &quot;pl128.nordvpn.com&quot;,\r\n    &quot;ip_address&quot;: &quot;194.99.105.100&quot;,\r\n    &quot;name&quot;: &quot;Poland #128&quot;,\r\n    &quot;ping_latency&quot;: 98767\r\n  },\r\n  {\r\n    &quot;domain&quot;: &quot;dk151.nordvpn.com&quot;,\r\n    &quot;ip_address&quot;: &quot;82.102.20.236&quot;,\r\n    &quot;name&quot;: &quot;Denmark #151&quot;,\r\n    &quot;ping_latency&quot;: 13\r\n  },\r\n  {\r\n    &quot;domain&quot;: &quot;be148.nordvpn.com&quot;,\r\n    &quot;ip_address&quot;: &quot;82.102.19.137&quot;,\r\n    &quot;name&quot;: &quot;Belgium #148&quot;,\r\n    &quot;ping_latency&quot;: 67\r\n  }\r\n]\r\n```\r\n\r\nMay be you know a quick better way?",
        "link": "https://stackoverflow.com/questions/71370136/with-jq-update-json-array-with-values-from-another-one-namely-join",
        "title": "With JQ update JSON array with values from another one, namely JOIN"
    },
    {
        "tags": [
            "input",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646614807,
                "post_id": 71375408,
                "comment_id": 126160434,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8919214,
                    "reputation": 1037,
                    "user_id": 6656508,
                    "user_type": "registered",
                    "accept_rate": 14,
                    "profile_image": "https://lh5.googleusercontent.com/-Cw00Euo9ls4/AAAAAAAAAAI/AAAAAAAAAD0/AxPxZMOm4qc/s256-rj/photo.jpg",
                    "display_name": "Logan Lee",
                    "link": "https://stackoverflow.com/users/6656508/logan-lee"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646614922,
                "post_id": 71375408,
                "comment_id": 126160447,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646615363,
                "post_id": 71375408,
                "comment_id": 126160515,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8919214,
                    "reputation": 1037,
                    "user_id": 6656508,
                    "user_type": "registered",
                    "accept_rate": 14,
                    "profile_image": "https://lh5.googleusercontent.com/-Cw00Euo9ls4/AAAAAAAAAAI/AAAAAAAAAD0/AxPxZMOm4qc/s256-rj/photo.jpg",
                    "display_name": "Logan Lee",
                    "link": "https://stackoverflow.com/users/6656508/logan-lee"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646615592,
                "post_id": 71375408,
                "comment_id": 126160547,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1646616155,
                "post_id": 71375408,
                "comment_id": 126160626,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1646615331,
                "creation_date": 1646615331,
                "answer_id": 71375478,
                "question_id": 71375408,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "These filters should do what you want:\r\n~~~sh\r\njq -n &#39;reduce inputs as $in ([]; if $in | has(1) then . + [$in[1]] else . end)&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/5jSAJAOpmV)\r\n\r\n~~~sh\r\njq -n &#39;[inputs | select(has(1))[1]]&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/q0IQjUtmS5)",
                "title": "jq reducing stream to an array of all leaf values using input"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1646675489,
        "creation_date": 1646614265,
        "last_edit_date": 1646675489,
        "question_id": 71375408,
        "body_markdown": "I want to receive streamed json inputs and reduce them to an array containing the leaf values.\r\n\r\nDemo: https://jqplay.org/s/cZxLguJFxv\r\n\r\nPlease consider\r\n\r\nfilter:\r\n\r\n```jq\r\ntry reduce range(30) as $i ( []; (.+[until(length==2;input)[1]] // error(.))  )\r\ncatch empty\r\n```\r\n\r\ninput:\r\n\r\n```json\r\n[\r\n  [\r\n    0,\r\n    0,\r\n    &quot;a&quot;\r\n  ],\r\n  null\r\n]\r\n[\r\n  [\r\n    0,\r\n    0,\r\n    &quot;a&quot;\r\n  ]\r\n]\r\n[\r\n  [\r\n    0,\r\n    1,\r\n    &quot;b&quot;\r\n  ],\r\n  null\r\n]\r\n[\r\n  [\r\n    0,\r\n    1,\r\n    &quot;b&quot;\r\n  ]\r\n]\r\n[\r\n  [\r\n    0,\r\n    1\r\n  ]\r\n]\r\n[\r\n  [\r\n    1\r\n  ],\r\n  0\r\n]\r\n...\r\n\r\noutput:\r\nempty\r\n```\r\n\r\nI expect the output: `[null, null, 0, ...]` but I get empty instead.\r\n\r\nI told `reduce` to iterate 30 times but the size of inputs is less than that. I&#39;m expecting it will `empty` those input of length other than 2 and produce an array containing all leaf values.\r\n\r\nI don&#39;t know how this will behave when there is no more `input` with length 2 left and there are iterations of `reduce` left.\r\n\r\nI want to know why my filter returns empty. What am I doing wrong? Thanks!",
        "link": "https://stackoverflow.com/questions/71375408/jq-reducing-stream-to-an-array-of-all-leaf-values-using-input",
        "title": "jq reducing stream to an array of all leaf values using input"
    },
    {
        "tags": [
            "arrays",
            "bash",
            "jq",
            "ref"
        ],
        "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": 1646678124,
                "post_id": 71385680,
                "comment_id": 126178451,
                "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": 1646678434,
                "post_id": 71385680,
                "comment_id": 126178564,
                "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": 1646678724,
                "post_id": 71385680,
                "comment_id": 126178652,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1646688142,
                "last_edit_date": 1646688142,
                "creation_date": 1646678346,
                "answer_id": 71385778,
                "question_id": 71385680,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s no need for `readarray` here: You can have two separate NUL-delimited `read`s as part of your `while` loop.\r\n\r\nSee the below answer demonstrated at https://replit.com/@CharlesDuffy2/GrandioseDraftyArguments#main.sh\r\n\r\n```\r\nwhile IFS= read -r -d &#39;&#39; key &amp;&amp; IFS= read -r -d &#39;&#39; value; do\r\n  hash_table[$key]=$value\r\ndone &lt; &lt;(jq -cjn --argjson d &quot;$arr&quot; \\\r\n           &#39;$d | to_entries[] | ( .key, &quot;\\u0000&quot;, .value, &quot;\\u0000&quot;)&#39;)\r\n```\r\n\r\nPutting this into context:\r\n\r\n```\r\njson_dict() {\r\n  declare key value in_value=&quot;${!1}&quot;\r\n  unset &quot;$1&quot;                   # FIXME: Better to take a $2 for output variable\r\n  declare -g -A &quot;$1&quot;\r\n  declare -n hash_table=&quot;$1&quot;\r\n  while IFS= read -r -d &#39;&#39; key &amp;&amp; IFS= read -r -d &#39;&#39; value; do\r\n    hash_table[$key]=$value\r\n  done &lt; &lt;(\r\n  \tjq -cjn --argjson d &quot;$in_value&quot; \\\r\n      &#39;$d | to_entries[] | ( .key, &quot;\\u0000&quot;, .value, &quot;\\u0000&quot;)&#39;\r\n  )\r\n}\r\n \r\narr=&#39;{&quot;a&quot;: &quot;aa&quot;, &quot;l&quot;: &quot;bb&quot;, &quot;c&quot;: &quot;ccccc&quot;}&#39;\r\njson_dict arr\r\ndeclare -p arr\r\n```\r\n\r\n...emits as output:\r\n\r\n```\r\ndeclare -A arr=([a]=&quot;aa&quot; [c]=&quot;ccccc&quot; [l]=&quot;bb&quot; )\r\n```\r\n\r\n\r\n---\r\n\r\nThat said, to answer the question _exactly as-asked_, thus using `readarray`:\r\n\r\n```\r\njson_dict() {\r\n  declare -a pieces=()\r\n\r\n  readarray -d &#39;&#39; pieces &lt; &lt;(\r\n    jq -cjn --argjson d &quot;${!1}&quot; \\\r\n      &#39;$d | to_entries[] | ( .key, &quot;\\u0000&quot;, .value, &quot;\\u0000&quot;)&#39;\r\n  )\r\n\r\n  unset &quot;$1&quot;\r\n  declare -g -A &quot;$1&quot;\r\n  declare -n hash_table=&quot;$1&quot;\r\n  set -- &quot;${pieces[@]}&quot;\r\n\r\n  while (( $# )); do\r\n    hash_table[$1]=$2\r\n    { shift &amp;&amp; shift; } || return\r\n  done\r\n}\r\n\r\narr=&#39;{&quot;a&quot;: &quot;aa&quot;, &quot;l&quot;: &quot;bb&quot;, &quot;c&quot;: &quot;ccccc&quot;}&#39;\r\njson_dict arr\r\ndeclare -p arr\r\n```\r\n",
                "title": "json dictionary to bash hash table using readarray"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1646769279,
                "last_edit_date": 1646769279,
                "creation_date": 1646678875,
                "answer_id": 71385875,
                "question_id": 71385680,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Wouldn&#39;t it be simpler to just use `declare` and have `jq` create the contents using `@sh` for shell conformity?\r\n\r\nIndexed array:\r\n~~~sh\r\nunset arr; arr=&#39;[&quot;a&quot;, &quot;b&quot;, &quot;c&quot;]&#39;\r\ndeclare -a arr=&quot;($(jq -r @sh &lt;&lt;&lt; &quot;$arr&quot;))&quot;\r\n~~~\r\n\r\nAssociative array:\r\n~~~sh\r\nunset arr; arr=&#39;{&quot;a&quot;: &quot;aa&quot;, &quot;l&quot;: &quot;bb&quot;, &quot;c&quot;: &quot;ccccc&quot;}&#39;\r\ndeclare -A arr=&quot;($(jq -r &#39;to_entries[] | @sh &quot;[\\(.key)]=\\(.value)&quot;&#39; &lt;&lt;&lt; &quot;$arr&quot;))&quot;\r\n~~~\r\n\r\n---\r\nReacting to an edit request: The above requires the values to be strings (numbers and booleans will kind of work, too), but other structures need to be brought into a stringy format first. In particular, following the request, `@json` could be used to encode an arbitrary JSON content as a string. However, keep in mind that in doing so, the bash array&#39;s items will be JSON-encoded, which means that also the simple cases (strings like `aa` from above) will be encoded (e.g. as `&quot;aa&quot;`, including the quotes, as required by JSON). If this is what you want, go for it:\r\n\r\nIndexed array with JSON-encoded values:\r\n~~~sh\r\nunset arr; arr=&#39;[&quot;a&quot;, {}, [null, {&quot;a&quot;: true}]]&#39;\r\ndeclare -a arr=&quot;($(jq -r &#39;map(@json) | @sh&#39; &lt;&lt;&lt; &quot;$arr&quot;))&quot;\r\n~~~\r\n\r\nAssociative array with JSON-encoded values:\r\n~~~sh\r\nunset arr; arr=&#39;{&quot;a&quot;: &quot;aa&quot;, &quot;b&quot;: {&quot;l&quot;: &quot;bb&quot;, &quot;c&quot;: &quot;ccccc&quot;}}&#39;\r\ndeclare -A arr=&quot;($(jq -r &#39;to_entries[] | @sh &quot;[\\(.key)]=\\(.value | @json)&quot;&#39; &lt;&lt;&lt; &quot;$arr&quot;))&quot;\r\n~~~",
                "title": "json dictionary to bash hash table using readarray"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1646769279,
        "creation_date": 1646677673,
        "question_id": 71385680,
        "body_markdown": "First a working example with arrays\r\n```\r\njson_array() {\r\n    local -n array=&quot;${1}&quot;\r\n    readarray -d $&#39;\\0&#39; -t array &lt; &lt;(\r\n        # Create nul delimited array entry using jq\r\n        jq -cjn --argjson arr &quot;$array&quot; &#39;$arr|map(tostring)|.[]+&quot;\\u0000&quot;&#39;\r\n    )\r\n}\r\n\r\n&gt; unset arr; arr=&#39;[&quot;a&quot;, &quot;b&quot;, &quot;c&quot;]&#39;; json_array arr; echo &quot;${arr[0]} ${arr[1]} ${arr[2]}&quot;\r\na b c\r\n```\r\n\r\nNow I&#39;m trying to do something similar with dict, convert a json dict into a bash associative array\r\n\r\n```\r\njson_dict() {\r\n    local -n dict=&quot;${1}&quot;\r\n    declare -A hash_table\r\n\r\n    append_to_hash_table() {\r\n        shift\r\n        { read -r key;  read -r value; } &lt;&lt;&lt;&quot;$1&quot;\r\n        hash_table+=([$key]=&quot;$value&quot;)\r\n    }\r\n\r\n    readarray -d $&#39;\\0&#39; -c 1 -C append_to_hash_table &lt; &lt;(\r\n        # Create nul delimited dict entry using jq\r\n        jq -cjn --argjson d &quot;$dict&quot; &#39;$d|to_entries|map(&quot;\\(.key)\\n\\(.value|tostring|@sh)&quot;)|.[]+&quot;\\u0000&quot;&#39;\r\n    )\r\n\r\n    # Here hash_table contain the correct output\r\n    dict=&quot;&quot;\r\n    dict=&quot;$hash_table&quot;\r\n}\r\n\r\n&gt; unset arr; arr=&#39;{&quot;a&quot;: &quot;aa&quot;, &quot;l&quot;: &quot;bb&quot;, &quot;c&quot;: &quot;ccccc&quot;}&#39;; json_dict arr; echo &quot;${arr[@]}&quot;\r\nNothing\r\n```\r\nIt seems `dict=&quot;$hash_table&quot;` doesn&#39;t correctly update the refname,\r\nHow can I make bash `dict` refname point to `hash_table`? ",
        "link": "https://stackoverflow.com/questions/71385680/json-dictionary-to-bash-hash-table-using-readarray",
        "title": "json dictionary to bash hash table using readarray"
    }
]