[
    {
        "tags": [
            "json",
            "nested",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1613447874,
                "creation_date": 1613447874,
                "answer_id": 66218511,
                "question_id": 66218359,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key to a straightforward solution is to write a helper function for extracting the key/key strings:\r\n```\r\n# emit a stream of key1/key3 strings\r\ndef pairs:\r\n  keys_unsorted[] as $k1\r\n  | .[$k1][]\r\n  | keys_unsorted[] as $k3\r\n  | &quot;\\($k1)/\\($k3)&quot;;\r\n```\r\n\r\nNow, thanks to jq&#39;s `|=` operator, the solution can be written simply as:\r\n```\r\nmap_values(.pairs |= [pairs])\r\n```",
                "title": "Reshape JSON with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1613447943,
        "creation_date": 1613446448,
        "last_edit_date": 1613447943,
        "question_id": 66218359,
        "body_markdown": "I&#39;m trying to reshape a JSON file using JQ, and I can&#39;t seems to find the correct way to do it.\r\n\r\nBasically I&#39;m trying to turn some of the keys into values, and re-organize some parts of the JSON.\r\n\r\nThe source JSON is the following :\r\n\r\n```\r\n{\r\n  &quot;ABCC&quot;: {\r\n    &quot;pairs&quot;: {\r\n      &quot;CND&quot;: {\r\n        &quot;tsyms&quot;: {\r\n          &quot;BTC&quot;: {\r\n            &quot;useless_variable1&quot;: &quot;useless_value1&quot;,\r\n            &quot;useless_variable2&quot;: &quot;useless_value2&quot;\r\n          },\r\n          &quot;ETH&quot;: {\r\n            &quot;useless_variable1&quot;: &quot;useless_value1&quot;,\r\n            &quot;useless_variable2&quot;: &quot;useless_value2&quot;\r\n          }\r\n        }\r\n      },\r\n      &quot;ELF&quot;: {\r\n        &quot;tsyms&quot;: {\r\n          &quot;ETH&quot;: {\r\n            &quot;useless_variable1&quot;: &quot;useless_value1&quot;,\r\n            &quot;useless_variable2&quot;: &quot;useless_value2&quot;\r\n          },\r\n          &quot;BTC&quot;: {\r\n            &quot;useless_variable1&quot;: &quot;useless_value1&quot;,\r\n            &quot;useless_variable2&quot;: &quot;useless_value2&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n  },\r\n  &quot;ACX&quot;: {\r\n    &quot;pairs&quot;: {\r\n      &quot;PLA&quot;: {\r\n        &quot;tsyms&quot;: {\r\n          &quot;AUD&quot;: {\r\n            &quot;useless_variable1&quot;: &quot;useless_value1&quot;,\r\n            &quot;useless_variable2&quot;: &quot;useless_value2&quot;\r\n          },\r\n          &quot;USDT&quot;: {\r\n            &quot;useless_variable1&quot;: &quot;useless_value1&quot;,\r\n            &quot;useless_variable2&quot;: &quot;useless_value2&quot;\r\n          }\r\n        }\r\n      },\r\n      &quot;BTC&quot;: {\r\n        &quot;tsyms&quot;: {\r\n          &quot;USDT&quot;: {\r\n            &quot;useless_variable1&quot;: &quot;useless_value1&quot;,\r\n            &quot;useless_variable2&quot;: &quot;useless_value2&quot;\r\n          },\r\n          &quot;AUD&quot;: {\r\n            &quot;useless_variable1&quot;: &quot;useless_value1&quot;,\r\n            &quot;useless_variable2&quot;: &quot;useless_value2&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nAnd the expected JSON output would be something like that :\r\n\r\n```\r\n{\r\n  &quot;ABCC&quot;: {\r\n    &quot;pairs&quot;: [\r\n      &quot;CND/BTC&quot;,\r\n      &quot;CND/ETH&quot;,\r\n      &quot;ELF/ETH&quot;,\r\n      &quot;ELF/BTC&quot;\r\n    ]\r\n  },\r\n  &quot;ACX&quot;: {\r\n    &quot;pairs&quot;: [\r\n      &quot;PLA/AUD&quot;,\r\n      &quot;PLA/USDT&quot;,\r\n      &quot;BTC/USDT&quot;,\r\n      &quot;BTC/AUD&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nAny idea how I could reach this result ?\r\n\r\nThanks !",
        "link": "https://stackoverflow.com/questions/66218359/reshape-json-with-jq",
        "title": "Reshape JSON with JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1613493045,
                "creation_date": 1613493045,
                "answer_id": 66228378,
                "question_id": 66224534,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could combine the two arrays and just group by the common ID field and form the desired output object\r\n\r\n```none\r\njq &#39;.employees + .sorted_employees | group_by(.id) | \r\n  map({&quot;Full name&quot;: .[0].&quot;full name&quot;, ID: .[0].id, &quot;Sales&quot;: .[1].sales})&#39;\r\n```",
                "title": "Combining fields from multiple arrays to a single object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1613493045,
        "creation_date": 1613479317,
        "last_edit_date": 1613492791,
        "question_id": 66224534,
        "body_markdown": "What I need is simply to extract **id**, **sales** from **sorted_employees** AND **full name** for that employee from **employees**.. like this:\r\n\r\n```json\r\n{ &quot;Full name&quot;: &quot;John Doe&quot;, &quot;ID&quot;: &quot;employee1&quot;, &quot;Sales&quot;: &quot;26&quot; }\r\n{ &quot;Full name&quot;: &quot;Sam Jones&quot;, &quot;ID&quot;: &quot;employee2&quot;, &quot;Sales&quot;: &quot;119&quot; }\r\n```\r\n\r\nWhat would be the easiest way to combine these 2 arrays ( employees &amp; sorted_employees ) ? I have problems merging the result, I have tried to cast results into an array and I tried purely with jq filters.. but it doesn&#39;t want to give me what I need..\r\n\r\n\r\n```bash\r\nemployees_id=$( echo &quot;${json_data}&quot; | jq -r &#39;.employees[] | .id&#39; )\r\nsorted_employees_id=$( echo &quot;${json_data}&quot; | jq -r &#39;.sorted_employees[] | .id&#39; )\r\nsorted_employees_sales=$( echo &quot;${json_data}&quot; | jq &#39;.sorted_employees[] | .sales&#39; )\r\n```\r\n\r\n```json\r\n{\r\n    &quot;employees&quot;: [ {\r\n       &quot;started_at&quot;: &quot;2018-05-01 12.00&quot;,\r\n       &quot;id&quot;: &quot;employee1&quot;,\r\n       &quot;facebook&quot;: &quot;https://fb/john_doe&quot;,\r\n       &quot;full name&quot;: &quot;John Doe&quot;\r\n    }, {\r\n       &quot;started_at&quot;: &quot;2017-05-01 12.00&quot;,\r\n       &quot;id&quot;: &quot;employee2&quot;,\r\n       &quot;facebook&quot;: &quot;https://fb/sam_jones&quot;,\r\n       &quot;full name&quot;: &quot;Sam Jones&quot;\r\n    }, {\r\n       &quot;started_at&quot;: &quot;2016-05-01 12.00&quot;,\r\n       &quot;id&quot;: &quot;employee3&quot;,\r\n       &quot;facebook&quot;: &quot;https://fb/jane_roe&quot;,\r\n       &quot;full name&quot;: &quot;Jane Roe&quot;\r\n\r\n    }],\r\n    &quot;sorted_employees&quot;: [{\r\n        &quot;id&quot;: &quot;employee1&quot;,\r\n        &quot;sales&quot;: 26\r\n    }, {\r\n        &quot;id&quot;: &quot;employee2&quot;,\r\n        &quot;sales&quot;: 119\r\n    }, {\r\n        &quot;id&quot;: &quot;employee3&quot;,\r\n        &quot;sales&quot;: 84\r\n    }]\r\n}\r\n```\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66224534/combining-fields-from-multiple-arrays-to-a-single-object",
        "title": "Combining fields from multiple arrays to a single object"
    },
    {
        "tags": [
            "json",
            "scripting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613479954,
                "post_id": 66224693,
                "comment_id": 117082460,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15935122,
                    "reputation": 161,
                    "user_id": 11498500,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-pOW3u_ow9ww/AAAAAAAAAAI/AAAAAAAADtk/7ixAhR3ty6M/s256-rj/photo.jpg",
                    "display_name": "Suhasini Subramaniam",
                    "link": "https://stackoverflow.com/users/11498500/suhasini-subramaniam"
                },
                "reply_to_user": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1613479995,
                "post_id": 66224693,
                "comment_id": 117082483,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1613488628,
                "post_id": 66224693,
                "comment_id": 117086691,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1613504555,
                "last_edit_date": 1613504555,
                "creation_date": 1613502886,
                "answer_id": 66230752,
                "question_id": 66224693,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ideally your input would be json but if that&#39;s the contents of the file, jq won&#39;t be able to process as json without tweaking the input. Fortunately, not too much, just read the file as a string, &quot;tweak it,&quot; parse `fromjson` and get the desired fields.\r\n\r\n```\r\n$ cat file.in\r\n                &quot;3&quot;: {\r\n                    &quot;cpumask&quot;: &quot;0x000000003C000000&quot;,\r\n                    &quot;devices&quot;: [\r\n                        &quot;Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01&quot;,\r\n                        &quot;Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01&quot;,\r\n                        &quot;Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01&quot;\r\n                    ]\r\n                },\r\n                &quot;2&quot;: {\r\n                    &quot;cpumask&quot;: &quot;0x0000000000060000&quot;,\r\n                    &quot;devices&quot;: [\r\n                        &quot;Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01&quot;,\r\n                        &quot;Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01&quot;\r\n                    ]\r\n                },\r\n$ &lt;/tmp/file.in jq -Rsr &#39;&quot;{\\(sub(&quot;\\\\},$&quot;; &quot;}&quot;))}&quot; | fromjson[].devices[]&#39; &gt;/tmp/sn310_dev.out\r\n$ cat /tmp/sn310_dev.out\r\nSamsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01\r\nSamsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01\r\nSamsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01\r\nSamsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01\r\nSamsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01\r\n```\r\n\r\nHere, the switches `-R` and `-s` takes the entire input in as a string while `-r` outputs the results as a raw string.\r\n\r\n```\r\n&quot;{\\(sub(&quot;\\\\},$&quot;; &quot;}&quot;))}&quot;\r\n```\r\n\r\nSubstitute the trailing `},` with a `}` and wrap all in `{}` to make it look like a json object.\r\n\r\n```\r\nfromjson[].devices[]\r\n```\r\n\r\nParse the json object string to a value, and extract the values from the object and the values from each of the values&#39; `devices` property.\r\n\r\n[jqplay](https://jqplay.org/s/d24L_9UrUM)",
                "title": "print the pattern between (and excluding) two pattern as many as occasion it appears"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1613504555,
        "creation_date": 1613479865,
        "last_edit_date": 1613480049,
        "question_id": 66224693,
        "body_markdown": "print the pattern between (and excluding) two pattern as many as occasion it appears\r\n\r\n***Input file***\r\n\r\n    $ cat /tmp/file.in\r\n                    &quot;3&quot;: {\r\n                        &quot;cpumask&quot;: &quot;0x000000003C000000&quot;,\r\n                        &quot;devices&quot;: [\r\n                            &quot;Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01&quot;,\r\n                            &quot;Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01&quot;,\r\n                            &quot;Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01&quot;\r\n                        ]\r\n                    },\r\n                    &quot;2&quot;: {\r\n                        &quot;cpumask&quot;: &quot;0x0000000000060000&quot;,\r\n                        &quot;devices&quot;: [\r\n                            &quot;Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01&quot;,\r\n                            &quot;Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01&quot;\r\n                        ]\r\n                    },\r\n\r\ntried but only prints the first occasion\r\n\r\n    $ sed &#39;1,/devices/d;/]/,$d&#39;  /tmp/sn310_dev.out\r\n                            &quot;Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01&quot;,\r\n                            &quot;Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01&quot;,\r\n                            &quot;Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66224693/print-the-pattern-between-and-excluding-two-pattern-as-many-as-occasion-it-app",
        "title": "print the pattern between (and excluding) two pattern as many as occasion it appears"
    },
    {
        "tags": [
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1613492775,
                "post_id": 66226257,
                "comment_id": 117088708,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28096,
                    "reputation": 2804,
                    "user_id": 74683,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/e2326aa08224115dd8724ff6c1c7f2ee?s=256&d=identicon&r=PG",
                    "display_name": "Gunnlaugur Briem",
                    "link": "https://stackoverflow.com/users/74683/gunnlaugur-briem"
                },
                "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": 1613657846,
                "post_id": 66226257,
                "comment_id": 117147350,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1613657902,
                "last_edit_date": 1613657902,
                "creation_date": 1613499407,
                "answer_id": 66229964,
                "question_id": 66226257,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This response only addresses the issue of finding a:\r\n&gt; way to output CSV header only once\r\n\r\nOne way is to use `input` to handle the very first JSON entity, and then use `inputs` to handle the rest, all with jq&#39;s -n command-line option.\r\n\r\n```\r\ninput\r\n| . as $in\r\n| (map(keys_unsorted) | add | unique) as $cols\r\n| $cols,\r\n  (($in, inputs) | map(. as $row | $cols | map($row[.])))\r\n\r\n```\r\nNote also the use of `keys_unsorted` here.",
                "title": "Access to array of input filenames (or other way to output CSV header only once)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1613657902,
        "creation_date": 1613485561,
        "question_id": 66226257,
        "body_markdown": "I run jq with multiple identically-structured json files as input, to output a single CSV stream, with a jq script ending like:\r\n\r\n```\r\n| (map(keys) | add | unique) as $cols\r\n| map(. as $row | $cols | map($row[.])) as $rows\r\n| if (input_filename == &quot;first-file.json&quot; then $cols, $rows[] else $rows[] end\r\n| @csv\r\n```\r\n\r\nwhere that third line is to avoid repeating the CSV header for each JSON file. It&#39;s an ugly hack because it hardcodes the first input filename. I&#39;d like to instead use `input_filenames[0]` but there is no such global property — or am I missing it? Or is there some other neater way to avoid repeating the header row in the output CSV?",
        "link": "https://stackoverflow.com/questions/66226257/access-to-array-of-input-filenames-or-other-way-to-output-csv-header-only-once",
        "title": "Access to array of input filenames (or other way to output CSV header only once)"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1613491985,
                "last_edit_date": 1613491985,
                "creation_date": 1613490900,
                "answer_id": 66227783,
                "question_id": 66227214,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `keys[]` attribute\r\n\r\n```none\r\n.RuntimeSources | keys[] \r\n```\r\n\r\nand also\r\n\r\n```none\r\n.RuntimeSources | keys[] as $k | .[$k] | keys[]\r\n```\r\n\r\nSince you had also mentioned, the structure doesn&#39;t change, you can just select the paths that contains 3 levels\r\n\r\n```none\r\npaths | select( length == 3 ) | .[1]\r\npaths | select( length == 3 ) | .[2]\r\n```",
                "title": "Extract the key names from a fixed JSON structure"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1613491116,
                "creation_date": 1613491116,
                "answer_id": 66227843,
                "question_id": 66227214,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I managed to get it with:\r\n\r\n    jq &#39;.RuntimeSources | .[] | keys&#39;\r\n\r\nNot sure if it&#39;s the best solution, but did the trick.",
                "title": "Extract the key names from a fixed JSON structure"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1613492695,
        "creation_date": 1613488857,
        "last_edit_date": 1613492695,
        "question_id": 66227214,
        "body_markdown": "I have a JSON with dynamic data and not sure how I can retrieve data with JQ.\r\nMy JSON is:\r\n\r\n```json\r\n{\r\n   &quot;RuntimeSources&quot;:{\r\n      &quot;env-name-DYNAMIC&quot;:{\r\n         &quot;the-dynamic-value-i-need-to-get&quot;:{\r\n            &quot;url&quot;:&quot;&quot;\r\n         }\r\n      }\r\n   },\r\n   &quot;DeploymentId&quot;:147,\r\n   &quot;Serial&quot;:158\r\n}\r\n```\r\n\r\n&#39;env-name-DYNAMIC&#39; is dynamic and &#39;the-dynamic-value-i-need-to-get&#39; is the same.\r\nThe json structure is always the same. How can I get &#39;the-dynamic-value-i-need-to-get&#39;? Also I may need to retrieve &#39;env-name-DYNAMIC&#39;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66227214/extract-the-key-names-from-a-fixed-json-structure",
        "title": "Extract the key names from a fixed JSON structure"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "precision",
            "geojson"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1613572454,
                "creation_date": 1613572454,
                "answer_id": 66244032,
                "question_id": 66243482,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "GNU  Awk maybe a possibility:\r\n\r\n    awk &#39;/coordinates/ { lne=NR } (NR==lne+1 || NR==lne+2) &amp;&amp; /-?[[:digit:]]+\\.[[:digit:]]++/ { match($0,/-?[[:digit:]]+\\.[[:digit:]]++/);printf &quot;%s%.6f%s\\n&quot;,substr($0,1,RSTART-1),substr($0,RSTART,RLENGTH),substr($0,RSTART+RLENGTH+1);next }1&#39; file\r\n\r\nExplanation:\r\n\r\n    awk &#39;/coordinates/ { \r\n                         lne=NR                                       # Track the line number when we see a &quot;coordinates&quot; tag\r\n                       } (NR==lne+1 || NR==lne+2) &amp;&amp; /-?[[:digit:]]+\\.[[:digit:]]++/ { \r\n                         match($0,/-?[[:digit:]]+\\.[[:digit:]]++/);   # When the line is one or two ahead of coordinates, and the line contains a floating point number, extract that floating point number.\r\n                         printf &quot;%s%.6f%s\\n&quot;,substr($0,1,RSTART-1),substr($0,RSTART,RLENGTH),substr($0,RSTART+RLENGTH+1);             # Construct the line with the data before the floating point number, the number to 6 decimal places and then the text after the number\r\n                         next                                         # Skip to the next line\r\n                       }1&#39; file                                       # Use 1 to print both modified and unmodified lines.",
                "title": "Simplify geojson coordinates precision with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1613575058,
                "last_edit_date": 1613575058,
                "creation_date": 1613574708,
                "answer_id": 66244736,
                "question_id": 66243482,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could pump your JSON through a **Perl** script that rewrites anything that looks like floating point numbers as numbers with 6 decimal places like this - but it is a bit kludgy and will edit **all** things in your JSON that look like floating point numbers but only you know if that is an issue.\r\n\r\n    GenerateJSON | perl -pe &#39;s/([+-]?[0-9]+[.]?[0-9]+)/sprintf(&quot;%.6f&quot;,$&amp;)/ge&#39;\r\n\r\n**Sample Output**\r\n\r\n    {\r\n      &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n      &quot;features&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;properties&quot;: { },\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;Point&quot;,\r\n            &quot;coordinates&quot;: [\r\n              -69.235840,\r\n              45.460131\r\n            ]\r\n          }\r\n        },\r\n        ...\r\n      ]\r\n    }\r\n\r\nIt is basically a substitution, but the `/ge` at the end makes Perl `evaluate` the `sprintf` in the replacement string.\r\n\r\nNote that **Perl** is a standard part of **macOS** - i.e. automatically included with all versions.\r\n",
                "title": "Simplify geojson coordinates precision with jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1613577646,
                "last_edit_date": 1613577646,
                "creation_date": 1613574747,
                "answer_id": 66244746,
                "question_id": 66243482,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There isn&#39;t a straight forward `sprintf` like function in the math library supported by `jq` that allows you to format floating point number with a specified precision e.g. say `&#39;%2.5f&#39;`. But you can use the string functions to convert the number to float and extract the digits and convert it back \r\n\r\n```bash\r\njq &#39;.features[].geometry.coordinates |= \r\n       map( tostring | capture(&quot;(?&lt;n&gt;-?[0-9]+\\\\.[0-9]{6})&quot;).n | tonumber )&#39;\r\n```\r\n\r\nNote that this **does not work** when the floats are expressed in scientific notation e.g. of formats like `1.5e9`\r\n\r\n---\r\n\r\nThe suggestion in the [comments by Lea Gris][1] is even better, that it doesn&#39;t involve any string manipulation.\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/66243482/simplify-geojson-coordinates-precision-with-jq#comment117118513_66244746",
                "title": "Simplify geojson coordinates precision with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1613590728,
        "creation_date": 1613570546,
        "last_edit_date": 1613590728,
        "question_id": 66243482,
        "body_markdown": "I am using `jq` to change some properties and lighten the weight of a `geojson` file. The coordinates have too much decimal numbers, so I would like to simplify them to 6 decimals.\r\n\r\nThe file is originally like that:\r\n\r\n    {\r\n      &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n      &quot;features&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;properties&quot;: { },\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;Point&quot;,\r\n            &quot;coordinates&quot;: [\r\n              -69.23583984375,\r\n              45.460130637921004\r\n            ]\r\n          }\r\n        },\r\n        ...\r\n      ]\r\n    }\r\n\r\nand I would like that precision:\r\n\r\n    {\r\n      &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n      &quot;features&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;properties&quot;: { },\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;Point&quot;,\r\n            &quot;coordinates&quot;: [\r\n              -69.235840,\r\n              45.460131\r\n            ]\r\n          }\r\n        },\r\n        ...\r\n      ]\r\n    }\r\n\r\nAny suggestion?",
        "link": "https://stackoverflow.com/questions/66243482/simplify-geojson-coordinates-precision-with-jq",
        "title": "Simplify geojson coordinates precision with jq"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3320207,
                    "reputation": 4706,
                    "user_id": 2791574,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/utfmN.jpg?s=256",
                    "display_name": "hakamairi",
                    "link": "https://stackoverflow.com/users/2791574/hakamairi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613637241,
                "post_id": 66256053,
                "comment_id": 117137667,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1613660510,
                "last_edit_date": 1613660510,
                "creation_date": 1613637330,
                "answer_id": 66256309,
                "question_id": 66256053,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You definitely can do single jq query.\r\n\r\n    cat test | jq -r &#39;.items[] | select(.type == &quot;KUDU_TSERVER&quot; ) | .name&#39;\r\n\r\nOther than that you could use `--stream` for large input files.",
                "title": "How to simplify a jq sentence?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1613667581,
        "creation_date": 1613636295,
        "last_edit_date": 1613667581,
        "question_id": 66256053,
        "body_markdown": "I have this file test.json\r\n\r\n\r\n``` {\r\n  &quot;items&quot; : [ {\r\n    &quot;name&quot; : &quot;kudu-KUDU_TSERVER-2d63fec551a74320fdcc0c65007c76e4&quot;,\r\n    &quot;type&quot; : &quot;KUDU_TSERVER&quot;,\r\n    &quot;serviceRef&quot; : {\r\n      &quot;clusterName&quot; : &quot;cluster&quot;,\r\n      &quot;serviceName&quot; : &quot;kudu&quot;\r\n    },\r\n    &quot;entityStatus&quot; : &quot;GOOD_HEALTH&quot;\r\n  }, {\r\n    &quot;name&quot; : &quot;kudu-KUDU_MASTER-95ebd4d9a5158d59306372ed306993fe&quot;,\r\n    &quot;type&quot; : &quot;KUDU_MASTER&quot;,\r\n    &quot;serviceRef&quot; : {\r\n      &quot;clusterName&quot; : &quot;cluster&quot;,\r\n      &quot;serviceName&quot; : &quot;kudu&quot;\r\n    },\r\n    &quot;entityStatus&quot; : &quot;GOOD_HEALTH&quot;\r\n  }\r\n... \r\n]\r\n}\r\n```\r\nSo I just want the value of *name*  when *type* is  KUDU_TSERVER\r\n\r\nI am using this sentence\r\n``` \r\ncat test |jq &#39;.items[]&#39; |jq  &#39;select(.type == &quot;KUDU_TSERVER&quot; )&#39; |jq -r &#39;.name&#39;\r\nkudu-KUDU_TSERVER-2d63fec551a74320fdcc0c65007c76e4\r\nkudu-KUDU_TSERVER-2f54da7e700b29f486dc977903077b42\r\nkudu-KUDU_TSERVER-c6eed063790c0ebff3f4c3caa29f35c2\r\nkudu-KUDU_TSERVER-668d476199e24b75dacdc2c142212d7f\r\nkudu-KUDU_TSERVER-b19f608fc0b214334b7cb9aa8911f30d\r\nkudu-KUDU_TSERVER-56aeb0bf37e61755e659be7ee1dd15cb\r\nkudu-KUDU_TSERVER-4b773838c3f005671ea6ab1d77c69ff7\r\n```\r\n\r\nAre there a better way to do it?. I feel that this process it is not optimized",
        "link": "https://stackoverflow.com/questions/66256053/how-to-simplify-a-jq-sentence",
        "title": "How to simplify a jq sentence?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "swap"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1613658835,
                "last_edit_date": 1613658835,
                "creation_date": 1613654448,
                "answer_id": 66260813,
                "question_id": 66260639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\n.food.fruit |= (\r\n   ( .[] | select( .type == &quot;apple&quot;  ) | .count ) as $count1 |\r\n   ( .[] | select( .type == &quot;banana&quot; ) | .count ) as $count2 |\r\n\r\n   ( .[] | select( .type == &quot;apple&quot;  ) | .count ) = $count2 |\r\n   ( .[] | select( .type == &quot;banana&quot; ) | .count ) = $count1\r\n)\r\n```\r\n\r\n[jq play](https://jqplay.org/s/UgV6hwVvpG)\r\n\r\n---\r\n\r\n```jq\r\n.food.fruit |= (\r\n   ( .[] | select( .type == &quot;apple&quot;  ) | .count ) as $count1 |\r\n   ( .[] | select( .type == &quot;banana&quot; ) | .count ) as $count2 |\r\n\r\n   .[] |= (\r\n      .count = (\r\n         if .type == &quot;apple&quot; then\r\n            $count2\r\n         elif .type == &quot;banana&quot; then\r\n            $count1\r\n         else\r\n            .count\r\n         end\r\n      )\r\n   )\r\n)\r\n```\r\n\r\n[jq play](https://jqplay.org/s/S3dsFQ_Spj)\r\n",
                "title": "Chaining JQ if: if A then B C else D end"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1613676747,
                "last_edit_date": 1613676747,
                "creation_date": 1613666266,
                "answer_id": 66264197,
                "question_id": 66260639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an efficient solution that may not even need to traverse the `fruit` array once completely.  \r\n\r\nThe idea is to find the paths to the &quot;apple&quot; and &quot;banana&quot; objects, so that the swap can be done without any further iteration. \r\n\r\nFor additional efficiency, the solution uses `foreach` in order to break out of the (single) loop once the paths to the &quot;apple&quot; and &quot;banana&quot; objects have been found. \r\n\r\n```\r\n.food.fruit |=\r\n  ( . as $fruits\r\n   | label $go\r\n   | (foreach paths(objects) as $p ({}; \r\n      ($fruits|getpath($p)) as $x\r\n      | if  ($x|.type)==&quot;apple&quot;\r\n        then .apple  = {path: ($p + [&quot;count&quot;]), count: $x.count}\r\n        elif ($x|.type) == &quot;banana&quot;\r\n        then .banana = {path: ($p + [&quot;count&quot;]), count: $x.count}\r\n        else . end;\r\n      if .apple and .banana then ., break $go else empty end)\r\n     ) as $dict\r\n   | if $dict | .apple and .banana\r\n     then setpath( $dict.apple.path;  $dict.banana.count) \r\n     |    setpath( $dict.banana.path; $dict.apple.count)\r\n     else . end\r\n )\r\n\r\n```\r\n\r\n### def swap/4\r\n\r\nThe above solution can be abstracted as follows:\r\n\r\n```\r\n# Input: an array of JSON objects.\r\n#\r\n# In the objects with .[$f1key] == $f1 and .[$f1key] == $f2 if any,\r\n# swap the values at .[$gkey].\r\n# If the the array has more than one object with .[$f1key] == $f1,\r\n# then the last one will be selected, and similarly with respect to $f2\r\n#\r\ndef swap($f1; $f2; $fkey; $gkey):\r\n  . as $in\r\n  | label $go\r\n  | (foreach paths(objects) as $p ({}; \r\n      ($in|getpath($p)) as $x\r\n      | if  ($x[$fkey])==$f1\r\n        then .f1 = {path: ($p + [$gkey]), count: $x[$gkey]}\r\n        elif ($x[$fkey]) == $f2\r\n        then .f2 = {path: ($p + [$gkey]), count: $x[$gkey]}\r\n        else . end;\r\n      if .f1 and .f2 then ., break $go else empty end)\r\n    ) as $dict\r\n  | if $dict | .f1 and .f2\r\n    then setpath( $dict.f1.path; $dict.f2.count) \r\n    |    setpath( $dict.f2.path; $dict.f1.count)\r\n    else . end ;\r\n\r\n.food.fruit |= swap(&quot;apple&quot;; &quot;banana&quot;; &quot;type&quot;; &quot;count&quot;)\r\n```",
                "title": "Chaining JQ if: if A then B C else D end"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1613780893,
                "last_edit_date": 1613780893,
                "creation_date": 1613678323,
                "answer_id": 66267290,
                "question_id": 66260639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a straightforward solution that only uses builtins and shows how updates can be chained together using &#39;|&#39; (*).\r\n```\r\n.food.fruit |=\r\n  (map(.type) as $types\r\n   | ($types | index(&quot;apple&quot;)) as $ia\r\n   | ($types | index(&quot;banana&quot;)) as $ib\r\n   | .[$ia].count as $ac\r\n   | .[$ia].count = .[$ib].count\r\n   | .[$ib].count = $ac\r\n  )\r\n```\r\n## More efficient solution\r\nHere is a similar solution that avoids the issues with `index` and is more space-efficient as it does not use `map`.\r\n\r\n```\r\n# index of $needle in a stream\r\ndef index_of($needle; stream):\r\n  label $go\r\n  | foreach stream as $x (-1; .+1; select($x==$needle) | (., break $go))\r\n    // null;\r\n\r\n.food.fruit |=\r\n  (  index_of(&quot;apple&quot;;  .[].type) as $ia\r\n   | index_of(&quot;banana&quot;; .[].type) as $ib\r\n   | .[$ia].count as $ac\r\n   | .[$ia].count = .[$ib].count\r\n   | .[$ib].count = $ac\r\n  )\r\n```\r\n\r\n### (*)\r\nThe built-in `index` is (in jq 1.6 and earlier) not implemented efficiently, though being written in C, it typically is fast.  Here is an algorithmically efficient implementation:\r\n```\r\ndef ix($x):\r\n  label $go\r\n  | foreach .[] as $v (-1; .+1; select($v == $x) | (., break $go)) \r\n    // null;\r\n```\r\n",
                "title": "Chaining JQ if: if A then B C else D end"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1613780893,
        "creation_date": 1613653746,
        "last_edit_date": 1613678524,
        "question_id": 66260639,
        "body_markdown": "I would like to swap two values in a JQ if statement. \r\n\r\nGiven the following JSON:\r\n```json\r\n{\r\n  &quot;food&quot;: {\r\n    &quot;fruit&quot;: [\r\n      {\r\n        &quot;type&quot;: &quot;apple&quot;,\r\n        &quot;count&quot;: 0\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;banana&quot;,\r\n        &quot;count&quot;: 1\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;orange&quot;,\r\n        &quot;count&quot;: 0\r\n      }\r\n    ]\r\n  }\r\n}\r\n\r\n```\r\n\r\nI want to swap the counts of the two objects based on a condition to result in the following, using JQ.\r\n```json\r\n{\r\n  &quot;food&quot;: {\r\n    &quot;fruit&quot;: [\r\n      {\r\n        &quot;type&quot;: &quot;apple&quot;,\r\n        &quot;count&quot;: 1\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;banana&quot;,\r\n        &quot;count&quot;: 0\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;orange&quot;,\r\n        &quot;count&quot;: 0\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n\r\nSo far I can correct the first fruit from 0 to 1 with \r\n```bash\r\njq &#39;\r\n  if .food.fruit[] | select(.type==&quot;apple&quot;) | .count == 0\r\n  then\r\n    .food.fruit[] | select(.type==&quot;apple&quot;) | .count = 1\r\n  else\r\n    empty\r\n  end\r\n&#39;\r\n```\r\nbut I can&#39;t get the correct operator to modify the second. Is something like the following possible, using JQ?\r\n```bash\r\njq &#39;\r\n  if .food.fruit[] | select(.type==&quot;apple&quot;) | .count == 0\r\n  then\r\n    .food.fruit[] | select(.type==&quot;apple&quot;) | .count = 1 &amp;\r\n    .food.fruit[] | select(.type==&quot;banana&quot;) | .count = 0\r\n  else\r\n    empty\r\n  end\r\n&#39;\r\n```\r\nI can&#39;t pipe it as that would pipe the single fruit object to the next line, so I&#39;m not sure which operator I&#39;m supposed to use here - if such functionality is even supported. \r\nAny help is greatly appreciated!",
        "link": "https://stackoverflow.com/questions/66260639/chaining-jq-if-if-a-then-b-c-else-d-end",
        "title": "Chaining JQ if: if A then B C else D end"
    },
    {
        "tags": [
            "json",
            "object",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1613683382,
                "last_edit_date": 1613683382,
                "creation_date": 1613674874,
                "answer_id": 66266483,
                "question_id": 66266130,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `add` to merge the propN objects into one, `del` to remove the original `props`:\r\n\r\n    jq &#39;[.[] | . + (.props | add) | del(.props)]&#39; file.json\r\n\r\nYou can indeed use `map` to shorten it a bit:\r\n\r\n    jq &#39;map(. + (.props | add) | del(.props))&#39; file.json\r\n",
                "title": "JQ convert json array to object properties"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1613683382,
        "creation_date": 1613673510,
        "last_edit_date": 1613678978,
        "question_id": 66266130,
        "body_markdown": "I have a json structured like this:\r\n```\r\n[\r\n    { \r\n      &quot;name&quot;: &quot;object1&quot;,\r\n      &quot;prop&quot;: &quot;prop1&quot;,\r\n      &quot;props&quot;: [\r\n        { &quot;prop1&quot;: &quot;value1&quot; },\r\n        { &quot;prop2&quot;: &quot;value2&quot; },\r\n        { &quot;prop3&quot;: &quot;value3&quot; }\r\n      ]\r\n    },\r\n    { \r\n      &quot;name&quot;: &quot;object2&quot;,\r\n      &quot;prop&quot;: &quot;prop2&quot;,\r\n      &quot;props&quot;: [\r\n        { &quot;prop1&quot;: &quot;value4&quot; },\r\n        { &quot;prop2&quot;: &quot;value5&quot; },\r\n        { &quot;prop3&quot;: &quot;value6&quot; }\r\n      ]\r\n    }\r\n]\r\n````\r\nI would like to extract the content of the `props` variable and have it as extra object properties, looking like this:\r\n```\r\n[\r\n    { \r\n      &quot;name&quot;: &quot;object1&quot;,\r\n      &quot;prop&quot;: &quot;prop1&quot;,\r\n      &quot;prop1&quot;: &quot;value1&quot;,\r\n      &quot;prop2&quot;: &quot;value2&quot;,\r\n      &quot;prop3&quot;: &quot;value3&quot;\r\n    },\r\n    { \r\n      &quot;name&quot;: &quot;object2&quot;,\r\n      &quot;prop&quot;: &quot;prop2&quot;,\r\n      &quot;prop1&quot;: &quot;value4&quot;,\r\n      &quot;prop2&quot;: &quot;value5&quot;,\r\n      &quot;prop3&quot;: &quot;value6&quot;\r\n    },\r\n]\r\n```\r\n\r\nI&#39;ve been trying to use `map` but I can&#39;t seem to be able to get rid of the array.",
        "link": "https://stackoverflow.com/questions/66266130/jq-convert-json-array-to-object-properties",
        "title": "JQ convert json array to object properties"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1613754023,
                "last_edit_date": 1613754023,
                "creation_date": 1613752615,
                "answer_id": 66281512,
                "question_id": 66281220,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This would be way easier if you used [`reduce`](https://stedolan.github.io/jq/manual/#Reduce) instead.\r\n``` shell\r\njq &#39;reduce inputs[] as $rec (INDEX(.reference);\r\n  .[$rec.reference | tostring].details += [$rec]\r\n) | map(.)&#39; es_file1.json es_file2.json\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/iOCLsTqKTp)&lt;sup&gt;",
                "title": "Fill arrays in the first input with elements from the second based on common field"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1613794676,
                "creation_date": 1613794676,
                "answer_id": 66287955,
                "question_id": 66281220,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward, reduce-free solution:\r\n```\r\njq &#39;\r\n  group_by(.reference)\r\n  | INDEX(.[]; .[0]|.reference|tostring) as $dict\r\n  | input\r\n  | map_values(. + {details: $dict[.reference|tostring]})\r\n&#39; 2.json 1.json \r\n```",
                "title": "Fill arrays in the first input with elements from the second based on common field"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1613794676,
        "creation_date": 1613751512,
        "last_edit_date": 1613753887,
        "question_id": 66281220,
        "body_markdown": "I have two files and I would need to merge the elements of the second file into an object array in the first file based on searching the `reference` field.\r\n\r\nThe first file:\r\n```\r\n[\r\n    {\r\n        &quot;reference&quot;: 25422,\r\n        &quot;order_number&quot;: &quot;10_1&quot;,\r\n        &quot;details&quot; : []\r\n    },\r\n    {\r\n        &quot;reference&quot;: 25423,\r\n        &quot;order_number&quot;: &quot;10_2&quot;,\r\n        &quot;details&quot; : []\r\n    }\r\n]\r\n```\r\n\r\nThe second file:\r\n```\r\n[\r\n    {\r\n        &quot;record_id&quot; : 1,\r\n        &quot;reference&quot;: 25422,\r\n        &quot;row_description&quot;: &quot;descr_1_0&quot;\r\n    },\r\n    {\r\n        &quot;record_id&quot; : 2,\r\n        &quot;reference&quot;: 25422,\r\n        &quot;row_description&quot;: &quot;descr_1_1&quot;\r\n    },\r\n    {\r\n        &quot;record_id&quot; : 3,\r\n        &quot;reference&quot;: 25423,\r\n        &quot;row_description&quot;: &quot;descr_2_0&quot;\r\n    }\r\n]\r\n```\r\n\r\nI would like to get:\r\n```\r\n[\r\n    {\r\n        &quot;reference&quot;: 25422,\r\n        &quot;order_number&quot;: &quot;10_1&quot;,\r\n        &quot;details&quot; : [\r\n            {\r\n                &quot;record_id&quot; : 1,\r\n                &quot;reference&quot;: 25422,\r\n                &quot;row_description&quot;: &quot;descr_1_0&quot;\r\n            },\r\n            {\r\n                &quot;record_id&quot; : 2,\r\n                &quot;reference&quot;: 25422,\r\n                &quot;row_description&quot;: &quot;descr_1_1&quot;\r\n            }\r\n        ]\r\n    },\r\n    {\r\n        &quot;reference&quot;: 25423,\r\n        &quot;order_number&quot;: &quot;10_2&quot;,\r\n        &quot;details&quot; :[\r\n            {\r\n                &quot;record_id&quot; : 3,\r\n                &quot;reference&quot;: 25423,\r\n                &quot;row_description&quot;: &quot;descr_2_0&quot;\r\n            }\r\n        ]\r\n    }\r\n]\r\n```\r\n\r\nBelow is my code in `es_func.jq` file launched by this command: \r\n```\r\njq -n --argfile f1 es_file1.json --argfile f2 es_file2.json -f es_func.jq\r\n```\r\n```\r\nINDEX($f2[] ; .reference) as $details \r\n| $f1 \r\n| map( ($details[.reference|tostring]| .row_description) as $vn \r\n| if $vn then .details = [{&quot;row_description&quot; : $vn}] else . end)\r\n```\r\n\r\nI get the result only for the last record in `25422` reference with `&quot;row description&quot;: &quot;descr_1_1&quot;` and not have `&quot;row_description&quot;: &quot;descr_1_0&quot;`\r\n\r\n```\r\n[\r\n  {\r\n    &quot;reference&quot;: 25422,\r\n    &quot;order_number&quot;: &quot;10_1&quot;,\r\n    &quot;details&quot;: [\r\n      {\r\n        &quot;row_description&quot;: &quot;descr_1_1&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;reference&quot;: 25423,\r\n    &quot;order_number&quot;: &quot;10_2&quot;,\r\n    &quot;details&quot;: [\r\n      {\r\n        &quot;row_description&quot;: &quot;descr_2_0&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI think I&#39;m close to the solution but something is still missing. Thank you\r\n",
        "link": "https://stackoverflow.com/questions/66281220/fill-arrays-in-the-first-input-with-elements-from-the-second-based-on-common-fie",
        "title": "Fill arrays in the first input with elements from the second based on common field"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1613755754,
                "creation_date": 1613755754,
                "answer_id": 66282278,
                "question_id": 66282000,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Remember the first two elements in a variable, extract the phase name and add it to the variable:\r\n\r\n    jq &#39;[.[0],.[1]] as $h | .[2][].phase_name | $h + [.]&#39;",
                "title": "How can I duplicate an array based on an internal array using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1613757569,
        "creation_date": 1613754516,
        "last_edit_date": 1613755095,
        "question_id": 66282000,
        "body_markdown": "I&#39;ve managed to chop down the initial file into a final array that I want, but I&#39;m uncertain on how to manipulate it. I have a clear before and desired &quot;after&quot;;\r\n\r\n**Before:**\r\n```\r\n[\r\n  &quot;Access Token Manipulation&quot;,\r\n  &quot;T1134&quot;,\r\n  [\r\n    {\r\n      &quot;kill_chain_name&quot;: &quot;mitre-attack&quot;,\r\n      &quot;phase_name&quot;: &quot;defense-evasion&quot;\r\n    },\r\n    {\r\n      &quot;kill_chain_name&quot;: &quot;mitre-attack&quot;,\r\n      &quot;phase_name&quot;: &quot;privilege-escalation&quot;\r\n    }\r\n  ]\r\n]\r\n```\r\n**After:**\r\n```\r\n[\r\n  &quot;Access Token Manipulation&quot;,\r\n  &quot;T1134&quot;,\r\n  &quot;defense-evasion&quot;\r\n]\r\n[\r\n  &quot;Access Token Manipulation&quot;,\r\n  &quot;T1134&quot;,\r\n  &quot;privilege-escalation&quot;\r\n]\r\n```\r\n\r\nI&#39;ll convert this with @csv afterwards, but the objects need to be split up first. Part of me thinks that recurse or a foreach works, but another part of me thinks that this is just so simple and I&#39;m looking over something.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66282000/how-can-i-duplicate-an-array-based-on-an-internal-array-using-jq",
        "title": "How can I duplicate an array based on an internal array using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1613854219,
                "creation_date": 1613854219,
                "answer_id": 66296406,
                "question_id": 66294487,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Adding one or more &quot;?&quot; would be one way to resolve the issue:\r\n```\r\n\r\n.[].result?.rows[] | select (.[2]==&quot;stop&quot;)\r\n\r\n```\r\n\r\nIf you want to specify the first key, use `keys_unsorted[0]`, as in:\r\n\r\n```\r\n.[keys_unsorted[0]].result.rows[] | select (.[2]==&quot;stop&quot;)\r\n```",
                "title": "Cannot index string with string &quot;foo&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1613854219,
        "creation_date": 1613841835,
        "last_edit_date": 1613842076,
        "question_id": 66294487,
        "body_markdown": "I have some json (included below), and the first key is a random number (a docker image ID), so I won&#39;t know what it is before I have to parse the json. \r\n\r\nwhat I would like to do is \r\n\r\n```\r\ncat eval.json | jq \\\r\n&#39;.&quot;3193328829c7b3ec6be0ab6bfd8988b97a35006ea578c9ce4ab7fe29cbc5ec94&quot;.result.rows[] | select (.[2]==&quot;stop&quot;)&#39;\r\n```\r\n\r\nThis works fine, except I need to do this in the general case where I don&#39;t know the Image ID ahead of time.\r\n\r\nI tried this, which sort of works except I get some &quot;cannot index&quot; errors:\r\n\r\n```\r\ncat eval.json | jq .[] | jq &#39;.result.rows[] | select (.[2]==&quot;stop&quot;)&#39;\r\n[\r\n  &quot;CVE-2021-3156+sudo&quot;,\r\n  &quot;HIGH Vulnerability found in os package type (dpkg) - sudo (fixed in: 1.8.31-1ubuntu1.2)(CVE-2021-3156 - http://people.ubuntu.com/~ubuntu-security/cve/CVE-2021-3156)&quot;,\r\n  &quot;stop&quot;,\r\n  false\r\n]\r\njq: error (at &lt;stdin&gt;:33): Cannot index array with string &quot;result&quot;\r\njq: error (at &lt;stdin&gt;:34): Cannot index string with string &quot;result&quot;\r\njq: error (at &lt;stdin&gt;:35): Cannot index array with string &quot;result&quot;\r\njq: error (at &lt;stdin&gt;:36): Cannot index array with string &quot;result&quot;\r\n```\r\n\r\na little refinement helped with the array issues, but I still have the string error:\r\n\r\n```\r\ncat eval.json | jq &#39;.[].result.rows[] | select (.[2]==&quot;stop&quot;)&#39;\r\n[\r\n  &quot;CVE-2021-3156+sudo&quot;,\r\n  &quot;HIGH Vulnerability found in os package type (dpkg) - sudo (fixed in: 1.8.31-1ubuntu1.2)(CVE-2021-3156 - http://people.ubuntu.com/~ubuntu-security/cve/CVE-2021-3156)&quot;,\r\n  &quot;stop&quot;,\r\n  false\r\n]\r\njq: error (at &lt;stdin&gt;:38): Cannot index array with string &quot;result&quot;\r\n```\r\n\r\nI can delete those last four keys (I don&#39;t think I&#39;ll ever need them for what I&#39;m trying to do), but that seems like a pretty clunky hack.\r\n\r\n```\r\ncat eval.json | jq &#39;del(.whitelist_names, .whitelist_data, .policy_name, .policy_data) |  .[].result.rows[] | select ((.[2]==&quot;stop&quot;) and (.[3]==false)) | .[0], .[1]&#39;\r\n&quot;CVE-2021-3156+sudo&quot;\r\n&quot;HIGH Vulnerability found in os package type (dpkg) - sudo (fixed in: 1.8.31-1ubuntu1.2)(CVE-2021-3156 - http://people.ubuntu.com/~ubuntu-security/cve/CVE-2021-3156)&quot;\r\n```\r\n\r\nIs there something better than using del to clear those keys out?  it seems like if there were some way to specify the first key like there is for the Nth element in an array, that would be a lot easier.  The other think I thought about was doing something awkward like just printing the keys out, capturing that long string in a variable, then using that to select that key directly, but that is more cumbersome than deleting the other keys.\r\n\r\nfull json below:\r\n\r\n```\r\n{\r\n  &quot;3193328829c7b3ec6be0ab6bfd8988b97a35006ea578c9ce4ab7fe29cbc5ec94&quot;: {\r\n    &quot;result&quot;: {\r\n      &quot;final_action&quot;: &quot;stop&quot;,\r\n      &quot;header&quot;: [\r\n        &quot;Trigger_Id&quot;,\r\n        &quot;Check_Output&quot;,\r\n        &quot;Gate_Action&quot;,\r\n        &quot;Whitelisted&quot;\r\n      ],\r\n      &quot;row_count&quot;: 3,\r\n      &quot;rows&quot;: [\r\n        [\r\n          &quot;41cb7cdf04850e33a11f80c42bf660b3&quot;,\r\n          &quot;Dockerfile directive &#39;HEALTHCHECK&#39; not found, matching condition &#39;not_exists&#39; check&quot;,\r\n          &quot;warn&quot;,\r\n          false\r\n        ],\r\n        [\r\n          &quot;CVE-2018-20839+libudev1&quot;,\r\n          &quot;MEDIUM Vulnerability found in os package type (dpkg) - libudev1 (CVE-2018-20839 - http://people.ubuntu.com/~ubuntu-security/cve/CVE-2018-20839)&quot;,\r\n          &quot;warn&quot;,\r\n          false\r\n        ],\r\n        [\r\n          &quot;CVE-2021-3156+sudo&quot;,\r\n          &quot;HIGH Vulnerability found in os package type (dpkg) - sudo (fixed in: 1.8.31-1ubuntu1.2)(CVE-2021-3156 - http://people.ubuntu.com/~ubuntu-security/cve/CVE-2021-3156)&quot;,\r\n          &quot;stop&quot;,\r\n          false\r\n        ]\r\n      ]\r\n    }\r\n  },\r\n  &quot;policy_data&quot;: [],\r\n  &quot;policy_name&quot;: &quot;&quot;,\r\n  &quot;whitelist_data&quot;: [],\r\n  &quot;whitelist_names&quot;: []\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/66294487/cannot-index-string-with-string-foo",
        "title": "Cannot index string with string &quot;foo&quot;"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613842877,
                "post_id": 66294605,
                "comment_id": 117203698,
                "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": 1613842950,
                "post_id": 66294605,
                "comment_id": 117203722,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6526463,
                    "reputation": 1160,
                    "user_id": 7042945,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fbde13ee69dc91884d3fc91d7df1647a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Dinero",
                    "link": "https://stackoverflow.com/users/7042945/dinero"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613843338,
                "post_id": 66294605,
                "comment_id": 117203826,
                "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": 1613931751,
                "post_id": 66294605,
                "comment_id": 117222518,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1613842524,
        "creation_date": 1613842524,
        "question_id": 66294605,
        "body_markdown": "I use the following command  `db_main_info=$(aws ssm get-parameter --name &quot;env_prod_db_main&quot; | jq -r &#39;.Parameter .Value&#39;)` to retrieve some credential information for my db. The output looks like the following. \r\n\r\n    { &quot;host&quot;: &quot;env-prod-blah-db.blah.us-east-1.rds.amazonaws.com&quot;, &quot;dbname&quot;: &quot;blah&quot;, &quot;user&quot;: &quot;root&quot;, &quot;password&quot;: &quot;blah&quot; } \r\n\r\nThen i use the following commands to store the `host`,`dbname`,`user`, and `password`.\r\n\r\n      db_main_host=$(echo $db_main_info | jq -r &#39;.host&#39;)\r\n      db_main_name=$(echo $db_main_info | jq -r &#39;.dbname&#39;)\r\n      db_main_user=$(echo $db_main_info | jq -r &#39;.user&#39;)\r\n      db_main_password=$(echo $db_main_info | jq -r &#39;.password&#39;)\r\n\r\nI am not very familiar with `bash` or `jq` and i am wondering if there is a better way to store the host,dbname,user,and password.",
        "link": "https://stackoverflow.com/questions/66294605/parsing-a-json-string-in-bash-to-extract-specific-key-value-information",
        "title": "Parsing a json string in bash to extract specific key value information"
    },
    {
        "tags": [
            "linux",
            "bash",
            "pipe",
            "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": 1613861069,
                "post_id": 66296840,
                "comment_id": 117208223,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1707439,
                    "reputation": 242707,
                    "user_id": 1566221,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/ce3ea4ffd1023d4382f397312352726d?s=256&d=identicon&r=PG",
                    "display_name": "rici",
                    "link": "https://stackoverflow.com/users/1566221/rici"
                },
                "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": 1,
                "creation_date": 1613861543,
                "post_id": 66296840,
                "comment_id": 117208297,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user14460566"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1613862837,
                "post_id": 66296840,
                "comment_id": 117208531,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1613863329,
                "post_id": 66296840,
                "comment_id": 117208625,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1613864922,
                "last_edit_date": 1613864922,
                "creation_date": 1613858092,
                "answer_id": 66296948,
                "question_id": 66296840,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` does some things differently if it detects that its output stream is a terminal. For one thing, it colour-codes its output (unless you explicitly turn that option off). But more relevantly to this question, for version 1.5, if it detects that its output stream is a terminal and its input stream is not a terminal and there are no non-option command-line arguments at all, it assumes that you meant to use the filter `.`.\r\n\r\nSo that&#39;s what happens when you type `cat *.json | jq`. In that case, jq&#39;s input stream is a pipe (from the `cat` command) but its output stream is the terminal. So it assumes a default filter of `.`.\r\n\r\nBut when you pipe the output of `jq` through `less`, `jq`&#39;s output stream is no longer a terminal. Now it&#39;s a pipe (connected to a `less` process). So the automatic filter `.` is not inserted, and `jq` complains that no filter was provided.\r\n\r\nHowever, if you upgrade to v1.6, you&#39;ll find that the behaviour has changed. In v1.6, an invocation without any filter will be adjusted to `.` unless *both* the input stream and the output stream are a terminal. So if you upgrade, you&#39;ll find that `cat *.json | jq | less` works roughly the same way as `cat *.json | jq`, except that the output is coloured and, of course, not paged.\r\n\r\nBy the way, if you wanted to see coloured output with `less` (and you&#39;re using Gnu `less`), then you could use the command:\r\n\r\n    cat *.json | jq . -C | less -R   # The . is not necessary with v1.6\r\n\r\n",
                "title": "Why does jq sometimes require a filter expression, and sometimes not?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1614697893,
        "creation_date": 1613857314,
        "last_edit_date": 1614697893,
        "question_id": 66296840,
        "body_markdown": "I have some unformatted JSON files. I want to format them with jq and see the formatted output via less:\r\n\r\n```sh\r\ncat *.json | jq | less\r\n```\r\n\r\nBut it doesn&#39;t work. Just shows the jq&#39;s help.\r\n\r\nO.K., jq needs a filter, minimum a `.`, but...\r\n\r\n```sh\r\ncat *.json | jq\r\n```\r\n\r\nworks for me.\r\n\r\nWhat is the difference? Is this a Bash bug, seeing that parsing the command line is the shell&#39;s task? Why does this only happen with jq?",
        "link": "https://stackoverflow.com/questions/66296840/why-does-jq-sometimes-require-a-filter-expression-and-sometimes-not",
        "title": "Why does jq sometimes require a filter expression, and sometimes not?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "linux",
            "parsing",
            "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": 1613879859,
                "post_id": 66298636,
                "comment_id": 117211085,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1613879690,
                "creation_date": 1613879690,
                "answer_id": 66298984,
                "question_id": 66298636,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming minor adjustments to your input to make it valid JSON,\r\n```\r\njq -r &#39;.features[].properties | &quot;\\(.description) \\(.rtmp_url)&quot;&#39; input.json\r\n```\r\nproduces\r\n```\r\ntest description test url1\r\ntest 2 description test rtmp_url\r\n```\r\nas per the problem description.",
                "title": "With a JSON file how would I list two objects thats are inside an array using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1613879690,
        "creation_date": 1613875348,
        "last_edit_date": 1613876675,
        "question_id": 66298636,
        "body_markdown": "Here is the top of my Json file. I am attempting to list two objects and its contents. I want to list the description and rtmp_url.\r\n\r\n       {\r\n          &quot;features&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;Feature&quot;,\r\n              &quot;geometry&quot;: {\r\n                &quot;coordinates&quot;: [\r\n                  -55.37174,\r\n                  55.77598\r\n                ],\r\n                &quot;type&quot;: &quot;Point&quot;\r\n              },\r\n              &quot;properties&quot;: {\r\n                &quot;direction&quot;: &quot;EB&quot;,\r\n                &quot;mrm&quot;: 55,\r\n                &quot;id&quot;: &quot;555&quot;,\r\n                &quot;jurisdiction&quot;: &quot;test&quot;,\r\n                &quot;route&quot;: &quot;I-64&quot;,\r\n                &quot;description&quot;: &quot;test description&quot;,\r\n                &quot;deviceid&quot;: &quot;&quot;,\r\n                &quot;rtmp_url&quot;: &quot;test url1&quot;,\r\n              \r\n              }\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;Feature&quot;,\r\n              &quot;geometry&quot;: {\r\n                &quot;coordinates&quot;: [\r\n                  -55.36782,\r\n                  55.77382\r\n                ],\r\n                &quot;type&quot;: &quot;Point&quot;\r\n              },\r\n              &quot;properties&quot;: {\r\n                &quot;direction&quot;: &quot;WB&quot;,\r\n                &quot;mrm&quot;: 44,\r\n                &quot;id&quot;: &quot;4444&quot;,\r\n                &quot;jurisdiction&quot;: &quot;test 2 jurisdiction&quot;,\r\n                &quot;route&quot;: &quot;I-64&quot;,\r\n                &quot;description&quot;: &quot;test 2 description&quot;,\r\n                &quot;deviceid&quot;: &quot;&quot;,\r\n                &quot;rtmp_url&quot;: &quot;test rtmp_url&quot;,\r\n                \r\n              }\r\n            },\r\n\r\nI want my output to be this. I just want to Grab  &quot;description&quot;: &amp; &quot;rtmp_url&quot;: \r\n\r\n    test description test url1\r\n    test 2 description test rtmp_url\r\n\r\n\r\nThis command \r\n\r\n    jq &#39;.features[] | {description, rtmp_url }&#39;\r\n\r\nGive me this output\r\n\r\n    {\r\n      &quot;description&quot;: null,\r\n      &quot;rtmp_url&quot;: null\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66298636/with-a-json-file-how-would-i-list-two-objects-thats-are-inside-an-array-using-jq",
        "title": "With a JSON file how would I list two objects thats are inside an array using JQ?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1614023946,
                "last_edit_date": 1614023946,
                "creation_date": 1614019189,
                "answer_id": 66321538,
                "question_id": 66320492,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are many possibilities, but probably the simplest, efficient solution would use the built-in function: `INDEX/2`, e.g. as follows:\r\n```\r\njq -n --slurpfile dict f2.json &#39;\r\n  (INDEX($dict[]; .id) | map_values(.name)) as $d\r\n  | inputs\r\n  | .name = ($d[.id|tostring] // .name)\r\n&#39; f1.json\r\n```\r\nThis uses `inputs` with the -n option to read the first file so that each JSON object can be processed in turn.\r\n\r\nSince the solution is so short, it should be easy enough to figure it out with the aid of the online [jq manual][1].\r\n\r\n### Caveat\r\nThis solution comes with a caveat: that there are no &quot;collisions&quot; between ids in the dictionary as a result of the use of &quot;tostring&quot; (e.g. if `{&quot;id&quot;: 10}` and `{&quot;id&quot;: &quot;10&quot;}` both occurred). \r\n\r\nIf the dictionary does or might have such collisions, then the above solution can be tweaked accordingly, but it is a bit tricky.\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "jq replace values based on external map"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1614027793,
        "creation_date": 1614014776,
        "last_edit_date": 1614027793,
        "question_id": 66320492,
        "body_markdown": "I would like to change a field in my json file as specified by another json file. My input file is something like:\r\n\r\n```json\r\n{&quot;id&quot;: 10, &quot;name&quot;: &quot;foo&quot;, &quot;some_other_field&quot;: &quot;value 1&quot;}\r\n{&quot;id&quot;: 20, &quot;name&quot;: &quot;bar&quot;, &quot;some_other_field&quot;: &quot;value 2&quot;}\r\n{&quot;id&quot;: 25, &quot;name&quot;: &quot;baz&quot;, &quot;some_other_field&quot;: &quot;value 10&quot;}\r\n```\r\n\r\nI have an external override file that specifies how `name` in certain objects should be overridden, for example:\r\n\r\n```json\r\n{&quot;id&quot;: 20, &quot;name&quot;: &quot;Bar&quot;}\r\n{&quot;id&quot;: 10, &quot;name&quot;: &quot;foo edited&quot;}\r\n```\r\n\r\nAs shown above, the override may be shorter than input, in which case the `name` should be unchanged. Both files can easily fit into available memory.\r\n\r\nGiven the above input and the override, I would like to obtain the following output:\r\n\r\n```json\r\n{&quot;id&quot;: 10, &quot;name&quot;: &quot;foo edited&quot;, &quot;some_other_field&quot;: &quot;value 1&quot;}\r\n{&quot;id&quot;: 20, &quot;name&quot;: &quot;Bar&quot;, &quot;some_other_field&quot;: &quot;value 2&quot;}\r\n{&quot;id&quot;: 25, &quot;name&quot;: &quot;baz&quot;, &quot;some_other_field&quot;: &quot;value 10&quot;}\r\n```\r\n\r\nBeing a beginner with `jq`, I wasn&#39;t really sure where to start. While there are some questions that cover similar ground (the closest being [this one](https://stackoverflow.com/questions/52991305/jq-replace-keys-with-corresponding-value-in-another-file)), I couldn&#39;t figure out how to apply the solutions to my case.",
        "link": "https://stackoverflow.com/questions/66320492/jq-replace-values-based-on-external-map",
        "title": "jq replace values based on external map"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1614015682,
                "creation_date": 1614015682,
                "answer_id": 66320729,
                "question_id": 66320608,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `map_values` on the `.properties` object The function returns the object back, selecting the field value given as part of the expression.\r\n\r\n```none\r\njq &#39;.properties | map_values(.default)&#39;\r\n```",
                "title": "Extract default value from json schema"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1615265173,
        "creation_date": 1614015230,
        "last_edit_date": 1615265173,
        "question_id": 66320608,
        "body_markdown": "I&#39;m trying to create a json from a json schema using default value provided in the schema\r\nso basically i want that a json like this \r\n```json\r\n{\r\n    &quot;type&quot; : &quot;object&quot;,\r\n    &quot;properties&quot;: {\r\n        &quot;string&quot;: {\r\n            &quot;type&quot; : &quot;ingeger&quot;,\r\n            &quot;default&quot; : &quot;the default string&quot;\r\n        },\r\n        &quot;number&quot;: {\r\n            &quot;type&quot; : &quot;number&quot;,\r\n            &quot;default&quot; : 1\r\n        },\r\n        &quot;object&quot;: {\r\n            &quot;type&quot; : &quot;object&quot;,\r\n            &quot;properties&quot; : {\r\n                &quot;string&quot;: {\r\n                    &quot;type&quot; : &quot;ingeger&quot;,\r\n                    &quot;default&quot; : &quot;the default string 2&quot;\r\n                },\r\n                &quot;number&quot;: {\r\n                    &quot;type&quot; : &quot;number&quot;,\r\n                    &quot;default&quot; : 2\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n```\r\nend up like this\r\n```json\r\n{\r\n  &quot;string&quot;: &quot;the default string&quot;,\r\n  &quot;number&quot;: 1,\r\n  &quot;object&quot;: {\r\n    &quot;string&quot;: &quot;the default string 2&quot;,\r\n    &quot;number&quot;: 2\r\n  }\r\n}\r\n```\r\nWhen i saw this https://stackoverflow.com/a/60940893/15261387 i thought it would be easy to adapt this for my current problem but after many many try, I have to face the facts that i don&#39;t understand anything to the jq language/syntax",
        "link": "https://stackoverflow.com/questions/66320608/extract-default-value-from-json-schema",
        "title": "Extract default value from json schema"
    },
    {
        "tags": [
            "json",
            "unix",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 44018,
                    "reputation": 99312,
                    "user_id": 128940,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7ddd875e6769f16ccb5e34c375548bea?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Beta",
                    "link": "https://stackoverflow.com/users/128940/beta"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614049474,
                "post_id": 66324241,
                "comment_id": 117259612,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7100941,
                    "reputation": 413,
                    "user_id": 5432511,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/913bb06ce7ead0835ed6dbd9da39796e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "curious_brain",
                    "link": "https://stackoverflow.com/users/5432511/curious-brain"
                },
                "reply_to_user": {
                    "account_id": 44018,
                    "reputation": 99312,
                    "user_id": 128940,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7ddd875e6769f16ccb5e34c375548bea?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Beta",
                    "link": "https://stackoverflow.com/users/128940/beta"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614052397,
                "post_id": 66324241,
                "comment_id": 117260134,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 44018,
                    "reputation": 99312,
                    "user_id": 128940,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7ddd875e6769f16ccb5e34c375548bea?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Beta",
                    "link": "https://stackoverflow.com/users/128940/beta"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614052802,
                "post_id": 66324241,
                "comment_id": 117260205,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7100941,
                    "reputation": 413,
                    "user_id": 5432511,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/913bb06ce7ead0835ed6dbd9da39796e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "curious_brain",
                    "link": "https://stackoverflow.com/users/5432511/curious-brain"
                },
                "reply_to_user": {
                    "account_id": 44018,
                    "reputation": 99312,
                    "user_id": 128940,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7ddd875e6769f16ccb5e34c375548bea?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Beta",
                    "link": "https://stackoverflow.com/users/128940/beta"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614053654,
                "post_id": 66324241,
                "comment_id": 117260365,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1614054284,
                "post_id": 66324241,
                "comment_id": 117260499,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1614092705,
                "last_edit_date": 1614092705,
                "creation_date": 1614054078,
                "answer_id": 66327015,
                "question_id": 66324241,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using [tag:jq]:\r\n```\r\n.payload[].location |= gsub(&quot;/&quot;;&quot;-&quot;)\r\n\r\n```\r\n\r\nOr, if you want every &quot;location&quot; key checked, irrespective of where the key occurs:\r\n\r\n```\r\nwalk(if type == &quot;object&quot; and (.location|type==&quot;string&quot;) \r\n     then .location |= gsub(&quot;/&quot;;&quot;-&quot;) else . end)\r\n```\r\n\r\n\r\n",
                "title": "Replace the string in a file in Unix - replace the part of the matching regular expression"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1614092705,
        "creation_date": 1614032237,
        "last_edit_date": 1614052418,
        "question_id": 66324241,
        "body_markdown": "I have a JSON document with such a repeating structure\r\n\r\n```\r\n{&quot;version&quot;:&quot;21.0.0.1&quot;,&quot;artifact&quot;:&quot;artifact&quot;,&quot;payload&quot;:[{&quot;id&quot;:&quot;ng-at-ng/at&quot;,&quot;name&quot;:&quot;ng/at&quot;,&quot;location&quot;:&quot;apmservices/at:21.3.0.2-linux-amd64&quot;,&quot;component&quot;:&quot;core&quot;,&quot;tag&quot;:&quot;21.3.0.2-linux-amd64&quot;},{&quot;id&quot;:&quot;doi-dspintegrator-doi/dspintegrator&quot;,&quot;name&quot;:&quot;doi/dspintegrator&quot;,&quot;location&quot;:&quot;doi/1.3.    3/dspintegrator:2.0.0-RELEASE_183&quot;,&quot;component&quot;:&quot;doi&quot;,&quot;tag&quot;:&quot;2.0.0-RELEASE_183&quot;}]}\r\n```\r\n\r\nI want to replace the value of all ```&quot;location&quot;``` tags with ```-``` wherever there is a ```/```. So after the replacement, the above text becomes:\r\n\r\n```\r\n{&quot;version&quot;:&quot;21.0.0.1&quot;,&quot;artifact&quot;:&quot;artifact&quot;,&quot;payload&quot;:[{&quot;id&quot;:&quot;ng-at-ng/at&quot;,&quot;name&quot;:&quot;ng/at&quot;,&quot;location&quot;:&quot;apmservices-at:21.3.0.2-linux-amd64&quot;,&quot;component&quot;:&quot;core&quot;,&quot;tag&quot;:&quot;21.3.0.2-linux-amd64&quot;}, {&quot;id&quot;:&quot;doi-dspintegrator-doi/dspintegrator&quot;,&quot;name&quot;:&quot;doi/dspintegrator&quot;,&quot;location&quot;:&quot;doi-1.3.3-dspintegrator:2.0.0-RELEASE_183&quot;,&quot;component&quot;:&quot;doi&quot;,&quot;tag&quot;:&quot;2.0.0-RELEASE_183&quot;}]}\r\n```\r\n\r\nNote that there can be multiple ```/``` and ```-``` in the value of ```&quot;location&quot;``` tags in the original JSON document.\r\n\r\nReading through some other posts, it appears that ```-E``` option in ```sed``` with capture should be used but I am not sure how to make it work. Please can someone help?",
        "link": "https://stackoverflow.com/questions/66324241/replace-the-string-in-a-file-in-unix-replace-the-part-of-the-matching-regular",
        "title": "Replace the string in a file in Unix - replace the part of the matching regular expression"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1614036587,
                "creation_date": 1614036587,
                "answer_id": 66324936,
                "question_id": 66324817,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Map thru the array, replace each element&#39;s &quot;id&quot; with a new value. In this case, convert original value&#39;s type to numeric, add 100 million and convert back to string.\r\n\r\nIn other words,\r\n\r\n```bash\r\njq &#39;map( . + { &quot;id&quot;: ( .id | tonumber + 100000000 ) | tostring } )&#39;\r\n```\r\n\r\n",
                "title": "jq modify value based on existing value of the attribute"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1614052290,
                "last_edit_date": 1614052290,
                "creation_date": 1614038583,
                "answer_id": 66325214,
                "question_id": 66324817,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; replace the first character of the string ...\r\n\r\nA concise solution using `map`:\r\n```\r\nmap(.id |= &quot;2&quot; + .[1:])\r\n\r\n```\r\nor more generally:\r\n```\r\nmap(.id |= (.[0:1]|tonumber+1|tostring) + .[1:])\r\n```\r\n\r\nEven more concisely:\r\n```\r\n[].id |= &quot;2&quot; + .[1:]\r\n```\r\netc...",
                "title": "jq modify value based on existing value of the attribute"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1614053643,
                "last_edit_date": 1614053643,
                "creation_date": 1614038735,
                "answer_id": 66325232,
                "question_id": 66324817,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I&#39;m looking for a way to get to the right regex \r\n\r\n```\r\n.[].id |= sub(&quot;^.&quot;; &quot;2&quot;)\r\n```\r\n\r\n(You could drop the &quot;^&quot; but it makes the intention abundantly clear.)\r\n\r\nMore generally:\r\n```\r\n.[].id |= (. as $id | sub(&quot;^.&quot;; $id[0:1] | tonumber+1 | tostring)\r\n```",
                "title": "jq modify value based on existing value of the attribute"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1614053643,
        "creation_date": 1614035768,
        "question_id": 66324817,
        "body_markdown": "I have an array of JSON objects, \r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;100006578&quot;,\r\n    &quot;name&quot;: &quot;Someone&quot;,\r\n    &quot;category&quot;: &quot;frontend&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;100005436&quot;,\r\n    &quot;name&quot;: &quot;Someone&quot;,\r\n    &quot;category&quot;: &quot;backend&quot;\r\n  }\r\n]\r\n```\r\n\r\nI want to replace the value of the id field based on its existing value. I want to use the existing value (100005436) of the id field and replace it with a new value (200005436) based on the existing value. Basically, I just want to replace the first character of the string in the existing value. The output should be like\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;200006578&quot;,\r\n    &quot;name&quot;: &quot;Someone&quot;,\r\n    &quot;category&quot;: &quot;frontend&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;200005436&quot;,\r\n    &quot;name&quot;: &quot;Someone&quot;,\r\n    &quot;category&quot;: &quot;backend&quot;\r\n  }\r\n]\r\n\r\n```\r\nI tried a lot of stuff. But still struggling with jq. \r\nNearest logical option I tried was to increment it \r\n``` jq &#39;.externalId|map(.id+100000000)&#39; fileWithJsonObject```\r\nbut it doesn&#39;t work because it is a string.\r\n\r\nI&#39;m really finding it hard to get the substitute expression that can take an existing value and only replace a particular part from it. There are many answers on stack overflow that talk about replacing the value of the key based on externally supplied value but I want to take the exiting value,  modify it and replace it. \r\nThe nearest I have gone till now is the following but unfortunately, it is not complete:\r\n``` jq &#39;.externalId|to_entries|map(if .id then sub(*regex*; *tostring*))&#39; fileWithJsonObject ```\r\n\r\nI&#39;m looking for a way to get to the right regex and how can I provide/use the current value of the id attribute in substitute. ",
        "link": "https://stackoverflow.com/questions/66324817/jq-modify-value-based-on-existing-value-of-the-attribute",
        "title": "jq modify value based on existing value of the attribute"
    },
    {
        "tags": [
            "windows",
            "command-line",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2578132,
                    "reputation": 1921,
                    "user_id": 2235381,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0061f9bd5384a544637692774a6e108f?s=256&d=identicon&r=PG",
                    "display_name": "lojza",
                    "link": "https://stackoverflow.com/users/2235381/lojza"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614077428,
                "post_id": 66330138,
                "comment_id": 117268442,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9876328,
                    "reputation": 1065,
                    "user_id": 7313949,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://lh5.googleusercontent.com/-D6G7pW2oAD8/AAAAAAAAAAI/AAAAAAAAAC0/Kg6ML7VNUys/s256-rj/photo.jpg",
                    "display_name": "Zerg Overmind",
                    "link": "https://stackoverflow.com/users/7313949/zerg-overmind"
                },
                "reply_to_user": {
                    "account_id": 2578132,
                    "reputation": 1921,
                    "user_id": 2235381,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0061f9bd5384a544637692774a6e108f?s=256&d=identicon&r=PG",
                    "display_name": "lojza",
                    "link": "https://stackoverflow.com/users/2235381/lojza"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614084589,
                "post_id": 66330138,
                "comment_id": 117271516,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1614071393,
        "creation_date": 1614071393,
        "question_id": 66330138,
        "body_markdown": "I&#39;m trying to invoke command on jq using commandline (called as a subprocess). I encountered that the following:\r\n\r\n```\r\njq -c &quot;. | test(\\&quot;hmm|quack\\&quot;)&quot;\r\n```\r\ncauses `The system cannot find the path specified`. It seems, that within an escaped string, `|` is interpreted as a pipe and executes what follows as a string. Yet without the symbol it behaves as it should. \r\n\r\nAnyone knows what is the reason for this, and how to use the regex `|` ?",
        "link": "https://stackoverflow.com/questions/66330138/windows-command-prompt-strange-behaviour-on-jq-pipes",
        "title": "Windows command prompt strange behaviour on jq pipes"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1614094457,
                "last_edit_date": 1614094457,
                "creation_date": 1614081245,
                "answer_id": 66332626,
                "question_id": 66332143,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [`map`](https://stedolan.github.io/jq/manual/#map(x),map_values(x)) for expanding each object in the third element to `resolution` and `url`.\r\n``` none\r\n.[:2] + (.[2] | map(.resolution, .url)) | @csv\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/skJzJBxyhl)&lt;/sup&gt;\r\n\r\nAlternatively, an exception-driven approach like below would also yield the same result given your sample input.\r\n``` none\r\nmap((.[] | .resolution, .url)? // .) | @csv\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/gWa-BT23Wu)&lt;/sup&gt;",
                "title": "Filter keys on various levels from large complex nested json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1614094457,
        "creation_date": 1614079259,
        "question_id": 66332143,
        "body_markdown": "# Problem\r\nI have a list of YouTube videos and and want to fetch their `id`, `name` and the preview image.  I&#39;m making use of `youtube-dl` to get a json output, that I parse for the keys `id`, `title` and the nested array `thumbnails`.\r\n\r\n# Input\r\nFor the purpose of a topical example video, let&#39;s take the perseverance landing:\r\n\r\n```\r\nyoutube-dl -j &quot;https://www.youtube.com/watch?v=4czjS9h4Fpg&quot; | jq -r &#39;[.id, .title, .thumbnails]&#39;\r\n```\r\n\r\nThis returns the following json:\r\n```\r\n[\r\n  &quot;4czjS9h4Fpg&quot;,\r\n  &quot;Perseverance Rover’s Descent and Touchdown on Mars (Official NASA Video)&quot;,\r\n  [\r\n    {\r\n      &quot;height&quot;: 94,\r\n      &quot;url&quot;: &quot;https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEbCKgBEF5IVfKriqkDDggBFQAAiEIYAXABwAEG&amp;rs=AOn4CLBeXaobqWQ3MHAvEzLHQtitoAKKow&quot;,\r\n      &quot;width&quot;: 168,\r\n      &quot;resolution&quot;: &quot;168x94&quot;,\r\n      &quot;id&quot;: &quot;0&quot;\r\n    },\r\n    {\r\n      &quot;height&quot;: 110,\r\n      &quot;url&quot;: &quot;https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEbCMQBEG5IVfKriqkDDggBFQAAiEIYAXABwAEG&amp;rs=AOn4CLB2j8DNX2ZOyXHUS2MwRz4gG8admQ&quot;,\r\n      &quot;width&quot;: 196,\r\n      &quot;resolution&quot;: &quot;196x110&quot;,\r\n      &quot;id&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;height&quot;: 138,\r\n      &quot;url&quot;: &quot;https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEcCPYBEIoBSFXyq4qpAw4IARUAAIhCGAFwAcABBg==&amp;rs=AOn4CLDUIrTqT-g6F5z62q_Jq2RXy3AydQ&quot;,\r\n      &quot;width&quot;: 246,\r\n      &quot;resolution&quot;: &quot;246x138&quot;,\r\n      &quot;id&quot;: &quot;2&quot;\r\n    },\r\n    {\r\n      &quot;height&quot;: 188,\r\n      &quot;url&quot;: &quot;https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEcCNACELwBSFXyq4qpAw4IARUAAIhCGAFwAcABBg==&amp;rs=AOn4CLDtiAfOuC4lgjiMxXeJ3qIh7uV6Zg&quot;,\r\n      &quot;width&quot;: 336,\r\n      &quot;resolution&quot;: &quot;336x188&quot;,\r\n      &quot;id&quot;: &quot;3&quot;\r\n    },\r\n    {\r\n      &quot;height&quot;: 1080,\r\n      &quot;url&quot;: &quot;https://i.ytimg.com/vi/4czjS9h4Fpg/maxresdefault.jpg&quot;,\r\n      &quot;width&quot;: 1920,\r\n      &quot;resolution&quot;: &quot;1920x1080&quot;,\r\n      &quot;id&quot;: &quot;4&quot;\r\n    }\r\n  ]\r\n]\r\n```\r\n\r\nAt this point I don&#39;t particularly care for selecting any specific video title image and would happily take all. I would like to process these further as CSV, and know that after selecting the according key/values I can pipe it to `| @csv`, but it&#39;s the selecting that I&#39;m a bit lost on.\r\n\r\n# Expected Output\r\nIdeally the output would look like this:\r\n```\r\n&quot;4czjS9h4Fpg&quot;,&quot;Perseverance Rover’s Descent and Touchdown on Mars (Official NASA Video)&quot;,&quot;168x94&quot;,&quot;https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEbCKgBEF5IVfKriqkDDggBFQAAiEIYAXABwAEG&amp;rs=AOn4CLBeXaobqWQ3MHAvEzLHQtitoAKKow&quot;,&quot;196x110&quot;,&quot;https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEbCMQBEG5IVfKriqkDDggBFQAAiEIYAXABwAEG&amp;rs=AOn4CLB2j8DNX2ZOyXHUS2MwRz4gG8admQ&quot;,&quot;246x138&quot;,&quot;https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEcCPYBEIoBSFXyq4qpAw4IARUAAIhCGAFwAcABBg==&amp;rs=AOn4CLDUIrTqT-g6F5z62q_Jq2RXy3AydQ&quot;,&quot;336x188&quot;,&quot;https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEcCNACELwBSFXyq4qpAw4IARUAAIhCGAFwAcABBg==&amp;rs=AOn4CLDtiAfOuC4lgjiMxXeJ3qIh7uV6Zg&quot;,&quot;1920x1080&quot;,&quot;https://i.ytimg.com/vi/4czjS9h4Fpg/maxresdefault.jpg&quot;,\r\n```\r\n\r\n# Pseudocode / Python?\r\nIn a more pythonic way, this is what I&#39;m looking for in the output. I&#39;m guessing I could pipe the json to python or so, but I&#39;m thinking this should be a simple thing to do in `jq` too, no?\r\n```\r\n$id,$title,($thumbnails.resolution,$thumbnails.url for item in thumbnails)\r\n```",
        "link": "https://stackoverflow.com/questions/66332143/filter-keys-on-various-levels-from-large-complex-nested-json",
        "title": "Filter keys on various levels from large complex nested json"
    },
    {
        "tags": [
            "json",
            "bash",
            "variables",
            "interpolation",
            "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"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614093987,
                "post_id": 66334680,
                "comment_id": 117276294,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 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": 1614094045,
                "post_id": 66334680,
                "comment_id": 117276327,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 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": 1614094143,
                "post_id": 66334680,
                "comment_id": 117276378,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1614089481,
                "creation_date": 1614089481,
                "answer_id": 66334794,
                "question_id": 66334680,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to use interpolation to have the filter evaluated.\r\n\r\n    {&quot;version&quot;: $value|tonumber, &quot;file&quot;: &quot;branding/\\($value|tonumber)&quot;}",
                "title": "how to pass variables to jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1614093865,
        "creation_date": 1614089118,
        "last_edit_date": 1614092943,
        "question_id": 66334680,
        "body_markdown": "I have a problem with passing variables into jq. Here is example file:\r\n\r\n    [\r\n      {\r\n        &quot;version&quot;: 24,\r\n        &quot;file&quot;: &quot;branding/24&quot;\r\n      }\r\n    ]\r\nand here is my script:\r\n\r\n    jq --arg value &quot;25&quot; &#39;. += [{&quot;version&quot;: $value|tonumber, &quot;file&quot;: &quot;branding/$value|tonumber&quot;}]&#39; versions.json &gt;tmp.json &amp;&amp; mv tmp.json versions.json\r\n\r\nThe result is:\r\n\r\n    [\r\n      {\r\n        &quot;version&quot;: 24,\r\n        &quot;file&quot;: &quot;branding/24&quot;\r\n      },\r\n      {\r\n        &quot;version&quot;: 25,\r\n        &quot;file&quot;: &quot;branding/$value|tonumber&quot;\r\n      }\r\n    ]\r\n\r\nExpected result:\r\n\r\n    [\r\n      {\r\n        &quot;version&quot;: 24,\r\n        &quot;file&quot;: &quot;branding/24&quot;\r\n      },\r\n      {\r\n        &quot;version&quot;: 25,\r\n        &quot;file&quot;: &quot;branding/25&quot;\r\n      }\r\n    ]\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66334680/how-to-pass-variables-to-jq",
        "title": "how to pass variables to jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1614151426,
                "last_edit_date": 1614151426,
                "creation_date": 1614099382,
                "answer_id": 66337574,
                "question_id": 66337430,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution which takes advantage of jq&#39;s TCO (tail-call optimization) by defining the recursive function as a filter with arity 0 (i.e., no arguments):\r\n```\r\n# input: [array, $path]\r\ndef unwrap:\r\n  .[1] as $path\r\n  | .[0][]\r\n  | if .children then [.children, $path + [.name]] | unwrap\r\n    else [$path + [.name], .value]\r\n    end;\r\n\r\n[.] | unwrap | &quot;\\(.[0]|join(&quot;/&quot;)) - \\(.[1])&quot;\r\n```",
                "title": "Extract full path in folder-like JSON structure using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1614143904,
                "last_edit_date": 1614143904,
                "creation_date": 1614100679,
                "answer_id": 66337952,
                "question_id": 66337430,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes, it is possible. You can use a recursive function like below for achieving this.\r\n``` none\r\ndef f($path):\r\n  ($path + [.name]) as $path\r\n  | if has(&quot;value&quot;)\r\n  then &quot;\\($path | join(&quot;/&quot;)) - \\(.value)&quot;\r\n  else .children[] | f($path) end;\r\n.[] | f([])\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/N1K4D8tvyJ)&lt;/sup&gt;",
                "title": "Extract full path in folder-like JSON structure using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1614151426,
        "creation_date": 1614098849,
        "question_id": 66337430,
        "body_markdown": "I have a JSON file which contains a structure like this:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;folder1&quot;,\r\n        &quot;children&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;file1&quot;,\r\n            &quot;value&quot;: &quot;value1&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;folder2&quot;,\r\n            &quot;children&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;file2&quot;,\r\n                &quot;value&quot;: &quot;value2&quot;\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;file3&quot;,\r\n        &quot;value&quot;: &quot;value3&quot; \r\n      }\r\n    ]\r\n\r\nI want to print full paths and values of every file using `jq`. For example, with input from above:\r\n\r\n    folder1/file1 - value1\r\n    folder1/folder2/file2 - value2\r\n    file3 - value3\r\n\r\nIs such thing possible? I haven&#39;t found any obvious way to do it, while reading the `jq` manual and StackOverflow answers about recursive search in `jq`.",
        "link": "https://stackoverflow.com/questions/66337430/extract-full-path-in-folder-like-json-structure-using-jq",
        "title": "Extract full path in folder-like JSON structure using jq"
    },
    {
        "tags": [
            "json",
            "command-line-arguments",
            "jq",
            "rc",
            "dotfiles"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1614150931,
                "last_edit_date": 1614150931,
                "creation_date": 1614136750,
                "answer_id": 66344215,
                "question_id": 66342200,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "All you have to do is add a suitable def for `grep/1` in ~/.jq.  For example, you could add (after `grep/2`):\r\n\r\n    def grep($q): grep($q; &quot;i&quot;);\r\n\r\nif you want &quot;i&quot; to be the default.  (You could change the default to be &quot;&quot; if you like, but then your query will not return any answers with json.txt.)\r\n\r\n## Example\r\n\r\nWith ~/.jq as above:\r\n\r\n```\r\njq -c --arg q &quot;colorhelper&quot; &#39;grep($q)&#39; json.txt\r\n[&quot;packages_cache&quot;,&quot;https://packagecontrol.io/repository.json&quot;,625,&quot;name&quot;]\r\n[&quot;packages_cache&quot;,&quot;https://packagecontrol.io/repository.json&quot;,625,&quot;homepage&quot;]\r\n[&quot;packages_cache&quot;,&quot;https://packagecontrol.io/repository.json&quot;,625,&quot;readme&quot;]\r\n[&quot;packages_cache&quot;,&quot;https://packagecontrol.io/repository.json&quot;,625,&quot;issues&quot;]\r\n[&quot;packages_cache&quot;,&quot;https://packagecontrol.io/repository.json&quot;,625,&quot;releases&quot;,0,&quot;url&quot;]\r\n[&quot;packages_cache&quot;,&quot;https://packagecontrol.io/repository.json&quot;,625,&quot;releases&quot;,1,&quot;url&quot;]\r\n[&quot;packages_cache&quot;,&quot;https://packagecontrol.io/repository.json&quot;,625,&quot;releases&quot;,2,&quot;url&quot;]\r\n[&quot;packages_cache&quot;,&quot;https://packagecontrol.io/repository.json&quot;,625,&quot;releases&quot;,3,&quot;url&quot;]\r\n[&quot;packages_cache&quot;,&quot;https://packagecontrol.io/repository.json&quot;,625,&quot;releases&quot;,4,&quot;url&quot;]\r\n[&quot;packages_cache&quot;,&quot;https://packagecontrol.io/repository.json&quot;,625,&quot;releases&quot;,5,&quot;url&quot;]\r\n[&quot;packages_cache&quot;,&quot;https://packagecontrol.io/repository.json&quot;,625,&quot;releases&quot;,6,&quot;url&quot;]\r\n```\r\n\r\nIf you also defined `grep/0` as `def grep: grep($q);` then your invocation would be a little less redundant:\r\n\r\n```\r\njq -c grep --arg q colorhelper json.txt\r\n```\r\n## N.B.\r\nHaving ~/.jq as a file is fine but a bit antiquated: recent versions of jq have a module system which tends to assume ~/.jq is a directory.\r\n\r\nSo if your grep/1 definition was in ~/.jq/lib.jq, you would find:\r\n\r\n```\r\necho &#39;[&quot;abc&quot;]&#39; | jq -c &#39;include &quot;lib&quot;; grep(&quot;a&quot;)&#39;\r\n[0]\r\n```\r\nand similarly:\r\n\r\n```\r\necho &#39;[&quot;abc&quot;]&#39; | jq -c &#39;import &quot;lib&quot; as lib; lib::grep(&quot;a&quot;)&#39;\r\n[0]\r\n```",
                "title": "How to pass parameters in jq to a function defined in the ~/.jq dotfile?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1614150931,
        "creation_date": 1614120453,
        "last_edit_date": 1614148601,
        "question_id": 66342200,
        "body_markdown": "### Goal\r\n\r\nI&#39;m trying to declare functions in my `~/.jq` so they can be re-used. I am not sure I&#39;ve got the correct syntax for passing parameters. I&#39;ve looked at the [builtin.jq source](https://github.com/stedolan/jq/blob/jq-1.6/src/builtin.jq) but the recursion flew over my head. Can anyone help clarify if the way I&#39;ve done it below is correct?\r\n\r\n&gt; ***N.B.*** I know it&#39;s more efficient to run `jq &lt;json.txt &#39;...&#39;` instead of the &quot;useless use of cat&quot;, but for clarity I&#39;ve written it that way so all the jq syntax is on the RHS.\r\n\r\n### Source JSON (what I used as a test):\r\n\r\n```bash\r\ncurl -s &#39;https://packagecontrol.io/channel_v3.json&#39; &gt;json.txt\r\n```\r\n\r\n### Example without using custom function\r\n\r\nThis is jq code executed on the commandline:\r\n\r\n```\r\n$ cat json.txt |\r\njq -c --arg q &quot;colorhelper&quot; &#39;paths as $p |\r\n  select(getpath($p)?|test($q;&quot;i&quot;)) |\r\n  $p&#39;\r\n\r\n==&gt; [&quot;packages_cache&quot;,&quot;https://packagecontrol.io/repository.json&quot;,625,&quot;name&quot;]...\r\n```\r\n\r\n### Function in ~/.jq\r\n\r\nI defined a function named `grep` in my `~/.jq`:\r\n\r\n```jq\r\ndef grep($q; $f):\r\n  paths as $p |\r\n  select(getpath($p)?|test($q;$f)) |\r\n  $p ;\r\n```\r\n\r\n...and call it like this:\r\n```bash\r\n$ cat json.txt | jq -c &#39;grep(&quot;colorhelper&quot;;&quot;i&quot;)&#39;\r\n==&gt; [&quot;packages_cache&quot;,&quot;https://packagecontrol.io/repository.json&quot;,625,&quot;name&quot;]...\r\n```\r\n\r\n&quot;It works&quot;, but I&#39;d like to know how to declare the function such that if the 2nd parameter is omitted (`&quot;i&quot;` in this case), it will still succeed. As-is, an error is thrown if the function is called with only a single parameter (`jq: error: grep/1 is not defined at &lt;top-level&gt;`)\r\n\r\n### Platform\r\n\r\n- macOS 11.2.1\r\n- `jq` 1.6 (Homebrew)\r\n```\r\n$ jq --version\r\njq-1.6\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/66342200/how-to-pass-parameters-in-jq-to-a-function-defined-in-the-jq-dotfile",
        "title": "How to pass parameters in jq to a function defined in the ~/.jq dotfile?"
    },
    {
        "tags": [
            "parsing",
            "null",
            "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": 1614165075,
                "post_id": 66349432,
                "comment_id": 117300455,
                "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": 1614166064,
                "post_id": 66349432,
                "comment_id": 117300908,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1929456,
                    "reputation": 645,
                    "user_id": 1739193,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8647dbcc49e11bd84e7d991fe0e52a15?s=256&d=identicon&r=PG",
                    "display_name": "btafarelo",
                    "link": "https://stackoverflow.com/users/1739193/btafarelo"
                },
                "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": 1614166914,
                "post_id": 66349432,
                "comment_id": 117301268,
                "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": 1614167050,
                "post_id": 66349432,
                "comment_id": 117301340,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1929456,
                    "reputation": 645,
                    "user_id": 1739193,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8647dbcc49e11bd84e7d991fe0e52a15?s=256&d=identicon&r=PG",
                    "display_name": "btafarelo",
                    "link": "https://stackoverflow.com/users/1739193/btafarelo"
                },
                "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": 1614167759,
                "post_id": 66349432,
                "comment_id": 117301666,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1929456,
                    "reputation": 645,
                    "user_id": 1739193,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8647dbcc49e11bd84e7d991fe0e52a15?s=256&d=identicon&r=PG",
                    "display_name": "btafarelo",
                    "link": "https://stackoverflow.com/users/1739193/btafarelo"
                },
                "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": 1614176658,
                "post_id": 66349432,
                "comment_id": 117305899,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1614233683,
                "last_edit_date": 1614233683,
                "creation_date": 1614182459,
                "answer_id": 66354444,
                "question_id": 66349432,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. E? is like `try E catch empty`, whereas what you seem to want is either `try E catch null` or perhaps`E? // null`\r\n\r\n2. `.p[]?` is not the same as `.p?[]` or .p?[]?:\r\n```\r\n     $ jq -n &#39;[] | .p[]?&#39;\r\n     jq: error (at &lt;unknown&gt;): Cannot index array with string &quot;p&quot;\r\n     $ jq -n &#39;[] | .p?[]&#39;\r\n     $\r\n     $ jq -n &#39;[] | .p?[]?&#39;\r\n     $\r\n```\r\nSpecifically, `.p[]` is like `.p | (try .[] catch empty)`, so there is nothing to stop the `.p` from raising an exception.\r\n\r\nYou might like to consider using `try` explicitly:\r\n\r\n    $ jq -n &#39;[] | try .p[] catch null&#39;\r\n    $\r\n\r\n",
                "title": "Parsing stops on null or []"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1614233683,
        "creation_date": 1614164147,
        "last_edit_date": 1614184706,
        "question_id": 66349432,
        "body_markdown": "I have this filter working well but after a new use case where the property &quot;p&quot; can be null or a empty array [], the parser stop to evaluate the expression.\r\n\r\n&quot;.p[]?.product.productId&quot; the issue is here, when p is null or an empty array [].\r\n\r\nWhen I have the p property like this, it works well. [{}] or [{&quot;id&quot;:123}]\r\n\r\nI&#39;m breaking the filter in lines to make it easy to understand.\r\n\r\n    .p as $p \r\n    | .p[]?.product.productId as $pa \r\n    | .io[] \r\n    | select(.product.productId == ($pa) or .description == &quot;product description x&quot;) \r\n    |  .product.productId as $pid \r\n    |  {&quot;offerId&quot;: .offerId, \r\n        &quot;description&quot;: .description, \r\n        &quot;required&quot;: \r\n           &quot;($p[] | select(.product.productId == $pid) | .required)&quot;, \r\n        &quot;applied&quot;: false, \r\n        &quot;amount&quot;: (if .prices | length == 0 \r\n           then 0 \r\n           elif .prices[0].amount != null \r\n           then .prices[0].amount \r\n           else .prices[0].amountPercentage \r\n           end)}\r\n\r\nInput:\r\n\r\n    {\r\n       &quot;p&quot;: null,\r\n       &quot;io&quot;: [{\r\n         &quot;offerId&quot;: 5593,\r\n         &quot;description&quot;: &quot;product description x&quot;,\r\n         &quot;product&quot;: {\r\n            &quot;productId&quot;: 393,\r\n            &quot;description&quot;: &quot;product description x 2&quot;,\r\n            &quot;type&quot;: &quot;Insurance&quot;\r\n         },\r\n         &quot;prices&quot;: [\r\n            {\r\n               &quot;amount&quot;: null,\r\n               &quot;amountPercentage&quot;: 4.13999987,\r\n               &quot;status&quot;: &quot;On&quot;\r\n            }\r\n         ]\r\n      }]\r\n    }\r\n\r\nAll I want is to be able to ignore the P when it is null or [].\r\n\r\n*I&#39;m aware about this literal expression &quot;($p[] | select(.product.productId == $pid) | .required)&quot;\r\n\r\njqplay.org/s/wYwKUFM2XR\r\n\r\nRegards",
        "link": "https://stackoverflow.com/questions/66349432/parsing-stops-on-null-or",
        "title": "Parsing stops on null or []"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614187849,
                "post_id": 66355350,
                "comment_id": 117311547,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5636865,
                    "reputation": 542,
                    "user_id": 4462095,
                    "user_type": "registered",
                    "accept_rate": 89,
                    "profile_image": "https://www.gravatar.com/avatar/853eb6459ce08abd8331a6081fa5c620?s=256&d=identicon&r=PG",
                    "display_name": "Arrrow",
                    "link": "https://stackoverflow.com/users/4462095/arrrow"
                },
                "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": 1614204216,
                "post_id": 66355350,
                "comment_id": 117318105,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1614207758,
                "last_edit_date": 1614207758,
                "creation_date": 1614188812,
                "answer_id": 66356154,
                "question_id": 66355350,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following jq program first finds the &quot;new&quot; paths in default.json by subtracting the paths in current.json from the paths in default.json, and then updates the &quot;current&quot; JSON by adding all the &quot;new&quot; paths and their associated values:\r\n```\r\njq --argfile default default.json &#39;\r\n . as $current\r\n | ([$default|paths] - [$current|paths]) as $new\r\n | reduce $new[] as $p ($current; \r\n     setpath($p; $default|getpath($p)))\r\n&#39; current.json\r\n```\r\n### Caveat\r\nAs of this writing, the --argfile option is officially &quot;deprecated&quot;, so you might like to use one of the many other ways to pass in the contents of default.json.",
                "title": "jq update json from another json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1614207758,
        "creation_date": 1614185665,
        "question_id": 66355350,
        "body_markdown": "I have a defaults.json and a current.json.\r\n\r\ndefaults.json gets copied to current.json, and current.json is used as the main configuration file.\r\n\r\ndefaults would looke something like this:\r\n \r\n\r\n    {\r\n          &quot;AttributeName&quot;:&quot;setting1&quot;\r\n          &quot;Value&quot;: [\r\n            {\r\n              &quot;ValueName&quot;: &quot;Disabled&quot;,\r\n              &quot;ValueDisplayName&quot;: &quot;Disabled&quot;\r\n            },\r\n            {\r\n              &quot;ValueName&quot;: &quot;Enabled&quot;,\r\n              &quot;ValueDisplayName&quot;: &quot;Enabled&quot;\r\n            }\r\n          ],\r\n          &quot;DefaultValue&quot;: &quot;Enabled&quot;\r\n        }\r\n\r\nand current.json would look like this:\r\n\r\n     {\r\n          &quot;AttributeName&quot;:&quot;setting1&quot;\r\n          &quot;Value&quot;: [\r\n            {\r\n              &quot;ValueName&quot;: &quot;Disabled&quot;,\r\n              &quot;ValueDisplayName&quot;: &quot;Disabled&quot;\r\n            },\r\n            {\r\n              &quot;ValueName&quot;: &quot;Enabled&quot;,\r\n              &quot;ValueDisplayName&quot;: &quot;Enabled&quot;\r\n            }\r\n          ],\r\n          &quot;DefaultValue&quot;: &quot;Enabled&quot;,\r\n          &quot;CurrentValue&quot;: &quot;Enabled&quot;\r\n        }\r\n\r\nNow when I add a new &quot;setting2&quot; (which has the same keys, but values can be different) to defaults.json, I would like to update current.json with that setting, without overwriting the &quot;currentvalue&quot; field. How can I do this using jq?\r\n\r\nI tried things like `jq -rs &#39;add&#39; defaults.json current.json` but this just prints current.json.\r\n\r\nI&#39;ve tried looking at some of the other questions regarding jq, but they all cater to a very specific situation, uncomparable to mine.",
        "link": "https://stackoverflow.com/questions/66355350/jq-update-json-from-another-json",
        "title": "jq update json from another json"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1614209016,
                "post_id": 66360203,
                "comment_id": 117319387,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1614211030,
                "post_id": 66360203,
                "comment_id": 117319873,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1614254372,
                "creation_date": 1614254372,
                "answer_id": 66368051,
                "question_id": 66360203,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yu need:\r\n   \r\n\r\n    cat data1.jtxt | jq &#39;to_entries|map({(.value.name):(.value.id)})&#39;\r\n\r\nMy output:\r\n\r\n    [\r\n\t\t  {\r\n\t\t    &quot;Robin&quot;: &quot;id1&quot;\r\n\t\t  },\r\n\t\t  {\r\n\t\t    &quot;John&quot;: &quot;id2&quot;\r\n\t\t  },\r\n\t\t  {\r\n\t\t    &quot;Jane&quot;: &quot;id3&quot;\r\n\t\t  }\r\n\t\t]",
                "title": "Re-organize json using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1653916046,
                "creation_date": 1653916046,
                "answer_id": 72434847,
                "question_id": 66360203,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I cannot understand how was this command so difficult to find\r\n```\r\n[.[] | {(.id):.name}] | add\r\n```\r\ngives you:\r\n```\r\n{\r\n  &quot;id1&quot;: &quot;Robin&quot;,\r\n  &quot;id2&quot;: &quot;John&quot;,\r\n  &quot;id3&quot;: &quot;Jane&quot;\r\n}\r\n```\r\n\r\nIf you want to keep the &quot;object separation&quot; just remove the `| add`\r\n\r\nThis [question](https://stackoverflow.com/questions/34226370/jq-print-key-and-value-for-each-entry-in-an-object) somehow led me to it.",
                "title": "Re-organize json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1653916046,
        "creation_date": 1614208624,
        "question_id": 66360203,
        "body_markdown": "I want to re-organize a json using jq.\r\nMy json is like:\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;id1&quot;,\r\n    &quot;name&quot;: &quot;Robin&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;id2&quot;,\r\n    &quot;name&quot;: &quot;John&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;id3&quot;,\r\n    &quot;name&quot;: &quot;Jane&quot;\r\n  }\r\n]\r\n```\r\nI want to have an output as :\r\n```\r\n[\r\n  {\r\n    &quot;Robin&quot;: &quot;id1&quot;\r\n  },\r\n  {\r\n    &quot;John&quot;: &quot;id2&quot;\r\n  },\r\n  {\r\n    &quot;Jane&quot;: &quot;id3&quot;\r\n  }\r\n]\r\n```\r\n\r\nHow to achieve this?\r\n\r\nThanks in advance",
        "link": "https://stackoverflow.com/questions/66360203/re-organize-json-using-jq",
        "title": "Re-organize json using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10648681,
                    "reputation": 13005,
                    "user_id": 7840440,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8YBUl.png?s=256",
                    "display_name": "Raman Sailopal",
                    "link": "https://stackoverflow.com/users/7840440/raman-sailopal"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1614264686,
                "post_id": 66370745,
                "comment_id": 117337702,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1485361,
                    "reputation": 1194,
                    "user_id": 1393761,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/91c46ea13c4332b51b4db0432db53e94?s=256&d=identicon&r=PG",
                    "display_name": "Jon Hudson",
                    "link": "https://stackoverflow.com/users/1393761/jon-hudson"
                },
                "reply_to_user": {
                    "account_id": 10648681,
                    "reputation": 13005,
                    "user_id": 7840440,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8YBUl.png?s=256",
                    "display_name": "Raman Sailopal",
                    "link": "https://stackoverflow.com/users/7840440/raman-sailopal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614265199,
                "post_id": 66370745,
                "comment_id": 117337970,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10648681,
                    "reputation": 13005,
                    "user_id": 7840440,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8YBUl.png?s=256",
                    "display_name": "Raman Sailopal",
                    "link": "https://stackoverflow.com/users/7840440/raman-sailopal"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1614265540,
                "post_id": 66370745,
                "comment_id": 117338146,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1485361,
                    "reputation": 1194,
                    "user_id": 1393761,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/91c46ea13c4332b51b4db0432db53e94?s=256&d=identicon&r=PG",
                    "display_name": "Jon Hudson",
                    "link": "https://stackoverflow.com/users/1393761/jon-hudson"
                },
                "reply_to_user": {
                    "account_id": 10648681,
                    "reputation": 13005,
                    "user_id": 7840440,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8YBUl.png?s=256",
                    "display_name": "Raman Sailopal",
                    "link": "https://stackoverflow.com/users/7840440/raman-sailopal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614267628,
                "post_id": 66370745,
                "comment_id": 117339189,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614273732,
                "post_id": 66370745,
                "comment_id": 117342112,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1614269381,
                "creation_date": 1614269381,
                "answer_id": 66372180,
                "question_id": 66370745,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```bash\r\n$ ary=($(echo &#39;{&quot;crew&quot;:[{&quot;name&quot;:&quot;kirk&quot;},{&quot;name&quot;:&quot;bones&quot;},{&quot;name&quot;:&quot;mr spock&quot;}]}&#39; | jq -r &#39;.crew[].name | @sh&#39;))\r\n$ declare -p ary\r\ndeclare -a ary=([0]=&quot;&#39;kirk&#39;&quot; [1]=&quot;&#39;bones&#39;&quot; [2]=&quot;&#39;mr&quot; [3]=&quot;spock&#39;&quot;)\r\n```\r\nThis does not work as expected because the command substitution is unquoted, bash will perform word splitting on the output. It doesn&#39;t matter that the actual output contains quote characters. Refer to [3.5 Shell Expansions](https://www.gnu.org/software/bash/manual/bash.html#Shell-Expansions) in the manual\r\n\r\nYou need to delay the array assignment until the contents of the output can be examined by the shell. This _could_ be done with `eval`, but for variable assignment it&#39;s better done with `declare`:\r\n```bash\r\n$ declare -a &quot;ary=($(echo &#39;{&quot;crew&quot;:[{&quot;name&quot;:&quot;kirk&quot;},{&quot;name&quot;:&quot;bones&quot;},{&quot;name&quot;:&quot;mr spock&quot;}]}&#39; | jq -r &#39;.crew[].name | @sh&#39;))&quot;\r\n$ declare -p ary\r\ndeclare -a ary=([0]=&quot;kirk&quot; [1]=&quot;bones&quot; [2]=&quot;mr spock&quot;)\r\n```\r\nFor readability, split that into steps:\r\n```bash\r\n$ jq_out=$(echo &#39;{&quot;crew&quot;:[{&quot;name&quot;:&quot;kirk&quot;},{&quot;name&quot;:&quot;bones&quot;},{&quot;name&quot;:&quot;mr spock&quot;}]}&#39; | jq -r &#39;.crew[].name | @sh&#39;)\r\n$ declare -a &quot;ary=( $jq_out )&quot;\r\n$ declare -p ary\r\ndeclare -a ary=([0]=&quot;kirk&quot; [1]=&quot;bones&quot; [2]=&quot;mr spock&quot;)\r\n",
                "title": "Assigning jq output to bash array when json value contains spaces"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1614283315,
                "creation_date": 1614283315,
                "answer_id": 66375693,
                "question_id": 66370745,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your bash does not support mapfile/readarray, you could use the idiom illustrated by the following:\r\n```\r\necho $BASH_VERSION\r\n\r\nwhile read -r name ; do\r\n    ary+=(&quot;$name&quot;)\r\ndone &lt; &lt;(echo &#39;{&quot;crew&quot;:[{&quot;name&quot;:&quot;kirk&quot;},{&quot;name&quot;:&quot;bones&quot;},{&quot;name&quot;:&quot;mr spock&quot;}]}&#39; |\r\n   jq -r &#39;.crew[].name&#39;)\r\n\r\ndeclare -p ary\r\n```\r\n#### Output\r\n```\r\n3.2.57(1)-release\r\ndeclare -a ary=&#39;([0]=&quot;kirk&quot; [1]=&quot;bones&quot; [2]=&quot;mr spock&quot;)&#39;\r\n```\r\n\r\nNotice in particular that \r\n* `$name` is quoted in the array-update line\r\n* there is no need to use `@sh`, which indeed in this case is probably not what you want.\r\n\r\nOf course, if the JSON strings might contain embedded new lines, then the above would have to be tweaked accordingly, e.g. to use NUL (`&quot;\\u0000&quot;`) as the delimiter. \r\n\r\n\r\n",
                "title": "Assigning jq output to bash array when json value contains spaces"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1614283315,
        "creation_date": 1614264198,
        "last_edit_date": 1614281654,
        "question_id": 66370745,
        "body_markdown": "When I do this:\r\n\r\n    arr=($(echo &#39;{&quot;crew&quot;:[{&quot;name&quot;:&quot;kirk&quot;},{&quot;name&quot;:&quot;bones&quot;},{&quot;name&quot;:&quot;mr spock&quot;}]}&#39; | jq -r &#39;.crew[].name | @sh&#39;))\r\n\r\nI get:\r\n\r\n    echo &quot;${arr[2]}&quot;\r\n    mr\r\n    echo &quot;${arr[3]}&quot;\r\n    spock\r\n\r\nHowever when I do this:\r\n\r\n    arr=(&quot;kirk&quot; &quot;bones&quot; &quot;mr spock&quot;)\r\n\r\nI get this:\r\n\r\n    echo &quot;${arr[2]}&quot;\r\n    mr spock\r\n\r\nWhy, in the first example, is bash ignoring the quotes that each jq value is wrapped in when it creates the array?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66370745/assigning-jq-output-to-bash-array-when-json-value-contains-spaces",
        "title": "Assigning jq output to bash array when json value contains spaces"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2891988,
                    "reputation": 49,
                    "user_id": 2480552,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2354ab9590f1245050d6577d1be858d6?s=256&d=identicon&r=PG",
                    "display_name": "user2480552",
                    "link": "https://stackoverflow.com/users/2480552/user2480552"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614284213,
                "post_id": 66375616,
                "comment_id": 117346415,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2891988,
                    "reputation": 49,
                    "user_id": 2480552,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2354ab9590f1245050d6577d1be858d6?s=256&d=identicon&r=PG",
                    "display_name": "user2480552",
                    "link": "https://stackoverflow.com/users/2480552/user2480552"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614293501,
                "post_id": 66375616,
                "comment_id": 117349345,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1614289345,
                "last_edit_date": 1614289345,
                "creation_date": 1614288979,
                "answer_id": 66376793,
                "question_id": 66375616,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The requirements are somewhat opaque but it&#39;s fairly clear that if the task can be done by computer, it can be done using jq.\r\n\r\nFrom the description, it would appear that one of the unusual aspects of the problem is that the &quot;dictionary&quot; defined by in1.json must be derived by splitting the key names that are CSV (comma-separated values).  Here therefore is a jq def that will do that:\r\n\r\n```\r\n# Input: a JSON dictionary for which some keys are CSV,\r\n# Output: a JSON dictionary with the CSV keys split on the commas\r\ndef refine:\r\n  . as $in\r\n  | reduce keys_unsorted[] as $k ({};\r\n    if ($k|index(&quot;,&quot;))\r\n    then ($k/&quot;,&quot;) as $keys\r\n    | . + ($keys | map( {(.): $in[$k]}) | add)\r\n    else .[$k] = $in[$k]\r\n    end );\r\n```\r\n\r\nYou can see how this works by running:\r\n```\r\nINDEX($mitre.records[]; .mitre_test) | refine\r\n```\r\n\r\nusing an invocation of jq such as:\r\n\r\n    jq --argfile mitre in1.json -f program.jq in2.json\r\n\r\n\r\nFor the joining part of the problem, there are many relevant Q&amp;As on SO, e.g.\r\n\r\nhttps://stackoverflow.com/questions/54506913/how-to-join-json-objects-on-particular-fields-using-jq",
                "title": "Combine files in jq based on similar ID object and reform data"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1614635680,
                "creation_date": 1614635680,
                "answer_id": 66430247,
                "question_id": 66375616,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is probably a much more elegant way to do this, but I ended up manually walking around things and piping to new output. \r\n\r\nExplanation:\r\nRead in both files, pull the fields I need.\r\n\r\nBreak out the mitre_test values that were previously just a comma separated set of values with map and try.\r\n\r\nStore the none-changing fields as a variable and then manipulate mitre_test to become an appropriately split array, removing nulls.\r\nGroup by mitre_test values, since they are the common thing that the output is based on.\r\n\r\nCleanup more nulls.\r\n\r\nSort output to look like I want it.\r\n\r\n```\r\njq . in1.json in2.json | \\\r\njq &#39;.[] |{number: .number, test: .test, mitreid: .mitreid, mitre_test: .mitre_test}&#39;  |\\\r\njq -s &#39;[. |map(try(.mitre_test |= split(&quot;,&quot;)) // .)|\\\r\n.[] | [.number,.test,.mitreid] as $h | .mitre_test[] |$h + [.] | \\\r\n{DET_ID: .[0], tactic: .[1], techniqueID: .[2], mitre_test: .[3]}] |\\\r\ndel(.[][] | nulls)&#39; |jq &#39;[group_by(.mitre_test)[]|{mitre_test: .[0].mitre_test, techniqueID: [.[].techniqueID],tactic: [.[].tactic], DET_ID: [.[].DET_ID]}]|\\\r\ndel(.[].techniqueID[] | nulls) | del(.[].tactic[] | nulls) | del(.[].DET_ID[] | nulls)&#39; | \\\r\njq &#39;.[]| [{techniqueID: .techniqueID[0],tactic: .tactic[0], metadata: [{name: &quot;DET_ID&quot;,value: .DET_ID[]}]}] | .[] | \\\r\nselect((.metadata|length)&gt;0)&#39;\r\n```\r\nIt was a long line, so I split it among some of the basic ideas.",
                "title": "Combine files in jq based on similar ID object and reform data"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1614635680,
        "creation_date": 1614282979,
        "last_edit_date": 1614630580,
        "question_id": 66375616,
        "body_markdown": "Preface: If the following is not possible with jq, then I completely accept that as an answer and will try to force this with bash.\r\n\r\nI have two files that contain some IDs that, with some massaging, should be able to be combined into a single file. I have some content that I&#39;ll add to that as well (as seen in output). Essentially &quot;mitre_test&quot; should get compared to &quot;sys_id&quot;. When compared, the &quot;mitreid&quot; from in2.json becomes technique_ID in the output (and is generally the unifying field of each output object).\r\n\r\nCaveats: \r\n\r\n1. There are some junk &quot;desc&quot; values placed in the in1.json that are there to make sure this is as programmatic as possible, and there are actually numerous junk inputs on the true input file I am using.\r\n\r\n1. some of the mitre_test values have pairs and are not in a real array. I can split on those and break them out, but find myself losing the other information from in1.json.\r\n\r\n2. Notice in the &quot;metadata&quot; for the output that is contains the &quot;number&quot; values from in1.json, and stored in a weird way (but the way that the receiving tool requires).\r\n\r\n\r\nin1.json\r\n```\r\n[\r\n{\r\n  &quot;test&quot;: &quot;Execution&quot;,\r\n  &quot;mitreid&quot;: &quot;T1204.001&quot;,\r\n  &quot;mitre_test&quot;: &quot;90b&quot;\r\n},\r\n{\r\n  &quot;test&quot;: &quot;Defense Evasion&quot;,\r\n  &quot;mitreid&quot;: &quot;T1070.001&quot;,\r\n  &quot;mitre_test&quot;: &quot;afa&quot;\r\n},\r\n{\r\n  &quot;test&quot;: &quot;Credential Access&quot;,\r\n  &quot;mitreid&quot;: &quot;T1556.004&quot;,\r\n  &quot;mitre_test&quot;: &quot;14b&quot;\r\n},\r\n{\r\n  &quot;test&quot;: &quot;Initial Access&quot;,\r\n  &quot;mitreid&quot;: &quot;T1200&quot;,\r\n  &quot;mitre_test&quot;: &quot;f22&quot;\r\n},\r\n{\r\n  &quot;test&quot;: &quot;Impact&quot;,\r\n  &quot;mitreid&quot;: &quot;T1489&quot;,\r\n  &quot;mitre_test&quot;: &quot;fa2&quot;\r\n}\r\n]\r\n```\r\n\r\nin2.json\r\n```\r\n[\r\n  {\r\n    &quot;number&quot;: &quot;REL0001346&quot;,\r\n    &quot;desc&quot;: &quot;apple&quot;,\r\n    &quot;mitre_test&quot;: &quot;afa&quot;\r\n  },\r\n  {\r\n    &quot;number&quot;: &quot;REL0001343&quot;,\r\n    &quot;desc&quot;: &quot;pear&quot;,\r\n    &quot;mitre_test&quot;: &quot;90b&quot;\r\n  },\r\n  {\r\n    &quot;number&quot;: &quot;REL0001366&quot;,\r\n    &quot;desc&quot;: &quot;orange&quot;,\r\n    &quot;mitre_test&quot;: &quot;14b,f22&quot;\r\n  },\r\n  {\r\n    &quot;number&quot;: &quot;REL0001378&quot;,\r\n    &quot;desc&quot;: &quot;pineapple&quot;,\r\n    &quot;mitre_test&quot;: &quot;90b&quot;\r\n  }\r\n]\r\n```\r\n\r\nThe output:\r\n```\r\n[{\r\n  &quot;techniqueID&quot;: &quot;T1070.001&quot;,\r\n  &quot;tactic&quot;: &quot;defense-evasion&quot;,\r\n  &quot;score&quot;: 1,\r\n  &quot;color&quot;: &quot;&quot;,\r\n  &quot;comment&quot;: &quot;&quot;,\r\n  &quot;enabled&quot;: true,\r\n  &quot;metadata&quot;: [{\r\n      &quot;name&quot;: &quot;DET_ID&quot;,\r\n      &quot;value&quot;: &quot;REL0001346&quot;\r\n    }],\r\n  &quot;showSubtechniques&quot;: true\r\n},\r\n{\r\n  &quot;techniqueID&quot;: &quot;T1204.001&quot;,\r\n  &quot;tactic&quot;: &quot;execution&quot;,\r\n  &quot;score&quot;: 1,\r\n  &quot;color&quot;: &quot;&quot;,\r\n  &quot;comment&quot;: &quot;&quot;,\r\n  &quot;enabled&quot;: true,\r\n  &quot;metadata&quot;: [{\r\n      &quot;name&quot;: &quot;DET_ID&quot;,\r\n      &quot;value&quot;: &quot;REL0001343&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;DET_ID&quot;,\r\n      &quot;value&quot;: &quot;REL0001378&quot;\r\n    }],\r\n  &quot;showSubtechniques&quot;: true\r\n},\r\n{\r\n  &quot;techniqueID&quot;: &quot;T1556.004&quot;,\r\n  &quot;tactic&quot;: &quot;credential-access&quot;,\r\n  &quot;score&quot;: 1,\r\n  &quot;color&quot;: &quot;&quot;,\r\n  &quot;comment&quot;: &quot;&quot;,\r\n  &quot;enabled&quot;: true,\r\n  &quot;metadata&quot;: [{\r\n      &quot;name&quot;: &quot;DET_ID&quot;,\r\n      &quot;value&quot;: &quot;REL0001366&quot;\r\n    }],\r\n  &quot;showSubtechniques&quot;: true\r\n},\r\n{\r\n  &quot;techniqueID&quot;: &quot;T1200&quot;,\r\n  &quot;tactic&quot;: &quot;initial-access&quot;,\r\n  &quot;score&quot;: 1,\r\n  &quot;color&quot;: &quot;&quot;,\r\n  &quot;comment&quot;: &quot;&quot;,\r\n  &quot;enabled&quot;: true,\r\n  &quot;metadata&quot;: [{\r\n      &quot;name&quot;: &quot;DET_ID&quot;,\r\n      &quot;value&quot;: &quot;REL0001366&quot;\r\n    }],\r\n  &quot;showSubtechniques&quot;: true\r\n}\r\n]\r\n```\r\n\r\nI&#39;m assuming I have some splitting to do on mitre_test with something like ```.mitre_test |= split(&quot;,&quot;))```, and there are some joins I&#39;m assuming, but doing so causes data loss or mixing up of the data. You&#39;ll notice the static data in the output exists as well, but is likely easy to place in and as such isn&#39;t as much of an issue.\r\n\r\nEdit: reduced some of the match IDs so that it is easier to look at while analyzing the in1 and in2 files. Also simplified the two inputs to have a similar structure so that the answer is easier to understand later.",
        "link": "https://stackoverflow.com/questions/66375616/combine-files-in-jq-based-on-similar-id-object-and-reform-data",
        "title": "Combine files in jq based on similar ID object and reform data"
    },
    {
        "tags": [
            "json",
            "jq",
            "jsonlines"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1614295582,
                "creation_date": 1614295582,
                "answer_id": 66377979,
                "question_id": 66377978,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq has an option for this:  --compact-output\r\n\r\n```\r\njq --compact-output ... foo.json\r\n{&quot;Name&quot;:&quot;stedolan&quot;,&quot;RecordTimestamp&quot;:&quot;2021-02-25T05:00:06.740+0000&quot;}\r\n```\r\nFull manual https://stedolan.github.io/jq/manual/v1.6/",
                "title": "Can jq produce output without newlines between fields, one line per record?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1629899456,
        "creation_date": 1614295582,
        "last_edit_date": 1629899456,
        "question_id": 66377978,
        "body_markdown": "jq always produces output with newlines/returns between each field:\r\n\r\n```\r\njq ... foo.json\r\n{\r\n  &quot;Name&quot;: &quot;stedolan&quot;,\r\n  &quot;RecordTimestamp&quot;: &quot;2021-02-25T05:00:06.740+0000&quot;\r\n}\r\n```\r\nHow can I make the output one line per record so that it looks like:\r\n\r\n    {&quot;Name&quot;:&quot;stedolan&quot;,&quot;RecordTimestamp&quot;:&quot;2021-02-25T05:00:06.740+0000&quot;}",
        "link": "https://stackoverflow.com/questions/66377978/can-jq-produce-output-without-newlines-between-fields-one-line-per-record",
        "title": "Can jq produce output without newlines between fields, one line per record?"
    },
    {
        "tags": [
            "command-line-interface",
            "jq",
            "github-actions"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 476555,
                    "reputation": 47257,
                    "user_id": 887539,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/5baef9617bdee6db2f534c118bcbccee?s=256&d=identicon&r=PG",
                    "display_name": "Andreas Louv",
                    "link": "https://stackoverflow.com/users/887539/andreas-louv"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1614326367,
                "post_id": 66381595,
                "comment_id": 117356454,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4091693,
                    "reputation": 4812,
                    "user_id": 3719845,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/622ad82db440f93202dfb9402e3bc2c7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ITChap",
                    "link": "https://stackoverflow.com/users/3719845/itchap"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614327793,
                "post_id": 66381595,
                "comment_id": 117356994,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14770,
                    "reputation": 87387,
                    "user_id": 30674,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/5f1a1d3e883676684f288f4ed973f9aa?s=256&d=identicon&r=PG",
                    "display_name": "Pure.Krome",
                    "link": "https://stackoverflow.com/users/30674/pure-krome"
                },
                "reply_to_user": {
                    "account_id": 476555,
                    "reputation": 47257,
                    "user_id": 887539,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/5baef9617bdee6db2f534c118bcbccee?s=256&d=identicon&r=PG",
                    "display_name": "Andreas Louv",
                    "link": "https://stackoverflow.com/users/887539/andreas-louv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614332384,
                "post_id": 66381595,
                "comment_id": 117358787,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14770,
                    "reputation": 87387,
                    "user_id": 30674,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/5f1a1d3e883676684f288f4ed973f9aa?s=256&d=identicon&r=PG",
                    "display_name": "Pure.Krome",
                    "link": "https://stackoverflow.com/users/30674/pure-krome"
                },
                "reply_to_user": {
                    "account_id": 4091693,
                    "reputation": 4812,
                    "user_id": 3719845,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/622ad82db440f93202dfb9402e3bc2c7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ITChap",
                    "link": "https://stackoverflow.com/users/3719845/itchap"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614332447,
                "post_id": 66381595,
                "comment_id": 117358818,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4091693,
                    "reputation": 4812,
                    "user_id": 3719845,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/622ad82db440f93202dfb9402e3bc2c7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ITChap",
                    "link": "https://stackoverflow.com/users/3719845/itchap"
                },
                "reply_to_user": {
                    "account_id": 476555,
                    "reputation": 47257,
                    "user_id": 887539,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/5baef9617bdee6db2f534c118bcbccee?s=256&d=identicon&r=PG",
                    "display_name": "Andreas Louv",
                    "link": "https://stackoverflow.com/users/887539/andreas-louv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614333967,
                "post_id": 66381595,
                "comment_id": 117359519,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14770,
                    "reputation": 87387,
                    "user_id": 30674,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/5f1a1d3e883676684f288f4ed973f9aa?s=256&d=identicon&r=PG",
                    "display_name": "Pure.Krome",
                    "link": "https://stackoverflow.com/users/30674/pure-krome"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614334179,
                "post_id": 66381595,
                "comment_id": 117359598,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14770,
                    "reputation": 87387,
                    "user_id": 30674,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/5f1a1d3e883676684f288f4ed973f9aa?s=256&d=identicon&r=PG",
                    "display_name": "Pure.Krome",
                    "link": "https://stackoverflow.com/users/30674/pure-krome"
                },
                "reply_to_user": {
                    "account_id": 4091693,
                    "reputation": 4812,
                    "user_id": 3719845,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/622ad82db440f93202dfb9402e3bc2c7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ITChap",
                    "link": "https://stackoverflow.com/users/3719845/itchap"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614334486,
                "post_id": 66381595,
                "comment_id": 117359738,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1614335844,
                "creation_date": 1614335844,
                "answer_id": 66384226,
                "question_id": 66381595,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "- I needed to use `&gt;&gt; $GITHUB_ENV` to set the environement variable.\r\n- I needed to get the correct syntax to run a set of command line programs, inline.\r\n\r\n```\r\n    - run: call some https endpoint &gt; at.json\r\n    - run: echo &quot;AUTH_TOKEN= $(jq &#39;.authorizationToken&#39; at.json)&quot; &gt;&gt; $GITHUB_ENV\r\n    - run: echo &quot;${{ env.AUTH_TOKEN }}&quot;\r\n```\r\n\r\nDetails to the above solution:\r\n- Line 1: some command which calls some external service via HTTPS. Response payload is JSON. this json data is then stored straight away into a file called `at.json`.\r\n- Line 2: display some text in the format `&lt;key&gt;=&lt;value&gt;`. Then _append_ this text to the github environment variable &#39;list/text/whatever&#39;. Now -&gt; here&#39;s the kicker =&gt; to calculate the `value` part of this key/value, run some command (or commands) inside this bit `$( .. )`. So for me, I&#39;m running `jq` command and extracting the value of the `authorizationToken` from the json text, from inside the file `at.json`. Phew!\r\n- Line3: just dump the value of my environment variable, to the log output. (yes, yes .. this is all insecure. I&#39;m doing this as a test.)\r\n\r\nand that&#39;s it!",
                "title": "Trying to parse JSON output in a Github Action"
            },
            {
                "up_vote_count": 14,
                "is_accepted": true,
                "score": 14,
                "last_activity_date": 1648479700,
                "last_edit_date": 1648479700,
                "creation_date": 1614336735,
                "answer_id": 66384454,
                "question_id": 66381595,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I will just add here some more solutions. Like you discovered yourself, you can pass it as an environment variable:\r\n```yaml\r\nsteps:\r\n  - run: |\r\n      token=$( callEndpoint | jq &#39;.authorizationToken&#39; )\r\n      echo &quot;AUTH_TOKEN=$token&quot; &gt;&gt; &quot;$GITHUB_ENV&quot;\r\n\r\n    - run: echo &quot;$AUTH_TOKEN&quot;\r\n```\r\nYou can also use a step output:\r\n```yaml\r\nsteps:\r\n  - id: get-token\r\n    run: |\r\n      token=$( callEndpoint | jq &#39;.authorizationToken&#39; )\r\n      echo &quot;::set-output name=auth_token::$token&quot;\r\n\r\n    - run: echo ${{ steps.get-token.outputs.auth_token }}\r\n```\r\nBoth of these solutions will work for passing values between steps **of the same job**.\r\n\r\nIf you need to pass values between steps of different jobs, you can use job outputs:\r\n```yaml\r\n\r\njobs:\r\n  job-a:\r\n    runs-on: ubuntu-latest\r\n    outputs:\r\n      auth_token: ${{ steps.get-token.outputs.auth_token }}\r\n    steps:\r\n      - id: get-token\r\n        run: |\r\n          token=$( callEndpoint | jq &#39;.authorizationToken&#39; )\r\n          echo &quot;::set-output name=auth_token::$token&quot;\r\n\r\n  job-b:\r\n    runs-on: ubuntu-latest\r\n    needs: job-a\r\n    steps:\r\n      - run: echo ${{ needs.job-a.outputs.auth_token }}\r\n```",
                "title": "Trying to parse JSON output in a Github Action"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 7,
        "last_activity_date": 1648479700,
        "creation_date": 1614323725,
        "last_edit_date": 1614455352,
        "question_id": 66381595,
        "body_markdown": "I&#39;m trying to extract the value of a HTTP request in a GitHub action and then use that value in another step.\r\n\r\nThis is the current code:\r\n\r\n```\r\n  - run: call some https endpoint\r\n```\r\nand that returns to the console output:\r\n\r\n```\r\n{\r\n    &quot;authorizationToken&quot;: &quot;&lt;snip&gt;&quot;,\r\n    &quot;expiration&quot;: &quot;2021-02-26T18:18:38+00:00&quot;\r\n}\r\n```\r\n\r\nand I&#39;m trying to extract the `authorizationToken` value and then use it in the next step, like\r\n\r\n```\r\n  -name: Get auth token\r\n   run: call some https endpoint\r\n   \r\n  -name: set something which uses the token\r\n   run: set blah --token $token_from_previous_step\r\n```\r\n\r\n&lt;strike&gt;\r\nNow, I couldn&#39;t even get the value of the authentication Token extracted from the json output using the `jq` program:\r\n\r\n```\r\n~  - run: call some https endpoint | echo &quot;jq &#39;.authorizationToken&#39;&quot;~\r\n```\r\n\r\nwhich errors with:\r\n\r\n```\r\njq &#39;.authorizationToken&#39;\r\nException ignored in: &lt;_io.TextIOWrapper name=&#39;&lt;stdout&gt;&#39; mode=&#39;w&#39; encoding=&#39;utf-8&#39;&gt;\r\nBrokenPipeError: [Errno 32] Broken pipe\r\n```\r\n&lt;/strike&gt;\r\n\r\nI&#39;m now able to extract the key/value .. but not sure how to set it as an environment variable, to be used in other steps.\r\n\r\nThis works:\r\n\r\n```\r\n    - run: call some https endpoint &gt; at.json\r\n    - run: jq &#39;.authorizationToken&#39; at.json\r\n```\r\n\r\nso that get the json output from that https endpoint result and saves the result into a file called `at.json` (which is the json text, above).\r\n\r\nNext, I then run the `jq` command, extracting the `authorizationToken` value. which works!\r\n\r\nNow I need to set this value as a env-var. [Reading the docs on this, it looks like it can be done][1], but I&#39;m not sure how to call `jq` and set the key/value into an env-var.\r\n\r\nI feel like I need to do something like this:\r\n\r\n```\r\n    - run: echo &quot;AUTH_TOKEN=run the jq command here&quot; &gt;&gt; $GITHUB_ENV\r\n```\r\n\r\nSomething like this (which totally fails):\r\n\r\n```\r\n    - run: echo &quot;AUTH_TOKEN=${{ jq &#39;.authorizationToken&#39; at.json }}&quot; &gt;&gt; $GITHUB_ENV\r\n```\r\n\r\n\r\n  [1]: https://docs.github.com/en/actions/reference/workflow-commands-for-github-actions#setting-an-environment-variable",
        "link": "https://stackoverflow.com/questions/66381595/trying-to-parse-json-output-in-a-github-action",
        "title": "Trying to parse JSON output in a Github Action"
    },
    {
        "tags": [
            "jq",
            "openapi"
        ],
        "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": 1614332864,
                "post_id": 66382300,
                "comment_id": 117358989,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 44601,
                    "reputation": 20464,
                    "user_id": 131021,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://i.sstatic.net/ox59l.png?s=256",
                    "display_name": "stwissel",
                    "link": "https://stackoverflow.com/users/131021/stwissel"
                },
                "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": 1614334002,
                "post_id": 66382300,
                "comment_id": 117359534,
                "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": 1614334920,
                "post_id": 66382300,
                "comment_id": 117359926,
                "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": 1614334960,
                "post_id": 66382300,
                "comment_id": 117359940,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39252,
                    "reputation": 99231,
                    "user_id": 113116,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/e0v1H.png?s=256",
                    "display_name": "Helen",
                    "link": "https://stackoverflow.com/users/113116/helen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614335080,
                "post_id": 66382300,
                "comment_id": 117360000,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 44601,
                    "reputation": 20464,
                    "user_id": 131021,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://i.sstatic.net/ox59l.png?s=256",
                    "display_name": "stwissel",
                    "link": "https://stackoverflow.com/users/131021/stwissel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614355983,
                "post_id": 66382300,
                "comment_id": 117369084,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1634106419,
                "last_edit_date": 1634106419,
                "creation_date": 1614353582,
                "answer_id": 66388614,
                "question_id": 66382300,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; My goal is to get a list of operationIds\r\n\r\nSince you only want the `operationId` values under `.path`, you could write:\r\n\r\n    .path | .. | objects | select(has(&quot;operationId&quot;)) | .operationId\r\n\r\nor if you want more control over the admissible paths, you could use the following as a template:\r\n\r\n    .path\r\n    | (paths | select(.[-1] == &quot;operationId&quot;)) as $p\r\n    | getpath($p)\r\n\r\n## &quot;Wildcard&quot; approach\r\n`..` is a recursive operation that in effect follows all &quot;paths&quot; under a JSON entity; in this context, therefore, the wildcard &quot;*&quot; expression is more akin to jq&#39;s `.[]?` expression (i.e. postfix `[]?`).  So your meta-expression `.paths.*.*.operationId` could be written in jq as:\r\n\r\n    .paths[]?[]?.operationId\r\n\r\nor\r\n\r\n    .paths[]?[]?.operationId?\r\n\r\ndepending on your interpretation of the expression with wildcards.\r\n\r\n\r\nWith the sample input, either of these produces:\r\n```\r\n&quot;listPets&quot;\r\n&quot;createPets&quot;\r\n&quot;showPetById&quot;\r\n```",
                "title": "How to extract the operationId from an OpenAPI spec using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1634106419,
        "creation_date": 1614327402,
        "last_edit_date": 1614421273,
        "question_id": 66382300,
        "body_markdown": "The OpenAPI spec defines operationId as child element of the method (GET, POST) of a path (e.g /customers ) which is a child of path. As dot notation it would look like:\r\n\r\n```\r\n.paths.&quot;/customers&quot;.get.operationId\r\n.paths.&quot;/customers&quot;.post.operationId\r\n.paths.&quot;/reports/daily&quot;.get.operationId\r\n```\r\n\r\nOr written with with wildcards: `.paths.*.*.operationId`\r\n\r\nI looked at the following information:\r\n\r\n- https://stackoverflow.com/questions/56355822/how-to-use-jq-wildcard\r\n- https://github.com/stedolan/jq/issues/82\r\n- https://unix.stackexchange.com/questions/320145/wildcard-in-jq-with-comparatives\r\n\r\nand tried `.path | .. | .. | .operationId` but with no success. \r\n\r\nMy goal is to get a list of operationIds. What do I miss?\r\n\r\n**Update** (as requested): [Sample Json OpenAPI spec](https://github.com/OAI/OpenAPI-Specification/blob/master/examples/v3.0/petstore.json)\r\n\r\n**Update** To clarify from [another question](https://stackoverflow.com/questions/64663297): The `operationId` might occur in other positions, other than 3 levels below path. Don&#39;t need those",
        "link": "https://stackoverflow.com/questions/66382300/how-to-extract-the-operationid-from-an-openapi-spec-using-jq",
        "title": "How to extract the operationId from an OpenAPI spec using JQ"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1614336255,
                "last_edit_date": 1614336255,
                "creation_date": 1614335289,
                "answer_id": 66384082,
                "question_id": 66383823,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use a little placeholder to store the value of `.query` and use it back when putting it in array\r\n\r\n```[tag:jq]\r\n.query as $q | .results[] | [.title, .content.id, $q] | @csv\r\n```\r\n\r\nOr put them in separate arrays. The `(...)` around `.results` path ensures, you don&#39;t walk to the path below and still remain at the top level node path.\r\n\r\n```[tag:jq]\r\n(.results[] | [.title, .content.id]) + [.query] | @csv\r\n```",
                "title": "Add element outside of array to csv output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1615265194,
        "creation_date": 1614334259,
        "last_edit_date": 1615265194,
        "question_id": 66383823,
        "body_markdown": "I have a JSON structure similar to this one:\r\n\r\n```json\r\n{\r\n  &quot;results&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;Page 1&quot;,\r\n      &quot;content&quot;: {\r\n        &quot;id&quot;: &quot;11111&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;Page 2&quot;,\r\n      &quot;content&quot;: {\r\n        &quot;id&quot;: &quot;22222&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;Page 3&quot;,\r\n      &quot;content&quot;: {\r\n        &quot;id&quot;: &quot;33333&quot;\r\n      }\r\n    }\r\n  ],\r\n  &quot;start&quot;: 0,\r\n  &quot;limit&quot;: 25,\r\n  &quot;size&quot;: 3,\r\n  &quot;totalSize&quot;: 3,\r\n  &quot;query&quot;: &quot;Hello World&quot;\r\n}\r\n```\r\n\r\nThe output I need is:\r\n```\r\n&quot;Page 1&quot;,&quot;11111&quot;,&quot;Hello World&quot;\r\n&quot;Page 2&quot;,&quot;22222&quot;,&quot;Hello World&quot;\r\n&quot;Page 3&quot;,&quot;33333&quot;,&quot;Hello World&quot;\r\n```\r\nI can get the elements from the array with:\r\n`cat my.json | jq -r &#39;.results[] | [.title, .content.id] | @csv&#39;`\r\nBut how do I add the &quot;query&quot; element which is outside of the array to each line in the output?\r\n\r\nI tried a bunch of options but I can&#39;t get it to work.\r\n",
        "link": "https://stackoverflow.com/questions/66383823/add-element-outside-of-array-to-csv-output",
        "title": "Add element outside of array to csv output"
    },
    {
        "tags": [
            "null",
            "key",
            "jq",
            "exists",
            "del"
        ],
        "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": 1614342102,
                "post_id": 66385148,
                "comment_id": 117362972,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15948987,
                    "reputation": 479,
                    "user_id": 11508787,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-nQCLmXHwqfQ/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rdbHA4s6yfb5wKsTg-xkCzNkjdhDQ/mo/s256-rj/photo.jpg",
                    "display_name": "Taras",
                    "link": "https://stackoverflow.com/users/11508787/taras"
                },
                "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": 1614342915,
                "post_id": 66385148,
                "comment_id": 117363281,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1614352180,
                "creation_date": 1614352180,
                "answer_id": 66388213,
                "question_id": 66385148,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Rather than creating the field and then deleting it, you could simply create it conditionally.\r\n\r\nA simple and robust (w.r.t. versions of jq) method for conditionally adding a key, $k, to an object, $o, is to use the template:\r\n\r\n    $o + (if CONDITION then {($k): $value} else null end)\r\n\r\nwhere CONDITION and $value each evaluates to a single value.\r\n\r\nSo in your case, you could write something like:\r\n\r\n    ((try first(.response.somefield4[].TheField[]) catch null) // null) as $value\r\n    . + (if $value then {SomeField6: $value} else null end)\r\n",
                "title": "JQ: how to delete field if null or not exist?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1614352933,
                "creation_date": 1614352933,
                "answer_id": 66388420,
                "question_id": 66385148,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; how to delete field if null or not exist?\r\n\r\nIf $o is an object which may or may not have a key, say $k, then to delete the key if its value is null, and leave $o as-is otherwise, you could write:\r\n\r\n    $o | if .[$k] == null then del(.[$k]) else . end\r\n\r\nor if the key is sufficiently simple (basically alphanumeric with leading alpha, where &quot;alpha&quot; includes &quot;_&quot;), you could write an expression along the lines of:\r\n\r\n    $o | if .k == null then del(.k) else . end\r\n\r\n",
                "title": "JQ: how to delete field if null or not exist?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1614355906,
        "creation_date": 1614339410,
        "last_edit_date": 1614355906,
        "question_id": 66385148,
        "body_markdown": "I need to delete field if it&#39;s null or not exist. Json looks like: \r\n\r\n    {\r\n    \t&quot;response&quot;: {\r\n    \t\t&quot;somefield1&quot;: 0,\r\n    \t\t&quot;somefield2&quot;: 0,\r\n    \t\t&quot;somefield3&quot;: 0.0,\r\n    \t\t&quot;somefield4&quot;: [{\r\n    \t\t\t&quot;somefield5&quot;: &quot;abc&quot;,\r\n    \t\t\t&quot;somefield6&quot;: &quot;123&quot;,\r\n    \t\t\t&quot;TheField&quot;: [&quot;\\u0000\\&quot;{\\&quot;id\\&quot;:\\&quot;123,SomeFields\\&quot;:{\\&quot;SomeField\\&quot;:{some data}}}\\&quot;\\u0000&quot;]\r\n    \t\t}]\r\n    \t}\r\n    }\r\n\r\nJQ\r\n\r\n    {\r\n            SomeField: &quot;%s&quot;,\r\n            SomeField1: &quot;%s&quot;,\r\n            SomeField2: &quot;a&quot;,\r\n            SomeField3: &quot;b&quot;,\r\n            SomeField4: {\r\n                a: &quot;%s&quot;,\r\n                b: &quot;%s&quot;\r\n            },\r\n            SomeField5: &quot;%s&quot;,\r\n          SomeField6: .response?.somefield4[]?.TheField[]?,\r\n    } | del(.SomeField6? | nulls)\r\n\r\nSo if &quot;TheField&quot; doesn&#39;t exist or it&#39;s null I need to delete SomeField6. Right now instead of delete current field JQ delete all statement and I get nothing on response.",
        "link": "https://stackoverflow.com/questions/66385148/jq-how-to-delete-field-if-null-or-not-exist",
        "title": "JQ: how to delete field if null or not exist?"
    },
    {
        "tags": [
            "json",
            "max",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1614415811,
                "last_edit_date": 1614415811,
                "creation_date": 1614386201,
                "answer_id": 66394481,
                "question_id": 66394429,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `max_by`:\r\n\r\n    jq -r &#39;max_by(.[0] | tonumber) | .[0]&#39; file.json",
                "title": "jq - how to select lowest or highest (no keys, no values in json)?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1614415811,
        "creation_date": 1614385648,
        "last_edit_date": 1614396125,
        "question_id": 66394429,
        "body_markdown": "I have this json:\r\n\r\n    [\r\n      [\r\n        &quot;0.99980000&quot;,\r\n        &quot;3813863.19000000&quot;\r\n      ],\r\n      [\r\n        &quot;0.99970000&quot;,\r\n        &quot;3813412.11000000&quot;\r\n      ],\r\n      [\r\n        &quot;0.99960000&quot;,\r\n        &quot;1188619.16000000&quot;\r\n      ],\r\n      [\r\n        &quot;0.99950000&quot;,\r\n        &quot;1992659.70000000&quot;\r\n      ],\r\n      [\r\n        &quot;0.99940000&quot;,\r\n        &quot;3258570.31000000&quot;\r\n      ]\r\n    ]\r\n\r\nI would like to select the &quot;highest of first&quot; values, being 0.99980000 - how do I go about it with jq?\r\n\r\n\r\nI wouldn&#39;t like to use shell&#39;s tail/head for that (i.e. &quot;jq -r &#39;.[] | .[]&#39; | head -1&quot; would output 0.99980000 - but it doesn&#39;t look that great and will not even work if the json data is not sorted already, at least not without yet more shell commands).",
        "link": "https://stackoverflow.com/questions/66394429/jq-how-to-select-lowest-or-highest-no-keys-no-values-in-json",
        "title": "jq - how to select lowest or highest (no keys, no values in json)?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq",
            "influxdb"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1614573228,
                "last_edit_date": 1614573228,
                "creation_date": 1614467373,
                "answer_id": 66404321,
                "question_id": 66403782,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following produces the required output in a way that \r\nallows for multiple values of &quot;time&quot; in each `.values` array, but does not refer to the specific headers except for &quot;name&quot;: \r\n```\r\ndef headers:\r\n (.tags | keys_unsorted) as $tags\r\n | ([&quot;name&quot;] + $tags + .columns); \r\n\r\n.results[0]\r\n| (.series[0] | headers),\r\n  (.series[] | ([.name, .tags[]] + .values[]))\r\n| @csv\r\n```\r\n\r\nThis of course assumes that the separate &quot;series&quot; are conformal.",
                "title": "InfluxDB query in json format transform to csv with jq including tags and fields"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1614510348,
                "creation_date": 1614510348,
                "answer_id": 66408373,
                "question_id": 66403782,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Why you just don&#39;t specify csv format directly in influxdb CLI https://docs.influxdata.com/influxdb/v1.8/tools/shell/ :\r\n\r\n&gt; -format &#39;json|csv|column&#39; Specifies the format of the server responses. \r\n\r\nSo you won&#39;t need any result post processing.",
                "title": "InfluxDB query in json format transform to csv with jq including tags and fields"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1614573228,
        "creation_date": 1614462621,
        "last_edit_date": 1614468790,
        "question_id": 66403782,
        "body_markdown": "I want to process data with a bash script but have trouble to get the InfluxDB output to the desired csv output with all tags and fields.\r\n\r\nBelow an example output from an influx query:\r\n\r\n    {\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;series&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;tickerPrice&quot;,\r\n              &quot;tags&quot;: {\r\n                &quot;symbol&quot;: &quot;AAVE&quot;,\r\n                &quot;symbolTo&quot;: &quot;EUR&quot;\r\n              },\r\n              &quot;columns&quot;: [\r\n                &quot;time&quot;,\r\n                &quot;priceMean&quot;\r\n              ],\r\n              &quot;values&quot;: [\r\n                [\r\n                  1614402874120627200,\r\n                  282.398263888889\r\n                ]\r\n              ]\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;tickerPrice&quot;,\r\n              &quot;tags&quot;: {\r\n                &quot;symbol&quot;: &quot;BTC&quot;,\r\n                &quot;symbolTo&quot;: &quot;EUR&quot;\r\n              },\r\n              &quot;columns&quot;: [\r\n                &quot;time&quot;,\r\n                &quot;priceMean&quot;\r\n              ],\r\n              &quot;values&quot;: [\r\n                [\r\n                  1614402874120627200,\r\n                  39189.756944444445\r\n                ]\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nAnd I would like to transform it to:\r\n\r\n    &quot;name&quot;,&quot;symbol&quot;,&quot;symbolTo&quot;,&quot;time&quot;,&quot;priceMean&quot;\r\n    &quot;tickerPrice&quot;,&quot;AAVE&quot;,&quot;EUR&quot;,1614402874120627200,282.398263888889\r\n    &quot;tickerPrice&quot;,&quot;BTC&quot;,&quot;EUR&quot;,1614402874120627200,39189.756944444445\r\n\r\nI have managed (google) to get the fields to a csv format but till now not managed to get all data in the csv. Here is the commands that I use for that:\r\n\r\n    $ jq -r &#39;(.results[0].series[0].columns), (.results[0].series[].values[])&#39;\r\n\r\nBecause this is not the only query I want to do it would be nice that it is universal for the content, so the number of fields and tags could be different.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66403782/influxdb-query-in-json-format-transform-to-csv-with-jq-including-tags-and-fields",
        "title": "InfluxDB query in json format transform to csv with jq including tags and fields"
    },
    {
        "tags": [
            "macos",
            "shell",
            "zsh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1614479667,
                "last_edit_date": 1614479667,
                "creation_date": 1614479014,
                "answer_id": 66405300,
                "question_id": 66405239,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. Use `--argjson` rather than `--arg` when passing JSON rather than strings.\r\n\r\n2. When in doubt, quote your strings; that way if the shell executing your code isn&#39;t the one you think it is, you won&#39;t have your values being munged. (It&#39;s also helpful to stay in the habits necessary to write portable code; the whole reason I dropped zsh after spending 6 months learning it back in the mid-2000s is that my code quality when writing for other shells suffered).\r\n\r\n---\r\n\r\n```\r\nobjName=&quot;objName&quot;\r\nobjJSON=&#39;{&quot;test&quot;: &quot;json&quot;}&#39;\r\necho &#39;{&quot;data&quot;:{}}&#39; |\r\n  jq --arg     objectName &quot;$objName&quot; \\\r\n     --argjson jsonString &quot;$objJSON&quot; \\\r\n    &#39;.data[$objectName] += $jsonString&#39;\r\n```\r\n\r\n...properly emits:\r\n\r\n```\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;objName&quot;: {\r\n      &quot;test&quot;: &quot;json&quot;\r\n    }\r\n  }\r\n}\r\n```",
                "title": "jq: Append JSON object via shell variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1614509755,
        "creation_date": 1614478116,
        "last_edit_date": 1614509755,
        "question_id": 66405239,
        "body_markdown": "I have a JSON file and I&#39;m trying to add another field to it.\r\n\r\n_Example JSON File_:\r\n```\r\n{&quot;data&quot;:{}}\r\n```\r\n\r\nLooking at other answers the `+=` seems to work:\r\n\r\n```\r\nobjectName=&quot;objName&quot;\r\ncat $jsonFile | jq --arg objName $objectName &#39;.data[$objName] += {&quot;test&quot;: &quot;json&quot;}&#39;\r\n```\r\nOutputs\r\n```\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;objName&quot;: {\r\n      &quot;test&quot;: &quot;json&quot;\r\n    }\r\n  }\r\n}\r\n```\r\njust as expected.\r\n\r\nThe problem is that I can&#39;t hardcode the JSON so I&#39;m inputting the string as a variable. But I can&#39;t get the syntax to work:\r\n```\r\nobjectName=&quot;objName&quot;\r\nobjJSON=&#39;{&quot;test&quot;: &quot;json&quot;}&#39;\r\ncat $jsonFile | jq -r --arg objName $objectName --arg jsonString $objJSON &#39;.data[$objName] += $jsonString&#39;\r\n```\r\nI&#39;m getting the error `jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&quot;json&quot;}`",
        "link": "https://stackoverflow.com/questions/66405239/jq-append-json-object-via-shell-variable",
        "title": "jq: Append JSON object via shell variable"
    },
    {
        "tags": [
            "arrays",
            "json",
            "insert",
            "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": 1614628090,
                "post_id": 66428658,
                "comment_id": 117437717,
                "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": 1614628139,
                "post_id": 66428658,
                "comment_id": 117437745,
                "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": 1614628879,
                "post_id": 66428658,
                "comment_id": 117438039,
                "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": 1614629687,
                "post_id": 66428658,
                "comment_id": 117438337,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1252466,
                    "reputation": 83889,
                    "user_id": 1212596,
                    "user_type": "registered",
                    "accept_rate": 52,
                    "profile_image": "https://www.gravatar.com/avatar/fc06d8fd3a1c96a1475f0e6e7264fbef?s=256&d=identicon&r=PG",
                    "display_name": "Paul Draper",
                    "link": "https://stackoverflow.com/users/1212596/paul-draper"
                },
                "reply_to_user": {
                    "account_id": 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": 1614642617,
                "post_id": 66428658,
                "comment_id": 117442669,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1252466,
                    "reputation": 83889,
                    "user_id": 1212596,
                    "user_type": "registered",
                    "accept_rate": 52,
                    "profile_image": "https://www.gravatar.com/avatar/fc06d8fd3a1c96a1475f0e6e7264fbef?s=256&d=identicon&r=PG",
                    "display_name": "Paul Draper",
                    "link": "https://stackoverflow.com/users/1212596/paul-draper"
                },
                "reply_to_user": {
                    "account_id": 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": 1614642638,
                "post_id": 66428658,
                "comment_id": 117442673,
                "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": 1614654785,
                "post_id": 66428658,
                "comment_id": 117445074,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1252466,
                    "reputation": 83889,
                    "user_id": 1212596,
                    "user_type": "registered",
                    "accept_rate": 52,
                    "profile_image": "https://www.gravatar.com/avatar/fc06d8fd3a1c96a1475f0e6e7264fbef?s=256&d=identicon&r=PG",
                    "display_name": "Paul Draper",
                    "link": "https://stackoverflow.com/users/1212596/paul-draper"
                },
                "reply_to_user": {
                    "account_id": 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": 1614739931,
                "post_id": 66428658,
                "comment_id": 117475118,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1614643532,
                "creation_date": 1614643532,
                "answer_id": 66431451,
                "question_id": 66428658,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not sure whether that&#39;s a good solution at all but there you go:\r\n\r\nFrom:\r\n\r\n```\r\n[0, 1, 3]\r\n```\r\n\r\nTo:\r\n\r\n```\r\n[0, 1, 2, 3]\r\n```\r\n\r\nWith:\r\n\r\n```\r\njq &#39;[.[0:2][], 2, .[2:][]]&#39; input.json\r\n//   ^         ^  ^\r\n//   A         B  C\r\n```\r\n\r\n- A: 1st filter: all the items _before_ the new item\r\n- B: 2nd filter: your new item\r\n- C: 3rd filter: all items _after_ the new item",
                "title": "How to insert element into array with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1614654547,
                "creation_date": 1614654547,
                "answer_id": 66432747,
                "question_id": 66428658,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here are two defs for inserting an item into an array:\r\n```\r\n# Insert $x into the input array, such that after insertion,\r\n# if $i is in range(0;length+1), then .[$i] == $x\r\ndef insert($i; $x): .[:$i] + [$x] + .[$i:];\r\n\r\n# Emit the zero-based index of $needle in the stream, s, but if s is empty, emit null:\r\ndef index_of($needle; s):\r\n label $go\r\n | foreach s as $x (-1; .+1; select($x==$needle) | (., break $go)) // null;\r\n\r\n# Insert $x after the first occurrence of $needle in the input array,\r\n# but if $needle is not present, then append $x:\r\ndef insert_after($needle; $x):\r\n index_of($needle; .[]) as $ix\r\n | if $ix then insert($ix + 1; $x) else . + [$x] end;\r\n```\r\n",
                "title": "How to insert element into array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1615006949,
        "creation_date": 1614628016,
        "last_edit_date": 1615006949,
        "question_id": 66428658,
        "body_markdown": "I have JSON\r\n\r\n```json\r\n[\r\n  {&quot;id&quot;: &quot;1&quot;},\r\n  {&quot;id&quot;: &quot;5&quot;},\r\n  {&quot;id&quot;: &quot;9&quot;},\r\n  {&quot;id&quot;: &quot;0&quot;},\r\n  {&quot;id&quot;: &quot;3&quot;}\r\n]\r\n```\r\n\r\nI want to insert an object to produce:\r\n\r\n```json\r\n[\r\n  {&quot;id&quot;: &quot;1&quot;},\r\n  {&quot;id&quot;: &quot;5&quot;},\r\n  {&quot;id&quot;: &quot;2&quot;},\r\n  {&quot;id&quot;: &quot;9&quot;},\r\n  {&quot;id&quot;: &quot;0&quot;},\r\n  {&quot;id&quot;: &quot;3&quot;}\r\n]\r\n```\r\n\r\nHow do I do this jq? Either by index or relative to other objects.\r\n\r\nEDIT: This is not a duplicate of https://stackoverflow.com/questions/42245288/add-new-element-to-existing-json-array-with-jq , which is about appending/prepending elements to arrays. As stated, I want to insert an element.",
        "link": "https://stackoverflow.com/questions/66428658/how-to-insert-element-into-array-with-jq",
        "title": "How to insert element into array with jq"
    },
    {
        "tags": [
            "linux",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1614657534,
                "last_edit_date": 1614657534,
                "creation_date": 1614655541,
                "answer_id": 66432870,
                "question_id": 66432229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "bash does not allow colons in variable names, so you will probably want to pass in the values using jq&#39;s `--arg` and/or `--argjson` command-line options, e.g. along the lines of:\r\n\r\n```\r\njq -n --arg Security_ClientId 123456 \\\r\n      --arg Security_clientSecret abcdefg \\\r\n      --arg AppSettings_Environment Dev &#39;\r\n{\r\n  &quot;AppSettings&quot;: {\r\n    &quot;Environment&quot;: $AppSettings_Environment\r\n  },\r\n  &quot;Security&quot;: {\r\n    &quot;ClientId&quot;: $Security_ClientId,\r\n    &quot;ClientSecret&quot;: $Security_clientSecret\r\n  }\r\n}\r\n&#39;\r\n```\r\n\r\nNote that the entire jq program could be put into a file, say config.jq, so the invocation would look like:\r\n\r\n```\r\njq -n --arg Security_ClientId 123456 \\\r\n      --arg Security_clientSecret abcdefg \\\r\n      --arg AppSettings_Environment Dev -f config.jq\r\n```\r\n\r\n### Using shell environment variables\r\n```\r\nSecurity_ClientId=123456\r\nSecurity_clientSecret=abcdefg\r\nAppSettings_Environment=Dev\r\n\r\n\r\njq -n &#39; {\r\n  &quot;AppSettings&quot;: {\r\n    &quot;Environment&quot;: env.AppSettings_Environment\r\n  },\r\n  &quot;Security&quot;: {\r\n    &quot;ClientId&quot;: env.Security_ClientId,\r\n    &quot;ClientSecret&quot;: env.Security_clientSecret\r\n  }\r\n}\r\n&#39;\r\n```",
                "title": "Convert environment variables into a json file"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1614676650,
                "creation_date": 1614676650,
                "answer_id": 66436501,
                "question_id": 66432229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following assumes the &quot;environment variable&quot; names and values could be made available as variable=value strings:\r\n\r\n```\r\nfunction data {\r\ncat &lt;&lt;EOF\r\nSecurity:ClientId=123456\r\nSecurity:clientSecret=abcdefg\r\nAppSettings:Environment=Dev\r\nEOF\r\n}\r\n\r\ndata | jq -nR &#39;\r\n\r\ndef parse: capture(&quot;(?&lt;x&gt;[^:]*):(?&lt;y&gt;[^=]*)=(?&lt;value&gt;.*)&quot;);\r\n\r\nreduce inputs as $line ({};\r\n   ($line | parse) as $p\r\n   | .[$p.x][$p.y] = ($p.value) )\r\n&#39;\r\n```\r\n### Output\r\nAs shown in the Q.\r\n ",
                "title": "Convert environment variables into a json file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1614676650,
        "creation_date": 1614650583,
        "question_id": 66432229,
        "body_markdown": "I am trying to find a way to feed configuration settings into my SPA application that is running in a container.\r\n\r\nMy current plan is to pass in the configuration as environment variables.  Then on container startup, generate a json file from those environment variables to pass to the browser (along with the SPA app).\r\n\r\nI am planning to format my environment variables like this:\r\n\r\n&lt;pre&gt;\r\nEnv Variable Name:  Security:ClientId \r\nEnv Variable Value: 123456\r\n\r\nEnv Variable Name:  Security:clientSecret\r\nEnv Variable Value: abcdefg\r\n\r\nEnv Variable Name:  AppSettings:Environment\r\nEnv Variable Value: Dev\r\n&lt;/pre&gt;\r\n\r\nThat will convert into:\r\n\r\n\r\n    {\r\n      &quot;AppSettings&quot;: {\r\n        &quot;Environment&quot;: &quot;Dev&quot;,\r\n      },\r\n      &quot;Security&quot;: {\r\n        &quot;ClientId&quot;: &quot;123456&quot;,\r\n        &quot;ClientSecret&quot;: &quot;abcdefg&quot;\r\n      }\r\n    }\r\n\r\nI am fairly inexperienced at shell scripting, but this has to be done in a shell script so it can run in a Linux container.\r\n\r\nI have read of `jq`, and it seems to be the way to interact with Json files in a shell script.  But they all seem to want you to start with an existing json file that you will be transforming to a different json file.\r\n\r\n**How do I create a new json file from a list of key value pairs, with sub sections and using `jq` (or something else in a shell script)?**",
        "link": "https://stackoverflow.com/questions/66432229/convert-environment-variables-into-a-json-file",
        "title": "Convert environment variables into a json file"
    },
    {
        "tags": [
            "json",
            "command-line-interface",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 419090,
                    "reputation": 1310,
                    "user_id": 796064,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/5aD9w.jpg?s=256",
                    "display_name": "drobert",
                    "link": "https://stackoverflow.com/users/796064/drobert"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1614702836,
                "post_id": 66443228,
                "comment_id": 117463294,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1614703052,
                "creation_date": 1614703052,
                "answer_id": 66443433,
                "question_id": 66443228,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This did it:\r\n\r\n&gt; jq -n &#39;[inputs] | add&#39; $(find . -name &#39;*.json&#39;) &gt; combined.json ",
                "title": "jq combine json files into single array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1614715121,
                "creation_date": 1614715121,
                "answer_id": 66446281,
                "question_id": 66443228,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following illustrates an efficient way to accomplish the required task:\r\n```\r\njq -n &#39;reduce inputs as $in (null;\r\n   . + if $in|type == &quot;array&quot; then $in else [$in] end)\r\n&#39; $(find . -name &#39;*.json&#39;) &gt; combined.json\r\n```\r\n\r\nThe -n command-line option is necessary to avoid skipping the first file.",
                "title": "jq combine json files into single array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1614715121,
        "creation_date": 1614702365,
        "question_id": 66443228,
        "body_markdown": "I have several json files I want to combine. Some are arrays of objects and some are single objects. I want to effectively concatenate all of this into a single array.\r\n\r\nFor example:\r\n\r\n```json\r\n[\r\n  { &quot;name&quot;: &quot;file1&quot; }\r\n]\r\n```\r\n\r\n```json\r\n{ &quot;name&quot;: &quot;file2&quot; }\r\n```\r\n\r\n```json\r\n{ &quot;name&quot;: &quot;file3&quot; }\r\n```\r\n\r\nAnd I want to end up with:\r\n\r\n```json\r\n[\r\n  { &quot;name&quot;: &quot;file1&quot; }\r\n  { &quot;name&quot;: &quot;file2&quot; },\r\n  { &quot;name&quot;: &quot;file3&quot; },\r\n]\r\n```\r\n\r\nHow can I do this using `jq` or similar?",
        "link": "https://stackoverflow.com/questions/66443228/jq-combine-json-files-into-single-array",
        "title": "jq combine json files into single array"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1614742558,
                "creation_date": 1614742558,
                "answer_id": 66450397,
                "question_id": 66449460,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should do it:\r\n\r\n```\r\ndef parse: capture(&quot;(?&lt;x&gt;[^:=]*)(:(?&lt;y&gt;[^:=]*))?=(?&lt;value&gt;.*)&quot;);\r\n\r\nreduce inputs as $line ({};\r\n   ($line | parse) as $p\r\n   | if $p.y then .[$p.x][$p.y] = $p.value\r\n     else .[$p.x] = $p.value end )\r\n```\r\nOf course this could be further robustified...",
                "title": "Optional element in &quot;reduce inputs&quot; clause"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1614742558,
        "creation_date": 1614735001,
        "last_edit_date": 1614736804,
        "question_id": 66449460,
        "body_markdown": "I am working on this [excellent answer][1] that I got from an earlier question.\r\n\r\nHere is what I currently have:\r\n\r\n\tfunction data {\r\n\tcat &lt;&lt;EOF\r\n\tSecurity:ClientId=123456\r\n\tSecurity:ClientSecret=abcdefg\r\n\tAppSettings:Environment=Dev\r\n\tAnotherCustomSetting=SomethingElse\r\n\tEOF\r\n\t}\r\n\r\n\tdata | jq -nR &#39;\r\n\r\n\tdef parse: capture(&quot;(?:(?&lt;group&gt;[^:=]*):)?(?&lt;property&gt;[^=]*)=(?&lt;value&gt;.*)&quot;);\r\n\r\n\treduce inputs as $line ({};\r\n\t   ($line | parse) as $envVar\r\n\t   | if .[$envVar.group] != null then .[$envVar.group][$envVar.property] = ($envVar.value) else .[$envVar.property] = ($envVar.value) end)\r\n\t&#39;\r\n\r\nMy end goal is to have a Json file like this:\r\n\r\n    {\r\n      &quot;Security&quot;: {\r\n        &quot;ClientId&quot;: &quot;123456&quot;,\r\n        &quot;ClientSecret&quot;: &quot;abcdefg&quot;\r\n      },\r\n      &quot;AppSettings&quot;: {\r\n        &quot;Environment&quot;: &quot;Dev&quot;\r\n      },\r\n      &quot;AnotherCustomSetting&quot;: &quot;SomethingElse&quot;      \r\n    }\r\n\r\nIn my previous question I did not indicate that I would need properties at the root level (`AnotherCustomSetting` in this case).  \r\n\r\nTo try to get root level properties working, I modified the RegEx to have an optional group, but the original answer&#39;s `reduce inputs` did not anticipate the `group` being null (and failed with a null error when it was).  So I attempted to put an `if` statement in the `reduce inputs` section.  Unfortunately it is failing with the following error:\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:4): Cannot index object with null\r\n\r\nIs it possible to do an `if then else` in a `reduce inputs` section like I am attempting?  If so, how is it done?\r\n\r\n  [1]: https://stackoverflow.com/a/66436501/16241",
        "link": "https://stackoverflow.com/questions/66449460/optional-element-in-reduce-inputs-clause",
        "title": "Optional element in &quot;reduce inputs&quot; clause"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq",
            "substitution"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614737397,
                "post_id": 66449754,
                "comment_id": 117474603,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14797711,
                    "reputation": 65,
                    "user_id": 10686923,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-GfD8MlybAnE/AAAAAAAAAAI/AAAAAAAAAAA/AGDgw-hio0xZl6sPAvQ4WcTSt9R14tKB9Q/mo/s256-rj/photo.jpg",
                    "display_name": "karan",
                    "link": "https://stackoverflow.com/users/10686923/karan"
                },
                "reply_to_user": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1614737902,
                "post_id": 66449754,
                "comment_id": 117474702,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1614743725,
                "last_edit_date": 1614743725,
                "creation_date": 1614740613,
                "answer_id": 66450178,
                "question_id": 66449754,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From the comments, it would appear you should be using `map_values` and perhaps something like `sub`. Consider therefore this example:\r\n```\r\necho &#39;{&quot;bucketname&quot;:&quot;test/$accountid/123&quot;,&quot;objectname&quot;:&quot;test/$accountid/123&quot;,&quot;targetlocation&quot;:&quot;$TARGET_LOCATION&quot;}&#39; |\r\n jq &#39;map_values( sub(&quot;[$]accountid&quot;;&quot;123&quot;) )&#39;\r\n```\r\n\r\nproduces:\r\n```\r\n{\r\n  &quot;bucketname&quot;: &quot;test/123/123&quot;,\r\n  &quot;objectname&quot;: &quot;test/123/123&quot;,\r\n  &quot;targetlocation&quot;: &quot;$TARGET_LOCATION&quot;\r\n}\r\n```\r\n\r\n## Sharpening\r\n\r\nYou might want to sharpen the criteria for substituion, e.g.\r\n\r\n    sub(&quot;[$]accountid(?&lt;tail&gt;(/|$))&quot;; &quot;123\\(.tail)&quot; ) ",
                "title": "update part of a value of a json object using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1614743725,
        "creation_date": 1614737239,
        "last_edit_date": 1614743222,
        "question_id": 66449754,
        "body_markdown": "Have a value inside a JSON object with a variable that needs to be updated using JQ, below is my son file and jq command I&#39;m using to update **accountid** in json file\r\n```\r\n{&quot;bucketname&quot;:&quot;test/$accountid/123&quot;,&quot;objectname&quot;:&quot;test/$accountid/123&quot;,&quot;targetlocation&quot;:&quot;$TARGET_LOCATION&quot;}\r\n```\r\n**JQ Command**\r\n```\r\njq &#39;map(.$accountid = &quot;123&quot;)&#39; myjson.json\r\n```\r\n**Error**\r\n```\r\njq: error (at myjson.json:1): Cannot index string with string &quot;$accountid&quot;\r\n```\r\nI&#39;m I missing something here?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66449754/update-part-of-a-value-of-a-json-object-using-jq",
        "title": "update part of a value of a json object using JQ"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "shell",
            "jq",
            "ecs-taskdefinition"
        ],
        "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": 1614742655,
                "post_id": 66450137,
                "comment_id": 117475612,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1614746347,
                "creation_date": 1614746347,
                "answer_id": 66450885,
                "question_id": 66450137,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not sure if the use of `jq` is required or not, but you can simplly use `sed` to do the replacement:\r\n\r\n\r\n```\r\nregion=&quot;us-east-1&quot;\r\naccount_id=&quot;12345&quot;\r\n\r\nsed &quot;s/region/${region}/g; s/aws_account_id/${account_id}/g&quot; /path/to/taskdef.json\r\n```\r\n\r\nif you want to **permanently** change the  values in the input file, add `-i`:\r\n\r\n```\r\nsed -i &quot;s/region/${region}/g; s/aws_account_id/${account_id}/g&quot; /path/to/taskdef.json\r\n``` ",
                "title": "Dynamically update a key value inside ecs taskdef.json using shell script"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1614746347,
        "creation_date": 1614740238,
        "question_id": 66450137,
        "body_markdown": "Below is my taskdef.json and want to update few values dynamically using shell script, I&#39;m trying to use JQ but doesn&#39;t seem to work as expected.\r\n```\r\n{\r\n    &quot;containerDefinitions&quot;: [{\r\n      &quot;logConfiguration&quot;: [{\r\n        &quot;logDriver&quot;: &quot;fluentd&quot;,\r\n        &quot;options&quot;: {\r\n          &quot;tag&quot;: &quot;fluentd demo&quot;\r\n        },\r\n        &quot;secretOptions&quot;: [{\r\n          &quot;name&quot;: &quot;fluentd-address&quot;,\r\n          &quot;valueFrom&quot;: &quot;arn:aws:ssm:region:aws_account_id:parameter:parameter_name&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;fluentd-name&quot;,\r\n          &quot;valueFrom&quot;: &quot;arn:aws:ssm:region:aws_account_id:parameter:parameter_name&quot;\r\n        }\r\n    ]\r\n      }]\r\n    }]\r\n  }\r\n```\r\nI want the region and aws_account_id to be updated dynamically instead of hardcoding the value directly inside the taskdef.json.Is there a way to update these value?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66450137/dynamically-update-a-key-value-inside-ecs-taskdef-json-using-shell-script",
        "title": "Dynamically update a key value inside ecs taskdef.json using shell script"
    },
    {
        "tags": [
            "jq",
            "exit-code",
            "exitstatus"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1614836499,
                "last_edit_date": 1614836499,
                "creation_date": 1614835434,
                "answer_id": 66469060,
                "question_id": 66468950,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should use `input` with `-n`/`--null-input` on the command line. This way JQ will fail if its input is empty. \r\n```\r\n$ echo | jq -n &#39;input.key&#39;\r\njq: error (at &lt;stdin&gt;:1): break\r\n$ echo $?\r\n5\r\n```\r\n```\r\n$ jq -n &#39;{key: 1}&#39; | jq -n &#39;input.key&#39;\r\n1\r\n$ echo $?\r\n0\r\n```",
                "title": "Exit with non-zero if input is empty"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1614840658,
                "creation_date": 1614840658,
                "answer_id": 66469960,
                "question_id": 66468950,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to specify the return code when the input is empty, you could use `halt_error/1`, like so:\r\n\r\n    $ echo &quot;&quot; | jq -n &#39;try input.key catch halt_error(9)&#39; 2&gt; /dev/null\r\n    $ echo $?\r\n    9",
                "title": "Exit with non-zero if input is empty"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1614876250,
        "creation_date": 1614834756,
        "last_edit_date": 1614876250,
        "question_id": 66468950,
        "body_markdown": "I am trying to parse my curl output with JQ and check the exit code, so when my curl output is empty, JQ return 0 exit code.\r\n\r\nFor example: \r\n```\r\n$ echo &quot;&quot; | jq &#39;.key&#39;\r\n$ echo $?\r\n0\r\n```\r\nHow to make this return 1 or some non-zero value?",
        "link": "https://stackoverflow.com/questions/66468950/exit-with-non-zero-if-input-is-empty",
        "title": "Exit with non-zero if input is empty"
    },
    {
        "tags": [
            "bash",
            "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": 1614850282,
                "post_id": 66471564,
                "comment_id": 117512769,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8908,
                    "reputation": 83000,
                    "user_id": 16241,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://www.gravatar.com/avatar/de3fa0861da7fd9ae3abc120ff6d957f?s=256&d=identicon&r=PG",
                    "display_name": "Vaccano",
                    "link": "https://stackoverflow.com/users/16241/vaccano"
                },
                "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": 1614874090,
                "post_id": 66471564,
                "comment_id": 117524359,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1614911078,
                "post_id": 66471564,
                "comment_id": 117536300,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1614848813,
                "creation_date": 1614848813,
                "answer_id": 66471806,
                "question_id": 66471564,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try it like this:\r\n\r\n    printf &#39;appConfig = JSON.parse(`%s`);&#39; &quot;$(\r\n    data | jq -nR &#39;\r\n    \r\n    def parse: capture(&quot;(?&lt;x&gt;[^:=]*)(:(?&lt;y&gt;[^:=]*))?=(?&lt;value&gt;.*)&quot;);\r\n    \r\n    reduce inputs as $line ({};\r\n       ($line | parse) as $p\r\n       | if $p.y then .[$p.x][$p.y] = $p.value\r\n         else .[$p.x] = $p.value end )\r\n    &#39;)&quot;\r\n\r\nTo store in var\r\n\r\n    printf -v var &#39;appConfig = JSON.parse(`%s`);&#39; &quot;$(\r\n    data | jq -nR &#39;\r\n    \r\n    def parse: capture(&quot;(?&lt;x&gt;[^:=]*)(:(?&lt;y&gt;[^:=]*))?=(?&lt;value&gt;.*)&quot;);\r\n    \r\n    reduce inputs as $line ({};\r\n       ($line | parse) as $p\r\n       | if $p.y then .[$p.x][$p.y] = $p.value\r\n         else .[$p.x] = $p.value end )\r\n    &#39;)&quot;\r\n    \r\n    $ echo &quot;$var&quot;\r\n    appConfig = JSON.parse(`{\r\n      &quot;Security&quot;: {\r\n        &quot;ClientId&quot;: &quot;123456&quot;,\r\n        &quot;ClientSecret&quot;: &quot;abcdefg&quot;\r\n      },\r\n      &quot;AppSettings&quot;: {\r\n        &quot;Environment&quot;: &quot;Dev&quot;\r\n      },\r\n      &quot;AnotherCustomSetting&quot;: &quot;SomethingElse&quot;\r\n    }`);",
                "title": "Prepend text to jq output"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1614849146,
                "creation_date": 1614849146,
                "answer_id": 66471896,
                "question_id": 66471564,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can append a `sed` to your pipeline:\r\n\r\n```\r\nsed &#39;1s@^@JSON.parse(`@; $s@$@`);@&#39;\r\n```\r\n\r\nIt&#39;s composed by two substitutions:\r\n\r\n- `1s@^@...@`: prepend to the first line\r\n- `$s@$@...@`: append to the last line",
                "title": "Prepend text to jq output"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1614911529,
                "creation_date": 1614911529,
                "answer_id": 66485918,
                "question_id": 66471564,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One all-jq possibility would be as follows:\r\n\r\n```\r\njq -nRrj &#39;\r\n  def parse: capture(&quot;(?&lt;x&gt;[^:=]*)(:(?&lt;y&gt;[^:=]*))?=(?&lt;value&gt;.*)&quot;);\r\n  reduce inputs as $line ({};\r\n    ($line | parse) as $p\r\n    | if $p.y then .[$p.x][$p.y] = $p.value\r\n      else .[$p.x] = $p.value end )\r\n  | &quot;appConfig = JSON.parse(`&quot;, ., &quot;`);&quot;\r\n&#39;\r\n```\r\nWith the sample input, this produces:\r\n```\r\nappConfig = JSON.parse(`{\r\n  &quot;Security&quot;: {\r\n    &quot;ClientId&quot;: &quot;123456&quot;,\r\n    &quot;ClientSecret&quot;: &quot;abcdefg&quot;\r\n  },\r\n  &quot;AppSettings&quot;: {\r\n    &quot;Environment&quot;: &quot;Dev&quot;\r\n  },\r\n  &quot;AnotherCustomSetting&quot;: &quot;SomethingElse&quot;\r\n}`);\r\n```",
                "title": "Prepend text to jq output"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1614911529,
        "creation_date": 1614847870,
        "question_id": 66471564,
        "body_markdown": "I have the following script (from this [answer][1])\r\n\r\n\tdata() {\r\n\tcat &lt;&lt;EOF\r\n\tSecurity:ClientId=123456\r\n\tSecurity:ClientSecret=abcdefg\r\n\tAppSettings:Environment=Dev\r\n\tAnotherCustomSetting=SomethingElse\r\n\tEOF\r\n\t}\r\n\r\n\tdata | jq -nR &#39;\r\n\r\n\tdef parse: capture(&quot;(?&lt;x&gt;[^:=]*)(:(?&lt;y&gt;[^:=]*))?=(?&lt;value&gt;.*)&quot;);\r\n\r\n\treduce inputs as $line ({};\r\n\t   ($line | parse) as $p\r\n\t   | if $p.y then .[$p.x][$p.y] = $p.value\r\n\t\t else .[$p.x] = $p.value end )\r\n\t&#39;\r\nIt works fantastically, and outputs this json:\r\n\r\n    {\r\n      &quot;Security&quot;: {\r\n        &quot;ClientId&quot;: &quot;123456&quot;,\r\n        &quot;ClientSecret&quot;: &quot;abcdefg&quot;\r\n      },\r\n      &quot;AppSettings&quot;: {\r\n        &quot;Environment&quot;: &quot;Dev&quot;\r\n      },\r\n      &quot;AnotherCustomSetting&quot;: &quot;SomethingElse&quot;\r\n    }\r\n\r\nI am struggling to prepend and postpend some text to this output.  I need to prepend \r\n\r\n    appConfig = JSON.parse(`\r\n\r\nand postpend \r\n\r\n    `);\r\n\r\nSo the final output would look like:\r\n\r\n    appConfig = JSON.parse(`{\r\n      &quot;Security&quot;: {\r\n        &quot;ClientId&quot;: &quot;123456&quot;,\r\n        &quot;ClientSecret&quot;: &quot;abcdefg&quot;\r\n      },\r\n      &quot;AppSettings&quot;: {\r\n        &quot;Environment&quot;: &quot;Dev&quot;\r\n      },\r\n      &quot;AnotherCustomSetting&quot;: &quot;SomethingElse&quot;\r\n    }`);\r\n\r\nI tried to do this by adding the following to the script:\r\n\r\n     | xargs printf &#39;appConfig = JSON.parse(`%s`);`\r\n\r\nbut it either printed nothing, or (with some fiddling) printed my prepend and postpend text on each line of json (instead of just adding to the front and end of the whole json).\r\n\r\n**How can I prepend and postpend text to this output?**\r\n\r\n  [1]: https://stackoverflow.com/a/66450397/16241",
        "link": "https://stackoverflow.com/questions/66471564/prepend-text-to-jq-output",
        "title": "Prepend text to jq output"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1615056259,
                "creation_date": 1615056259,
                "answer_id": 66509389,
                "question_id": 66509004,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This seemed to work ```jq -s &#39;.[0] * .[1]&#39; File1 File2```",
                "title": "Merging Two Json Files using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1615056311,
        "creation_date": 1615053967,
        "last_edit_date": 1615056311,
        "question_id": 66509004,
        "body_markdown": "I have two json files that I would like to merge using jq in order to pass to AWS Lambda as a payload. \r\n\r\nFile 1\r\n```\r\n {\r\n    &quot;Product&quot;: {\r\n      &quot;name&quot;: &quot;Foo&quot;\r\n      &quot;description&quot;: &quot;bar&quot;,\r\n     }\r\n}\r\n```\r\n\r\nFile 2\r\n```\r\n {\r\n    &quot;Store&quot;: {\r\n      &quot;id&quot;: &quot;123&quot;\r\n      &quot;location&quot;: &quot;abc&quot;,\r\n     }\r\n}\r\n```\r\n\r\nMy desired output: \r\n```\r\n {\r\n    &quot;Product&quot;: {\r\n      &quot;name&quot;: &quot;Foo&quot;\r\n      &quot;description&quot;: &quot;bar&quot;,\r\n     },\r\n    &quot;Store&quot;: {\r\n      &quot;id&quot;: &quot;123&quot;\r\n      &quot;location&quot;: &quot;abc&quot;,\r\n     }\r\n}\r\n```\r\n\r\nI know I can do ```jq -s . File1 File2```, but this puts it into an array - is there a way to do this merge without putting the two files into an array? ",
        "link": "https://stackoverflow.com/questions/66509004/merging-two-json-files-using-jq",
        "title": "Merging Two Json Files using JQ"
    },
    {
        "tags": [
            "azure-devops",
            "azure-pipelines",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1615149891,
                "creation_date": 1615149891,
                "answer_id": 66521227,
                "question_id": 66515843,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If `.lighthouseResult.categories.performance.score` does indeed contain a single space, then you could remove it by using this jq program:\r\n\r\n    .lighthouseResult.categories.performance.score | sub(&quot; &quot;;&quot;&quot;) \r\n\r\nTo remove all spaces, change `sub` to `gsub`.\r\n\r\nOne wonders, though, where does the &quot;special character&quot; come from?  To remove unwanted characters, you might wish to consider a filter such as:\r\n\r\n     gsub(&quot;[^A-Za-z0-9.]&quot;;&quot;&quot;) \r\n\r\n  ",
                "title": "Removing Spaces of jq command output when reading values from json file"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1615149891,
        "creation_date": 1615115507,
        "last_edit_date": 1615118502,
        "question_id": 66515843,
        "body_markdown": "Working on Azure DevOps pipeline to generate performance reports of the user provided url&#39;s (parameter value while they trigger pipeline - inputs urls) using google page speed API, saving the output to json file and using jq to get the values from the json file and saving it to a CSV file. Below is my setup in yml file.\r\n\r\n\r\n\r\n    - task: Bash@3\r\n      condition: eq(&#39;${{ parameters.TestOnMobileDevice }}&#39;, true)\r\n\r\n      displayName: WebPage_API\r\n\r\n      inputs:\r\n        targetType: &#39;inline&#39;\r\n\r\n        script: |\r\n          touch web-URL.csv\r\n          chmod 660 web-URL.csv\r\n\r\n          echo &quot;\r\n          Website URL,Time Stamp,Mobile Overall Score,Desktop Overall Score&quot; &gt; web-URL.csv\r\n\r\n          IFS=&#39; &#39; read -r -a url &lt;&lt;&lt; &quot;${{ parameters.webPages }}&quot;\r\n          #echo &quot;${url[0]}&quot;\r\n          for webPages in &quot;${url[@]}&quot;\r\n          do\r\n\r\n               curl -s &quot;https://www.googleapis.com/pagespeedonline/v5/runPagespeed?url={$webPages}&amp;key=*****&quot; -o web.json\r\n\r\n               curl -s &quot;https://www.googleapis.com/pagespeedonline/v5/runPagespeed?url={$webPages}&amp;strategy=mobile&amp;key=******&quot; -o mobile.json\r\n\r\n               printf &quot;\\n&quot;\r\n               MobileOverallScore=$(jq .lighthouseResult.categories.performance.score mobile.json)\r\n\r\n               DesktopOverallScore=$(jq .lighthouseResult.categories.performance.score web.json)\r\n\r\n                echo &quot;\r\n\r\n               &quot;$webPages&quot;,&quot;$(TimeStamp)&quot;,&quot;$MobileOverallScore&quot;,&quot;$DesktopOverallScore&quot;&quot; &gt;&gt; web-URL.csv\r\n\r\n           done\r\n\r\n\r\n\r\nEverything is working fine, but for example the output of\r\n\r\n &quot;jq .lighthouseResult.categories.performance.score web.json&quot; is &quot;2.8  s&quot; and when I see the same value in CSV, I see a special character due the space in between 2.8 and s.\r\n\r\n[![CSV][1]][1]\r\n\r\nHow do I publish the value to csv without any spaces ??\r\n\r\n\r\n  [1]: https://i.sstatic.net/KErxr.png",
        "link": "https://stackoverflow.com/questions/66515843/removing-spaces-of-jq-command-output-when-reading-values-from-json-file",
        "title": "Removing Spaces of jq command output when reading values from json file"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "jsonschema"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17598203,
                    "reputation": 639,
                    "user_id": 12768731,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/uucN0.png?s=256",
                    "display_name": "644",
                    "link": "https://stackoverflow.com/users/12768731/644"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615218890,
                "post_id": 66532654,
                "comment_id": 117617147,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 346626,
                    "reputation": 10386,
                    "user_id": 680268,
                    "user_type": "registered",
                    "accept_rate": 66,
                    "profile_image": "https://www.gravatar.com/avatar/4694129cb36beeeeab3615b21e947708?s=256&d=identicon&r=PG",
                    "display_name": "Stealth Rabbi",
                    "link": "https://stackoverflow.com/users/680268/stealth-rabbi"
                },
                "reply_to_user": {
                    "account_id": 17598203,
                    "reputation": 639,
                    "user_id": 12768731,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/uucN0.png?s=256",
                    "display_name": "644",
                    "link": "https://stackoverflow.com/users/12768731/644"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615219395,
                "post_id": 66532654,
                "comment_id": 117617414,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1615223134,
                "last_edit_date": 1615223134,
                "creation_date": 1615220283,
                "answer_id": 66533382,
                "question_id": 66532654,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I&#39;m understanding you correctly, you want to read all $ref objects into an array in bash\r\n\r\nSo to get the list of $ref&#39;s\r\n\r\n    jq -r &#39;.properties[] | select(.&quot;$ref&quot; != null) | .&quot;$ref&quot;&#39; filename\r\n\r\nThen to add them to an array, use mapfile\r\n\r\n    mapfile -t array_name &lt; &lt;(jq -r &#39;.properties[] | select(.&quot;$ref&quot; != null) | .&quot;$ref&quot;&#39; filename)\r\n\r\nThe -t option in mapfile will strip the trailing delimiter from each line read.",
                "title": "Get all $ref values, if any, from a JSON schema"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1615223819,
                "creation_date": 1615223819,
                "answer_id": 66534243,
                "question_id": 66532654,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. One way to be succinct while being sure to retrieve just the values at the `&quot;$ref&quot;` key:\r\n```\r\njq -r &#39;.properties[] | .&quot;$ref&quot; // empty&#39;\r\n```\r\n2. If your shell does not have `mapfile`, then assuming there are no newlines embedded in the &#39;$ref&#39; values, and that you can ignore leading and trailing spaces, you could use a loop along the lines of:\r\n\r\n```\r\nary=()\r\nwhile -r read it ; do\r\n    ary+=(&quot;$it&quot;)\r\ndone &lt; &lt;(jq -r &#39;.properties[] | .&quot;$ref&quot; // empty&#39; filename)\r\n```\r\n\r\nOf course, if you only need to iterate over the &quot;$ref&quot; values, you might not need the shell array at all ....",
                "title": "Get all $ref values, if any, from a JSON schema"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1615272155,
        "creation_date": 1615217676,
        "last_edit_date": 1615272155,
        "question_id": 66532654,
        "body_markdown": "I&#39;m new to jq and json schemas. I&#39;m trying to figure out how to examine a schema and get back all $refs (specifically, their values) in to an array that I can examine in bash. I&#39;m trying to get a list of `$ref`s that are external to the file. Let&#39;s say I have a schema like this, how can I get an array of &quot;Apple.schema.json&quot; and &quot;Banaan.schema.json&quot; (or the entire propery would be fine)?\r\n\r\n\r\nI&#39;m using jq, and I&#39;m struggling with knowing how to get a filter. I can look at properties via `jq &#39;.properties&#39; [file], but beyond that, I&#39;m not sure how to proceed.\r\n\r\n```\r\n{\r\n    &quot;$schema&quot;: &quot;http://json-schema.org/draft-07/schema&quot;,\r\n    &quot;$id&quot;: &quot;MySchema.schema.json&quot;,\r\n    &quot;version&quot;: &quot;1.2.3&quot;,\r\n    &quot;type&quot;: &quot;object&quot;,\r\n    &quot;properties&quot;: {\r\n        &quot;DEFINED_TYPE&quot;: { &quot;type&quot;: &quot;string&quot; },\r\n        &quot;Apple&quot;: {&quot;$ref&quot;: &quot;Apple.schema.json&quot;},\r\n\t\t&quot;Banana&quot;: {&quot;$ref&quot;: &quot;Banana.schema.json&quot;},\r\n\t\t&quot;Chicken&quot;: {\r\n            &quot;$ref&quot;: &quot;#/definitions/Chicken&quot;\r\n        }\r\n\t\t&quot;TIME&quot;: {\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;format&quot;: &quot;date-time&quot;\r\n        }\r\n\t\t\r\n\t}\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/66532654/get-all-ref-values-if-any-from-a-json-schema",
        "title": "Get all $ref values, if any, from a JSON schema"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615247442,
                "post_id": 66538285,
                "comment_id": 117627533,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1131025,
                    "reputation": 23,
                    "user_id": 6112053,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5b534437f95af32a7d89e28c053caf71?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Wicaeed",
                    "link": "https://stackoverflow.com/users/6112053/wicaeed"
                },
                "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": 1615251127,
                "post_id": 66538285,
                "comment_id": 117628303,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1615251591,
                "creation_date": 1615251591,
                "answer_id": 66539334,
                "question_id": 66538285,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think given your particular inputs and your desired result, I don&#39;t think the hashing is necessary. It seems like all you need to do is select the inputs from `dest_sr.json` where it doesn&#39;t match the id in `src_templates.json`, then combine it with the desired values from the template.\r\n\r\n```\r\n$ jq --argfile template src_templates.json &#39;\r\nselect(.Pool_ID != $template.Pool_ID) + ($template|{Template_Name,Template_ID})\r\n&#39; dest_sr.json\r\n```\r\n",
                "title": "How do I merge based on a missing elements with JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1615251591,
        "creation_date": 1615243369,
        "last_edit_date": 1615250874,
        "question_id": 66538285,
        "body_markdown": "I have two JSON files that I am working with: dest_sr.json and src_templates.json\r\n\r\nWhat I would like to is create a new JSON object that combines keys from JSON object #1 (specifically the Template_SR key) and JSON object #2 (the Template_Name and Template_ID keys), but only when a VM-Template cannot be found on Pool_ID that matches on both object #1 and object #2\r\n\r\n\r\nFor the two given JSON objects:\r\ndest_sr.json:\r\n```\r\n{\r\n  &quot;Type&quot;: &quot;pool&quot;,\r\n  &quot;Pool_ID&quot;: &quot;adb58e84&quot;,\r\n  &quot;Template_SR&quot;: &quot;fc820294&quot;\r\n}\r\n{\r\n  &quot;Type&quot;: &quot;pool&quot;,\r\n  &quot;Pool_ID&quot;: &quot;d2dea684&quot;,\r\n  &quot;Template_SR&quot;: &quot;313f2a07&quot;\r\n}\r\n```\r\n\r\nsrc_templates.json:\r\n```\r\n{\r\n  &quot;Type&quot;: &quot;VM-template&quot;,\r\n  &quot;Template_Name&quot;: &quot;CentOS 7 CloudInit V1&quot;,\r\n  &quot;Template_ID&quot;: &quot;9b1833a3&quot;,\r\n  &quot;Pool_ID&quot;: &quot;adb58e84&quot;\r\n}\r\n```\r\n\r\n\r\nI would like to create a new JSON object that looks like this:\r\n```\r\n{\r\n  &quot;Template_ID&quot;,:&quot;9b1833a3&quot;,\r\n  &quot;Template_SR&quot;:&quot;313f2a07&quot;,\r\n  &quot;Template_Name&quot;:&quot;CentOS 7 CloudInit V1&quot;,\r\n}\r\n```\r\n\r\n\r\nUsing Stackoverflow I was able to hack together a hashJoin from examples that looks like this, where it performs a hashJoin on the .Pool_ID attribute to create a new object:\r\n\r\n```\r\n# hashJoin(a1; a2; field) expects a1 and a2 to be arrays of JSON objects\r\n# and that for each of the objects, the field value is a string.\r\n# A relational join is performed on &quot;field&quot;.\r\n\r\ndef hashJoin(a1; a2; field):\r\n  # hash phase:\r\n  (reduce a1[] as $o ({};  . + { ($o | field): $o } )) as $h1\r\n  | (reduce a2[] as $o ({};  . + { ($o | field): $o } )) as $h2\r\n  # join phase:\r\n  | reduce ($h1|keys[]) as $key\r\n      ([]; if $h2|has($key) then . + [ $h1[$key] + $h2[$key] ] else . end) ;\r\n\r\nhashJoin( $file1; $file2; .Pool_ID)[]\r\n```\r\n\r\nWhen I call JQ to perform the hashJoin, I get a new object that looks like this:\r\n```\r\n/tmp $ jq -nc --slurpfile file1 /tmp/dest_sr.json --slurpfile file2 /tmp/src_templates.json -f hashJoinSimple.jq\r\n\r\n{\r\n  &quot;Type&quot;:&quot;VM-template&quot;,\r\n  &quot;Pool_ID&quot;:&quot;adb58e84&quot;,\r\n  &quot;Template_SR&quot;:&quot;fc820294&quot;,\r\n  &quot;Template_Name&quot;:&quot;CentOS 7 CloudInit V1&quot;,\r\n  &quot;Template_ID&quot;:&quot;9b1833a3&quot;\r\n}\r\n\r\n```\r\n\r\nIs there any way I can write my merge so that the object would look like this? \r\n```\r\n{\r\n  &quot;Type&quot;:&quot;VM-template&quot;,\r\n  &quot;Pool_ID&quot;:&quot;d2dea684&quot;,\r\n  &quot;Template_SR&quot;:&quot;fc820294&quot;,\r\n  &quot;Template_Name&quot;:&quot;CentOS 7 CloudInit V1&quot;,\r\n  &quot;Template_ID&quot;:&quot;9b1833a3&quot;\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/66538285/how-do-i-merge-based-on-a-missing-elements-with-jq",
        "title": "How do I merge based on a missing elements with JQ?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1615260650,
                "post_id": 66540184,
                "comment_id": 117630224,
                "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": 1615262003,
                "post_id": 66540184,
                "comment_id": 117630464,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19660822,
                    "reputation": 267,
                    "user_id": 14392284,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-6-H277iXoIE/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnGjKJbGyshngi2LmH-_GGeW9nCJA/s256-rj/photo.jpg",
                    "display_name": "Jimmy Chen",
                    "link": "https://stackoverflow.com/users/14392284/jimmy-chen"
                },
                "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": 1615262423,
                "post_id": 66540184,
                "comment_id": 117630545,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": -1,
                "last_activity_date": 1615273055,
                "last_edit_date": 1615273055,
                "creation_date": 1615264393,
                "answer_id": 66540842,
                "question_id": 66540184,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The requirements are unclear, so here are three approaches that might be (or might be the basis for) solutions:\r\n\r\n### 1. jq+sed\r\n```\r\njq  -M &#39;.person[] | .name + &quot; &quot; + .description&#39; | sed -e &#39;s/^&quot;//&#39; -e &#39;s/&quot;$//&#39;\r\n```\r\n### 2. jq+read+sed\r\n```\r\njq  -M &#39;.person[] | .name + &quot; &quot; + .description&#39;  |\r\n  while IFS=$&#39; &#39; read -r line ; do\r\n    printf &quot;%s\\n&quot; &quot;$line&quot; | sed -e &#39;s/^&quot;//&#39; -e &#39;s/&quot;$//&#39;\r\n    echo &quot;----------------------------------------done---------------------&quot;\r\n  done\r\n```\r\n### 3. jq + (read+sed)^2\r\n```\r\njq -M &#39;.person[] | .name, .description&#39;  |\r\n  threewhile IFS=$&#39; &#39; read -r name ; do\r\n\tname=$(sed -e &#39;s/^&quot;//&#39; -e &#39;s/&quot;$//&#39; &lt;&lt;&lt; $name)\r\n\tread -r description\r\n\tdescription=$(sed -e &#39;s/^&quot;//&#39; -e &#39;s/&quot;$//&#39; &lt;&lt;&lt; $description)\r\n    echo &quot;$name $description&quot; \r\n    echo &quot;----------------------------------------done---------------------&quot;\r\n  done\r\n```\r\n",
                "title": "Using bash and jq and reading in a json file with \\n in the contents"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1615268241,
                "creation_date": 1615268241,
                "answer_id": 66541373,
                "question_id": 66540184,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can actually do this directly in `jq`, by replacing actual newlines (which are represented by `\\n` in JSON strings) with literal `\\` and `n` characters:\r\n\r\n    $ jq -r -M &#39;.person[] | .name + &quot; &quot; + (.description | gsub(&quot;\\n&quot;; &quot;\\\\n&quot;))&#39; file.json\r\n    Alex A really\\nnice kid\r\n    James One mature\\nBoy who\\ndoes his homework\r\n\r\nAnd feeding it into your `while read` loop:\r\n\r\n    $ jq -r -M &#39;.person[] | .name + &quot; &quot; + (.description | gsub(&quot;\\n&quot;; &quot;\\\\n&quot;))&#39; file.json |\r\n    &gt; while IFS=$&#39; &#39; read -r  nameX  descriptionX; do\r\n    &gt; echo &quot;${nameX} ${descriptionX}&quot;\r\n    &gt; echo &quot;----------------------------------------done---------------------&quot;\r\n    &gt; done\r\n    Alex A really\\nnice kid\r\n    ----------------------------------------done---------------------\r\n    James One mature\\nBoy who\\ndoes his homework\r\n    ----------------------------------------done---------------------\r\n\r\n",
                "title": "Using bash and jq and reading in a json file with \\n in the contents"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1615302147,
        "creation_date": 1615258812,
        "last_edit_date": 1615262657,
        "question_id": 66540184,
        "body_markdown": "Need some help with jq and reading in a json file that must have \\n values because I need to import it into something else later. How can I have jq interpret it as a literal \\n instead of the line breaks below....?  Notice my json has a \\n and I want it like that. I don&#39;t want it to treat it as a carriage return like it&#39;s doing in the output\r\n\r\n\r\n\r\nfile.json (note the \\n in the description)\r\n\r\n    {\r\n    &quot;person&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;Alex&quot;,\r\n            &quot;age&quot;: &quot;10&quot;,\r\n            &quot;description&quot;: &quot;A really\\nnice kid&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;James&quot;,\r\n            &quot;age&quot;: &quot;17&quot;,\r\n            &quot;description&quot;: &quot;One mature\\nBoy who\\ndoes his homework&quot;\r\n        }\r\n    ]\r\n}\r\n\r\n\r\nScript:\r\n\r\n    jq -r -M &#39;.person[] | .name + &quot; &quot; + .description&#39; file.json  \\\r\n    | while IFS=$&#39; &#39; read -r  nameX  descriptionX; do\r\n    echo &quot;${nameX} ${descriptionX}&quot;\r\n    echo &quot;----------------------------------------done---------------------&quot;\r\n    done\r\n\r\n\r\n\r\nWrong Output right now it&#39;s doing this:\r\n\r\n    Alex A really\r\n    ----------------------------------------done---------------------\r\n    nice kid\r\n    ----------------------------------------done---------------------\r\n    James One mature\r\n    ----------------------------------------done---------------------\r\n    Boy who\r\n    ----------------------------------------done---------------------\r\n    does his homework\r\n    ----------------------------------------done---------------------\r\n\r\n\r\nIt should look like this, but it looks like the one above. How can I make it look like this.\r\n\r\n    Alex A really\\nnice kid\r\n    ----------------------------------------done---------------------\r\n    James One mature\\nBoy who\\ndoes his homework\r\n    ----------------------------------------done---------------------\r\n",
        "link": "https://stackoverflow.com/questions/66540184/using-bash-and-jq-and-reading-in-a-json-file-with-n-in-the-contents",
        "title": "Using bash and jq and reading in a json file with \\n in the contents"
    },
    {
        "tags": [
            "json",
            "config",
            "jq",
            "ini"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1615379389,
                "creation_date": 1615379389,
                "answer_id": 66564827,
                "question_id": 66564551,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can iterate over the entries in the object with `to_entries`, then format each to a string and use the `-r` (--raw-output) flag, like so:\r\n\r\n```sh\r\n$ cat example.json\r\n{\r\n  &quot;key1&quot;: &quot;value1&quot;,\r\n  &quot;key2&quot;: &quot;value2&quot;,\r\n  &quot;keyn&quot;: &quot;valuen&quot;\r\n}\r\n$ jq -r &#39;to_entries[] | (.key | ascii_upcase) + &quot;=&quot; + .value&#39; &lt; example.json\r\nKEY1=value1\r\nKEY2=value2\r\nKEYN=valuen\r\n```",
                "title": "Convert JSON to simple key=value file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1615379389,
        "creation_date": 1615378364,
        "question_id": 66564551,
        "body_markdown": "I have a JSON file that looks like this:\r\n\r\n    {\r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;,\r\n      ...\r\n      &quot;keyn&quot;: &quot;valuen&quot;\r\n    }\r\n\r\nNo arrays or nested objects, just a simple key-&gt;value map. I want to use `jq` to convert this file to a plain text configuration file of a following format:\r\n\r\n    KEY1=value1\r\n    KEY2=value2\r\n    ...\r\n    KEYn=valuen\r\n\r\n(the keys should be uppercased in the result file). I have searched various `jq` tutorials available on the Net expecting that such an obvious (in my opinion) example would be covered there (at least without uppercasing), but it is not. All tutorials I have found use more complicated examples, like extracting specific values from JSON file, handling arrays or nested structures etc. However, no simple JSON-to-text conversion. `man jq` doesn&#39;t help either, it&#39;s not too clear. Could you help me in obtaining the result I want?\r\n\r\nNote: it must be done with `jq`, not any other tool, because it will be used in a script that has access to `jq`, but no other tool for handling JSON is guaranteed to be present on the system.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66564551/convert-json-to-simple-key-value-file-using-jq",
        "title": "Convert JSON to simple key=value file using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1615400689,
                "post_id": 66570695,
                "comment_id": 117681484,
                "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": 1615400755,
                "post_id": 66570695,
                "comment_id": 117681511,
                "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": 1615400807,
                "post_id": 66570695,
                "comment_id": 117681533,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13872629,
                    "reputation": 133,
                    "user_id": 12458881,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e43abe9b23f01dfa6846a12ecc835bd3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "L. Ouellet",
                    "link": "https://stackoverflow.com/users/12458881/l-ouellet"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615400859,
                "post_id": 66570695,
                "comment_id": 117681554,
                "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": 1615400868,
                "post_id": 66570695,
                "comment_id": 117681559,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 346626,
                    "reputation": 10386,
                    "user_id": 680268,
                    "user_type": "registered",
                    "accept_rate": 66,
                    "profile_image": "https://www.gravatar.com/avatar/4694129cb36beeeeab3615b21e947708?s=256&d=identicon&r=PG",
                    "display_name": "Stealth Rabbi",
                    "link": "https://stackoverflow.com/users/680268/stealth-rabbi"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615401176,
                "post_id": 66570695,
                "comment_id": 117681724,
                "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": 1615401254,
                "post_id": 66570695,
                "comment_id": 117681758,
                "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": 1615401435,
                "post_id": 66570695,
                "comment_id": 117681843,
                "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": 1615401551,
                "post_id": 66570695,
                "comment_id": 117681887,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1615401003,
        "creation_date": 1615400634,
        "question_id": 66570695,
        "body_markdown": "I have a loop where I&#39;m creating a json structure using `jq`. I create individual json structures with the following. \r\n\r\n\r\n \r\n\r\n    jq -n \\\r\n      --arg name $myname \\\r\n      --arg subject $mysubject \\\r\n      --arg version &quot;1&quot; \\\r\n      &#39;{name: $name, subject: $subject, version: $version}&#39;\r\n\r\n\r\n\r\nBut I want to concatenate each structure in to an array, like:\r\n\r\n    [\r\n    \t{\r\n    \t  &quot;name&quot;: &quot;name1&quot;,\r\n    \t  &quot;subject&quot;: &quot;subj1&quot;,\r\n    \t  &quot;version&quot;: &quot;1&quot;\r\n    \t},\r\n    \t{\r\n    \t  &quot;name&quot;: &quot;name2&quot;,\r\n    \t  &quot;subject&quot;: &quot;subj2&quot;,\r\n    \t  &quot;version&quot;: &quot;1&quot;\r\n    \t}\r\n    ]\r\n\r\n\r\n\r\nI&#39;m trying something like this with pipes, but the array doesn&#39;t get populated.\r\n\r\n    $myarray=$myarray jq -n \\\r\n      --arg name $myname \\\r\n      --arg subject $mysubject \\\r\n      --arg version &quot;1&quot; \\\r\n      &#39;{name: $name, subject: $subject, version: $version}&#39;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66570695/appending-json-structures-to-an-array-in-bash",
        "title": "Appending JSON structures to an array in bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1615405101,
                "post_id": 66571645,
                "comment_id": 117683326,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4412853,
                    "reputation": 765,
                    "user_id": 3595231,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/696098c5643657e2de534c56bf80b2a1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3595231",
                    "link": "https://stackoverflow.com/users/3595231/user3595231"
                },
                "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": 1615405290,
                "post_id": 66571645,
                "comment_id": 117683402,
                "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": 1615408010,
                "post_id": 66571645,
                "comment_id": 117684557,
                "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": 1615408118,
                "post_id": 66571645,
                "comment_id": 117684601,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4412853,
                    "reputation": 765,
                    "user_id": 3595231,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/696098c5643657e2de534c56bf80b2a1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3595231",
                    "link": "https://stackoverflow.com/users/3595231/user3595231"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615502835,
                "post_id": 66571645,
                "comment_id": 117718443,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1615407976,
                "last_edit_date": 1615407976,
                "creation_date": 1615407738,
                "answer_id": 66572309,
                "question_id": 66571645,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After some googling and have tried some different options, I have just figured out how to make it work, which is: \r\n\r\n```bash\r\necho &quot;$json&quot; | jq -c &#39;{&quot;count&quot;: .payload.count, &quot;users&quot;: [.payload.results[].id]}&#39;\r\n```\r\n",
                "title": "How can I collect ids from a list of JSON objects into a list?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1615502818,
        "creation_date": 1615404803,
        "last_edit_date": 1615502818,
        "question_id": 66571645,
        "body_markdown": "I want to do some filter with jq command. My input json body is as of such format:  \r\n\r\n        {\r\n          &quot;payload&quot;: {\r\n            &quot;count&quot;: 23,\r\n            &quot;results&quot;: [\r\n              {\r\n                &quot;id&quot;: 2,\r\n                &quot;name&quot;: &quot;bob&quot;\r\n              },\r\n              {\r\n                &quot;id&quot;: 5,\r\n                &quot;name&quot; &quot;John&quot;\r\n              }\r\n           ]\r\n         }\r\n       }\r\n\r\nAnd I want to get the results as such:  \r\n\r\n    {&quot;count&quot;: 23, &quot;users&quot;: [2, 5]} \r\n\r\nwhere all the ids are grouped into an array. How the jq command would look like ?  \r\n\r\nThanks. \r\n\r\nChun \r\n\r\n",
        "link": "https://stackoverflow.com/questions/66571645/how-can-i-collect-ids-from-a-list-of-json-objects-into-a-list",
        "title": "How can I collect ids from a list of JSON objects into a list?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615419426,
                "post_id": 66574180,
                "comment_id": 117688362,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4411402,
                    "reputation": 35,
                    "user_id": 3594235,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/42396287c9482df1633bd1c04ebc47b5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3594235",
                    "link": "https://stackoverflow.com/users/3594235/user3594235"
                },
                "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": 1615421337,
                "post_id": 66574180,
                "comment_id": 117688768,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1615431363,
                "creation_date": 1615431363,
                "answer_id": 66575829,
                "question_id": 66574180,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way:\r\n```\r\n.records[]\r\n| [.title, .login, .uid] + ((.folders[]? // null) | [.shared_folder, .folder])\r\n| @tsv\r\n```",
                "title": "Converting json into csv with jq while only capturing specific keys"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1615455139,
                "last_edit_date": 1615455139,
                "creation_date": 1615448122,
                "answer_id": 66578162,
                "question_id": 66574180,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You an error in your JSON, [you must add a `,`][1].\r\n\r\nOnce done, the command is [this][2]\r\n\r\n```\r\njq --raw-output &#39;.records[] | [.title, .login, .uid, .folders[0].shared_folder,.folders[0].folder] |@tsv&#39;\r\n```\r\n\r\n\r\n  [1]: https://gist.github.com/aborruso/6db52150565970db10f3f6281fee16a2/revisions\r\n  [2]: https://jqplay.org/s/SHf_cgKAyr",
                "title": "Converting json into csv with jq while only capturing specific keys"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1615455139,
        "creation_date": 1615417657,
        "last_edit_date": 1615422261,
        "question_id": 66574180,
        "body_markdown": "This is my first post so apologies if I make mistakes. Consider I have the following json output\r\n\r\n    {\r\n      &quot;records&quot;: [\r\n        {\r\n          &quot;title&quot;: &quot;root logon&quot;,\r\n          &quot;login&quot;: &quot;61819009&quot;,\r\n    \t  &quot;uid&quot;: &quot;ajsd879asdjksasda123asd1asd1&quot;,\r\n          &quot;password&quot;: &quot;OizfD19jC$ySaV$MKpSF&quot;,\r\n          &quot;login_url&quot;: &quot;http://192.168.0.1/&quot;,\r\n          &quot;notes&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;title&quot;: &quot;important admin account&quot;,\r\n          &quot;login&quot;: &quot;admin&quot;,\r\n    \t  &quot;uid&quot;: &quot;asdjhkasdh89eoajdiuas98ue9aoi&quot;,\r\n          &quot;password&quot;: &quot;0z5gDUC#Rb354TlLq$KJ&quot;,\r\n          &quot;login_url&quot;: &quot;&quot;,\r\n          &quot;notes&quot;: &quot;&quot;,\r\n          &quot;folders&quot;: [\r\n            {\r\n              &quot;shared_folder&quot;: &quot;Department&quot;,\r\n              &quot;folder&quot;: &quot;Important&quot;,\r\n              &quot;option1&quot;: false,\r\n              &quot;option2&quot;: false\r\n            }\r\n          ]\r\n        }\r\n    \t{\r\n          &quot;title&quot;: &quot;another important admin&quot;,\r\n          &quot;login&quot;: &quot;admin@domain.com&quot;,\r\n    \t  &quot;uid&quot;: &quot;asjhe98asiajsijeouiaueiaiu&quot;,\r\n          &quot;password&quot;: &quot;3pUs@uXEqsxCv7PRkDlJ&quot;,\r\n          &quot;login_url&quot;: &quot;http://192.168.0.2/&quot;,\r\n          &quot;notes&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;title&quot;: &quot;switch admin&quot;,\r\n          &quot;login&quot;: &quot;admin&quot;,\r\n    \t  &quot;uid&quot;: &quot;asjhe89ausiodjakljskea90ik&quot;,\r\n          &quot;password&quot;: &quot;hMB!eMsAE8q4aDQuM4LY&quot;,\r\n          &quot;login_url&quot;: &quot;&quot;,\r\n          &quot;notes&quot;: &quot;&quot;,\r\n          &quot;folders&quot;: [\r\n            {\r\n              &quot;shared_folder&quot;: &quot;Department2&quot;,\r\n              &quot;folder&quot;: &quot;network\\\\switches&quot;,\r\n              &quot;option1&quot;: false,\r\n              &quot;option2&quot;: false\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nfrom the list above, I would like to only export title, login, uid, shared folder, and folder fields to csv file. When I run the following command\r\n\r\n    jq --raw-output &#39;.records[] | [.title, .login, .uid, .shared_folder, .folder] | @ tsv &gt; file \r\n\r\nwhat I am expecting as a CSV output is \r\n\r\n| title | login | uid | shared_folder | folder |\r\n|:---- |:------:| :-----:| :-----:| :-----:|\r\n| root logon  | 61819009 | ajsd879asdjksasda123asd1asd1 |  |  |\r\n| important admin account |admin| asdjhkasdh89eoajdiuas98ue9aoi | Department | Important|\r\n| another important admin | admin@domain.com| asjhe98asiajsijeouiaueiaiu | | |\r\n| switch admin |  admin| asjhe89ausiodjakljskea90ik | Department2 | network\\\\switches |\r\n\r\ninstead I&#39;m getting the following CSV output:\r\n\r\n| title | login | uid |\r\n|:---- |:------:| :-----:|\r\n| root logon  | 61819009 | ajsd879asdjksasda123asd1asd1 |\r\n| important admin account |admin| asdjhkasdh89eoajdiuas98ue9aoi |\r\n| another important admin | admin@domain.com| asjhe98asiajsijeouiaueiaiu |\r\n| switch admin |  admin| asjhe89ausiodjakljskea90ik | \r\n\r\nmy goal is to eliminate capturing following fields\r\n\r\n - password\r\n - login_url\r\n - notes\r\n - option1\r\n - option2",
        "link": "https://stackoverflow.com/questions/66574180/converting-json-into-csv-with-jq-while-only-capturing-specific-keys",
        "title": "Converting json into csv with jq while only capturing specific keys"
    },
    {
        "tags": [
            "json",
            "curl",
            "group-by",
            "count",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1615527773,
                "last_edit_date": 1615527773,
                "creation_date": 1615473695,
                "answer_id": 66584765,
                "question_id": 66579607,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could do the `group_by` first and then derive the rest of the fields from there\r\n\r\n```\r\ngroup_by(.countryCode) \r\n  | map([ .[0].countryCode, length, min_by(.load).load, max_by(.load).load])\r\n```\r\n**EDIT**: Removed the redundant sort as pointed out by @peak\r\n\r\nYou could optionally add `.[] | @tsv` to get the table structure that you have in the question",
                "title": "Using jq group_by and count to sort JSON output from curl into sorted and counted list"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1615527773,
        "creation_date": 1615454516,
        "last_edit_date": 1615454947,
        "question_id": 66579607,
        "body_markdown": "Can anyone help me to understand and assist with a jq script please (only using jq)? Can anyone help me to write a script to take the output of:\r\n\r\n    `curl --silent &quot;https://api.surfshark.com/v3/server/clusters&quot; | jq` \r\n\r\nand list the number of servers in each **countryCode** and the **min** and **max** loadings on those servers, **sorted by countryCode**?\r\n```\r\n.countryCode &#39;count of number of servers&#39; &#39;lowest .load&#39; &#39;highest .load&#39;\r\nAU    5    13%       30%\r\nUK   10    35%       88%\r\nUS   25    12%       50%\r\n```\r\netc....\r\n\r\nI believe the use of group_by, or a combination of that and map, set path, get path and count may work, but I&#39;m hoping someone with higher skills can help me.\r\n\r\nEach json entry looks like this:\r\n\r\n```\r\n\r\n[\r\n  {\r\n    &quot;country&quot;: &quot;Albania&quot;,\r\n    &quot;**countryCode**&quot;: &quot;AL&quot;,\r\n    &quot;region&quot;: &quot;Europe&quot;,\r\n    &quot;regionCode&quot;: &quot;EU&quot;,\r\n    &quot;**load**&quot;: 12,\r\n    &quot;id&quot;: &quot;4c333aa2-d08b-4d11-9073-61c351ce1c1e&quot;,\r\n    &quot;coordinates&quot;: {\r\n      &quot;longitude&quot;: 19.8188889,\r\n      &quot;latitude&quot;: 41.3275\r\n    },\r\n    &quot;info&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;55994450-0c87-4df3-b585-3836c67a863d&quot;,\r\n        &quot;entry&quot;: {\r\n          &quot;value&quot;: &quot;U2FsdGVkX1/VX5IKc3H3ruClgbw7JgnqW7Eacumx8aM=&quot;\r\n        }\r\n      }\r\n    ],\r\n    &quot;type&quot;: &quot;generic&quot;,\r\n    &quot;location&quot;: &quot;Tirana&quot;,\r\n    &quot;**connectionName**&quot;: &quot;al-tia.prod.surfshark.com&quot;,\r\n```\r\n\r\nExtract from another post referencing some of the possible commands\r\n\r\n    \r\n    &#39;map(.Properties.ItmId)\r\n    | reduce .[] as $i (\r\n        {}; setpath([$i]; getpath([$i]) + 1)\r\n      )\r\n    | to_entries | .[] | { &quot;ItemId&quot;: .key, &quot;Count&quot;: .value }&#39;",
        "link": "https://stackoverflow.com/questions/66579607/using-jq-group-by-and-count-to-sort-json-output-from-curl-into-sorted-and-counte",
        "title": "Using jq group_by and count to sort JSON output from curl into sorted and counted list"
    },
    {
        "tags": [
            "sorting",
            "dictionary",
            "curl",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1615464625,
                "creation_date": 1615464625,
                "answer_id": 66582315,
                "question_id": 66581331,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Is this what you wanted ?\r\n\r\n```\r\ncurl --silent &quot;https://api.surfshark.com/v3/server/clusters&quot; | \r\n    jq -r -c &#39;map(select(.countryCode == &quot;US&quot; and .load &lt;= 99)) |\r\n              sort_by(.load) |\r\n              limit(20;.[]) |\r\n              &quot;\\(.countryCode) \\(.connectionName) \\(.load)%&quot;&#39;\r\n```",
                "title": "Using jq and outputting specific columns with formatting"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1615464625,
        "creation_date": 1615460862,
        "question_id": 66581331,
        "body_markdown": "Can anyone help me to understand how I can print countryCode followed by connectionName and load with a percentage symbol all on one line nicely formatted - all using jq - not using sed, column or any other unix external command. I cannot seem print anything other than the one column\r\n\r\ncurl --silent &quot;https://api.surfshark.com/v3/server/clusters&quot; | jq -r -c &quot;map(select(.countryCode == \\&quot;US\\&quot; and .load &lt;= \\&quot;99\\&quot;)) | sort_by(.load) | limit(20;.[]) | [.countryCode, .connectionName, .load] | (.[1])",
        "link": "https://stackoverflow.com/questions/66581331/using-jq-and-outputting-specific-columns-with-formatting",
        "title": "Using jq and outputting specific columns with formatting"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1615486188,
                "post_id": 66588112,
                "comment_id": 117711963,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20931298,
                    "reputation": 3,
                    "user_id": 15377639,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c4978029b0993d2896725fb153c2ae47?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "kc27",
                    "link": "https://stackoverflow.com/users/15377639/kc27"
                },
                "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": 1615494747,
                "post_id": 66588112,
                "comment_id": 117715497,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1615494980,
                "last_edit_date": 1615494980,
                "creation_date": 1615487279,
                "answer_id": 66588394,
                "question_id": 66588112,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [tag:jq]&#39;s [`add`][1], this will concatenate all the input objects;\r\n```\r\n// Multiple variables holding objects\r\njq -s add &lt;&lt;&lt; &quot;$j1 $j2 $j3&quot;\r\n\r\n// Multiple files holding objects\r\njq -s add file1 file2 file3\r\n\r\n// Command output with multiple columns\r\ncommand | jq -s add\r\n```\r\n\r\n## Manually\r\nYou can add multiple columns by hand like so;\r\n```\r\njq -s &#39;.[0] * .[1] * .[2]&#39; file1 file2 file3\r\n```\r\n## Result\r\nBoth options result in:\r\n```json\r\n{\r\n  &quot;Woonkamer&quot;: {\r\n    &quot;currentTemperature&quot;: 21.8,\r\n    &quot;battery&quot;: 75,\r\n    &quot;isFailed&quot;: false\r\n  },\r\n  &quot;Hal&quot;: {\r\n    &quot;currentTemperature&quot;: 19.5,\r\n    &quot;battery&quot;: 48,\r\n    &quot;isFailed&quot;: false\r\n  },\r\n  &quot;Bijkeuken&quot;: {\r\n    &quot;currentTemperature&quot;: 18.4,\r\n    &quot;battery&quot;: 56,\r\n    &quot;isFailed&quot;: false\r\n  }\r\n}\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#example33",
                "title": "concatenate json objects with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1615499461,
        "creation_date": 1615486053,
        "last_edit_date": 1615499461,
        "question_id": 66588112,
        "body_markdown": "I am new with jq and I have these json output of an app:\r\n```\r\n{\r\n  &quot;Woonkamer&quot;: {\r\n    &quot;currentTemperature&quot;: 21.8,\r\n    &quot;battery&quot;: 75,\r\n    &quot;isFailed&quot;: false\r\n  }\r\n}\r\n{\r\n  &quot;Hal&quot;: {\r\n    &quot;currentTemperature&quot;: 19.5,\r\n    &quot;battery&quot;: 48,\r\n    &quot;isFailed&quot;: false\r\n  }\r\n}\r\n{\r\n  &quot;Bijkeuken&quot;: {\r\n    &quot;currentTemperature&quot;: 18.4,\r\n    &quot;battery&quot;: 56,\r\n    &quot;isFailed&quot;: false\r\n  }\r\n}\r\n```\r\nI want them to join to one json object like:\r\n```\r\n{\r\n  &quot;Woonkamer&quot;: {\r\n    &quot;currentTemperature&quot;: 21.8,\r\n    &quot;battery&quot;: 75,\r\n    &quot;isFailed&quot;: false\r\n  },\r\n  &quot;Hal&quot;: {\r\n    &quot;currentTemperature&quot;: 19.5,\r\n    &quot;battery&quot;: 48,\r\n    &quot;isFailed&quot;: false\r\n  },\r\n  &quot;Bijkeuken&quot;: {\r\n    &quot;currentTemperature&quot;: 18.4,\r\n    &quot;battery&quot;: 56,\r\n    &quot;isFailed&quot;: false\r\n  }\r\n}\r\n```\r\n\r\nI cannot get figured out how to do that with jq (I read the manual),\r\n\r\nCan someone help me?",
        "link": "https://stackoverflow.com/questions/66588112/concatenate-json-objects-with-jq",
        "title": "concatenate json objects with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1615502154,
                "post_id": 66591472,
                "comment_id": 117718227,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1615502986,
                "last_edit_date": 1615502986,
                "creation_date": 1615502434,
                "answer_id": 66591612,
                "question_id": 66591472,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try something like the following:\r\n\r\n    jq -n &#39;{ Interactions: [ inputs.Interactions ] | add }&#39; file1.json file2.json\r\n\r\nThis assumes that you have made both input files valid JSON by stripping that trailing comma at the end of each object in the `Interactions` array.\r\n\r\nFor input file1.json:\r\n\r\n    {\r\n      &quot;Interactions&quot;: [\r\n        {\r\n          &quot;ID&quot;: &quot;file1&quot;,\r\n          &quot;Type&quot;: &quot;1&quot;,\r\n          &quot;Timestamp&quot;: &quot;8/27/2020 11:11:11 PM&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nand input file2.json:\r\n\r\n    {\r\n      &quot;Interactions&quot;: [\r\n        {\r\n          &quot;ID&quot;: &quot;file2&quot;,\r\n          &quot;Type&quot;: &quot;2&quot;,\r\n          &quot;Timestamp&quot;: &quot;8/27/2020 22:22:22 PM&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nthis results in:\r\n\r\n    {\r\n      &quot;Interactions&quot;: [\r\n        {\r\n          &quot;ID&quot;: &quot;file1&quot;,\r\n          &quot;Type&quot;: &quot;1&quot;,\r\n          &quot;Timestamp&quot;: &quot;8/27/2020 11:11:11 PM&quot;\r\n        },\r\n        {\r\n          &quot;ID&quot;: &quot;file2&quot;,\r\n          &quot;Type&quot;: &quot;2&quot;,\r\n          &quot;Timestamp&quot;: &quot;8/27/2020 22:22:22 PM&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "Unify JSON files with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1615502986,
        "creation_date": 1615501588,
        "question_id": 66591472,
        "body_markdown": "I&#39;m new in the community and I&#39;m not a dev, but I have a task I need to find a solution for. I hope I can get your ideas.\r\n\r\nI have a set of JSON files. I want to be able to use jq or a command line that can help me unify the files into one single file.\r\n\r\nFor example:\r\n\r\nFile 1, has the following format:\r\n\r\n    {\r\n      &quot;Interactions&quot;: [\r\n        {\r\n          &quot;ID&quot;: &quot;ispring://presentations/F7385CB7-DFDC-4D05-90FA-B927DB3D170D/quizzes/&quot;,\r\n          &quot;Type&quot;: &quot;2&quot;,\r\n          &quot;TimestampUtc&quot;: &quot;8/27/2020 12:09:54 PM&quot;,\r\n          &quot;Timestamp&quot;: &quot;8/27/2020 12:09:54 PM&quot;,\r\n          &quot;Weighting&quot;: &quot;&quot;,\r\n          &quot;Result&quot;: &quot;1&quot;,\r\n          &quot;Latency&quot;: &quot;1000&quot;,\r\n          &quot;Description&quot;: &quot;What is the purpose of Summarizing next steps?\\n\\nSelect the correct box or boxes&quot;,\r\n          &quot;LearnerResponse&quot;: &quot;0_correct_answer[,]1_Rectangle_2&quot;,\r\n          &quot;ScormActivityId&quot;: &quot;12392705&quot;,\r\n          &quot;InteractionIndex&quot;: &quot;3&quot;,\r\n          &quot;AULMRID&quot;: &quot;38093846&quot;\r\n        },\r\n      ]\r\n    }\r\n\r\n\r\nFile 2:\r\n\r\n    {\r\n      &quot;Interactions&quot;: [\r\n        {\r\n          &quot;ID&quot;: &quot;ispring://presentations/CAA34147-7B48-40C6-84FD-5CE8077DB2BF/quizzes/&quot;,\r\n          &quot;Type&quot;: &quot;2&quot;,\r\n          &quot;TimestampUtc&quot;: &quot;12/8/2020 6:19:12 PM&quot;,\r\n          &quot;Timestamp&quot;: &quot;12/8/2020 6:19:12 PM&quot;,\r\n          &quot;Weighting&quot;: &quot;&quot;,\r\n          &quot;Result&quot;: &quot;1&quot;,\r\n          &quot;Latency&quot;: &quot;1300&quot;,\r\n          &quot;Description&quot;: &quot;&#39;Can&#39;t do&#39; language tends to relay this impression...\\n\\nSelect one.&quot;,\r\n          &quot;LearnerResponse&quot;: &quot;4_All_of_the_above&quot;,\r\n          &quot;ScormActivityId&quot;: &quot;13334358&quot;,\r\n          &quot;InteractionIndex&quot;: &quot;3&quot;,\r\n          &quot;AULMRID&quot;: &quot;40715598&quot;\r\n        },\r\n      ]\r\n    }\r\n\r\nAnd this is my expected result in a third file:\r\n\r\n    {\r\n      &quot;Interactions&quot;: [\r\n        {\r\n          &quot;ID&quot;: &quot;ispring://presentations/F7385CB7-DFDC-4D05-90FA-B927DB3D170D/quizzes/&quot;,\r\n          &quot;Type&quot;: &quot;2&quot;,\r\n          &quot;TimestampUtc&quot;: &quot;8/27/2020 12:09:54 PM&quot;,\r\n          &quot;Timestamp&quot;: &quot;8/27/2020 12:09:54 PM&quot;,\r\n          &quot;Weighting&quot;: &quot;&quot;,\r\n          &quot;Result&quot;: &quot;1&quot;,\r\n          &quot;Latency&quot;: &quot;1000&quot;,\r\n          &quot;Description&quot;: &quot;What is the purpose of Summarizing next steps?\\n\\nSelect the correct box or boxes&quot;,\r\n          &quot;LearnerResponse&quot;: &quot;0_correct_answer[,]1_Rectangle_2&quot;,\r\n          &quot;ScormActivityId&quot;: &quot;12392705&quot;,\r\n          &quot;InteractionIndex&quot;: &quot;3&quot;,\r\n          &quot;AULMRID&quot;: &quot;38093846&quot;\r\n        },\r\n       {\r\n          &quot;ID&quot;: &quot;ispring://presentations/CAA34147-7B48-40C6-84FD-5CE8077DB2BF/quizzes/&quot;,\r\n          &quot;Type&quot;: &quot;2&quot;,\r\n          &quot;TimestampUtc&quot;: &quot;12/8/2020 6:19:12 PM&quot;,\r\n          &quot;Timestamp&quot;: &quot;12/8/2020 6:19:12 PM&quot;,\r\n          &quot;Weighting&quot;: &quot;&quot;,\r\n          &quot;Result&quot;: &quot;1&quot;,\r\n          &quot;Latency&quot;: &quot;1300&quot;,\r\n          &quot;Description&quot;: &quot;&#39;Can&#39;t do&#39; language tends to relay this impression...\\n\\nSelect one.&quot;,\r\n          &quot;LearnerResponse&quot;: &quot;4_All_of_the_above&quot;,\r\n          &quot;ScormActivityId&quot;: &quot;13334358&quot;,\r\n          &quot;InteractionIndex&quot;: &quot;3&quot;,\r\n          &quot;AULMRID&quot;: &quot;40715598&quot;\r\n        },\r\n      ]\r\n    }\r\n\r\nAny ideas on how to unify them ?\r\n\r\nThank you!\r\n\r\nRG",
        "link": "https://stackoverflow.com/questions/66591472/unify-json-files-with-jq",
        "title": "Unify JSON files with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615503346,
                "post_id": 66591547,
                "comment_id": 117718593,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5546213,
                    "reputation": 664,
                    "user_id": 4400810,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://lh3.googleusercontent.com/-zYK-gADw_VU/AAAAAAAAAAI/AAAAAAAAABQ/lk7Rf7bzAY4/s256-rj/photo.jpg",
                    "display_name": "MaryCoding",
                    "link": "https://stackoverflow.com/users/4400810/marycoding"
                },
                "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": 1615504337,
                "post_id": 66591547,
                "comment_id": 117718823,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615504710,
                "post_id": 66591547,
                "comment_id": 117718901,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615504907,
                "post_id": 66591547,
                "comment_id": 117718946,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5546213,
                    "reputation": 664,
                    "user_id": 4400810,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://lh3.googleusercontent.com/-zYK-gADw_VU/AAAAAAAAAAI/AAAAAAAAABQ/lk7Rf7bzAY4/s256-rj/photo.jpg",
                    "display_name": "MaryCoding",
                    "link": "https://stackoverflow.com/users/4400810/marycoding"
                },
                "reply_to_user": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615504976,
                "post_id": 66591547,
                "comment_id": 117718970,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615505306,
                "post_id": 66591547,
                "comment_id": 117719041,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5546213,
                    "reputation": 664,
                    "user_id": 4400810,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://lh3.googleusercontent.com/-zYK-gADw_VU/AAAAAAAAAAI/AAAAAAAAABQ/lk7Rf7bzAY4/s256-rj/photo.jpg",
                    "display_name": "MaryCoding",
                    "link": "https://stackoverflow.com/users/4400810/marycoding"
                },
                "reply_to_user": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615505982,
                "post_id": 66591547,
                "comment_id": 117719178,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1615539303,
                "last_edit_date": 1615539303,
                "creation_date": 1615507602,
                "answer_id": 66592334,
                "question_id": 66591547,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "# How to act on each element in an array\r\n\r\nYou have an array in `.test`. If you want to extract the individual elements of that array to use in the rest of your filter, use `.test[]`. If you want to process them but keep the results in an array, use `.test|map(...)` where `...` is the filter you want to apply to the elements of the array.\r\n\r\n# How to filter objects with multiple conditions\r\n\r\nAs described [in this question](https://stackoverflow.com/questions/33057420/jq-select-multiple-conditions) you can use the `select()` filter with multiple conditions. So, for example:\r\n\r\n```\r\njq &#39;.test[]|\r\n    select(\r\n        (.outdated or .deprecated) and\r\n        .release != &quot;never-update-app&quot; and\r\n        .release != &quot;never-upgrade-app&quot;\r\n    )&#39;\r\n```\r\n\r\n# How to combine non-trivial filters\r\n\r\nUse parentheses! As an example, suppose you want to replace the two &quot;never-&quot; tests with a `startswith` test. By surrounding the pipes with parentheses you isolated the calculation and just get the true/false answer to combine in a boolean expression.\r\n\r\n```\r\njq &#39;.test[]|\r\n    select(\r\n        (.outdated or .deprecated) and\r\n        (.release|startswith(&quot;never-&quot;)|not)\r\n    )&#39;\r\n```\r\n\r\n# How to format results in a table\r\n\r\nI think this answer on [formatting results in a table](https://stackoverflow.com/a/54854136/2283) is probably sufficient. If you have more specific needs I think you might want to spin this off into a separate question.",
                "title": "jq - looping through json object and only displaying certain values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1649057945,
                "creation_date": 1649057945,
                "answer_id": 71733555,
                "question_id": 66591547,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Filter\r\n```\r\n([&quot;ReleaseName&quot;,&quot;Installed&quot;,&quot;Latest&quot;,&quot;Old&quot;,&quot;Deprecated&quot;] | @tsv), (.test[] | select(   (.outdated==true or .deprecated==true) and ((.release==&quot;never-update-app&quot; or .release==&quot;never-upgrade-app&quot;) | not)   ) | &quot;\\(.release) \\(.Installed.version) \\(.Latest.version) \\(.outdated) \\(.deprecated)&quot; / &quot; &quot; | @tsv)\r\n```\r\n\r\nOutput\r\n```\r\nReleaseName\tInstalled\tLatest\tOld\tDeprecated\r\ntest-app\t1.0.0\t2.0.0\ttrue\tfalse\r\n```\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/B4a5cxlL28",
                "title": "jq - looping through json object and only displaying certain values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1649057945,
        "creation_date": 1615502027,
        "last_edit_date": 1615506199,
        "question_id": 66591547,
        "body_markdown": "I am currently learning how to usage `jq`. I have a json object and I am able to loop and read values with `jq` as such `cat test.json | jq  -r  &#39;.test&#39;`. However, I am running into some complexity when I only want to display on values that have `outdated` or `deprecated` = `true` but ommit from result if `relase` = `never-update-app` or `never-upgrade-app`. I am trying `cat test.json | jq &#39;.test | select(.[].outdated==true)&#39;` but this is not returning the desired results. Is this something possible through jq and have it display in the below desired format? \r\n\r\nMy desired output is shown below:\r\n\r\n    Release Name                                             Installed    Latest    Old      Deprecated\r\n    test-app                                                 1.0.0        2.0.0     true     false  \r\n\r\n  \r\n   \r\njson:\r\n\r\n    {\r\n    \t&quot;test&quot;: [{\r\n    \t\t&quot;release&quot;: &quot;myapp1&quot;,\r\n    \t\t&quot;Installed&quot;: {\r\n    \t\t\t&quot;version&quot;: &quot;0.3.0&quot;,\r\n    \t\t\t&quot;appVersion&quot;: &quot;v1.2.6&quot;\r\n    \t\t},\r\n    \t\t&quot;Latest&quot;: {\r\n    \t\t\t&quot;version&quot;: &quot;&quot;,\r\n    \t\t\t&quot;appVersion&quot;: &quot;&quot;\r\n    \t\t},\r\n    \t\t&quot;outdated&quot;: false,\r\n    \t\t&quot;deprecated&quot;: false\r\n    \t}, {\r\n    \t\t&quot;release&quot;: &quot;myapp2&quot;,\r\n    \t\t&quot;Installed&quot;: {\r\n    \t\t\t&quot;version&quot;: &quot;6.5.13&quot;,\r\n    \t\t\t&quot;appVersion&quot;: &quot;1.9.1&quot;\r\n    \t\t},\r\n    \t\t&quot;Latest&quot;: {\r\n    \t\t\t&quot;version&quot;: &quot;&quot;,\r\n    \t\t\t&quot;appVersion&quot;: &quot;&quot;\r\n    \t\t},\r\n    \t\t&quot;outdated&quot;: false,\r\n    \t\t&quot;deprecated&quot;: false\r\n    \t}, {\r\n    \t\t&quot;release&quot;: &quot;test-app&quot;,\r\n    \t\t&quot;Installed&quot;: {\r\n    \t\t\t&quot;version&quot;: &quot;1.0.0&quot;,\r\n    \t\t\t&quot;appVersion&quot;: &quot;&quot;\r\n    \t\t},\r\n    \t\t&quot;Latest&quot;: {\r\n    \t\t\t&quot;version&quot;: &quot;2.0.0&quot;,\r\n    \t\t\t&quot;appVersion&quot;: &quot;&quot;\r\n    \t\t},\r\n    \t\t&quot;outdated&quot;: true,\r\n    \t\t&quot;deprecated&quot;: false\r\n    \t}, {\r\n    \t\t&quot;release&quot;: &quot;never-update-app&quot;,\r\n    \t\t&quot;Installed&quot;: {\r\n    \t\t\t&quot;version&quot;: &quot;1.0.0&quot;,\r\n    \t\t\t&quot;appVersion&quot;: &quot;&quot;\r\n    \t\t},\r\n    \t\t&quot;Latest&quot;: {\r\n    \t\t\t&quot;version&quot;: &quot;3.0.0&quot;,\r\n    \t\t\t&quot;appVersion&quot;: &quot;&quot;\r\n    \t\t},\r\n    \t\t&quot;outdated&quot;: true,\r\n    \t\t&quot;deprecated&quot;: false\r\n    \t}, {\r\n    \t\t&quot;release&quot;: &quot;never-upgrade-app&quot;,\r\n    \t\t&quot;Installed&quot;: {\r\n    \t\t\t&quot;version&quot;: &quot;2.0.0&quot;,\r\n    \t\t\t&quot;appVersion&quot;: &quot;&quot;\r\n    \t\t},\r\n    \t\t&quot;Latest&quot;: {\r\n    \t\t\t&quot;version&quot;: &quot;2.0.0&quot;,\r\n    \t\t\t&quot;appVersion&quot;: &quot;&quot;\r\n    \t\t},\r\n    \t\t&quot;outdated&quot;: false,\r\n    \t\t&quot;deprecated&quot;: true\r\n    \t}]\r\n    }",
        "link": "https://stackoverflow.com/questions/66591547/jq-looping-through-json-object-and-only-displaying-certain-values",
        "title": "jq - looping through json object and only displaying certain values"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1615516039,
                "creation_date": 1615516039,
                "answer_id": 66593342,
                "question_id": 66592859,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Both `@csv` and `@tsv` expect an array as input, so you could just append the following to your jq filter:\r\n```\r\n| [.release, .Installed.version, .Latest.version, .outdated, .deprecated]\r\n| @tsv\r\n```",
                "title": "Jq tsv error in formatting an array/object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1615516074,
        "creation_date": 1615511880,
        "last_edit_date": 1615516074,
        "question_id": 66592859,
        "body_markdown": "I have json file that I am able to loop and get the desired values with the below command. I am trying to gain some insights in displaying these values into a table format. I am using `@tsv` but getting an error `object ({&quot;release&quot;:...) cannot be tsv-formatted, only array`. How can I get the below output display? \r\n\r\n\r\nMy desired output is shown below:\r\n\r\n    Release         Installed    Latest    Old      Deprecated\r\n    -------         ---------    ------    ---      ----------\r\n    test-app        1.0.0        2.0.0     true     false    \r\n\r\njq:\r\n\r\n    cat test.json | jq &#39;.test[] | select((.outdated or .deprecated) and ((.release|startswith(&quot;update&quot;)) | not) and ((.release|startswith(&quot;upgrade&quot;)) | not))&#39;\r\n\r\n   \r\njson:\r\n\r\n    {\r\n        &quot;test&quot;: [{\r\n            &quot;release&quot;: &quot;myapp1&quot;,\r\n            &quot;Installed&quot;: {\r\n                &quot;version&quot;: &quot;0.3.0&quot;,\r\n                &quot;appVersion&quot;: &quot;v1.2.6&quot;\r\n            },\r\n            &quot;Latest&quot;: {\r\n                &quot;version&quot;: &quot;&quot;,\r\n                &quot;appVersion&quot;: &quot;&quot;\r\n            },\r\n            &quot;outdated&quot;: false,\r\n            &quot;deprecated&quot;: false\r\n        }, {\r\n            &quot;release&quot;: &quot;myapp2&quot;,\r\n            &quot;Installed&quot;: {\r\n                &quot;version&quot;: &quot;6.5.13&quot;,\r\n                &quot;appVersion&quot;: &quot;1.9.1&quot;\r\n            },\r\n            &quot;Latest&quot;: {\r\n                &quot;version&quot;: &quot;&quot;,\r\n                &quot;appVersion&quot;: &quot;&quot;\r\n            },\r\n            &quot;outdated&quot;: false,\r\n            &quot;deprecated&quot;: false\r\n        }, {\r\n            &quot;release&quot;: &quot;test-app&quot;,\r\n            &quot;Installed&quot;: {\r\n                &quot;version&quot;: &quot;1.0.0&quot;,\r\n                &quot;appVersion&quot;: &quot;&quot;\r\n            },\r\n            &quot;Latest&quot;: {\r\n                &quot;version&quot;: &quot;2.0.0&quot;,\r\n                &quot;appVersion&quot;: &quot;&quot;\r\n            },\r\n            &quot;outdated&quot;: true,\r\n            &quot;deprecated&quot;: false\r\n        }, {\r\n            &quot;release&quot;: &quot;update-app&quot;,\r\n            &quot;Installed&quot;: {\r\n                &quot;version&quot;: &quot;1.0.0&quot;,\r\n                &quot;appVersion&quot;: &quot;&quot;\r\n            },\r\n            &quot;Latest&quot;: {\r\n                &quot;version&quot;: &quot;3.0.0&quot;,\r\n                &quot;appVersion&quot;: &quot;&quot;\r\n            },\r\n            &quot;outdated&quot;: true,\r\n            &quot;deprecated&quot;: false\r\n        }, {\r\n            &quot;release&quot;: &quot;upgrade-app&quot;,\r\n            &quot;Installed&quot;: {\r\n                &quot;version&quot;: &quot;2.0.0&quot;,\r\n                &quot;appVersion&quot;: &quot;&quot;\r\n            },\r\n            &quot;Latest&quot;: {\r\n                &quot;version&quot;: &quot;2.0.0&quot;,\r\n                &quot;appVersion&quot;: &quot;&quot;\r\n            },\r\n            &quot;outdated&quot;: false,\r\n            &quot;deprecated&quot;: true\r\n        }]\r\n    }",
        "link": "https://stackoverflow.com/questions/66592859/jq-tsv-error-in-formatting-an-array-object",
        "title": "Jq tsv error in formatting an array/object"
    },
    {
        "tags": [
            "json",
            "jq",
            "fromjson"
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1615536117,
        "creation_date": 1615522233,
        "last_edit_date": 1615536117,
        "question_id": 66594074,
        "body_markdown": "I am trying to parse out a json string value. It looks like a json nested object, but it&#39;s a string value for a key. I can use `-r` on jq to do raw output, which strips the double-quotes, and thereby makes it a json object.. or so I think. The `-r` also removes the escapes. However, It doesn&#39;t &quot;pretty print&quot; it, the way I would expect. I&#39;ve tried different ways of parsing, piping steaming, etc., with no luck. \r\n\r\nHere&#39;s my little blob of json, and I will jq it as-is, and raw. As you can see I&#39;m going into the `rows` array and getting key values, etc. I&#39;m trying to get the value(s) of `cpu`. The snippet below is only a snippet of the zillion things I&#39;ve tried.\r\n\r\n```\r\n{\r\n &quot;rows&quot;: [\r\n  {\r\n    &quot;display_name&quot;: &quot;sfsrocks&quot;,\r\n    &quot;name&quot;: &quot;sfs&quot;,\r\n    &quot;is_muted&quot;: false,\r\n    &quot;mute_timeout&quot;: null,\r\n    &quot;meta&quot;: {\r\n      &quot;socket-hostname&quot;: &quot;sfssocket&quot;\r\n      },\r\n    &quot;host_id&quot;: 449792622,\r\n    &quot;hw&quot;: &quot;{\\&quot;cpu\\&quot;:{\\&quot;cache_size\\&quot;:\\&quot;15360 KB\\&quot;,\\&quot;cpu_cores\\&quot;:\\&quot;4\\&quot;,\\&quot;cpu_logical_processors\\&quot;:\\&quot;4\\&quot;,\\&quot;family\\&quot;:\\&quot;6\\&quot;,\\&quot;mhz\\&quot;:\\&quot;2397.223\\&quot;,\\&quot;model\\&quot;:\\&quot;58\\&quot;,\\&quot;model_name\\&quot;:\\&quot;Intel(R) Xeon(R) CPU E5-2620 v3 @ 2.40GHz\\&quot;,\\&quot;stepping\\&quot;:\\&quot;0\\&quot;,\\&quot;vendor_id\\&quot;:\\&quot;GenuineIntel\\&quot;}}&quot;,\r\n    &quot;pythonV&quot;: &quot;n/a&quot;,\r\n    &quot;processor&quot;: &quot;Intel(R) Xeon(R) CPU E5-2620 v3 @ 2.40GHz&quot;,\r\n    &quot;socket-fqdn&quot;: &quot;sofree.us.&quot;,\r\n    &quot;agent_version&quot;: &quot;6.1.1&quot;\r\n  }\r\n ]\r\n}\r\n# %\r\n# % cat sfstest.json | jq &#39;.rows[]|.display_name,.name,.meta.&quot;socket-hostname&quot;,.hw&#39;\r\n&quot;sfsrocks&quot;\r\n&quot;sfs&quot;\r\n&quot;sfssocket&quot;\r\n&quot;{\\&quot;cpu\\&quot;:{\\&quot;cache_size\\&quot;:\\&quot;15360 KB\\&quot;,\\&quot;cpu_cores\\&quot;:\\&quot;4\\&quot;,\\&quot;cpu_logical_processors\\&quot;:\\&quot;4\\&quot;,\\&quot;family\\&quot;:\\&quot;6\\&quot;,\\&quot;mhz\\&quot;:\\&quot;2397.223\\&quot;,\\&quot;model\\&quot;:\\&quot;58\\&quot;,\\&quot;model_name\\&quot;:\\&quot;Intel(R) Xeon(R) CPU E5-2620 v3 @ 2.40GHz\\&quot;,\\&quot;stepping\\&quot;:\\&quot;0\\&quot;,\\&quot;vendor_id\\&quot;:\\&quot;GenuineInt\r\nel\\&quot;}}&quot;\r\n# %\r\n# % cat sfstest.json | jq -r &#39;.rows[]|.display_name,.name,.meta.&quot;socket-hostname&quot;,.hw&#39;\r\nsfsrocks\r\nsfs\r\nsfssocket\r\n{&quot;cpu&quot;:{&quot;cache_size&quot;:&quot;15360 KB&quot;,&quot;cpu_cores&quot;:&quot;4&quot;,&quot;cpu_logical_processors&quot;:&quot;4&quot;,&quot;family&quot;:&quot;6&quot;,&quot;mhz&quot;:&quot;2397.223&quot;,&quot;model&quot;:&quot;58&quot;,&quot;model_name&quot;:&quot;Intel(R) Xeon(R) CPU E5-2620 v3 @ 2.40GHz&quot;,&quot;stepping&quot;:&quot;0&quot;,&quot;vendor_id&quot;:&quot;GenuineIntel&quot;}}\r\n# %\r\n# % cat sfstest.json | jq -r &#39;.rows[]|.display_name,.name,.meta.&quot;socket-hostname&quot;,.hw.&quot;cpu&quot;&#39;\r\nsfsrocks\r\nsfs\r\nsfssocket\r\njq: error (at &lt;stdin&gt;:19): Cannot index string with string &quot;cpu&quot;\r\n# % cat sfstest.json | jq -r &#39;.rows[]|.display_name,.name,.meta.&quot;socket-hostname&quot;,.hw.cpu&#39;\r\nsfsrocks\r\nsfs\r\nsfssocket\r\njq: error (at &lt;stdin&gt;:19): Cannot index string with string &quot;cpu&quot;\r\n# %\r\n```\r\n\r\nBut if I throw that `hw` &quot;value&quot; line into a file, I can act on it as I would expect.. just not as part of the total `jq` line.\r\n```# % cat hw\r\n{&quot;cpu&quot;:{&quot;cache_size&quot;:&quot;15360 KB&quot;,&quot;cpu_cores&quot;:&quot;4&quot;,&quot;cpu_logical_processors&quot;:&quot;4&quot;,&quot;family&quot;:&quot;6&quot;,&quot;mhz&quot;:&quot;2397.223&quot;,&quot;model&quot;:&quot;58&quot;,&quot;model_name&quot;:&quot;Intel(R) Xeon(R) CPU E5-2620 v3 @ 2.40GHz&quot;,&quot;stepping&quot;:&quot;0&quot;,&quot;vendor_id&quot;:&quot;GenuineIntel&quot;}}\r\n# %\r\n# % cat hw | jq &#39;.&#39;\r\n{\r\n  &quot;cpu&quot;: {\r\n    &quot;cache_size&quot;: &quot;15360 KB&quot;,\r\n    &quot;cpu_cores&quot;: &quot;4&quot;,\r\n    &quot;cpu_logical_processors&quot;: &quot;4&quot;,\r\n    &quot;family&quot;: &quot;6&quot;,\r\n    &quot;mhz&quot;: &quot;2397.223&quot;,\r\n    &quot;model&quot;: &quot;58&quot;,\r\n    &quot;model_name&quot;: &quot;Intel(R) Xeon(R) CPU E5-2620 v3 @ 2.40GHz&quot;,\r\n    &quot;stepping&quot;: &quot;0&quot;,\r\n    &quot;vendor_id&quot;: &quot;GenuineIntel&quot;\r\n  }\r\n}\r\n# %\r\n# % cat hw | jq &#39;.cpu.mhz&#39;\r\n&quot;2397.223&quot;\r\n# % cat hw | jq &#39;.cpu.cache_size&#39;\r\n&quot;15360 KB&quot;\r\n# %\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/66594074/how-to-extract-elements-from-a-string-value-in-json-using-jq",
        "title": "How to extract elements from a string value in json, using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1615534569,
                "last_edit_date": 1615534569,
                "creation_date": 1615534072,
                "answer_id": 66595876,
                "question_id": 66595618,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The first thing is to get your ducks in a row:\r\n```\r\nmap({release, installed: .Installed.version, latest: .Latest.version, deprecated})\r\n```\r\nNow the headers are easy: \r\n```\r\n( .[0] | keys_unsorted | map(ascii_upcase))\r\n```\r\n... and it&#39;s safe to use .[] to fetch the values:\r\n```\r\n.[] | [.[]]\r\n```\r\n\r\nPutting it all together:\r\n```\r\nmap({release, installed: .Installed.version, latest: .Latest.version, deprecated})\r\n| ( .[0] | keys_unsorted | map(ascii_upcase)),\r\n  (.[] | [.[]])\r\n| @tsv\r\n```\r\n\r\n### A line of dashes under the headers\r\nIn your related question at https://stackoverflow.com/questions/66592859/jq-tsv-error-in-formatting-an-array-object, you required a line of dashes under the headers.\r\n\r\nTo automate the production of such a line, see\r\nhttps://stackoverflow.com/questions/39139107/how-to-format-a-json-string-as-a-table-using-jq\r\n\r\n\r\n",
                "title": "Jq tsv - create headers from keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1615719884,
        "creation_date": 1615532652,
        "last_edit_date": 1615719884,
        "question_id": 66595618,
        "body_markdown": "I am trying to get jq to render a json object into tsv format. I came across a way to generate headers dynamically using the key name. \r\n\r\nI am getting this error: \r\n\r\n&gt; object ({&quot;version&quot;:...) is not valid in a csv row\r\n\r\nI am guessing this is due to some fields being arrays: `Installed` and `Latest`. How can I make this work with those fields? Also, why is my output including `\\t`?\r\n\r\nCurrent Output:\r\n\r\n    &quot;RELEASE\\tINSTALLED\\tLATEST\\tOUTDATED\\tDEPRECATED&quot;\r\n    jq: error (at &lt;stdin&gt;:28): object ({&quot;version&quot;:...) is not valid in a csv row\r\n\r\n\r\nDesired output:\r\n\r\n    RELEASE         INSTALLED    LATEST    OUTDATED      DEPRACATED\r\n    test-app        1.0.0        2.0.0     true          false    \r\n    test-app2       3.0.0        3.5.0     true          false \r\n\r\n  \r\n\r\njq\r\n\r\n    cat test1.json | jq &#39;[.[]| with_entries( .key |= ascii_upcase ) ] | (.[0] |keys_unsorted | @tsv), (.[]|.|map(.) |@tsv)&#39;\r\n\r\njson:\r\n\r\n    [\r\n      {\r\n        &quot;release&quot;: &quot;test-app&quot;,\r\n        &quot;Installed&quot;: {\r\n          &quot;version&quot;: &quot;1.0.0&quot;,\r\n          &quot;appVersion&quot;: &quot;&quot;\r\n        },\r\n        &quot;Latest&quot;: {\r\n          &quot;version&quot;: &quot;2.0.0&quot;,\r\n          &quot;appVersion&quot;: &quot;&quot;\r\n        },\r\n        &quot;outdated&quot;: true,\r\n        &quot;deprecated&quot;: false\r\n      },\r\n      {\r\n        &quot;release&quot;: &quot;test-app2&quot;,\r\n        &quot;Installed&quot;: {\r\n          &quot;version&quot;: &quot;3.0.0&quot;,\r\n          &quot;appVersion&quot;: &quot;&quot;\r\n        },\r\n        &quot;Latest&quot;: {\r\n          &quot;version&quot;: &quot;3.5.0&quot;,\r\n          &quot;appVersion&quot;: &quot;&quot;\r\n        },\r\n        &quot;outdated&quot;: true,\r\n        &quot;deprecated&quot;: false\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/66595618/jq-tsv-create-headers-from-keys",
        "title": "Jq tsv - create headers from keys"
    },
    {
        "tags": [
            "json",
            "bash",
            "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": 0,
                "creation_date": 1615570862,
                "post_id": 66603976,
                "comment_id": 117741104,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1615571264,
                "creation_date": 1615571264,
                "answer_id": 66604770,
                "question_id": 66603976,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`&quot;&quot;` is not classed as `null` as Philippe pointed out, but if you&#39;re unable to change the json to make the `&quot;&quot;` become `null`, what you can do is\r\n\r\n    jq -r &#39;map({release, installed: .Installed.version, latest: (if .Latest.version == &quot;&quot; then &quot;-&quot; else .Latest.version end), deprecated}) | ( .[0] | keys_unsorted | map(ascii_upcase)), (.[] | [.[]]) | @tsv&#39; data.json | column -t",
                "title": "Jq handling empty strings and replacing them with a default value"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1615595635,
                "creation_date": 1615595635,
                "answer_id": 66608936,
                "question_id": 66603976,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If empty string `&quot;&quot;` is the only case you want to treat as `null`, you could just use the alternative operator to force to it then replace as needed.\r\n\r\n```\r\n.Latest.version // &quot;&quot; | select(. != &quot;&quot;) // &quot;-&quot;\r\n\r\n# or using if-then-else\r\n.Latest.version // &quot;&quot; | if . == &quot;&quot; then &quot;-&quot; else . end\r\n\r\n# or if you&#39;re using the latest dev version, else is optional\r\n.Latest.version // &quot;&quot; | if . == &quot;&quot; then &quot;-&quot; end\r\n```",
                "title": "Jq handling empty strings and replacing them with a default value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1615595635,
        "creation_date": 1615567871,
        "question_id": 66603976,
        "body_markdown": "I currently have a json file I am manipulating with jq. I am able to display it how I want for the most part. However, I am running into a problem when displaying values for a field that&#39;s empty. I am using the `//` alternative operator but it is not returning the desired output. What is the right way to handle empty strings with jq? \r\n\r\nCurrent Output:\r\n\r\n    RELEASE    INSTALLED  LATEST  DEPRECATED\r\n    test-app   1.0.0      2.0.0   false\r\n    test-app2  3.0.0      true\r\n\r\nDesired Output:\r\n\r\n    RELEASE    INSTALLED  LATEST  DEPRECATED\r\n    test-app   1.0.0      2.0.0   false\r\n    test-app2  3.0.0      -        true\r\n\r\nJq:\r\n\r\n    cat test1.json | jq -r &#39;map({release, installed: .Installed.version, latest: (.Latest.version // &quot;-&quot;), deprecated}) | ( .[0] | keys_unsorted | map(ascii_upcase)), (.[] | [.[]]) | @tsv&#39; | column -t\r\n\r\nJson:\r\n\r\n    [\r\n      {\r\n        &quot;release&quot;: &quot;test-app&quot;,\r\n        &quot;Installed&quot;: {\r\n          &quot;version&quot;: &quot;1.0.0&quot;,\r\n          &quot;appVersion&quot;: &quot;&quot;\r\n        },\r\n        &quot;Latest&quot;: {\r\n          &quot;version&quot;: &quot;2.0.0&quot;,\r\n          &quot;appVersion&quot;: &quot;&quot;\r\n        },\r\n        &quot;outdated&quot;: true,\r\n        &quot;deprecated&quot;: false\r\n      },\r\n      {\r\n        &quot;release&quot;: &quot;test-app2&quot;,\r\n        &quot;Installed&quot;: {\r\n          &quot;version&quot;: &quot;3.0.0&quot;,\r\n          &quot;appVersion&quot;: &quot;&quot;\r\n        },\r\n        &quot;Latest&quot;: {\r\n          &quot;version&quot;: &quot;&quot;,\r\n          &quot;appVersion&quot;: &quot;&quot;\r\n        },\r\n        &quot;outdated&quot;: false,\r\n        &quot;deprecated&quot;: true\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/66603976/jq-handling-empty-strings-and-replacing-them-with-a-default-value",
        "title": "Jq handling empty strings and replacing them with a default value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615578791,
                "post_id": 66606261,
                "comment_id": 117744246,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11813379,
                    "reputation": 1201,
                    "user_id": 8644283,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/a8550e7700822d070f4ee0f75ecc29a1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kade Williams",
                    "link": "https://stackoverflow.com/users/8644283/kade-williams"
                },
                "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": 1615579531,
                "post_id": 66606261,
                "comment_id": 117744506,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1615661380,
                "last_edit_date": 1615661380,
                "creation_date": 1615579918,
                "answer_id": 66606593,
                "question_id": 66606261,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can add application to the constructed structure:\r\n\r\n    jq &#39;.data[]\r\n       | .computers[] + .file + {application}\r\n       | &quot;\\(.hostname) \\(.application) \\(.filename)&quot;&#39;",
                "title": "Getting value when Object and String cannot be added"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1615662918,
                "creation_date": 1615662918,
                "answer_id": 66617569,
                "question_id": 66606261,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One technique you could employ is &quot;expanding&quot; the array of computers, then you could generate the results you want.\r\n\r\n```\r\n.computers = .computers[] | &quot;\\(.computers.hostname) \\(.application) \\(.file.filename)&quot;\r\n```\r\n\r\n---\r\n\r\n```\r\n.computers = .computers[]\r\n```\r\n\r\nThis changes the input where each item in the `computers` array is substituted in place of the array itself to something that looks like this:\r\n\r\n```\r\n{\r\n  &quot;application&quot;: &quot;Microsoft Office&quot;,\r\n  &quot;computers&quot;: {\r\n    &quot;active&quot;: true,\r\n    &quot;hostname&quot;: &quot;computer1.domain.local&quot;\r\n  },\r\n  &quot;file&quot;: {\r\n    &quot;filename&quot;: &quot;WINWORD.EXE&quot;,\r\n    &quot;identity&quot;: {\r\n      &quot;sha256&quot;: &quot;270fe88cca8156912303ebdf9481de99e4265c878cfd41964b2a94131f6c41ad&quot;\r\n    }\r\n  }\r\n}\r\n{\r\n  &quot;application&quot;: &quot;Microsoft Office&quot;,\r\n  &quot;computers&quot;: {\r\n    &quot;active&quot;: false,\r\n    &quot;hostname&quot;: &quot;computer2.domain.local&quot;\r\n  },\r\n  &quot;file&quot;: {\r\n    &quot;filename&quot;: &quot;WINWORD.EXE&quot;,\r\n    &quot;identity&quot;: {\r\n      &quot;sha256&quot;: &quot;270fe88cca8156912303ebdf9481de99e4265c878cfd41964b2a94131f6c41ad&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n",
                "title": "Getting value when Object and String cannot be added"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1615662918,
        "creation_date": 1615578275,
        "last_edit_date": 1615579520,
        "question_id": 66606261,
        "body_markdown": "I have a test.json file:\r\n\r\n    {\r\n    &quot;data&quot; : [\r\n        {\r\n            &quot;application&quot; : &quot;Microsoft Office&quot;,\r\n            &quot;computers&quot; : [\r\n                {\r\n                &quot;active&quot; : true,\r\n                &quot;hostname&quot; : &quot;computer1.domain.local&quot;\r\n                }\r\n            ],\r\n            &quot;file&quot; : {\r\n                &quot;filename&quot; : &quot;WINWORD.EXE&quot;,\r\n                &quot;identity&quot; : {\r\n                &quot;sha256&quot; : &quot;270fe88cca8156912303ebdf9481de99e4265c878cfd41964b2a94131f6c41ad&quot;\r\n                }\r\n            }\r\n        }\r\n    ]\r\n    }\r\n\r\nI can run the following command:\r\n\r\n    jq &#39;.data[] | .computers[] + .file | &quot;\\(.hostname) \\(.filename)&quot;&#39; test.json\r\n\r\nWhich gives me:\r\n\r\n    &quot;computer1.domain.local WINWORD.EXE&quot;\r\n\r\nHow can I include the value of the application key?\r\n\r\nIf I use a command such as\r\n\r\n    jq &#39;.data[] | .computers[] + .application + .file | &quot;\\(.hostname) \\(.application) \\(.filename)&quot;&#39; test.json\r\n\r\nI get the error:\r\n\r\n    jq: error (at test.json:19): object ({&quot;active&quot;:t...) and string (&quot;Microsoft ...) cannot be added\r\n\r\nI would like an output of:\r\n\r\n    &quot;computer1.domain.local Microsoft Office WINWORD.EXE&quot;",
        "link": "https://stackoverflow.com/questions/66606261/getting-value-when-object-and-string-cannot-be-added",
        "title": "Getting value when Object and String cannot be added"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1615581451,
                "last_edit_date": 1615581451,
                "creation_date": 1615580982,
                "answer_id": 66606806,
                "question_id": 66606742,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n\r\naws sts assume-role --role-arn role_arn --role-session-name session_name &gt; mysession.json\r\n\r\n\r\n$ak = jq -r &quot;.Credentials.AccessKeyId&quot; mysession.json\r\n$sk = jq -r &quot;.Credentials.SecretAccessKey&quot; mysession.json\r\n$tk = jq -r &quot;.Credentials.SessionToken&quot; mysession.json\r\n\r\nWrite-Host &quot;Acccess Key ID:&quot; $ak\r\nWrite-Host &quot;Secret Acccess Key:&quot; $sk\r\nWrite-Host &quot;Session Token:&quot; $tk\r\n```\r\n\r\n\r\n**Powershell**\r\n\r\n```\r\n$source_profile = &quot;default&quot;\r\n$region = &quot;ap-southeast-2&quot;\r\n$role_arn = &quot;arn:aws:iam::account_id:role/role-test&quot;\r\n$target_profile = &quot;test&quot;\r\n$target_profile_path =  &quot;$HOME\\.aws\\credentials&quot;\r\n$session_name = &quot;test&quot;\r\n\r\n# Assume Role\r\n$Response = (Use-STSRole -Region $region -RoleArn  $role_arn -RoleSessionName $session_name -ProfileName $source_profile).Credentials\r\n\r\n# Export Crendentail as environment variable\r\n$env:AWS_ACCESS_KEY_ID=$Response.AccessKeyId\r\n$env:AWS_SECRET_ACCESS_KEY=$Response.SecretAccessKey\r\n$env:AWS_SESSION_TOKEN=$Response.SessionToken\r\n\r\n# Create Profile with Credentials\r\nSet-AWSCredential -StoreAs $target_profile -ProfileLocation $target_profile_path -AccessKey $Response.AccessKeyId -SecretKey $Response.SecretAccessKey -SessionToken $Response.SessionToken\r\n\r\n# Print expiration time\r\nWrite-Host(&quot;Credentials will expire at: &quot; + $Response.Expiration)\r\n```\r\n\r\n[AWS Assume Role Script](https://ripon-banik.medium.com/aws-assume-role-script-4e7d3b548f20)\r\n\r\n\r\n[How can I parse an assumed role&#39;s credentials in powershell and set them as a variable in a script?](https://stackoverflow.com/a/52671797/2246345)",
                "title": "jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end in windows"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1667434804,
                "creation_date": 1667434804,
                "answer_id": 74296932,
                "question_id": 66606742,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "On the jq site it mentions [syntax adjustments for Windows][1]:\r\n\r\n&gt; &quot;when using the Windows command shell (cmd.exe) it&#39;s best to use\r\n&gt; double quotes around your jq program when given on the command-line\r\n&gt; (instead of the -f program-file option), but then double-quotes in the\r\n&gt; jq program need backslash escaping.&quot;\r\n\r\nSo, instead of \r\n\r\n    jq -r &#39;&quot;.Credentials.AccessKeyId&quot;&#39; mysession.json\r\n\r\nYou&#39;ll need to escape double quotes, then change single quotes to double.\r\n\r\n    jq -r &quot;\\&quot;.Credentials.AccessKeyId\\&quot;&quot; mysession.json\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Invokingjq\r\n\r\n",
                "title": "jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end in windows"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1667434804,
        "creation_date": 1615580598,
        "last_edit_date": 1615739659,
        "question_id": 66606742,
        "body_markdown": "I am trying to read credentials from assume role like `AcccessKeyID` and store in a variable but getting error:\r\nMy code and error is:\r\n\r\n```\r\njq -r &#39;&quot;.Credentials.AccessKeyId&quot;&#39; mysession.json | awk &#39;&quot;{print &quot;set&quot;,&quot;AWS_ACCESS_KEY_ID=&quot;$0}&quot;&#39; &gt; variables\r\n```\r\n\r\n&gt;jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Windows cmd shell quoting issues?) at , line 1:\r\n&#39;&quot;.Credentials.AccessKeyId&quot;&#39;\r\njq: 1 compile error\r\nawk: &#39;&quot;{print\r\nawk: ^ invalid char &#39;&#39;&#39; in expression\r\n\r\nPlease suggest me how to achieve this activity in **windows CMD** .I have installed jq and awk in windows.",
        "link": "https://stackoverflow.com/questions/66606742/jq-error-syntax-error-unexpected-invalid-character-expecting-end-in-windows",
        "title": "jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end in windows"
    },
    {
        "tags": [
            "syntax",
            "jq",
            "disjunction"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615589761,
                "post_id": 66608197,
                "comment_id": 117747720,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1615592944,
                "last_edit_date": 1615592944,
                "creation_date": 1615590150,
                "answer_id": 66608345,
                "question_id": 66608197,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In your query, you would need parentheses for correct grouping:\r\n```\r\n.entries[] |\r\n (.varFields[] | select(.fieldTag==&quot;l&quot;) | .content // &quot;&quot;), \r\n (.varFields[] | select(.fieldTag==&quot;b&quot;) | .content // &quot;&quot;)\r\n```\r\nor to avoid scanning .varFields redundantly:\r\n```\r\n.entries[]\r\n| (INDEX(.varFields[]; .fieldTag) | map_values(.content)) as $dict\r\n| $dict[&quot;l&quot;,&quot;b&quot;]\r\n| . // &quot;&quot;\r\n```\r\n\r\nIf ordering is unimportant and if both &quot;l&quot; and &quot;b&quot; are known to be present, you could alternatively write:\r\n```\r\n.entries[]\r\n| .varFields[] \r\n| select(.fieldTag | . == &quot;l&quot; or . == &quot;b&quot; ) \r\n| .content // &quot;&quot;\r\n```\r\n\r\nThe disjunctive &quot;select&quot; immediately above could also be written even more DRYly as:\r\n\r\n`select(.fieldTag | IN(&quot;l&quot;,&quot;b&quot; ))` \r\n",
                "title": "Why does this jq expression work if used once, but not twice?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1615789795,
        "creation_date": 1615589075,
        "last_edit_date": 1615789795,
        "question_id": 66608197,
        "body_markdown": "I have a json document \r\n\r\n    {\r\n      &quot;total&quot;: 2000,\r\n      &quot;start&quot;: 0,\r\n      &quot;entries&quot;: [\r\n        {\r\n          &quot;updatedDate&quot;: &quot;2021-03-12T13:00:05Z&quot;,\r\n          &quot;createdDate&quot;: &quot;2010-06-17T05:34:42Z&quot;,\r\n          &quot;deleted&quot;: false,\r\n          &quot;suppressed&quot;: false,\r\n          &quot;names&quot;: [\r\n            &quot;Doe, John&quot;\r\n          ],\r\n          &quot;barcodes&quot;: [\r\n            &quot;23082599944&quot;\r\n          ],\r\n          &quot;expirationDate&quot;: &quot;2022-05-06&quot;,\r\n          &quot;emails&quot;: [\r\n            &quot;name@uni.edu&quot;\r\n          ],\r\n          &quot;patronType&quot;: 14,\r\n          &quot;patronCodes&quot;: {\r\n            &quot;pcode1&quot;: &quot;-&quot;,\r\n            &quot;pcode2&quot;: 0\r\n          },\r\n          &quot;varFields&quot;: [\r\n            {\r\n              &quot;fieldTag&quot;: &quot;b&quot;,\r\n              &quot;content&quot;: &quot;23082501799944&quot;\r\n            },\r\n            {\r\n              &quot;fieldTag&quot;: &quot;l&quot;,\r\n              &quot;content&quot;: &quot;jdoe&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nThat I need to extract the .content where fieldTag is &quot;b&quot; or &quot;l&quot;. In the example, I&#39;ve removed many fields, and the fields I seek will not always be present.\r\n\r\nIf I cat the file into \r\n\r\n    cat myfile |jq -r &#39;.entries[] |\r\n            .varFields[] |select(.fieldTag==&quot;l&quot;) | .content // &quot;&quot;\r\n    &#39;\r\n\r\nworks exactly as expected but \r\n\r\n    cat myfile|jq -r &#39;.entries[] |\r\n            .varFields[] |select(.fieldTag==&quot;l&quot;) | .content // &quot;&quot;, \r\n            .varFields[] |select(.fieldTag==&quot;b&quot;) | .content // &quot;&quot; \r\n    &#39;\r\n\r\nreturns `jq: error (at &lt;stdin&gt;:37): Cannot index string with string &quot;fieldTag&quot;`. I seem to be able to select any field I want, so long as I only select one. Otherwise, I get the error. What am I missing?",
        "link": "https://stackoverflow.com/questions/66608197/why-does-this-jq-expression-work-if-used-once-but-not-twice",
        "title": "Why does this jq expression work if used once, but not twice?"
    },
    {
        "tags": [
            "hex",
            "decimal",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1615618203,
                "creation_date": 1615618203,
                "answer_id": 66610815,
                "question_id": 66610232,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use jq&#39;s -r command-line option to stop jq from emitting the characters strings as JSON strings, i.e. with quotation marks.",
                "title": "The hex string got from jq can&#39;t be converted to decimal value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1615618203,
        "creation_date": 1615610889,
        "question_id": 66610232,
        "body_markdown": "I define some hex strings in json file as follows:\r\n\r\n*$ cat test.json*\r\n\r\n    {\r\n        &quot;device&quot;: {\r\n            &quot;value&quot;: &quot;0x5&quot;,\r\n            &quot;mask&quot;: &quot;0x4&quot;\r\n        }\r\n    }\r\n\r\nAnd the below test.sh script is to read it from json file using jq and then convert the hex string to decimal integer, and then do AND operation. \r\n\r\n$ cat test.sh\r\n\r\n    #!/bin/sh\r\n    \r\n    JSON_FILE=&quot;test.json&quot;\r\n    \r\n    VALUE=$(jq &#39;.device.value&#39; $JSON_FILE)\r\n    echo &quot;Value: $VALUE&quot;\r\n    MASK=$(jq &#39;.device.mask&#39; $JSON_FILE)\r\n    echo &quot;Mask: $MASK&quot;\r\n    \r\n    ret_1=$(printf %u ${VALUE})\r\n    ret_2=$(printf %u ${MASK})\r\n    echo &quot;value: ${ret_1}, mask: ${ret_2}&quot;\r\n    \r\n    RESULT=$((${ret_1} &amp; ${ret_2}))\r\n    echo &quot;Result: $RESULT&quot;\r\n\r\nHowever, we get the incorrect result because the step to convert hex string is failed, which is always 48 (0x30). Is there better solution? Thanks.\r\n\r\n$ ./test.sh\r\n\r\n    Value: &quot;0x5&quot;\r\n    Mask: &quot;0x4&quot;\r\n    value: 48, mask: 48\r\n    Result: 48",
        "link": "https://stackoverflow.com/questions/66610232/the-hex-string-got-from-jq-cant-be-converted-to-decimal-value",
        "title": "The hex string got from jq can&#39;t be converted to decimal value"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1615703675,
                "last_edit_date": 1615703675,
                "creation_date": 1615702752,
                "answer_id": 66621664,
                "question_id": 66621445,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Split `$key` into individual paths and convert each to a format `getpath` could understand. Then you can collect values they point to in an array and join them by commas.\r\n\r\nFor example, if it&#39;s guaranteed that no single path component contain a dot character, something like this should work fine:\r\n``` none\r\n[getpath(($key / &quot;,&quot;)[] / &quot;.&quot;)] | join(&quot;,&quot;)\r\n```\r\n```\r\n$ KEYS=id,coord.lon,coord.lat\r\n$ jq -r &#39;[getpath(($key / &quot;,&quot;)[] / &quot;.&quot;)] | join(&quot;,&quot;)&#39; file --arg key &quot;$KEYS&quot;\r\n707860,34.283333,44.549999\r\n```",
                "title": "How to parse JSON with keys from a BASH variable using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1615703675,
        "creation_date": 1615700431,
        "last_edit_date": 1615701441,
        "question_id": 66621445,
        "body_markdown": "I have a JSON array in this format\r\n\r\n    {\r\n      &quot;id&quot;: 707860,\r\n      &quot;name&quot;: &quot;Hurzuf&quot;,\r\n      &quot;country&quot;: &quot;UA&quot;,\r\n      &quot;coord&quot;: {\r\n        &quot;lon&quot;: 34.283333,\r\n        &quot;lat&quot;: 44.549999\r\n      }\r\n    }\r\n\r\nI am using `jq` to parse it. I&#39;m trying to extract the values of only the keys which are provided in a BASH variable. I tried this with one key in the variable and it works.\r\n\r\n    KEY=id\r\n    jq -r --arg key $KEY &#39;.[] | .[$key]&#39;\r\n\r\n\r\nHowever when I tried the same with `KEY=coord.lat` the output is `null` and I&#39;m stumped when the number of keys isn&#39;t a given.\r\n\r\nFor example, if the variable is\r\n\r\n    KEYS=id,name\r\n\r\nthen the output should be\r\n\r\n    707860,&quot;Hurzuf&quot;\r\n\r\nor, if the variable is\r\n\r\n    KEYS=coord.lon,coord.lat\r\n\r\nthen the output should be\r\n\r\n     34.283333,44.549999\r\n\r\nHow can this be done?",
        "link": "https://stackoverflow.com/questions/66621445/how-to-parse-json-with-keys-from-a-bash-variable-using-jq",
        "title": "How to parse JSON with keys from a BASH variable using jq?"
    },
    {
        "tags": [
            "json",
            "csv",
            "tensorflow",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1615791635,
                "post_id": 66633378,
                "comment_id": 117790577,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9088643,
                    "reputation": 120,
                    "user_id": 8398127,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3f0030b4d0e6a89561b70ceed1b13692?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "David Moore",
                    "link": "https://stackoverflow.com/users/8398127/david-moore"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615802397,
                "post_id": 66633378,
                "comment_id": 117794444,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1615809071,
                "last_edit_date": 1615809071,
                "creation_date": 1615792082,
                "answer_id": 66633653,
                "question_id": 66633378,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\n. as $data |\r\nkeys_unsorted as $ids |\r\n( .[ $ids[0] ] | keys_unsorted ) as $fields |\r\n(\r\n   [ &quot;id&quot;, $fields[] ],\r\n   ( $ids[] | [ ., $data[.][$fields[]] ] )\r\n) | @csv\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/zF5h5xsJF0)\r\n\r\nor\r\n\r\n```jq\r\nkeys_unsorted as $ids |\r\n( .[ $ids[0] ] | keys_unsorted ) as $fields |\r\n(\r\n   [ &quot;id&quot;, $fields[] ],\r\n   ( to_entries[] | [ .key, .value[$fields[]] ] )\r\n) | @csv\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/f_pi5E6SAV)\r\n\r\nNeither handles an empty input (`{}`) well.\r\n\r\n---\r\n\r\nFor comparison, @peak&#39;s solution with headers would be\r\n\r\n```jq\r\nkeys_unsorted as $ids |\r\n( .[ $ids[0] ] | keys_unsorted ) as $fields |\r\n(\r\n   [ &quot;id&quot;, $fields[] ],\r\n   ( $ids[] as $id | [ $id, .[$id][$fields[]] ] )\r\n) | @csv\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/YDFSulx_hy)\r\n\r\nIt doesn&#39;t handle an empty input (`{}`) well either\r\n",
                "title": "Need jq help to turn a semi-malformed but very simple json file into csv"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1615820328,
                "last_edit_date": 1615820328,
                "creation_date": 1615792513,
                "answer_id": 66633723,
                "question_id": 66633378,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following solution is a bit trickier than it might otherwise be because it is &quot;data-driven&quot; (no key names other than &quot;File&quot; are hard-coded in the jq program) while not assuming that the inner keys are ordered consistently:\r\n\r\n```\r\n  keys_unsorted as $outer\r\n  | (.[$outer[0]] | keys_unsorted) as $inner\r\n  | [&quot;File&quot;] + ($inner|map((.[:1]|ascii_upcase) + .[1:])),\r\n    ($outer[] as $k\r\n     | [$k] + [.[$k] | .[$inner[]]])\r\n  | @tsv\r\n```\r\n\r\nYou might of course wish to use `@csv` instead of `@tsv`.\r\n\r\n(There are many SO questions illustrating how headers can be added, e.g. the following includes an illustration of how to add them without hardcoding them, and with dynamically generated &quot;-&quot; lines beneath the primary headers: https://stackoverflow.com/questions/39139107/how-to-format-a-json-string-as-a-table-using-jq)",
                "title": "Need jq help to turn a semi-malformed but very simple json file into csv"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1615820328,
        "creation_date": 1615790398,
        "last_edit_date": 1615792859,
        "question_id": 66633378,
        "body_markdown": "I have a bit of a problem. I&#39;ve tried so many different iterations of `jq -r` against a large set of json files being spit out by an object detector but I just can&#39;t make it happy enough to give me a csv file. I simplified these massive files into a very short example below with the exact same data structure (note, the names of things like &quot;book&quot;, &quot;person&quot;, &quot;animal&quot; are ever changing among the scripts, so if there is a way to do this without hardcoding the keys in the command, that would be most desirous but not requiredous) \r\n\r\nExample:\r\n\r\n```\r\n{\r\n    &quot;/src/files/image_1.png&quot;: {\r\n        &quot;book&quot;: 0.01711445301771164,\r\n        &quot;person&quot;: 0.000330559065533263624,\r\n        &quot;place&quot;: 0.9814764857292175,\r\n        &quot;animal&quot;: 1.8662762158783153e-05,\r\n        &quot;vehicle&quot;: 0.0010597968939691782\r\n    },\r\n    &quot;/src/files/image_2.png&quot;: {\r\n        &quot;book&quot;: 0.23741412162780762,\r\n        &quot;person&quot;: 0.1587823033328247,\r\n        &quot;place&quot;: 0.59659236669504,\r\n        &quot;animal&quot;: 0.0036556862760335207,\r\n        &quot;vehicle&quot;: 0.003555471543222666\r\n    }\r\n}\r\n```\r\n\r\nIdeally, I&#39;d like to make a csv file whose tabular format would look something like this:  \r\n\r\n\r\n|File|Book|Person|Place|Animal|Vehicle|\r\n|----|----|------|-----|------|-------|\r\n|/src/files/image_1.png|0.01711445301771164|0.000330559065533263624|0.9814764857292175|1.8662762158783153e-05|0.0010597968939691782|\r\n|/src/files/image_2.png|0.23741412162780762|0.1587823033328247|0.59659236669504|0.0036556862760335207|0.003555471543222666|\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66633378/need-jq-help-to-turn-a-semi-malformed-but-very-simple-json-file-into-csv",
        "title": "Need jq help to turn a semi-malformed but very simple json file into csv"
    },
    {
        "tags": [
            "json",
            "jq",
            "parent",
            "recursive-datastructures"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1615824347,
                "last_edit_date": 1615824347,
                "creation_date": 1615818668,
                "answer_id": 66639922,
                "question_id": 66639380,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is easy. Get the path to the string you&#39;re looking for, retrieve the path to its grand grandparent out of it, and extract `text` from there.\r\n``` none\r\ngetpath(\r\n  paths(strings\r\n    | select(. == &quot;acca&quot;)\r\n  )[:-3]\r\n) .text\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/KIws-K6WMq)&lt;/sup&gt;",
                "title": "JQ - Recursive JSON return parent"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1615822786,
                "creation_date": 1615822786,
                "answer_id": 66641104,
                "question_id": 66639380,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a succinct, parameterized solution that does not require explicit use of `recurse`:\r\n\r\n```\r\npaths(objects | select(.text == $needle)) as $p\r\n| getpath($p[:-2]).text\r\n```\r\nExample usage:\r\n\r\n    jq --arg needle acca -f program.jq input.json\r\n\r\n(Notice that there might not be any need to quote the &quot;needle&quot;.)\r\n\r\n",
                "title": "JQ - Recursive JSON return parent"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1615824347,
        "creation_date": 1615816701,
        "last_edit_date": 1615823873,
        "question_id": 66639380,
        "body_markdown": "I&#39;m tryng to return a parent in this kind of json using JQ:\r\n\r\n```\r\n{\r\n\t&quot;all&quot; : {\r\n\t\t&quot;text&quot;: &quot;a&quot;,\r\n\t\t&quot;children&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;text&quot;: &quot;aa&quot;,\r\n\t\t\t\t&quot;children&quot;: []\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;text&quot;: &quot;ab&quot;,\r\n\t\t\t\t&quot;children&quot;: []\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;text&quot;: &quot;ac&quot;,\r\n\t\t\t\t&quot;children&quot;: [\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;text&quot;: &quot;aca&quot;,\r\n\t\t\t\t\t\t&quot;children&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;text&quot;: &quot;acb&quot;,\r\n\t\t\t\t\t\t&quot;children&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;text&quot;: &quot;acc&quot;,\r\n\t\t\t\t\t\t&quot;children&quot;: [\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;text&quot;: &quot;acca&quot;,\r\n\t\t\t\t\t\t\t\t&quot;children&quot;: []\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\r\n\t\t\t\t\t\t]\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n}\r\n\r\n```\r\n\r\nThe goal is to retrieve the parent text for an element.\r\nFor example:\r\n - searching acca --&gt; acc\r\n - searching  acc --&gt; ac\r\n\r\n\r\nThis code doesn&#39;t work:\r\n```.all  | .children[] as $parent | select(.children[].text == &quot;acca&quot; )  | $parent.text```\r\n\r\nSomeone can help me?\r\nThanks! :)",
        "link": "https://stackoverflow.com/questions/66639380/jq-recursive-json-return-parent",
        "title": "JQ - Recursive JSON return parent"
    },
    {
        "tags": [
            "json",
            "group-by",
            "jq",
            "data-manipulation",
            "counting"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1615827755,
                "last_edit_date": 1615827755,
                "creation_date": 1615825962,
                "answer_id": 66641957,
                "question_id": 66641816,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    echo &#39;[{&quot;name&quot;: &quot;test&quot;}, {&quot;name&quot;: &quot;hello&quot;}, {&quot;name&quot;: &quot;hello&quot;}]&#39; | jq &#39;group_by (.name)[] | {name: .[0].name, count: length}&#39; | jq -s\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;hello&quot;,\r\n    &quot;count&quot;: 2\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;test&quot;,\r\n    &quot;count&quot;: 1\r\n  }\r\n]\r\n```",
                "title": "Group and count JSON using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1615828775,
                "last_edit_date": 1615828775,
                "creation_date": 1615826116,
                "answer_id": 66641987,
                "question_id": 66641816,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\ngroup_by(.name) \r\n    | map({name: .[0].name, count: length})   \r\n```\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;hello&quot;,\r\n    &quot;count&quot;: 2\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;test&quot;,\r\n    &quot;count&quot;: 1\r\n  }\r\n]\r\n```\r\n\r\n## [Jq▷Play][1]\r\n\r\n\r\n&lt;hr&gt; \r\n\r\nBased on OP&#39;s [comment][2], use the following jq filter to count each name across multiple objects, where the `.name` is nested.\r\n```\r\nmap(.labels) \r\n    | map({name: .[0].name, count: length})\r\n```\r\n\r\n[Jq▷Play](https://jqplay.org/s/XNVHIvTfVk)\r\n\r\n  [1]: https://jqplay.org/s/BbTsCyTPCy\r\n  [2]: https://stackoverflow.com/questions/66641816/group-and-count-json-using-jq/66641987?noredirect=1#comment117806635_66641987",
                "title": "Group and count JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1615828775,
        "creation_date": 1615825445,
        "last_edit_date": 1615827962,
        "question_id": 66641816,
        "body_markdown": "I am trying to convert the following JSON into a csv which has each unique &quot;name&quot; and the total count (i.e: number of times that name appears).\r\n\r\n## Current data:\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;test&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;hello&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;hello&quot;\r\n  }\r\n]\r\n```\r\n\r\n## Ideal output:\r\n```json\r\n[\r\n    {\r\n        &quot;name&quot;: &quot;hello&quot;,\r\n        &quot;count&quot;: 2\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;test&quot;,\r\n        &quot;count&quot;: 1\r\n    }\r\n]\r\n```\r\n\r\nI&#39;ve tried `[.[] | group_by (.name)[] ]` but get the following error:\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:11): Cannot index string with string &quot;name&quot;\r\n\r\nJQ play link: https://jqplay.org/s/fWqNUii1b2\r\n\r\nNote, I am already using jq to format the initial raw data into the format above. Please see the JQ play link here: https://jqplay.org/s/PwwRYscmBK",
        "link": "https://stackoverflow.com/questions/66641816/group-and-count-json-using-jq",
        "title": "Group and count JSON using jq"
    },
    {
        "tags": [
            "json",
            "object",
            "key",
            "jq",
            "query-by-example"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1615861416,
                "last_edit_date": 1615861416,
                "creation_date": 1615842520,
                "answer_id": 66645697,
                "question_id": 66645317,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could easily define your `myFilter` using `reduce`:\r\n\r\n    def myFilter($keys):\r\n      . as $in\r\n      | reduce $keys[] as $k (null; . + {($k): $in[$k]} );\r\n\r\nMore interestingly, if you&#39;re willing to modify your &quot;Query By Example&quot; requirements slightly, you can simply specify the keys of interest in braces, as illustrated by this example:\r\n```\r\njq -n &#39;{name: &quot;Chris&quot;, age: 25, city: &quot;Chicago&quot;} | {name, age}&#39;\r\n```\r\n\r\nIf any of the keys cannot be specified in this abbreviated format, simply double-quote them.\r\n\r\n",
                "title": "How can I reference dynamic keys on an object in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1615861416,
        "creation_date": 1615840586,
        "last_edit_date": 1615857250,
        "question_id": 66645317,
        "body_markdown": "I&#39;m trying to define some custom filter functions and one thing I need to be able to do is pass a list of strings to a filter and get the corresponding values of the input object. For example:\r\n\r\n`jq -n &#39;{name: &quot;Chris&quot;, age: 25, city: &quot;Chicago&quot;} | myFilter([&quot;name&quot;, &quot;age&quot;])&#39;`\r\n\r\nshould return:\r\n\r\n`{&quot;name&quot;: &quot;Chris&quot;, &quot;age&quot;: 25}`.\r\n\r\nI know I can use `.[some_string]` to dynamically get a value on an object for a specific string key, but I don&#39;t know how to utilize this for multiple string keys. I think the problem I&#39;m running into is that jq by default iterates over *objects* streamed into a filter, but doesn&#39;t give a way to iterate over an argument to that filter, even if I use `def myFilter($var)` syntax that the manual recommends for *value-argument behavior*.",
        "link": "https://stackoverflow.com/questions/66645317/how-can-i-reference-dynamic-keys-on-an-object-in-jq",
        "title": "How can I reference dynamic keys on an object in jq?"
    },
    {
        "tags": [
            "curl",
            "jq",
            "xargs"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1615862313,
                "last_edit_date": 1615862313,
                "creation_date": 1615858508,
                "answer_id": 66647941,
                "question_id": 66647704,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re right about the relevance of `|=` for updating the input, which I&#39;ll assume is in a file named input.json\r\n\r\nUnfortunately, as you&#39;ve already noticed, jq doesn&#39;t support &quot;external&quot; evaluations, but here is one approach that at least is direct and only requires two invocations of jq:\r\n\r\n```\r\nwhile read url ; do\r\n    curl -sSL &quot;$url&quot; -o /dev/null -w &#39;%{content_type}&#39;\r\ndone &lt; &lt;(jq -r .data[].Url input.json) | \r\njq -Rn --argfile json input.json &#39;\r\n  [inputs] as $in\r\n  | $json\r\n  | .data |= reduce range(0;length) as $i (.;\r\n               .[$i].ContentType = $in[$i])\r\n&#39;\r\n",
                "title": "jq - add entry calculated with external command"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1615861519,
                "creation_date": 1615861519,
                "answer_id": 66648288,
                "question_id": 66647704,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Creating an array of content types and merging it back into the original JSON:\r\n\r\n    jq &#39;.data[].Url&#39; input.json |\\\r\n    xargs -n1 curl -sSL -o /dev/null -w &#39;%{content_type}\\n&#39; |\\\r\n    jq --slurp --raw-input &#39;split(&quot;\\n&quot;)[:-1] | map({&quot;Content-Type&quot;: .})&#39; |\\\r\n    jq -n --argfile in1 input.json --argfile in2 /dev/stdin &#39;$in1 | .data |= ([., $in2] | transpose| map(add))&#39;",
                "title": "jq - add entry calculated with external command"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1615862313,
        "creation_date": 1615856215,
        "question_id": 66647704,
        "body_markdown": "My input:\r\n\r\n```json\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;Name&quot;: &quot;name 1&quot;,\r\n      &quot;Url&quot;: &quot;https://some-content.com&quot;\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;name 2&quot;,\r\n      &quot;Url&quot;: &quot;https://soming-else.com&quot;\r\n    }\r\n}\r\n```\r\n\r\nI want to check `content-type` of each `Url` with `curl` and add it to each object. So, I&#39;ll get:\r\n\r\n```json\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;Name&quot;: &quot;name 1&quot;,\r\n      &quot;Url&quot;: &quot;https://some-content.com&quot;,\r\n      &quot;ContentType&quot;: &quot;video&quot;\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;name 2&quot;,\r\n      &quot;Url&quot;: &quot;https://soming-else.com&quot;,\r\n      &quot;ContentType&quot;: &quot;text&quot;\r\n    }\r\n}\r\n```\r\n\r\nThe command I am using to check the value of a `content-type` response header:\r\n\r\n```sh\r\ncurl -sSL &lt;url&gt; -o /dev/null -w &#39;%{content_type}&#39;\r\n```\r\n\r\nI have a feeling that `xargs` is the right way to go, but I haven&#39;t figured out how to add the result of it to the input JSON in the fashion described above.\r\n\r\nI&#39;m also aware of jq&#39;s `=|` operator, but I don&#39;t know how to get the result of `xrags` in it.\r\n\r\nIs there a solution to my problem? Can it be done with the tools I&#39;m trying to do it with?",
        "link": "https://stackoverflow.com/questions/66647704/jq-add-entry-calculated-with-external-command",
        "title": "jq - add entry calculated with external command"
    },
    {
        "tags": [
            "json",
            "mongodb",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 26377,
                    "reputation": 363501,
                    "user_id": 68587,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/7d9fd158e03cbde94f7e0b33b78222af?s=256&d=identicon&r=PG",
                    "display_name": "John Kugelman",
                    "link": "https://stackoverflow.com/users/68587/john-kugelman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615875527,
                "post_id": 66649822,
                "comment_id": 117820022,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615875532,
                "post_id": 66649822,
                "comment_id": 117820026,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615875555,
                "post_id": 66649822,
                "comment_id": 117820029,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1615875667,
                "post_id": 66649822,
                "comment_id": 117820064,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1615875715,
                "post_id": 66649822,
                "comment_id": 117820078,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1615877905,
                "last_edit_date": 1615877905,
                "creation_date": 1615877595,
                "answer_id": 66650297,
                "question_id": 66649822,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to use jq with your data, you will first have to convert it to (or render it as) JSON. This can be done in various ways, e.g. using `mongoexport`:\r\n\r\n&gt; mongoexport is a command-line tool that produces a JSON or CSV export of data stored in a MongoDB instance.\r\n\r\nhttps://docs.mongodb.com/database-tools/mongoexport/",
                "title": "How to parse this json with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1615877708,
                "creation_date": 1615877708,
                "answer_id": 66650320,
                "question_id": 66649822,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The logfile is in BSON format, however `jq` parses only JSON, see [JSON and BSON][1]. \r\n\r\nObviously your files comes from `db.currentOp()`, see https://dba.stackexchange.com/questions/287020/save-output-of-a-mongo-command-to-a-variable-bash-script\r\n\r\nWhy do you try to run a shell script? You an do it all in mongo shell script (which is JavaScript). Could look similar to this:\r\n\r\n    db.currentOp().inprog.forEach(function (x) {\r\n       if (x.op == &quot;find&quot; &amp;&amp; x.secs_running &gt; 5) {\r\n          db.killOp(x.opid);\r\n       }\r\n    })\r\n\r\n\r\nPrinting all commands would be similar to this:\r\n\r\n    db.currentOp().inprog.map(x =&gt; x.command)\r\n\r\nI would say, it&#39;s time to learn [JavaScript][2].\r\n\r\n\r\n  [1]: https://www.mongodb.com/json-and-bson\r\n  [2]: https://www.w3schools.com/js/DEFAULT.asp",
                "title": "How to parse this json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1615877905,
        "creation_date": 1615874355,
        "last_edit_date": 1615876445,
        "question_id": 66649822,
        "body_markdown": "    { &quot;inprog&quot; : [ { &quot;host&quot; : &quot;DESKTOP-LTB3QQ5:27017&quot;, &quot;desc&quot; : &quot;conn25&quot;, &quot;connectionId&quot; : 25, &quot;client&quot; : &quot;127.0.0.1:38354&quot;, &quot;appName&quot; : &quot;MongoDB Shell&quot;, &quot;clientMetadata&quot; : { &quot;application&quot; : { &quot;name&quot; : &quot;MongoDB Shell&quot; }, &quot;driver&quot; : { &quot;name&quot; : &quot;MongoDB Internal Client&quot;, &quot;version&quot; : &quot;3.6.8&quot; }, &quot;os&quot; : { &quot;type&quot; : &quot;Linux&quot;, &quot;name&quot; : &quot;Ubuntu&quot;, &quot;architecture&quot; : &quot;x86_64&quot;, &quot;version&quot; : &quot;20.04&quot; } }, &quot;active&quot; : true, &quot;currentOpTime&quot; : &quot;2021-03-16T11:01:14.599+0530&quot;, &quot;opid&quot; : 3135, &quot;lsid&quot; : { &quot;id&quot; : UUID(&quot;82088a94-16c2-4aa2-92d8-c557e74049a1&quot;), &quot;uid&quot; : BinData(0,&quot;47DEQpj8HBSa+/TImW+5JCeuQeRkm5NMpJWZG3hSuFU=&quot;) }, &quot;secs_running&quot; : NumberLong(0), &quot;microsecs_running&quot; : NumberLong(65), &quot;op&quot; : &quot;command&quot;, &quot;ns&quot; : &quot;admin.$cmd.aggregate&quot;, &quot;command&quot; : { &quot;currentOp&quot; : 1, &quot;lsid&quot; : { &quot;id&quot; : UUID(&quot;82088a94-16c2-4aa2-92d8-c557e74049a1&quot;) }, &quot;$db&quot; : &quot;admin&quot; }, &quot;numYields&quot; : 0, &quot;locks&quot; : { }, &quot;waitingForLock&quot; : false, &quot;lockStats&quot; : { } } ], &quot;ok&quot; : 1 }\r\n\r\ncommand ```cat mon.json | jq```\r\n\r\nwhen I parse this with jq I get this error \r\n\r\n```parse error: Invalid numeric literal at line 1, column 493```\r\n\r\nI think this is because &quot;id&quot;: UUID(&quot;82088a94-16c2-4aa2-92d8-c557e74049a1&quot;) ",
        "link": "https://stackoverflow.com/questions/66649822/how-to-parse-this-json-with-jq",
        "title": "How to parse this json with jq"
    },
    {
        "tags": [
            "json",
            "object",
            "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": 1615907744,
                "post_id": 66657350,
                "comment_id": 117834316,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3958942,
                    "reputation": 572,
                    "user_id": 3266589,
                    "user_type": "registered",
                    "accept_rate": 58,
                    "profile_image": "https://i.sstatic.net/vAroQ.jpg?s=256",
                    "display_name": "Tiggyboo",
                    "link": "https://stackoverflow.com/users/3266589/tiggyboo"
                },
                "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": 1615910839,
                "post_id": 66657350,
                "comment_id": 117835910,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1615925121,
                "last_edit_date": 1615925121,
                "creation_date": 1615918292,
                "answer_id": 66660990,
                "question_id": 66657350,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A minimalist &quot;reduce-free&quot; solution, here spread over multiple lines for clarity:\r\n```\r\njq -Rn &#39;\r\n  [inputs|split(&quot;|&quot;)]\r\n  | transpose\r\n  | map({(.[0]): .[1]})\r\n  | add&#39; labels.psv data.psv\r\n```\r\n\r\n### Multiple data lines\r\nThe following handles multiple data lines, and is a little more robust as well:\r\n```\r\njq -nR &#39;\r\n  # From the web:\r\n  def objectify($keys):\r\n    [$keys, .] | transpose | map({(.[0]): .[1]}) | add;\r\n\r\n  (input|split(&quot;|&quot;)) as $keys\r\n  | inputs | split(&quot;|&quot;) | objectify($keys)\r\n&#39; labels.psv data.psv\r\n\r\n\r\n",
                "title": "Convert piped file to json using jq and insert labels"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1615925286,
        "creation_date": 1615905328,
        "last_edit_date": 1615925286,
        "question_id": 66657350,
        "body_markdown": "Given a couple of pipe delimited text files:\r\n\r\nfile 1:\r\n\r\n`data1|data2|data3|data4`\r\n\r\nfile 2:\r\n\r\n`label1|label2|label3|label4`\r\n\r\nI&#39;m looking to create json output like this:\r\n\r\n`{\r\n  &quot;label1&quot;: &quot;data1&quot;,\r\n  &quot;label2&quot;: &quot;data2&quot;,\r\n  &quot;label3&quot;: &quot;data3&quot;,\r\n  &quot;label4&quot;: &quot;data4&quot;\r\n}`\r\n\r\nI&#39;ve gotten this far:\r\n\r\n`jq -R -s &#39;rtrimstr(&quot;\\n&quot;) | split(&quot;|&quot;) | to_entries | reduce .[] as $o ({}; .[&quot;field&quot; + ($o.key+1|tostring)] |= $o.value )&#39;`\r\n\r\n...which just increments fieldx labels, and doesn&#39;t use a &quot;label&quot; file, which is my main objective.\r\n\r\n`{\r\n  &quot;field1&quot;: &quot;data1&quot;,\r\n  &quot;field2&quot;: &quot;data2&quot;,\r\n  &quot;field3&quot;: &quot;data3&quot;,\r\n  &quot;field4&quot;: &quot;data4&quot;\r\n}`\r\n\r\nI realize there are lots of ways to get  this done, but I&#39;m hoping to stay with jq for my own learning experience.\r\n\r\nThanks in advance for any tips!\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66657350/convert-piped-file-to-json-using-jq-and-insert-labels",
        "title": "Convert piped file to json using jq and insert labels"
    },
    {
        "tags": [
            "ubuntu",
            "ansible",
            "jq",
            "adhoc"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1616011416,
                "creation_date": 1616011416,
                "answer_id": 66680449,
                "question_id": 66680372,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To avoid having to navigate to the relevant object, you could let jq do the walking:\r\n\r\n    jq &#39;.. | objects | .ansible_distribution_file_variety // empty&#39; data.json\r\n\r\n",
                "title": "How to get OS version using ad hoc and jq from json output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1616041594,
        "creation_date": 1616011109,
        "last_edit_date": 1616041594,
        "question_id": 66680372,
        "body_markdown": "It&#39;s such a silly question, but could someone give an example (and if it possible, a couple of links to clearly understand jq using (it&#39;s a little bit hard for me to understand official jq documentation) ) how to get OS name *Debian* from line  *&quot;ansible_distribution_file_variety&quot;: &quot;Debian&quot;*, from the result of the command: \r\n```\r\nansible all -m setup -a &#39;filter=ansible_distribution*&#39; -u vagrant --ask-pass\r\n``` \r\n\r\nthe output of the command is:\r\n```\r\n{\r\n    &quot;custom_stats&quot;: {},\r\n    &quot;global_custom_stats&quot;: {},\r\n    &quot;plays&quot;: [\r\n        {\r\n            &quot;play&quot;: {\r\n                &quot;duration&quot;: {\r\n                    &quot;end&quot;: &quot;2021-03-17T19:44:59.156229Z&quot;,\r\n                    &quot;start&quot;: &quot;2021-03-17T19:44:55.293502Z&quot;\r\n                },\r\n                &quot;id&quot;: &quot;080027fa-0b32-fdef-8eef-000000000007&quot;,\r\n                &quot;name&quot;: &quot;Ansible Ad-Hoc&quot;\r\n            },\r\n            &quot;tasks&quot;: [\r\n                {\r\n                    &quot;hosts&quot;: {\r\n                        &quot;localhost&quot;: {\r\n                            &quot;_ansible_no_log&quot;: false,\r\n                            &quot;_ansible_verbose_override&quot;: true,\r\n                            &quot;action&quot;: &quot;setup&quot;,\r\n                            &quot;ansible_facts&quot;: {\r\n                                &quot;ansible_distribution&quot;: &quot;Ubuntu&quot;,\r\n                                &quot;ansible_distribution_file_parsed&quot;: true,\r\n                                &quot;ansible_distribution_file_path&quot;: &quot;/etc/os-release&quot;,\r\n                                &quot;ansible_distribution_file_variety&quot;: &quot;Debian&quot;,\r\n                                &quot;ansible_distribution_major_version&quot;: &quot;16&quot;,\r\n                                &quot;ansible_distribution_release&quot;: &quot;xenial&quot;,\r\n                                &quot;ansible_distribution_version&quot;: &quot;16.04&quot;,\r\n                                &quot;discovered_interpreter_python&quot;: &quot;/usr/bin/python&quot;\r\n                            },\r\n                            &quot;changed&quot;: false,\r\n                            &quot;deprecations&quot;: [\r\n                                {\r\n                                    &quot;msg&quot;: &quot;Distribution Ubuntu 16.04 on host localhost should use /usr/bin/python3, but is using /usr/bin/python for backward compatibility with prior Ansible releases. A future Ansible release will default to using the discovered platform python for this host. See https://docs.ansible.com/ansible/2.9/reference_appendices/interpreter_discovery.html for more information&quot;,\r\n                                    &quot;version&quot;: &quot;2.12&quot;\r\n                                }\r\n                            ],\r\n                            &quot;invocation&quot;: {\r\n                                &quot;module_args&quot;: {\r\n                                    &quot;fact_path&quot;: &quot;/etc/ansible/facts.d&quot;,\r\n                                    &quot;filter&quot;: &quot;ansible_distribution*&quot;,\r\n                                    &quot;gather_subset&quot;: [\r\n                                        &quot;all&quot;\r\n                                    ],\r\n                                    &quot;gather_timeout&quot;: 10\r\n                                }\r\n                            }\r\n                        }\r\n                    },\r\n                    &quot;task&quot;: {\r\n                        &quot;duration&quot;: {\r\n                            &quot;end&quot;: &quot;2021-03-17T19:44:59.156229Z&quot;,\r\n                            &quot;start&quot;: &quot;2021-03-17T19:44:55.361244Z&quot;\r\n                        },\r\n                        &quot;id&quot;: &quot;080027fa-0b32-fdef-8eef-000000000009&quot;,\r\n                        &quot;name&quot;: &quot;setup&quot;\r\n                    }\r\n                }\r\n            ]\r\n        }\r\n    ],\r\n    &quot;stats&quot;: {\r\n        &quot;localhost&quot;: {\r\n            &quot;changed&quot;: 0,\r\n            &quot;failures&quot;: 0,\r\n            &quot;ignored&quot;: 0,\r\n            &quot;ok&quot;: 1,\r\n            &quot;rescued&quot;: 0,\r\n            &quot;skipped&quot;: 0,\r\n            &quot;unreachable&quot;: 0\r\n        }\r\n    }\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/66680372/how-to-get-os-version-using-ad-hoc-and-jq-from-json-output",
        "title": "How to get OS version using ad hoc and jq from json output"
    },
    {
        "tags": [
            "arrays",
            "yaml",
            "jq",
            "yq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 101098,
                    "reputation": 2657,
                    "user_id": 272159,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/kZ1oq.jpg?s=256",
                    "display_name": "wsams",
                    "link": "https://stackoverflow.com/users/272159/wsams"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1616021805,
                "post_id": 66682183,
                "comment_id": 117876759,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 101098,
                    "reputation": 2657,
                    "user_id": 272159,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/kZ1oq.jpg?s=256",
                    "display_name": "wsams",
                    "link": "https://stackoverflow.com/users/272159/wsams"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1616022435,
                "post_id": 66682183,
                "comment_id": 117876922,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1616023714,
                "creation_date": 1616023714,
                "answer_id": 66682707,
                "question_id": 66682183,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `|=`, e.g. like so:\r\n\r\n```\r\nyq eval &#39;.pets[] |= (.shots = (.name + &quot;.upToDate&quot;))&#39; pets.yaml\r\n```",
                "title": "Conditionally add properties to elements of array with yq (version 4)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1616023714,
        "creation_date": 1616020244,
        "last_edit_date": 1616021426,
        "question_id": 66682183,
        "body_markdown": "I have a YAML document that contains an array. I would like to conditionally add properties to the elements of that array using [`yq` version 4](https://mikefarah.gitbook.io/yq/v/v4.x/upgrading-from-v3) from mikefarah.\r\n\r\nHere is a sample YAML document.\r\n\r\n```\r\nname: &quot;My Pets&quot;\r\npets:\r\n- name: &quot;cat&quot;\r\n  age: 8\r\n- name: &quot;dog&quot;\r\n  age: 3\r\n- name: &quot;mouse&quot;\r\n  age: 1\r\n```\r\n\r\nI would like to transform this into,\r\n\r\n```\r\nname: &quot;My Pets&quot;\r\npets:\r\n- name: &quot;cat&quot;\r\n  age: 8\r\n  shots: cat.upToDate\r\n- name: &quot;dog&quot;\r\n  age: 3\r\n  shots: dog.upToDate\r\n- name: &quot;mouse&quot;\r\n  age: 1\r\n  shots: mouse.upToDate\r\n```\r\n\r\nwhere we add a `shots` property to each element of `pets`. The value of `shots` should be whatever the `name` value is, dot, `upToDate`.\r\n\r\nI&#39;m trying something like this,\r\n\r\n```\r\nyq eval &#39;.pets[] | select(.name == &quot;cat&quot;).shots = &quot;cat.upToDate&quot;&#39; test.yaml\r\n```\r\n\r\nbut that produces,\r\n\r\n```\r\nname: &quot;cat&quot;\r\nage: 8\r\nshots: cat.upToDate\r\nname: &quot;dog&quot;\r\nage: 3\r\nname: &quot;mouse&quot;\r\nage: 1\r\n```\r\n\r\nI need to preserve the entire original YAML document and just insert the `shots` property.\r\n\r\nThis is close but missing all of the other pets.\r\n\r\n```\r\nyq eval &#39;.pets = (.pets[] | select(.name == &quot;cat&quot;).shots = &quot;cats.upToDate&quot;)&#39; test.yaml\r\n```\r\n\r\nIt produces,\r\n\r\n```\r\nname: &quot;My Pets&quot;\r\npets:\r\n  name: &quot;cat&quot;\r\n  age: 8\r\n  shots: cats.upToDate\r\n```\r\n\r\nI&#39;m thinking maybe we could store the name of the pet in a variable and reference that later, but v4 is brand new to me today.\r\n\r\nI would prefer to have a one-liner so that I don&#39;t have to filter on `.name`. This array has less than 10 elements so I could easily hard-code the name and call `yq` 10 times.\r\n\r\nAny thoughts or suggestions? Many thanks, Weldon",
        "link": "https://stackoverflow.com/questions/66682183/conditionally-add-properties-to-elements-of-array-with-yq-version-4",
        "title": "Conditionally add properties to elements of array with yq (version 4)"
    },
    {
        "tags": [
            "python",
            "json",
            "mapping",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1616089779,
                "creation_date": 1616089779,
                "answer_id": 66696465,
                "question_id": 66694992,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Presumably you mean:\r\n```\r\n.metrics[] | { &quot;valueQuantity&quot; : { &quot;unit&quot; : .unit, &quot;value&quot; : .value}, &quot;category&quot; : .type }\r\n```\r\nwhich can be shortened to:\r\n```\r\n.metrics[] | { valueQuantity: {unit, value}, category: .type }\r\n```",
                "title": "Python PYJQ map nested fields to multiple top level fields"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1616089779,
        "creation_date": 1616084362,
        "question_id": 66694992,
        "body_markdown": "I&#39;m trying to map some json data to a different schema. My original schema and the field in question look like this \r\n\r\n    &quot;metrics&quot;:[  \r\n      {  \r\n         &quot;type&quot;:&quot;active_duration&quot;,\r\n         &quot;unit&quot;:&quot;s&quot;,\r\n         &quot;value&quot;:135.0\r\n      },\r\n      {  \r\n         &quot;type&quot;:&quot;basal_energy_burned&quot;,\r\n         &quot;unit&quot;:&quot;kcal&quot;,\r\n         &quot;value&quot;:2371.7412956\r\n      },\r\n      {  \r\n         &quot;type&quot;:&quot;distance&quot;,\r\n         &quot;unit&quot;:&quot;m&quot;,\r\n         &quot;value&quot;:1510.36558533\r\n      },\r\n      {  \r\n         &quot;type&quot;:&quot;active_energy_burned&quot;,\r\n         &quot;unit&quot;:&quot;kcal&quot;,\r\n         &quot;value&quot;:295.203469907\r\n      },\r\n      {  \r\n         &quot;type&quot;:&quot;steps&quot;,\r\n         &quot;unit&quot;:&quot;count&quot;,\r\n         &quot;value&quot;:1877\r\n      },\r\n      {  \r\n         &quot;type&quot;:&quot;energy_burned&quot;,\r\n         &quot;unit&quot;:&quot;kcal&quot;,\r\n         &quot;value&quot;:2666.944765507\r\n      }\r\n       ],\r\n\r\nand desired output\r\n\r\n    {\r\n        &quot;valueQuantity&quot; : { &quot;unit&quot; : &quot;count&quot;, &quot;value&quot; : 1877} ,\r\n        &quot;category&quot; : &quot;steps&quot;\r\n    },\r\n    {\r\n        &quot;valueQuantity&quot; : { &quot;unit&quot; : &quot;kcal&quot;, &quot;value&quot; : 2666.944765507} ,\r\n        &quot;category&quot; : &quot;energy_burned&quot;\r\n    }\r\n    ....\r\n\r\nI&#39;ve tried this\r\n\r\n    import pyjq\r\n\r\n    t = pyjq.all(&quot;&quot;&quot;\r\n        {\r\n            &quot;valueQuantity&quot; : .metrics[] | { &quot;unit&quot; : .unit, &quot;value&quot; : .value} ,\r\n            &quot;category&quot; : .metrics[].type\r\n        }&quot;&quot;&quot;, data)\r\n\r\nbut the issue is that .metrics[] runs more than one and I end up having 36 rows (instead of 6)\r\nIs there a way to achive that?\r\n",
        "link": "https://stackoverflow.com/questions/66694992/python-pyjq-map-nested-fields-to-multiple-top-level-fields",
        "title": "Python PYJQ map nested fields to multiple top level fields"
    },
    {
        "tags": [
            "json",
            "group-by",
            "statistics",
            "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": 1616090585,
                "post_id": 66696632,
                "comment_id": 117901368,
                "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": 1616090643,
                "post_id": 66696632,
                "comment_id": 117901389,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1049080,
                    "reputation": 1627,
                    "user_id": 1053408,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/c60c6fd502a7c82780c9607dee02c691?s=256&d=identicon&r=PG",
                    "display_name": "d123",
                    "link": "https://stackoverflow.com/users/1053408/d123"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1616090655,
                "post_id": 66696632,
                "comment_id": 117901395,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1049080,
                    "reputation": 1627,
                    "user_id": 1053408,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/c60c6fd502a7c82780c9607dee02c691?s=256&d=identicon&r=PG",
                    "display_name": "d123",
                    "link": "https://stackoverflow.com/users/1053408/d123"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1616090707,
                "post_id": 66696632,
                "comment_id": 117901418,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1616092752,
                "creation_date": 1616092752,
                "answer_id": 66697172,
                "question_id": 66696632,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Quite sure this is not the most &#39;clean&#39; solution, but thought I&#39;d share it until there&#39;s a better approach\r\n\r\nIdea:\r\n\r\n1) `group_by` each `InstanceType`\r\n2) `map` each `SpotPrice`, add those values by using `add`, devide by `map` `length` to get avarage\r\n    `(map(.SpotPrice | tonumber) | add / length)` \r\n\r\n```jq\r\n.SpotPriceHistory | group_by(.InstanceType)[] | { &quot;InstanceType&quot;: .[0].InstanceType, &quot;SpotPrice&quot;: (map(.SpotPrice | tonumber) | add / length) }\r\n```\r\n\r\nResult:\r\n```json\r\n{\r\n  &quot;InstanceType&quot;: &quot;m1.large&quot;,\r\n  &quot;SpotPrice&quot;: 0.028300000000000002\r\n}\r\n{\r\n  &quot;InstanceType&quot;: &quot;r5ad.24xlarge&quot;,\r\n  &quot;SpotPrice&quot;: 1.6444\r\n}\r\n{\r\n  &quot;InstanceType&quot;: &quot;t4g.small&quot;,\r\n  &quot;SpotPrice&quot;: 0.0030666666666666668\r\n}\r\n```\r\n\r\n[Jq▷Play](https://jqplay.org/s/C2JY9zH9hY)",
                "title": "JSON jq grouping and average"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1616419007,
        "creation_date": 1616090419,
        "last_edit_date": 1616419007,
        "question_id": 66696632,
        "body_markdown": "Looking to try to group and average the following json\r\n\r\n```\r\n{\r\n    &quot;SpotPriceHistory&quot;: [\r\n        {\r\n        &quot;AvailabilityZone&quot;: &quot;ap-southeast-1c&quot;,\r\n        &quot;InstanceType&quot;: &quot;t4g.small&quot;,\r\n        &quot;ProductDescription&quot;: &quot;Linux/UNIX&quot;,\r\n        &quot;SpotPrice&quot;: &quot;0.001200&quot;,\r\n        &quot;Timestamp&quot;: &quot;2021-03-17T18:27:08+00:00&quot;\r\n        },\r\n        {\r\n        &quot;AvailabilityZone&quot;: &quot;ap-southeast-1a&quot;,\r\n        &quot;InstanceType&quot;: &quot;t4g.small&quot;,\r\n        &quot;ProductDescription&quot;: &quot;Linux/UNIX&quot;,\r\n        &quot;SpotPrice&quot;: &quot;0.002400&quot;,\r\n        &quot;Timestamp&quot;: &quot;2021-03-17T18:27:08+00:00&quot;\r\n        },\r\n        {\r\n        &quot;AvailabilityZone&quot;: &quot;ap-southeast-1b&quot;,\r\n        &quot;InstanceType&quot;: &quot;t4g.small&quot;,\r\n        &quot;ProductDescription&quot;: &quot;Linux/UNIX&quot;,\r\n        &quot;SpotPrice&quot;: &quot;0.005600&quot;,\r\n        &quot;Timestamp&quot;: &quot;2021-03-17T18:27:08+00:00&quot;\r\n        },\r\n        {\r\n        &quot;AvailabilityZone&quot;: &quot;ap-southeast-1a&quot;,\r\n        &quot;InstanceType&quot;: &quot;m1.large&quot;,\r\n        &quot;ProductDescription&quot;: &quot;Linux/UNIX&quot;,\r\n        &quot;SpotPrice&quot;: &quot;0.033300&quot;,\r\n        &quot;Timestamp&quot;: &quot;2021-03-17T18:20:33+00:00&quot;\r\n        },\r\n        {\r\n        &quot;AvailabilityZone&quot;: &quot;ap-southeast-1b&quot;,\r\n        &quot;InstanceType&quot;: &quot;m1.large&quot;,\r\n        &quot;ProductDescription&quot;: &quot;Linux/UNIX&quot;,\r\n        &quot;SpotPrice&quot;: &quot;0.023300&quot;,\r\n        &quot;Timestamp&quot;: &quot;2021-03-17T18:20:33+00:00&quot;\r\n        },\r\n        {\r\n        &quot;AvailabilityZone&quot;: &quot;ap-southeast-1b&quot;,\r\n        &quot;InstanceType&quot;: &quot;r5ad.24xlarge&quot;,\r\n        &quot;ProductDescription&quot;: &quot;Linux/UNIX&quot;,\r\n        &quot;SpotPrice&quot;: &quot;1.644400&quot;,\r\n        &quot;Timestamp&quot;: &quot;2021-03-17T18:20:20+00:00&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nLooking for the output to look something like,\r\n\r\n```\r\n{\r\n    &quot;AvailabilityZone&quot;: &quot;ap-southeast&quot;,\r\n    &quot;InstanceType&quot;: &quot;t4g.small&quot;,\r\n    &quot;ProductDescription&quot;: &quot;Linux/UNIX&quot;,\r\n    &quot;SpotPrice&quot;: &quot;0.00306&quot;\r\n},\r\n{\r\n    &quot;AvailabilityZone&quot;: &quot;ap-southeast&quot;,\r\n    &quot;InstanceType&quot;: &quot;m1.large&quot;,\r\n    &quot;ProductDescription&quot;: &quot;Linux/UNIX&quot;,\r\n    &quot;SpotPrice&quot;: &quot;0.0283&quot;\r\n},\r\n{\r\n    &quot;AvailabilityZone&quot;: &quot;ap-southeast&quot;,\r\n    &quot;InstanceType&quot;: &quot;r5ad.24xlarge&quot;,\r\n    &quot;ProductDescription&quot;: &quot;Linux/UNIX&quot;,\r\n    &quot;SpotPrice&quot;: &quot;1.644400&quot;\r\n}\r\n```\r\n\r\nI&#39;ve got something like `.SpotPriceHistory | group_by(.InstanceType)[]` to group. ",
        "link": "https://stackoverflow.com/questions/66696632/json-jq-grouping-and-average",
        "title": "JSON jq grouping and average"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 966995,
                    "reputation": 610,
                    "user_id": 990262,
                    "user_type": "registered",
                    "accept_rate": 73,
                    "profile_image": "https://www.gravatar.com/avatar/5c9247a9d04f889ea1f6e3e37253ba1a?s=256&d=identicon&r=PG",
                    "display_name": "ec2011",
                    "link": "https://stackoverflow.com/users/990262/ec2011"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1616152347,
                "post_id": 66700469,
                "comment_id": 117919111,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1616144228,
                "last_edit_date": 1616144228,
                "creation_date": 1616121025,
                "answer_id": 66701753,
                "question_id": 66700469,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have come across one of the (somewhat well-known) deficiencies of jq, namely that the trio of `map`, `|=`, `try` (and therefore postfix `?`) do not mix well.\r\n\r\nThe good news is that the following will work in jq 1.5 and later:\r\n```\r\nmap(.value = (.value | . as $v | try fromjson catch $v))\r\n```\r\n\r\nor equivalently:\r\n```\r\nmap(.value as $v | .value = try ($v|fromjson) catch $v)\r\n```\r\n\r\n\r\n",
                "title": "Why doesn&#39;t fromjson work as a map function on an array of objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1616144228,
        "creation_date": 1616109555,
        "last_edit_date": 1616115618,
        "question_id": 66700469,
        "body_markdown": "I&#39;m trying to iterate through an object and convert any value (top level only for now, no recursion) that is a valid json string to json.\r\n\r\nI think the answer lies in using the correct incantation perhaps something like `with_entries(.value |= try fromjson)`, but I&#39;m having trouble getting it working. So I broke it down a bit to try something simpler.\r\n\r\nHow about the following list of objects - I just want to parse the value key of each of them if it is a string that yields valid json (let&#39;s ignore the invalid cases for now, they can return null).\r\n\r\nSo I tried this:\r\n\r\n    $ jq -n &#39;[{key: &quot;one&quot;, value: 1},{key: &quot;two&quot;, value: &quot;{\\&quot;object\\&quot;:true}&quot;}] | map(.value |= try fromjson)&#39;\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;one&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;two&quot;\r\n      }\r\n    ]\r\n\r\nValues are both missing even though the `two` key is a valid json string.\r\n\r\nBut if I try the same with a simple array, it works as expected:\r\n\r\n    $ jq -n &#39;[1, &quot;two&quot;, &quot;{\\&quot;three\\&quot;:3}&quot;] | .[] | fromjson?&#39;\r\n    {\r\n      &quot;three&quot;: 3\r\n    }\r\n\r\nSo my question is what I am doing wrong here?\r\nThanks in advance for any pointers.\r\n",
        "link": "https://stackoverflow.com/questions/66700469/why-doesnt-fromjson-work-as-a-map-function-on-an-array-of-objects",
        "title": "Why doesn&#39;t fromjson work as a map function on an array of objects?"
    },
    {
        "tags": [
            "json",
            "yaml",
            "jq",
            "substitution",
            "yq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1616145261,
                "last_edit_date": 1616145261,
                "creation_date": 1616141341,
                "answer_id": 66704539,
                "question_id": 66703892,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given the input shown, the following jq program produces the expected output and seems to conform with the general requirements, and should be easy to modify according to your more detailed requirements:\r\n```\r\nwalk(if type==&quot;object&quot; and (.allOf | (type == &quot;array&quot;) and (length == 2))\r\n     then {&quot;$ref&quot;: .allOf[0][&quot;$ref&quot;]}\r\n     else . end)\r\n```\r\n\r\nFYPI, the &quot;then&quot; clause can be abbreviated to:\r\n```\r\n.allOf[0] | {&quot;$ref&quot;}\r\n```",
                "title": "How to refer to &#39;subdocument&#39; in when doing transformations with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1616159971,
        "creation_date": 1616137837,
        "last_edit_date": 1616159971,
        "question_id": 66703892,
        "body_markdown": "I&#39;m trying to do a transformation of an OpenAPI specification file with `jq`. I want to &#39;recognise&#39; the pattern \r\n\r\n``` json\r\n&quot;status&quot;: {\r\n  &quot;allOf&quot;: [\r\n    {\r\n      &quot;$ref&quot;: &quot;#/components/schemas/Status&quot;\r\n    },\r\n    {\r\n      &quot;description&quot;: &quot;Status&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nand change it into\r\n\r\n```\r\n&quot;status&quot;: {\r\n  &quot;$ref&quot;: &quot;#/components/schemas/Status&quot;\r\n}\r\n```\r\n\r\nI don&#39;t think that is all that hard, but when I try to do it on a larger example, I run into trouble. Let&#39;s take as example:\r\n\r\n\r\n``` json\r\n  {\r\n    &quot;components&quot;: {\r\n      &quot;schemas&quot;: {\r\n        &quot;ObjectStatusType&quot;: {\r\n          &quot;required&quot;: [\r\n            &quot;status&quot;,\r\n            &quot;type&quot;,\r\n            &quot;agreement&quot;\r\n          ],\r\n          &quot;type&quot;: &quot;object&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;agreement&quot;: {\r\n              &quot;description&quot;: &quot;An agreement&quot;,\r\n              &quot;maxLength&quot;: 5,\r\n              &quot;type&quot;: &quot;string&quot;\r\n            },\r\n            &quot;status&quot;: {\r\n              &quot;allOf&quot;: [\r\n                {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/Status&quot;\r\n                },\r\n                {\r\n                  &quot;description&quot;: &quot;Status&quot;\r\n                }\r\n              ]\r\n            },\r\n            &quot;type&quot;: {\r\n              &quot;allOf&quot;: [\r\n                {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/Type&quot;\r\n                },\r\n                {\r\n                  &quot;description&quot;: &quot;Type&quot;\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        },\r\n        &quot;BallType&quot;: {\r\n          &quot;required&quot;: [\r\n            &quot;colour&quot;,\r\n            &quot;type&quot;,\r\n            &quot;physics&quot;\r\n          ],\r\n          &quot;type&quot;: &quot;object&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;colour&quot;: {\r\n              &quot;description&quot;: &quot;Ball colour&quot;,\r\n              &quot;maxLength&quot;: 5,\r\n              &quot;type&quot;: &quot;string&quot;\r\n            },\r\n            &quot;type&quot;: {\r\n              &quot;allOf&quot;: [\r\n                {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/Type&quot;\r\n                },\r\n                {\r\n                  &quot;description&quot;: &quot;Type&quot;\r\n                }\r\n              ]\r\n            },\r\n            &quot;physics&quot;: {\r\n              &quot;allOf&quot;: [\r\n                {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/Physics&quot;\r\n                },\r\n                {\r\n                  &quot;description&quot;: &quot;Physics&quot;\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n```\r\n\r\nwhich I&#39;d like to turn into \r\n\r\n``` json\r\n  {\r\n    &quot;components&quot;: {\r\n      &quot;schemas&quot;: {\r\n        &quot;ObjectStatusType&quot;: {\r\n          &quot;required&quot;: [\r\n            &quot;status&quot;,\r\n            &quot;type&quot;,\r\n            &quot;agreement&quot;\r\n          ],\r\n          &quot;type&quot;: &quot;object&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;agreement&quot;: {\r\n              &quot;description&quot;: &quot;An agreement&quot;,\r\n              &quot;maxLength&quot;: 5,\r\n              &quot;type&quot;: &quot;string&quot;\r\n            },\r\n            &quot;status&quot;: {\r\n              &quot;$ref&quot;: &quot;#/components/schemas/Status&quot;\r\n            },\r\n            &quot;type&quot;: {\r\n              &quot;$ref&quot;: &quot;#/components/schemas/Type&quot;\r\n            }\r\n          }\r\n        },\r\n        &quot;BallType&quot;: {\r\n          &quot;required&quot;: [\r\n            &quot;colour&quot;,\r\n            &quot;type&quot;,\r\n            &quot;physics&quot;\r\n          ],\r\n          &quot;type&quot;: &quot;object&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;colour&quot;: {\r\n              &quot;description&quot;: &quot;Ball colour&quot;,\r\n              &quot;maxLength&quot;: 5,\r\n              &quot;type&quot;: &quot;string&quot;\r\n            },\r\n            &quot;type&quot;: {\r\n              &quot;$ref&quot;: &quot;#/components/schemas/Type&quot;\r\n            },\r\n            &quot;physics&quot;: {\r\n              &quot;$ref&quot;: &quot;#/components/schemas/Physics&quot;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n```\r\n\r\nI&#39;ve tried with the expression `(.components | .schemas | .[] | .properties // empty | .[]  | select(.allOf // empty | .[] // empty | .description) | select(.allOf // empty | .[] // empty | .&quot;$ref&quot;))  = { &quot;$ref&quot; : &quot;what to put here&quot;  } `, which gives me\r\n\r\n``` json\r\n{\r\n  &quot;components&quot;: {\r\n    &quot;schemas&quot;: {\r\n      &quot;ObjectStatusType&quot;: {\r\n        &quot;required&quot;: [\r\n          &quot;status&quot;,\r\n          &quot;type&quot;,\r\n          &quot;agreement&quot;\r\n        ],\r\n        &quot;type&quot;: &quot;object&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;agreement&quot;: {\r\n            &quot;description&quot;: &quot;An agreement&quot;,\r\n            &quot;maxLength&quot;: 5,\r\n            &quot;type&quot;: &quot;string&quot;\r\n          },\r\n          &quot;status&quot;: {\r\n            &quot;$ref&quot;: &quot;what to put here&quot;\r\n          },\r\n          &quot;type&quot;: {\r\n            &quot;$ref&quot;: &quot;what to put here&quot;\r\n          }\r\n        }\r\n      },\r\n      &quot;BallType&quot;: {\r\n        &quot;required&quot;: [\r\n          &quot;colour&quot;,\r\n          &quot;type&quot;,\r\n          &quot;physics&quot;\r\n        ],\r\n        &quot;type&quot;: &quot;object&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;colour&quot;: {\r\n            &quot;description&quot;: &quot;Ball colour&quot;,\r\n            &quot;maxLength&quot;: 5,\r\n            &quot;type&quot;: &quot;string&quot;\r\n          },\r\n          &quot;type&quot;: {\r\n            &quot;$ref&quot;: &quot;what to put here&quot;\r\n          },\r\n          &quot;physics&quot;: {\r\n            &quot;$ref&quot;: &quot;what to put here&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI need some reference to a &#39;subdocument&#39; instead of `what to put here`. I&#39;ve tried variables, but they can only be globally defined, and `.` on the right hand side refers to the entire document and not just the part being replaced.\r\n\r\nWe use YAML for the OpenAPI specification, so if there is a solution that also works with `yq` that would be preferable.",
        "link": "https://stackoverflow.com/questions/66703892/how-to-refer-to-subdocument-in-when-doing-transformations-with-jq",
        "title": "How to refer to &#39;subdocument&#39; in when doing transformations with jq"
    },
    {
        "tags": [
            "syntax",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1616176154,
                "post_id": 66712560,
                "comment_id": 117930023,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1616175880,
                "creation_date": 1616175880,
                "answer_id": 66713176,
                "question_id": 66712560,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just put the keys in quotes `&quot;..&quot;`,\r\n\r\n```bash\r\njq &#39;.&quot;801&quot;.&quot;170&quot;.&quot;101&quot;&#39;\r\n```\r\nor use `argjson` to make the path configurable to select on\r\n\r\n```bash\r\njq --argjson path &#39;[&quot;801&quot;, &quot;170&quot;, &quot;101&quot;]&#39; &#39;getpath($path)&#39;\r\n```",
                "title": "How to use jq to query a value of a numeric sub-key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1616187205,
        "creation_date": 1616173402,
        "last_edit_date": 1616187205,
        "question_id": 66712560,
        "body_markdown": "I would like to use **jq** to display the value of 801.170.101 in the following JSON string:\r\n\r\n```\r\n{&quot;801&quot;:{&quot;170&quot;:{&quot;100&quot;:&quot;abc&quot;,&quot;101&quot;:33,&quot;102&quot;:55}}}\r\n```\r\n\r\nI read that I need to use [] for numeric key names. The following works to return the 170 key and it&#39;s sub-values:\r\n\r\n```\r\necho &#39;{&quot;801&quot;:{&quot;170&quot;:{&quot;100&quot;:&quot;abc&quot;,&quot;101&quot;:33,&quot;102&quot;:55}}}&#39; | jq &#39;.[&quot;801&quot;]&#39;\r\n```\r\n\r\nHowever, the following doesn&#39;t work:\r\n\r\n```\r\necho &#39;{&quot;801&quot;:{&quot;170&quot;:{&quot;100&quot;:&quot;abc&quot;,&quot;101&quot;:33,&quot;102&quot;:55}}}&#39; | jq &#39;.[&quot;801&quot;].[&quot;170&quot;].[&quot;101&quot;]&#39;\r\njq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.[&quot;801&quot;].[&quot;170&quot;].[&quot;101&quot;]         \r\njq: 1 compile error\r\n\r\n```\r\n\r\nWhat is the correct syntax to retrieve the value of 801.170.101 (33)?\r\n\r\nThanks.",
        "link": "https://stackoverflow.com/questions/66712560/how-to-use-jq-to-query-a-value-of-a-numeric-sub-key",
        "title": "How to use jq to query a value of a numeric sub-key"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1616252390,
                "post_id": 66723014,
                "comment_id": 117946338,
                "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": 1616252421,
                "post_id": 66723014,
                "comment_id": 117946345,
                "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": 1616252628,
                "post_id": 66723014,
                "comment_id": 117946400,
                "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": 1616253669,
                "post_id": 66723014,
                "comment_id": 117946760,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1616252665,
                "creation_date": 1616252665,
                "answer_id": 66723101,
                "question_id": 66723014,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re already checking an object&#39;s `type` once -- just do it again:\r\n\r\n```\r\njq -r &#39;\r\n  def camel:\r\n    if type == &quot;string&quot; then\r\n      gsub( &quot;https://&quot;; &quot;https://staging.&quot;)\r\n    else\r\n      .[] |= camel\r\n    end;\r\n\r\n  walk( if type==&quot;object&quot; and .configURL then (.configURL |= camel) else . end)\r\n&#39; apps.json\r\n```",
                "title": "jq code to rewrite URLs where some values are arrays and some strings"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1616406260,
                "creation_date": 1616406260,
                "answer_id": 66743598,
                "question_id": 66723014,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another approach is to use `(.[]? // .)` - it&#39;s essentially an if/else - the `?` catches the error and `// .` returns the original value.\r\n\r\n```\r\n$ jq -r &#39;(.[].configURL | (.[]? // .))&#39; apps.json\r\nhttps://companyX.com/app1/config.json\r\nhttps://some-company.com/app2/config.json\r\nhttps://some-company.com/app2/config-resources.json\r\nhttp://some-company.com/app2/config-resources.json\r\nhttps://staging.app4.com/app4/installs/binaries.ini\r\nhttps://different-company.com/app3/config.json\r\nhttps://different-company.com/app3/config-resources.json\r\nhttps://different-company.com/app3/config-binaries.json\r\n```\r\n\r\nYou can then transform the results directly.\r\n\r\n```\r\njq -r &#39;(.[].configURL | (.[]? // .)) |= sub(&quot;^https://&quot;; &quot;https://staging.&quot;)&#39;\r\n```\r\n\r\nYour `configURL` keys are all in the same place so you don&#39;t need recurse/walk but if you do you need to filter out potential nulls with `select()` \r\n\r\n```\r\njq -r &#39;(.. | .configURL? | select(.) | (.[]? // .)) |= sub(&quot;^https://&quot;; &quot;https://staging.&quot;)&#39;\r\n```",
                "title": "jq code to rewrite URLs where some values are arrays and some strings"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1616406260,
        "creation_date": 1616252173,
        "last_edit_date": 1616260426,
        "question_id": 66723014,
        "body_markdown": "In the following json I need to rewrite the `configURL` values and add `staging.` after(and only) `https://` - and ignore &#39;http://&#39;. The thing is some of the values stored by `configURL` key are arrays. Original json looks like:\r\n\r\n```\r\n{\r\n\t&quot;app1.json&quot;: {\r\n\t\t&quot;content&quot;: &quot;app-config&quot;,\r\n\t\t&quot;updates&quot;: 2,\r\n\t\t&quot;configURL&quot;: &quot;https://companyX.com/app1/config.json&quot;\r\n\t},\r\n\t&quot;app2.json&quot;: {\r\n\t\t&quot;content&quot;: &quot;app-config&quot;,\r\n\t\t&quot;updates&quot;: 2,\r\n\t\t&quot;configURL&quot;: [\r\n\t\t\t&quot;https://some-company.com/app2/config.json&quot;,\r\n\t\t\t&quot;https://some-company.com/app2/config-resources.json&quot;,\r\n\t\t\t&quot;http://some-company.com/app2/config-resources.json&quot;\r\n\t\t]\r\n\t},\r\n\t&quot;app3.ini&quot;: {\r\n\t\t&quot;content&quot;: &quot;binaries&quot;,\r\n\t\t&quot;scope&quot;: &quot;deploy&quot;,\r\n\t\t&quot;configURL&quot;: &quot;https://staging.app4.com/app4/installs/binaries.ini&quot;,\r\n\t\t&quot;resources&quot;: [\r\n\t\t\t&quot;https://app4.com/resource&quot;,\r\n\t\t\t&quot;https://app4.com/resource.bin&quot;,\r\n\t\t\t&quot;https://app4.com/resource2.bin&quot;\r\n\t\t]\r\n\t},\r\n\t&quot;app4.json&quot;: {\r\n\t\t&quot;content&quot;: &quot;app-config&quot;,\r\n\t\t&quot;updates&quot;: 3,\r\n\t\t&quot;configURL&quot;: [\r\n\t\t\t&quot;https://different-company.com/app3/config.json&quot;,\r\n\t\t\t&quot;https://different-company.com/app3/config-resources.json&quot;,\r\n\t\t\t&quot;https://different-company.com/app3/config-binaries.json&quot;\r\n\t\t],\r\n\t\t&quot;resources&quot;: [\r\n\t\t\t&quot;https://different-company.com/resource&quot;,\r\n\t\t\t&quot;https://different-company.com/resource.bin&quot;,\r\n\t\t\t&quot;https://different-company.com/resource2.bin&quot;\r\n\t\t]\r\n\t}\r\n}\r\n```\r\n\r\nThe desired output is\r\n\r\n```\r\n\r\n{\r\n\t&quot;app1.json&quot;: {\r\n\t\t&quot;content&quot;: &quot;app-config&quot;,\r\n\t\t&quot;updates&quot;: 2,\r\n\t\t&quot;configURL&quot;: &quot;https://staging.companyX.com/app1/config.json&quot;\r\n\t},\r\n\t&quot;app2.json&quot;: {\r\n\t\t&quot;content&quot;: &quot;app-config&quot;,\r\n\t\t&quot;updates&quot;: 2,\r\n\t\t&quot;configURL&quot;: [\r\n\t\t\t&quot;https://staging.some-company.com/app2/config.json&quot;,\r\n\t\t\t&quot;https://staging.some-company.com/app2/config-resources.json&quot;,\r\n\t\t]\r\n\t},\r\n\t&quot;app3.ini&quot;: {\r\n\t\t&quot;content&quot;: &quot;binaries&quot;,\r\n\t\t&quot;scope&quot;: &quot;deploy&quot;,\r\n\t\t&quot;configURL&quot;: &quot;https://staging.staging.app4.com/app4/installs/binaries.ini&quot;,\r\n\t\t&quot;resources&quot;: [\r\n\t\t\t&quot;https://app4.com/resource&quot;,\r\n\t\t\t&quot;https://app4.com/resource.bin&quot;,\r\n\t\t\t&quot;https://app4.com/resource2.bin&quot;\r\n\t\t]\r\n\t},\r\n\t&quot;app4.json&quot;: {\r\n\t\t&quot;content&quot;: &quot;app-config&quot;,\r\n\t\t&quot;updates&quot;: 3,\r\n\t\t&quot;configURL&quot;: [\r\n\t\t\t&quot;https://staging.different-company.com/app3/config.json&quot;,\r\n\t\t\t&quot;https://staging.different-company.com/app3/config-resources.json&quot;,\r\n\t\t\t&quot;https://staging.different-company.com/app3/config-binaries.json&quot;\r\n\t\t],\r\n\t\t&quot;resources&quot;: [\r\n\t\t\t&quot;https://different-company.com/resource&quot;,\r\n\t\t\t&quot;https://different-company.com/resource.bin&quot;,\r\n\t\t\t&quot;https://different-company.com/resource2.bin&quot;\r\n\t\t]\r\n\t}\r\n}\r\n```\r\n\r\nThe following solution I managed to come up with works only when there aren&#39;t multiple URLs, but only one; I don&#39;t know how to add condition for, and modify each value in the array.\r\n```\r\njq -r &#39;def camel:gsub( &quot;https://&quot;; &quot;https://staging.&quot;); walk( if type==&quot;object&quot; and .configURL then (.configURL |= camel) else . end)&#39; apps.json\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/66723014/jq-code-to-rewrite-urls-where-some-values-are-arrays-and-some-strings",
        "title": "jq code to rewrite URLs where some values are arrays and some strings"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1616269461,
                "creation_date": 1616269461,
                "answer_id": 66725782,
                "question_id": 66725582,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re getting an array for each speaker that way. What you want is a single array containing all so that you can join them, which is done like this:\r\n```\r\n.speakers | map(&quot;\\(.firstName) \\(.lastName)&quot;) | join(&quot; and &quot;)\r\n```",
                "title": "Join a list of json values using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1616290720,
                "creation_date": 1616290720,
                "answer_id": 66728092,
                "question_id": 66725582,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n    $ jq -c &#39;.speakers[] | [ &quot;\\(.firstName) \\(.lastName)&quot; ]&#39; speakers.json\r\n    [&quot;Abe Abraham&quot;]\r\n    [&quot;Max Miller&quot;]\r\n\r\nIf you move your opening `[` you get a single array with all the names.\r\n\r\n    $ jq -c &#39;[ .speakers[] | &quot;\\(.firstName) \\(.lastName)&quot; ]&#39; speakers.json\r\n    [&quot;Abe Abraham&quot;,&quot;Max Miller&quot;]\r\n\r\nWhich you can pass to `join()`\r\n```\r\n$ jq -r &#39;[ .speakers[] | &quot;\\(.firstName) \\(.lastName)&quot; ] | join(&quot; and &quot;)&#39; speakers.json\r\nAbe Abraham and Max Miller\r\n```\r\n\r\nIf there are no other keys you can also write it like:\r\n\r\n```\r\n$ jq -r &#39;[.speakers[] | join(&quot; &quot;)] | join(&quot; and &quot;)&#39; speakers.json \r\nAbe Abraham and Max Miller\r\n```",
                "title": "Join a list of json values using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1616290720,
        "creation_date": 1616268141,
        "last_edit_date": 1616269054,
        "question_id": 66725582,
        "body_markdown": "I&#39;m attempting to reduce this list of names to a single line of text.\r\n\r\nI have JSON like this:\r\n\r\n```\r\n{\r\n    &quot;speakers&quot;: [\r\n        {\r\n            &quot;firstName&quot;: &quot;Abe&quot;,\r\n            &quot;lastName&quot;: &quot;Abraham&quot;\r\n        },\r\n        {\r\n            &quot;firstName&quot;: &quot;Max&quot;,\r\n            &quot;lastName&quot;: &quot;Miller&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nExpected output:\r\n\r\n```\r\nAbe Abraham and Max Miller\r\n```\r\n\r\nOne of the many attempts I&#39;ve made is this:\r\n\r\n```\r\njq -r &#39;.speakers[] | [&quot;\\(.firstName) \\(.lastName)&quot;] | join(&quot; and &quot;)&#39;\r\n```\r\n\r\nThe results are printed out on separate lines like this:\r\n\r\n```\r\nAbe Abraham\r\nMax Miller\r\n```\r\n\r\nI think the `join` command is just joining the single-element array piped to it (one name per array). How can I get the full list of names passed to `join` as a single array, so I get the expected output shown above?",
        "link": "https://stackoverflow.com/questions/66725582/join-a-list-of-json-values-using-jq",
        "title": "Join a list of json values using jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "key-value"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 96703,
                    "reputation": 733,
                    "user_id": 262708,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9cc4ff56153d5086fe369e75711a4262?s=256&d=identicon&r=PG",
                    "display_name": "Lil Devil",
                    "link": "https://stackoverflow.com/users/262708/lil-devil"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1616284922,
                "post_id": 66727605,
                "comment_id": 117954467,
                "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": 1616285869,
                "post_id": 66727605,
                "comment_id": 117954619,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1616298333,
                "last_edit_date": 1616298333,
                "creation_date": 1616296577,
                "answer_id": 66728501,
                "question_id": 66727605,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\n&quot;(?x:\r\n   ^\r\n   (?: \\\\d{4}-\\\\d{2}-\\\\d{2}T\r\n   |   \\\\w{3},[ ][\\\\d ]\\\\d[ ]\\\\w{3}[ ]\\\\d{4}\r\n   )\r\n)&quot; as $date_pattern |\r\n\r\n( .. | select(type == &quot;object&quot;) ) |= del(.[\r\n   . as $o |\r\n   keys_unsorted[] |\r\n   select( $o[.] | type == &quot;string&quot; and test($date_pattern) )\r\n])\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/Qvn4LcOFYE)\r\n\r\nAdjust the pattern to your liking.\r\n",
                "title": "Remove key if the value matches pattern"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1616307969,
                "last_edit_date": 1616307969,
                "creation_date": 1616307578,
                "answer_id": 66729419,
                "question_id": 66727605,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A straightforward way to delete key-value pairs from a JSON object is using `with_entries`, e.g. like so:\r\n```\r\ndef matches:\r\n  type == &quot;string&quot;\r\n  and test(&quot;^[1-9]\\\\d{3}-\\\\d+-\\\\d|[1-9]\\\\d{3} \\\\d{2}:\\\\d{2}:\\\\d{2}&quot;);\r\n\r\nwalk(if type==&quot;object&quot;\r\n     then with_entries(if .value|matches then empty else . end)\r\n     else . end)\r\n```\r\n\r\nYou may of course wish to adjust `def matches:` according to your requirements, or to shorten the filter-argument of `with_entries` to:\r\n\r\n```\r\nselect(.value|matches|not)\r\n```\r\n",
                "title": "Remove key if the value matches pattern"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1616321411,
                "creation_date": 1616321411,
                "answer_id": 66731053,
                "question_id": 66727605,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a superficially complicated but very efficient and actually quite simple solution.  It uses jq&#39;s streaming parser and would thus be especially suitable for very large JSON input(s).  Of course the `matches` filter as defined here should be taken as illustrative rather than definitive.\r\n```\r\njq --stream -n &#39;\r\n  def matches:\r\n    type == &quot;string&quot;\r\n    and test(&quot;^[1-9]\\\\d{3}-\\\\d+-\\\\d|[1-9]\\\\d{3} \\\\d{2}:\\\\d{2}:\\\\d{2}&quot;);\r\n\r\n  fromstream(inputs\r\n    | select((length==2\r\n                and (.[0][-1]|type)==&quot;string&quot;\r\n                and (.[-1]|matches))\r\n             | not) )\r\n&#39; input.json\r\n\r\n```",
                "title": "Remove key if the value matches pattern"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1616321411,
        "creation_date": 1616284423,
        "last_edit_date": 1616307742,
        "question_id": 66727605,
        "body_markdown": "I have following json and want to remove keys if the &quot;value&quot; matches specific pattern. Name of the keys are not fixed or pre-determined.\r\n\r\n```json\r\n{\r\n\t&quot;resources&quot;: [{\r\n\t\t&quot;tags&quot;: null,\r\n\t\t&quot;properties&quot;: {\r\n\t\t\t&quot;customerId&quot;: &quot;1234-cbd9-42bc-9193-f6432a6ef0d4&quot;,\r\n\t\t\t&quot;provisioningState&quot;: &quot;Succeeded&quot;,\r\n\t\t\t&quot;sku&quot;: {\r\n\t\t\t\t&quot;maxCapacityReservationLevel&quot;: 3000,\r\n\t\t\t\t&quot;lastSkuUpdate&quot;: &quot;Fri, 19 Mar 2021 16:38:12 GMT&quot;\r\n\t\t\t},\r\n\t\t\t&quot;createdDate&quot;: &quot;Fri, 19 Mar 2021 16:38:12 GMT&quot;,\r\n\t\t\t&quot;modifiedDate&quot;: &quot;Fri, 19 Mar 2021 17:27:54 GMT&quot;,\r\n\t\t\t&quot;status&quot;: {\r\n\t\t\t\t&quot;events&quot;: [{\r\n\t\t\t\t\t&quot;count&quot;: 1,\r\n\t\t\t\t\t&quot;firstTimestamp&quot;: &quot;2021-03-19T16:40:59Z&quot;,\r\n\t\t\t\t\t&quot;lastTimestamp&quot;: &quot;2021-03-19T16:40:59Z&quot;,\r\n\t\t\t\t\t&quot;name&quot;: &quot;Pulling&quot;,\r\n\t\t\t\t\t&quot;type&quot;: &quot;Normal&quot;\r\n\t\t\t\t}]\r\n\t\t\t}\r\n\r\n\t\t}\r\n\t}]\r\n}\r\n```\r\n\r\nExpected output\r\n\r\nAfter removal of the following keys as values matched timestamp format.\r\n\r\n- lastSkuUpdate\r\n- createdDate\r\n- modifiedDate\r\n- firstTimestamp\r\n- lastTimestamp\r\n\r\n```json\r\n{\r\n\t&quot;resources&quot;: [{\r\n\t\t&quot;tags&quot;: null,\r\n\t\t&quot;properties&quot;: {\r\n\t\t\t&quot;customerId&quot;: &quot;1234-cbd9-42bc-9193-f6432a6ef0d4&quot;,\r\n\t\t\t&quot;provisioningState&quot;: &quot;Succeeded&quot;,\r\n\t\t\t&quot;sku&quot;: {\r\n\t\t\t\t&quot;maxCapacityReservationLevel&quot;: 3000,\r\n\t\t\t},\r\n\t\t\t&quot;status&quot;: {\r\n\t\t\t\t&quot;events&quot;: [{\r\n\t\t\t\t\t&quot;count&quot;: 1,\r\n\t\t\t\t\t&quot;name&quot;: &quot;Pulling&quot;,\r\n\t\t\t\t\t&quot;type&quot;: &quot;Normal&quot;\r\n\t\t\t\t}]\r\n\t\t\t}\r\n\r\n\t\t}\r\n\t}]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/66727605/remove-key-if-the-value-matches-pattern",
        "title": "Remove key if the value matches pattern"
    },
    {
        "tags": [
            "json",
            "bash",
            "dynamic",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9326165,
                    "reputation": 21,
                    "user_id": 6923398,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/18751bb0fdd5a2223cd371f532ca06c4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user6923398",
                    "link": "https://stackoverflow.com/users/6923398/user6923398"
                },
                "reply_to_user": {
                    "account_id": 15669817,
                    "reputation": 184,
                    "user_id": 11306669,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/77b6aa4383cd3ac99fb756f6ba0978ba?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Tuxinose",
                    "link": "https://stackoverflow.com/users/11306669/tuxinose"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1616415861,
                "post_id": 66745739,
                "comment_id": 117986536,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1616416099,
                "post_id": 66745739,
                "comment_id": 117986647,
                "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": 3,
                "creation_date": 1616416478,
                "post_id": 66745739,
                "comment_id": 117986818,
                "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": 1616419885,
                "post_id": 66745739,
                "comment_id": 117988548,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1616418288,
                "last_edit_date": 1616418288,
                "creation_date": 1616417887,
                "answer_id": 66746551,
                "question_id": 66745739,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n    jq &#39;to_entries[]&#39; | sed -e &#39;s/^[{}]//&#39; -e &#39;s/^  //&#39;\r\n\r\nIf the quotes around the top-level `key` and `value` tokens are an issue, you can easily extend the sed directives based on the uniform indentation.",
                "title": "bash - jq iterating over json with spaces in key and value"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1616418288,
        "creation_date": 1616414887,
        "question_id": 66745739,
        "body_markdown": "Trying to iterate the top level keys and corresponding json object value from a file with following structure.\r\n\r\n```\r\n{\r\n   &quot;parkey1&quot;:{\r\n      &quot;parkey1subkey1&quot;:&quot;sub val1&quot;,\r\n      &quot;parkey1subkey2&quot;:&quot;sub val2&quot;\r\n   },\r\n   &quot;parkey2&quot;:{\r\n      &quot;parkey2subkey1&quot;:{\r\n         &quot;subsubkey1&quot;:&quot;val with space&quot;,\r\n         &quot;subsubkey2&quot;:{\r\n            &quot;subsubval3&quot;:&quot;val space&quot;\r\n         }\r\n      }\r\n   }\r\n}\r\n```\r\nThe above structure is just a sample. The keys and values can be anything. The expected output is to get the keys and corresponding json object values. With to_entries the spaces between the string values are breaking the logic.\r\n\r\nDesired output: \r\n```\r\nkey: &quot;parkey1&quot;\r\nvalue: {\r\n      &quot;parkey1subkey1&quot;:&quot;sub val1&quot;,\r\n      &quot;parkey1subkey2&quot;:&quot;sub val2&quot;\r\n   }\r\n\r\nkey: parkey2\r\nvalue: {\r\n      &quot;parkey2subkey1&quot;:{\r\n         &quot;subsubkey1&quot;:&quot;val with space&quot;,\r\n         &quot;subsubkey2&quot;:{\r\n            &quot;subsubval3&quot;:&quot;val space&quot;\r\n         }\r\n      }\r\n   }\r\n```",
        "link": "https://stackoverflow.com/questions/66745739/bash-jq-iterating-over-json-with-spaces-in-key-and-value",
        "title": "bash - jq iterating over json with spaces in key and value"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1616447084,
                "post_id": 66752932,
                "comment_id": 118001083,
                "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": 1616447097,
                "post_id": 66752932,
                "comment_id": 118001088,
                "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": 1616452354,
                "post_id": 66752932,
                "comment_id": 118002735,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1616452557,
        "creation_date": 1616442550,
        "last_edit_date": 1616446637,
        "question_id": 66752932,
        "body_markdown": "\r\nI&#39;m writing a shell script to remove the second element in the array using jq where ID= &quot;dimes-snapshot&quot; and time= 2017-01-09T22:41:46.229000+00:00\r\n\r\nThe array is in a snapshot.json file and I would like the changes to the array be reflected in that file\r\n```\r\n[\r\n    {\r\n        &quot;ID&quot;: &quot;delete-05032019&quot;,\r\n        &quot;Time&quot;: &quot;2019-05-03T18:01:12.375000+00:00&quot;\r\n    },\r\n    {\r\n        &quot;ID&quot;: &quot;dimes-snapshot&quot;,\r\n        &quot;Time&quot;: &quot;2017-01-09T22:41:46.229000+00:00&quot;\r\n    },\r\n    {\r\n        &quot;ID&quot;: &quot;dimes-snapshot-2&quot;,\r\n        &quot;Time&quot;: &quot;2018-02-28T16:06:09.091000+00:00&quot;\r\n    }\r\n]\r\n```\r\n\r\nI&#39;ve tried this command but it doesn&#39;t work\r\n```\r\njq &quot;del(.[] | select(.id == $ID))&quot; snapshots.json \r\n",
        "link": "https://stackoverflow.com/questions/66752932/how-do-i-remove-an-element-from-json-array-using-bash-script",
        "title": "How do I remove an element from json array using bash script"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1616484177,
                "creation_date": 1616484177,
                "answer_id": 66758826,
                "question_id": 66758677,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The [Array/String Slice `[:]`][1] operation returns an array, you still need to select the sub-object values from it\r\n\r\n```bash\r\njq -r &#39;.Attendees[1:4][].Name&#39;\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Array/StringSlice:.[10:15]",
                "title": "Using jq array slicing but encountering array error"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1616502768,
                "last_edit_date": 1616502768,
                "creation_date": 1616502161,
                "answer_id": 66763055,
                "question_id": 66758677,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I want to filter the name Jasmine until Mark\r\n\r\nSo first find their respective indices:\r\n```\r\n  .Attendees\r\n  | map(.Name)\r\n  | index(&quot;Jasmine&quot;) as $first\r\n  | index(&quot;Mark&quot;) as $last\r\n  | select($first and $last))      # if both must be present\r\n  | .[$first: $last+1][]\r\n```\r\n\r\nHere&#39;s an alternative that (a) deals with the edge cases differently, and (b) illustrates how to avoid constructing a second array:\r\n```\r\n  .Attendees | map(.Name)\r\n  | (index(&quot;Jasmine&quot;) // 0) as $first\r\n  | (index(&quot;Mark&quot;) // length) as $last\r\n  | .[ range($first; $last+1) ]\r\n```",
                "title": "Using jq array slicing but encountering array error"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1616502768,
        "creation_date": 1616483455,
        "last_edit_date": 1616487412,
        "question_id": 66758677,
        "body_markdown": "I have this on my attendees.txt as an example. Now I want to filter the name Jasmine until Mark such that it will only output the Name.\r\n\r\n    {\r\n        &quot;Attendees&quot;: [\r\n            {\r\n                &quot;Name&quot;: &quot;Joseph&quot;,\r\n                &quot;CreationDate&quot;: &quot;2019-08-13T08:35:17+00:00&quot;\r\n            },\r\n            {\r\n                &quot;Name&quot;: &quot;Jasmine&quot;,\r\n                &quot;CreationDate&quot;: &quot;2019-01-07T03:24:01+00:00&quot;\r\n            },\r\n            {\r\n                &quot;Name&quot;: &quot;Rebecca&quot;,\r\n                &quot;CreationDate&quot;: &quot;2020-05-19T13:20:58+00:00&quot;\r\n            },\r\n            {\r\n                &quot;Name&quot;: &quot;Mark&quot;,\r\n                &quot;CreationDate&quot;: &quot;2019-01-30T15:09:39+00:00&quot;\r\n            }\r\n\r\nI can use the command below:\r\n\r\n    jq -r &#39;.Attendees[1,2,3].Name&#39; &lt; attendees.txt\r\n\r\nBut what if i have a thousand line of Names and I want to filter just 300-500? How can I properly filter the range and only output the names? I entered the command below and it says Cannot index array with string &quot;Name&quot;.\r\n\r\n    jq -r &#39;.Attendees[300:500].Name&#39; &lt; attendees.txt\r\n\r\nOr similarly if I need to filter the above Names using range, I encounter the same error.\r\n\r\n    jq -r &#39;.Attendees[1:3].Name&#39; &lt; attendees.txt\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66758677/using-jq-array-slicing-but-encountering-array-error",
        "title": "Using jq array slicing but encountering array error"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1616487813,
                "post_id": 66758755,
                "comment_id": 118010435,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1616498679,
                "last_edit_date": 1616498679,
                "creation_date": 1616498209,
                "answer_id": 66762076,
                "question_id": 66758755,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The logic of the transformation you have in mind escapes me, but given the\r\ninputs in your example, the following does produce the required result\r\nand can easily be extended in various ways:\r\n```\r\njq -n &#39;\r\n  input as $one\r\n  | input as $two\r\n  | reduce ($two | paths(scalars)) as $p  ($one;\r\n      getpath($p) as $v\r\n      | ($two | getpath($p)) as $x\r\n      | if $v\r\n        then setpath($p; &quot;\\($v)\\n\\($x)&quot;)\r\n        else setpath($p; $x)\r\n        end)\r\n&#39; en.json zh.json\t\t\t\t    \r\n```\t\t\t\t   \r\n\t      \r\n",
                "title": "Merge JSON objects by joining common fields"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1616969895,
                "creation_date": 1616969895,
                "answer_id": 66846740,
                "question_id": 66758755,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Or similarly, the same query could be achieved using `jtc` - unix _JSON_ processor:\r\n\r\n```\r\nbash $ &lt;en.json jtc -mi zh.json / -w&#39;&lt;&gt;i:&#39; -u&#39;&lt;&gt;i:&#39; -T&#39;&quot;{$a}\\n{$b}&quot;&#39;\r\n{\r\n   &quot;error&quot;: {\r\n      &quot;payment&quot;: {\r\n         &quot;value1&quot;: &quot;v1\\nv2&quot;,\r\n         &quot;value2&quot;: &quot;v5&quot;\r\n      }\r\n   },\r\n   &quot;name&quot;: &quot;Apple\\norange&quot;\r\n}\r\n```\r\n\r\n\\- The first chain (`-mi zh.json`) recursively merges both JSONs;  \r\n\\- the second chain (`-w&#39;&lt;&gt;i:&#39; -u&#39;&lt;&gt;i:&#39; -T&#39;&quot;{$a}\\n{$b}&quot;&#39;`) concatenates scalars resulted from the merge\r\n\r\nPS. it so happens, that i&#39;m also the creator of the `jtc`.  \r\nPPS. the above disclaimer is required by SO.\r\n\r\n",
                "title": "Merge JSON objects by joining common fields"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1623529460,
                "creation_date": 1623529460,
                "answer_id": 67952726,
                "question_id": 66758755,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem you&#39;re trying to solve as far as I understand it is that you&#39;re taking a set of json that fits some structure and you want to collect all values set on the same json path and construct an object with the aggregated values.\r\n\r\nFor a general approach assuming there will be no arrays in this structure, you could break out all the scalar values on the set of objects (streams will be helpful with this), group them by the path, then reconstruct the object structure.\r\n\r\n```bash\r\n$ jq -n &#39;\r\n[inputs | tostream | select(length==2)] #1\r\n  | group_by(.[0]) #2\r\n  | map({\r\n      path: .[0][0],\r\n      values: [.[][1]]\r\n    }) #3\r\n  | reduce .[] as {$path, $values} (\r\n      {};\r\n      setpath($path; $values | join(&quot;\\n&quot;))\r\n    ) #4\r\n&#39; en.json zh.json\r\n```\r\n\r\nNote the `-n` flag.\r\n\r\n 1. Converts the objects to an array of path/value pairs from a stream\r\n 1. Groups the pairs by the path\r\n 1. Maps the grouped pairs to something more readable (not necessary)\r\n 1. Creates a new object based on the groupings. Also takes the array of values and combines them as a single `\\n` delimited string. (as you needed in the expected result)\r\n\r\nhttps://jqplay.org/s/Aa2KoeS2M6",
                "title": "Merge JSON objects by joining common fields"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1623529460,
        "creation_date": 1616483847,
        "last_edit_date": 1616485482,
        "question_id": 66758755,
        "body_markdown": "I have 2 locale file and want to group different words into same key\r\n\r\nfile1 en.json\r\n\r\n    {\r\n        &quot;name&quot;: &quot;Apple&quot;,\r\n        &quot;error&quot;: {\r\n            &quot;payment&quot;: {\r\n                &quot;value1&quot;: &quot;v1&quot;\r\n            }\r\n        }\r\n    }\r\n\r\nfile2 zh.json\r\n\r\n    {\r\n        &quot;name&quot;: &quot;orange&quot;,\r\n        &quot;error&quot;: {\r\n            &quot;payment&quot;: {\r\n                &quot;value1&quot;: &quot;v2&quot;,\r\n                &quot;value2&quot;: &quot;v5&quot;\r\n            }\r\n        }\r\n    }\r\n\r\nexpected result\r\n\r\n    {\r\n        &quot;name&quot;: &quot;Apple\\norange&quot;,\r\n        &quot;error&quot;: {\r\n            &quot;payment&quot;: {\r\n                &quot;value1&quot;: &quot;v1\\nv2&quot;,\r\n                &quot;value2&quot;: &quot;v5&quot;\r\n            }\r\n        }\r\n    }\r\n\r\n\r\nI try `jq -s . en.json zh.json | jq &#39;.[]&#39;| jq -s`, but it can&#39;t combine by key.\r\n\r\n    {\r\n      &quot;name&quot;: &quot;orange&quot;,\r\n      &quot;error&quot;: {\r\n        &quot;payment&quot;: {\r\n          &quot;value1&quot;: &quot;v2&quot;,\r\n          &quot;value2&quot;: &quot;v5&quot;\r\n        }\r\n      }\r\n    }",
        "link": "https://stackoverflow.com/questions/66758755/merge-json-objects-by-joining-common-fields",
        "title": "Merge JSON objects by joining common fields"
    },
    {
        "tags": [
            "json",
            "jq",
            "array-merge"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1616499149,
                "post_id": 66762135,
                "comment_id": 118015376,
                "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": 1616500547,
                "post_id": 66762135,
                "comment_id": 118016003,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1616499173,
                "creation_date": 1616499173,
                "answer_id": 66762314,
                "question_id": 66762135,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Create two lists, one from `.a` and one from `.b`, and merge them with `+`.\r\nIn the first list, create objects with `value:` set to the original content and add `from: &quot;a&quot;`; in the second list, remove `.x` from elements of `.b` and add the from again.\r\n\r\n    jq &#39;[.a[] | {value:(.), from: &quot;a&quot;}] + [.b[] | del(.x) + {from: &quot;b&quot;}]",
                "title": "Using jq to merge two arrays into one array of objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1616499705,
                "creation_date": 1616499705,
                "answer_id": 66762438,
                "question_id": 66762135,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a very slightly generic, but hardly robust, solution:\r\n\r\n```\r\nmap_values( if type == &quot;array&quot; \r\n            then map(if type == &quot;object&quot; then .value else . end) \r\n            else . end)\r\n| [ keys_unsorted[] as $k\r\n    | .[$k][] as $v\r\n    | { value: $v, from: $k } ]\r\n```",
                "title": "Using jq to merge two arrays into one array of objects"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1617167907,
        "creation_date": 1616498464,
        "last_edit_date": 1617167907,
        "question_id": 66762135,
        "body_markdown": "I am very beginner into jq and I want to reshape my JSON file.\r\n\r\nI have ve got JSON structured like this:\r\n```\r\n{\r\n   &quot;a&quot;: [1, 2, 3, 4 ...],\r\n   &quot;b&quot;: [\r\n      {\r\n         &quot;x&quot;: 1000,\r\n         &quot;value&quot;: 1\r\n      },\r\n      {\r\n         &quot;x&quot;: 1000,\r\n         &quot;value&quot;: 2\r\n      },\r\n      {\r\n         &quot;x&quot;: 1000,\r\n         &quot;value&quot;: 3\r\n      }\r\n      ...\r\n   ]\r\n}\r\n```\r\nI am wondering how I can achieve result like this with jq:\r\n\r\n```\r\n[\r\n   {\r\n      &quot;value&quot;: 1,\r\n      &quot;from&quot;: &quot;a&quot;,\r\n   },\r\n   {\r\n      &quot;value&quot;: 2,\r\n      &quot;from&quot;: &quot;a&quot;\r\n   },\r\n   ...\r\n   {\r\n      &quot;value&quot;: 1,\r\n      &quot;from&quot;: &quot;b&quot;\r\n   },\r\n   {\r\n      &quot;value&quot;: 2,\r\n      &quot;from&quot;: &quot;b&quot;\r\n   }\r\n   ...\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/66762135/using-jq-to-merge-two-arrays-into-one-array-of-objects",
        "title": "Using jq to merge two arrays into one array of objects"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15854886,
                    "reputation": 1187,
                    "user_id": 11439562,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/YKiqj.jpg?s=256",
                    "display_name": "Yves Gurcan",
                    "link": "https://stackoverflow.com/users/11439562/yves-gurcan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1616524832,
                "post_id": 66767971,
                "comment_id": 118028333,
                "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": 1616529647,
                "post_id": 66767971,
                "comment_id": 118030453,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1616520846,
                "creation_date": 1616520846,
                "answer_id": 66768353,
                "question_id": 66767971,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nmap(.name = .details[0].name)\r\n```\r\n\r\n1) Map through each object\r\n2) Set `name` key to the `name` of the `0`&#39;st index in `details` array\r\n\r\nResult:\r\n```json\r\n[\r\n  {\r\n    &quot;session&quot;: &quot;One&quot;,\r\n    &quot;name&quot;: &quot;Session One&quot;,\r\n    &quot;details&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Session One&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;session&quot;: &quot;Two&quot;,\r\n    &quot;name&quot;: &quot;Session Two&quot;,\r\n    &quot;details&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Session Two&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\n### [Jq▶Play](https://jqplay.org/s/sgYYFx8499)\r\n\r\n&lt;hr&gt;\r\n\r\nTo save jq&#39;s output to a new json file;\r\n```\r\njq &#39;map(.name = .details[0].name)&#39; tst.json &gt; &#39;newjson.json&#39;\r\n```",
                "title": "Replace recursively key value pair using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1616520846,
        "creation_date": 1616519472,
        "question_id": 66767971,
        "body_markdown": "I have the below json contents in a file one.json. \r\n\r\n    [{\r\n\t\t&quot;session&quot;: &quot;One&quot;,\r\n\t\t&quot;name&quot;: &quot;First Session&quot;,\r\n\t\t&quot;details&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;name&quot;: &quot;Session One&quot;\r\n\t\t\t}\r\n\t\t]\r\n\t},\r\n\t{\r\n\t\t&quot;session&quot;: &quot;Two&quot;,\r\n\t\t&quot;name&quot;: &quot;Second Session&quot;,\r\n\t\t&quot;details&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;name&quot;: &quot;Session Two&quot;\r\n\t\t\t}\r\n\t\t]\r\n\t}]\r\n\r\n\r\n\r\nI want to create another json file two.json with the below output\r\n\r\n    [{\r\n\t\t&quot;session&quot;: &quot;One&quot;,\r\n\t\t&quot;name&quot;: &quot;Session One&quot;,\r\n\t\t&quot;details&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;name&quot;: &quot;Session One&quot;\r\n\t\t\t}\r\n\t\t]\r\n\t},\r\n\t{\r\n\t\t&quot;session&quot;: &quot;Two&quot;,\r\n\t\t&quot;name&quot;: &quot;Session Two&quot;,\r\n\t\t&quot;details&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;name&quot;: &quot;Session Two&quot;\r\n\t\t\t}\r\n\t\t]\r\n\t}]\r\n\r\nThe difference between file one and file two is the value of &quot;name&quot; is replaced with details[0].name in each instance recursively. Unfortunately I can only use &#39;jq&#39; to achieve this due to some limitations. I am new to the world of shell script and this one is really bugging me.",
        "link": "https://stackoverflow.com/questions/66767971/replace-recursively-key-value-pair-using-jq",
        "title": "Replace recursively key value pair using jq"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1616531462,
                "last_edit_date": 1616531462,
                "creation_date": 1616530897,
                "answer_id": 66770754,
                "question_id": 66770114,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your sample input, the following program, which does not depend on the ordering of the &quot;attribute&quot; keys:\r\n\r\n```\r\njq -r &#39;\r\n[&quot;Attribute 1&quot;, &quot;Attribute 2&quot;, &quot;Attribute 3&quot;, &quot;Attribute 4&quot;] as $attributes\r\n# Header row\r\n| [&quot;authType&quot;, &quot;status&quot;] \r\n  + ($attributes | map( (.[:1] | ascii_upcase) + .[1:])),\r\n# Data rows:\r\n  (.[]\r\n   | (INDEX(.userCustomAttributes[]; .customAttributeName)\r\n      | map_values(.customAttributeValue)) as $dict\r\n   | [.auth, .status] + [ $dict[ $attributes[] ] ]\r\n   )\r\n| @csv\r\n&#39;\r\n```\r\nproduces the following CSV:\r\n```\r\n&quot;authType&quot;,&quot;status&quot;,&quot;Attribute 1&quot;,&quot;Attribute 2&quot;,&quot;Attribute 3&quot;,&quot;Attribute 4&quot;\r\n1,&quot;Active&quot;,&quot;Value 1&quot;,&quot;Value 2&quot;,&quot;Value 3&quot;,\r\n1,&quot;Active&quot;,&quot;Value 1&quot;,&quot;Value 2&quot;,&quot;Value 3&quot;,&quot;Value 4&quot;\r\n\r\n```\r\n\r\nYou can easily modify this to emit a literal string of your choice in place of a JSON null value.\r\n\r\n## Explanation\r\n\r\n`$dict[ $a[] ]` produces the stream of values:\r\n```\r\n$dict[ $a[0] ]\r\n$dict[ $a[1] ]\r\n...\r\n```\r\nThis is used to ensure the columns are produced in the correct order, independently of the ordering or even presence of the keys.",
                "title": "Using JQ to specific csv format"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1616553936,
        "creation_date": 1616528084,
        "last_edit_date": 1616553936,
        "question_id": 66770114,
        "body_markdown": "I have a json that looks like this:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;auth&quot;: 1,\r\n    &quot;status&quot;: &quot;Active&quot;,\r\n    &quot;userCustomAttributes&quot;: [\r\n      {\r\n        &quot;customAttributeName&quot;: &quot;Attribute 1&quot;,\r\n        &quot;customAttributeValue&quot;: &quot;Value 1&quot;\r\n      },\r\n      {\r\n        &quot;customAttributeName&quot;: &quot;Attribute 2&quot;,\r\n        &quot;customAttributeValue&quot;: &quot;Value 2&quot;\r\n      },\r\n      {\r\n        &quot;customAttributeName&quot;: &quot;Attribute 3&quot;,\r\n        &quot;customAttributeValue&quot;: &quot;Value 3&quot;\r\n      }\r\n    ],\r\n  },\r\n  {\r\n    &quot;auth&quot;: 1,\r\n    &quot;status&quot;: &quot;Active&quot;,\r\n    &quot;userCustomAttributes&quot;: [\r\n      {\r\n        &quot;customAttributeName&quot;: &quot;Attribute 1&quot;,\r\n        &quot;customAttributeValue&quot;: &quot;Value 1&quot;\r\n      },\r\n      {\r\n        &quot;customAttributeName&quot;: &quot;Attribute 2&quot;,\r\n        &quot;customAttributeValue&quot;: &quot;Value 2&quot;\r\n      },\r\n      {\r\n        &quot;customAttributeName&quot;: &quot;Attribute 3&quot;,\r\n        &quot;customAttributeValue&quot;: &quot;Value 3&quot;\r\n      },\r\n      {\r\n        &quot;customAttributeName&quot;: &quot;Attribute 4&quot;,\r\n        &quot;customAttributeValue&quot;: &quot;Value 4&quot;\r\n      }\r\n    ],\r\n  }\r\n]\r\n```\r\n\r\nI would like to parse this and have a css output that looks something like this:\r\n\r\n```\r\nauthType, status, attribute 1, attribute 2, attribute 3, attribute 4\r\n&quot;1&quot;, &quot;active&quot;, &quot;value1&quot;, &quot;value2&quot;, &quot;value3&quot;,&quot;&quot;\r\n&quot;1&quot;, &quot;active&quot;, &quot;value1&quot;, &quot;value2&quot;, &quot;value3&quot;,&quot;value 4&quot;\r\n```\r\n\r\nThe json has over 180k records in the array so it would need to loop through all of them. Some records don&#39;t have all the attributes. Some have all 4 yet some only have 1. I am hoping to show a null value in the csv for the records that don&#39;t have the attribute.\r\n",
        "link": "https://stackoverflow.com/questions/66770114/using-jq-to-specific-csv-format",
        "title": "Using JQ to specific csv format"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "reverse",
            "latitude-longitude"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1616537964,
                "last_edit_date": 1616537964,
                "creation_date": 1616533215,
                "answer_id": 66771222,
                "question_id": 66770884,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### Part 1\r\n&gt; flip the coordinates lines \r\n\r\nFor clarity and ease of testing, let&#39;s define a helper function:\r\n```\r\n# input: a JSON object with a coordinates array of arrays of pairs\r\ndef flip: .coordinates |= map(map(reverse)) ;\r\n```\r\n\r\nor even better - before invoking `reverse`, check the array has the expected length, e.g.:\r\n```\r\ndef flip:\r\n  .coordinates\r\n  |= map(map(if length == 2 then reverse \r\n             else error(&quot;incorrect length: \\(length)&quot;)\r\n             end)) ;\r\n```\r\n\r\nTo flip the coordinates, we can now simply write:\r\n```\r\n.features[].geometry |= flip\r\n```\r\n\r\n### Part 2\r\n&gt; change the &quot;type&quot; key to &quot;layer&quot;\r\n```\r\n{layer: .type} + .\r\n| del(.type)\r\n```\r\n\r\n### Putting it together\r\n```\r\n{layer:.type} + .\r\n| del(.type)\r\n| .features[].geometry |= flip\r\n```",
                "title": "How to flip lines and change keys in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1616537964,
        "creation_date": 1616531457,
        "last_edit_date": 1616534027,
        "question_id": 66770884,
        "body_markdown": "I&#39;m creating a interactive map of my campus, the ideia is to replicate what I did on uMaps, [in this link][1]. The geojson was downloaded from UMap and I&#39;m using the coordinates that came with it.\r\n\r\nMy first issue is my coordinates in the json, originally were a GeoJson, are sorted wrongly, my long came first then lat, thus when parse Google Maps can&#39;t read properly. \r\n\r\nJson:\r\n\r\n```\r\n{\r\n  &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n  &quot;features&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;name&quot;: &quot;Almoxarifado / Patrim&#244;nio&quot;\r\n      },\r\n      &quot;geometry&quot;: {\r\n        &quot;type&quot;: &quot;Polygon&quot;,\r\n        &quot;coordinates&quot;: [\r\n          [\r\n            [\r\n              -52.163317,\r\n              -32.075462\r\n            ],\r\n            [\r\n              -52.163884,\r\n              -32.075467\r\n            ],\r\n            [\r\n              -52.163883,\r\n              -32.075336\r\n            ],\r\n            [\r\n              -52.163321,\r\n              -32.075332\r\n            ],\r\n            [\r\n              -52.163317,\r\n              -32.075462\r\n            ]\r\n          ]\r\n        ]\r\n      }\r\n    },\r\n   {\r\n    ...\r\n   },\r\n   {\r\n    ...\r\n   },\r\n   ...\r\n  ]\r\n}\r\n```\r\nSo, I have to flip the coordinates lines to proper put in my Google Maps Api.\r\n\r\nAnd my second issue is chaging the &quot;type&quot; key to &quot;layer&quot;, for a better sepation layers in my app. \r\n\r\nI&#39;ve tried:\r\n```\r\n.features[] | .[&quot;type&quot;]  |= .[&quot;new value&quot;]\r\n```\r\nHow ever that changes the value and only accepts float values\r\n\r\n\r\nAny help, advice or guidance would be greatly appreciated.\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n [1]: http:////umap.openstreetmap.fr/pt-br/map/mapa-interativo-furg_354207?scaleControl=false&amp;miniMap=false&amp;scrollWheelZoom=false&amp;zoomControl=true&amp;allowEdit=false&amp;moreControl=true&amp;searchControl=null&amp;tilelayersControl=null&amp;embedControl=null&amp;datalayersControl=true&amp;onLoadPanel=undefined&amp;captionBar=false",
        "link": "https://stackoverflow.com/questions/66770884/how-to-flip-lines-and-change-keys-in-jq",
        "title": "How to flip lines and change keys in JQ"
    },
    {
        "tags": [
            "json",
            "group-by",
            "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": 1616575106,
                "post_id": 66777320,
                "comment_id": 118042265,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1616576213,
                "creation_date": 1616576213,
                "answer_id": 66777672,
                "question_id": 66777320,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq -rs &#39;group_by(.loc)[] | ([.[].loc] | first) + &quot; ---------------------&quot;,(.[] | &quot;\\(.name) \\(.mem/1024/1024|floor)&quot;)  &#39; /tmp/data1.json\r\n\r\nYou need to address each element first and then pipe the info you want to show, you already have everything inside each single object of the array.",
                "title": "jq string concatenation produces cartesian product?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1616620841,
        "creation_date": 1616574710,
        "last_edit_date": 1616620841,
        "question_id": 66777320,
        "body_markdown": "I&#39;m trying to concatenate and output two fields in an object, but i&#39;m getting the cartesian product instead\r\n\r\nmy input data (data1.json)\r\n```\r\n{&quot;name&quot;:&quot;asdf&quot;,&quot;loc&quot;:&quot;lxd2&quot;,&quot;mem&quot;:332320768}\r\n{&quot;name&quot;:&quot;ghjk&quot;,&quot;loc&quot;:&quot;lxd1&quot;,&quot;mem&quot;:307908608}\r\n{&quot;name&quot;:&quot;qwer&quot;,&quot;loc&quot;:&quot;lxd1&quot;,&quot;mem&quot;:1195794432}\r\n{&quot;name&quot;:&quot;tyui&quot;,&quot;loc&quot;:&quot;lxd2&quot;,&quot;mem&quot;:269889536}\r\n{&quot;name&quot;:&quot;zxcv&quot;,&quot;loc&quot;:&quot;lxd1&quot;,&quot;mem&quot;:1578475520}\r\n{&quot;name&quot;:&quot;bnml&quot;,&quot;loc&quot;:&quot;lxd2&quot;,&quot;mem&quot;:48967680}\r\n```\r\n\r\ni want to produce an output grouped by loc containing loc as a header and name + mem field underneath. If i try only the name i get:\r\n```\r\njq -rs &#39;group_by(.loc)[] | ([.[].loc] | first) + &quot; ---------------------&quot;,(&quot;\\(.[].name)&quot;)  &#39; /tmp/data1.json\r\nlxd1 ---------------------\r\nghjk\r\nqwer\r\nzxcv\r\nlxd2 ---------------------\r\nasdf\r\ntyui\r\nbnml\r\n```\r\n\r\nso far so good, but as soon as i try to add a second field, it produces a cartesian product:\r\n```\r\n$ jq -rs &#39;group_by(.loc)[] | ([.[].loc] | first) + &quot; ---------------------&quot;,(&quot;\\(.[].name) \\(.[].mem/1024/1024|floor)&quot;)  &#39; /tmp/data1.json | less\r\nlxd1 ---------------------\r\nghjk 293\r\nqwer 293\r\nzxcv 293\r\nghjk 1140\r\nqwer 1140\r\nzxcv 1140\r\nghjk 1505\r\nqwer 1505\r\nzxcv 1505\r\nlxd2 ---------------------\r\nasdf 316\r\ntyui 316\r\nbnml 316\r\nasdf 257\r\ntyui 257\r\nbnml 257\r\nasdf 46\r\ntyui 46\r\nbnml 46\r\n```\r\n\r\nwhat i want is:\r\n```\r\nlxd1 ---------------------\r\nghjk 293\r\nqwer 1140\r\nzxcv 1505\r\nlxd2 ---------------------\r\nasdf 316\r\ntyui 257\r\nbnml 46\r\n```\r\n\r\nWhat am I doing wrong here?",
        "link": "https://stackoverflow.com/questions/66777320/jq-string-concatenation-produces-cartesian-product",
        "title": "jq string concatenation produces cartesian product?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5351266,
                    "reputation": 73064,
                    "user_id": 4265352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-lzAUc5pYb24/AAAAAAAAAAI/AAAAAAAAAGQ/q3h7bZUnqrs/s256-rj/photo.jpg",
                    "display_name": "axiac",
                    "link": "https://stackoverflow.com/users/4265352/axiac"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1616575409,
                "post_id": 66777394,
                "comment_id": 118042387,
                "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": 3,
                "creation_date": 1616575417,
                "post_id": 66777394,
                "comment_id": 118042393,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16919484,
                    "reputation": 39,
                    "user_id": 12236615,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Z5pzB.jpg?s=256",
                    "display_name": "JoshuaSmeda",
                    "link": "https://stackoverflow.com/users/12236615/joshuasmeda"
                },
                "reply_to_user": {
                    "account_id": 5351266,
                    "reputation": 73064,
                    "user_id": 4265352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-lzAUc5pYb24/AAAAAAAAAAI/AAAAAAAAAGQ/q3h7bZUnqrs/s256-rj/photo.jpg",
                    "display_name": "axiac",
                    "link": "https://stackoverflow.com/users/4265352/axiac"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1616576234,
                "post_id": 66777394,
                "comment_id": 118042705,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user15398259"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1616577700,
                "post_id": 66777394,
                "comment_id": 118043336,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16919484,
                    "reputation": 39,
                    "user_id": 12236615,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Z5pzB.jpg?s=256",
                    "display_name": "JoshuaSmeda",
                    "link": "https://stackoverflow.com/users/12236615/joshuasmeda"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1616579565,
                "post_id": 66777394,
                "comment_id": 118044241,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1616579783,
                "creation_date": 1616579783,
                "answer_id": 66778596,
                "question_id": 66777394,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can pass it to `add` to get a single object.\r\n\r\n```\r\njq &#39;.[].facts.data | add&#39;\r\n\r\n{\r\n  &quot;usrwww_size&quot;: false,\r\n  &quot;architecture&quot;: &quot;amd64&quot;,\r\n  &quot;bios_version&quot;: &quot;rel-1.11.2-0-gf9626ccb91-prebuilt.qemu-project.org&quot;,\r\n  &quot;blockdevices&quot;: &quot;sr0,vda&quot;\r\n}\r\n```\r\n\r\nYou can add the outer `{ values: }` wrapping needed.\r\n\r\n```\r\njq &#39;{ values: .[].facts.data | add }&#39;\r\n\r\n{\r\n  &quot;values&quot;: {\r\n    &quot;usrwww_size&quot;: false,\r\n    &quot;architecture&quot;: &quot;amd64&quot;,\r\n    &quot;bios_version&quot;: &quot;rel-1.11.2-0-gf9626ccb91-prebuilt.qemu-project.org&quot;,\r\n    &quot;blockdevices&quot;: &quot;sr0,vda&quot;\r\n  }\r\n}",
                "title": "Unpack JSON into a single JSON element using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1616579783,
        "creation_date": 1616574978,
        "last_edit_date": 1616579521,
        "question_id": 66777394,
        "body_markdown": "I have a JSON array that I&#39;m trying to unpack into a single element using jq (needed to be able to be read by another program), but I&#39;m struggling to find the solution.\r\n\r\nConsidering the following example:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;timestamp&quot;: &quot;2021-03-24T06:15:42.437Z&quot;,\r\n    &quot;facts&quot;: {\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;usrwww_size&quot;: false\r\n        },\r\n        {\r\n          &quot;architecture&quot;: &quot;amd64&quot;\r\n        },\r\n        {\r\n          &quot;bios_version&quot;: &quot;rel-1.11.2-0-gf9626ccb91-prebuilt.qemu-project.org&quot;\r\n        },\r\n        {\r\n          &quot;blockdevices&quot;: &quot;sr0,vda&quot;\r\n        }\r\n        ]\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nI would like to make it look like this, as an example:\r\n\r\n```\r\n{\r\n  &quot;values&quot;: {\r\n    &quot;usrwww_size&quot;: false,\r\n    &quot;architecture&quot;: &quot;amd64&quot;,\r\n    &quot;bios_version&quot;: &quot;rel-1.11.2-0-gf9626ccb91-prebuilt.qemu-project.org&quot;,\r\n    &quot;blockdevices&quot;: &quot;sr0,vda&quot;\r\n  }\r\n}\r\n```\r\n\r\nI have tried the following but having no success:\r\n\r\n```map (with_entries(select(.key != &quot;facts&quot;)) + (.facts | with_entries(.value = .value[])) )```\r\n\r\nOutput:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;timestamp&quot;: &quot;2021-03-24T06:15:42.437Z&quot;,\r\n    &quot;data&quot;: [\r\n      {\r\n        &quot;usrwww_size&quot;: false\r\n      },\r\n      {\r\n        &quot;architecture&quot;: &quot;amd64&quot;\r\n      },\r\n      {\r\n        &quot;bios_version&quot;: &quot;rel-1.11.2-0-gf9626ccb91-prebuilt.qemu-project.org&quot;\r\n      },\r\n      {\r\n        &quot;blockdevices&quot;: &quot;sr0,vda&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nThis only unpacks one value, or multiple in the wrong format if I adjust the ```.value[] to .[]```\r\n\r\nI&#39;ve looked at **map**, **filter**, **slurping** but unfortunately haven&#39;t been successful. Does anyone perhaps have a solution or can point me in the right direction? I am quite stumped at the moment.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/66777394/unpack-json-into-a-single-json-element-using-jq",
        "title": "Unpack JSON into a single JSON element using JQ"
    },
    {
        "tags": [
            "json",
            "inheritance",
            "merge",
            "jq",
            "ancestor"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1616831496,
                "last_edit_date": 1616831496,
                "creation_date": 1616610715,
                "answer_id": 66787214,
                "question_id": 66786315,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the inheritance hierarchy contains no loops, as is the case with the example, we can break the problem down into the pieces shown below:\r\n```\r\n# Use an inner function of arity 0 to take advantage of jq&#39;s TCO\r\ndef inherits_from($dict):\r\n  def from:\r\n    if .name == &quot;default&quot; then .\r\n    else $dict[.inherits] as $next\r\n    | ., ($next | from)\r\n    end;\r\n  from;\r\n\r\ndef chain($start):\r\n  INDEX(.configurePresets[]; .name) as $dict\r\n  | $dict[$start] | inherits_from($dict);\r\n\r\nreduce chain(&quot;arm&quot;) as $x (null;\r\n  ($x.cacheVariables + .cacheVariables) as $cv\r\n  | $x + .\r\n  | .cacheVariables = $cv)\r\n| del(.inherits)\r\n```\r\n\r\nThis produces the desired output efficiently.\r\n\r\nOne advantage of the above formulation of a solution is that it can easily be modified to handle circular dependencies.  \r\n\r\n## Using `recurse/1`\r\n`inherits_from/1` could also be defined using the built-in function `recurse/1`:\r\n```\r\ndef inherits_from($dict):\r\n  recurse( select(.name != &quot;default&quot;) | $dict[.inherits]) ;\r\n```\r\nor perhaps more interestingly:\r\n```\r\ndef inherits_from($dict):\r\n  recurse( select(.inherits) | $dict[.inherits]) ;\r\n```\r\n### Using `*`\r\n\r\nUsing `*` to combine objects has a high overhead because of its recursive semantics, which is often either not required or not wanted.  However,\r\nif it is acceptable here to use `*` for combining the objects, the above can be simplified to:\r\n```\r\ndef inherits_from($dict):\r\n  recurse( select(.inherits) | $dict[.inherits]) ;\r\n\r\nINDEX(.configurePresets[]; .name) as $dict\r\n| $dict[&quot;arm&quot;] \r\n| reduce inherits_from($dict) as $x ({};  $x * .)\r\n| del(.inherits)\r\n```\r\n",
                "title": "How to recursively merge inherited json array elements?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1616836731,
                "last_edit_date": 1616836731,
                "creation_date": 1616762879,
                "answer_id": 66817258,
                "question_id": 66786315,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Writing a recursive function is actually simple, once you get the hang of it:\r\n\r\n\tjq --arg name &quot;$1&quot; &#39;\r\n\t\tdef _get_in(input; n):\r\n\t\t\t(input[] | select(.name == n)) |\r\n\t\t\t(if .inherits then .inherits as $n | _get_in(input; $n) else {} end) * .;\r\n\t\tdef get(name):\r\n\t\t\t.configurePresets as $input | _get_in($input; name);\r\n\t\tget($name)\r\n\t&#39; &quot;$presetfile&quot;\r\n\r\nFirst I filter only `.configurePresets` then in a function I get `input[] |  select(.name == n)` only the part I am interested in. Then `if .inherits` if it has inherits, then `.inherits as $n | _get_in(input; $n)` take the name in inherits and call itself again. Else return `else {} end` empty. Then that is `* .` merged with the result of `input[] | select(.name == n)` - the itself. So it recursively loads all the `{} * (input[]|select()) * (input[]|select()) * (input[]|select())`.",
                "title": "How to recursively merge inherited json array elements?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1616836731,
        "creation_date": 1616607128,
        "last_edit_date": 1616620310,
        "question_id": 66786315,
        "body_markdown": "I have the following json file named `CMakePresets.json` that is a cmake-preset file:\r\n\r\n    {\r\n      &quot;configurePresets&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;default&quot;,\r\n          &quot;hidden&quot;: true,\r\n          &quot;generator&quot;: &quot;Ninja&quot;,\r\n          &quot;binaryDir&quot;: &quot;${sourceDir}/_build/${presetName}&quot;,\r\n          &quot;cacheVariables&quot;: {\r\n            &quot;YIO_DEV&quot;: &quot;1&quot;,\r\n            &quot;BUILD_TESTING&quot;: &quot;1&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;debug&quot;,\r\n          &quot;inherits&quot;: &quot;default&quot;,\r\n          &quot;cacheVariables&quot;: {\r\n            &quot;CMAKE_BUILD_TYPE&quot;: &quot;Debug&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;release&quot;,\r\n          &quot;inherits&quot;: &quot;default&quot;,\r\n          &quot;binaryDir&quot;: &quot;${sourceDir}/_build/Debug&quot;,\r\n          &quot;cacheVariables&quot;: {\r\n            &quot;CMAKE_BUILD_TYPE&quot;: &quot;Release&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;arm&quot;,\r\n          &quot;inherits&quot;: &quot;debug&quot;,\r\n          &quot;cacheVariables&quot;: {\r\n            &quot;CMAKE_TOOLCHAIN_FILE&quot;: &quot;${sourceDir}/cmake/Toolchain/arm-none-eabi-gcc.cmake&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nI want recursively merge with `*` the `configurePresets` elements that inherit themselves for a specific entry `name`. I have example a node with name `arm` and want to have resulting json object with resolved inheritance. The parent has the name stored inside `.inherits` of each element. `arm` inherits over `debug` which inherits over `default`.\r\n\r\nI could write a bash shell loop that I believe works, with the help of https://stackoverflow.com/questions/48529016/remove-a-keyvalue-from-an-json-object-using-jq and [this answer](https://stackoverflow.com/a/36218044/9072753):\r\n \r\n    input=arm\r\n    # extract one element\r\n    g() { jq --arg name &quot;$1&quot; &#39;.configurePresets[] | select(.name == $name)&#39; CMakePresets.json; };\r\n    # get arm element\r\n    acc=$(g &quot;$input&quot;);\r\n    # If .inherits field exists\r\n    while i=$(&lt;&lt;&lt;&quot;$acc&quot; jq -r .inherits) &amp;&amp; [[ -n &quot;$i&quot; &amp;&amp; &quot;$i&quot; != &quot;null&quot; ]]; do\r\n       # remove it from input\r\n       a=$(&lt;&lt;&lt;&quot;$acc&quot; jq &#39;del(.inherits)&#39;);\r\n       # get parent element\r\n       b=$(g &quot;$i&quot;);\r\n       # merge parent with current\r\n       acc=$(printf &quot;%s\\n&quot; &quot;$b&quot; &quot;$a&quot; | jq -s &#39;reduce .[] as $item ({}; . * $item)&#39;);\r\n    done;\r\n    echo &quot;$acc&quot;\r\n\r\noutputs, which I believe is the expected output for `arm`:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;arm&quot;,\r\n      &quot;hidden&quot;: true,\r\n      &quot;generator&quot;: &quot;Ninja&quot;,\r\n      &quot;binaryDir&quot;: &quot;${sourceDir}/_build/${presetName}&quot;,\r\n      &quot;cacheVariables&quot;: {\r\n        &quot;YIO_DEV&quot;: &quot;1&quot;,\r\n        &quot;BUILD_TESTING&quot;: &quot;1&quot;,\r\n        &quot;CMAKE_BUILD_TYPE&quot;: &quot;Debug&quot;,\r\n        &quot;CMAKE_TOOLCHAIN_FILE&quot;: &quot;${sourceDir}/cmake/Toolchain/arm-none-eabi-gcc.cmake&quot;\r\n      }\r\n    }\r\n\r\nBut I want to write it in `jq`. I tried and `jq` language is not intuitive for me. I can do it for example for two (ie. countable) elements:\r\n\r\n    &lt; CMakePresets.json jq --arg name &quot;arm&quot; &#39;\r\n       def g(n): .configurePresets[] | select(.name == n);\r\n       g($name) * (g($name) | .inherits) as $name2 | g($name2)\r\n    &#39;\r\n\r\nBut I do not know how to do `reduce .[] as $item ({}; . * $item)` when the `$item` is really `g($name)` that depends on the last `g($name) | .inherits`. I tried reading [jq manual](https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions) and learning about variables and loops, but `jq` has a very different syntax. I tried to use `while`, but that&#39;s just syntax error that I do not understand and do not know how to fix. I guess `while` and `until` might not be right here, as they operate on previous loop output, while the elements are always from root.\r\n\r\n    $ &lt; CMakePresets.json jq --arg name &quot;arm&quot; &#39;def g(n): .configurePresets[] | select(.name == n);\r\n    while(g($name) | .inherits as $name; g($name))   \r\n    &#39;\r\n    jq: error: syntax error, unexpected &#39;;&#39;, expecting &#39;|&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 2:\r\n    while(g($name) | .inherits as $name; g($name))                                      \r\n    jq: 1 compile error\r\n\r\nHow to write such loop in `jq` language?\r\n",
        "link": "https://stackoverflow.com/questions/66786315/how-to-recursively-merge-inherited-json-array-elements",
        "title": "How to recursively merge inherited json array elements?"
    },
    {
        "tags": [
            "json",
            "object",
            "select",
            "substring",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1616812611,
                "last_edit_date": 1616812611,
                "creation_date": 1616785276,
                "answer_id": 66822908,
                "question_id": 66820040,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution that illustrates that there is no need to invoke jq more than once. In accordance with the jq program shown in the question, it also assumes that the selection is to be based on the values of the &quot;id&quot; key.\r\n```\r\n&lt; ids.txt jq -nR --argfile json input.json &#39;\r\n  # Is the input an acceptable value?\r\n  def acceptable($array): any(contains($array[]); .);\r\n\r\n  [inputs] as $substrings\r\n  | $json \r\n  | map( select(.id | acceptable($substrings)) )\r\n&#39;\r\n```\r\n\r\n### Note on `--argfile`\r\n`--argfile` has been deprecated, so you may wish to use `--slurpfile` instead, in which case you&#39;d have to write `$json[0]`. ",
                "title": "Filter in jq based on an array of string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1616827728,
        "creation_date": 1616773318,
        "last_edit_date": 1616827728,
        "question_id": 66820040,
        "body_markdown": "This is close to this question: https://stackoverflow.com/questions/61534283/jq-filter-json-array-based-on-value-in-list , the only difference being the condition.  I don&#39;t want equality as a condition, but a &quot;contains&quot;, but I am struggling to do it correctly.\r\n\r\nThe problem:\r\nIf want to filter elements of an input file based on the presence of a specific value in an entry\r\nThe input file:\r\n\r\n   \r\n    [{\r\n        &quot;id&quot;:&quot;type 1 is great&quot;\r\n    },{\r\n        &quot;id&quot;:&quot;type 2&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;:&quot;this is another type 2&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;:&quot;type 4&quot;\r\n    }]\r\n\r\nThe filter file:\r\nids.txt:\r\n\r\n    type 2\r\n    type 1\r\n\r\nThe select.jq file:\r\n\r\n\r\n     def isin($a): . as $in | any($a[]; contains($in));\r\n     map( select( .id | contains($ids) ) )\r\n\r\n\r\nThe jq command:\r\n\r\n    jq --argjson ids &quot;$(jq -R . ids.txt | jq -s .)&quot; -f select.jq test.json\r\n\r\nThe expected result should be something like:\r\n \r\n\r\n\r\n    [{\r\n      &quot;id&quot;:&quot;type 1 is great&quot;\r\n    },{\r\n     &quot;id&quot;:&quot;type 2&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;:&quot;this is another type 2&quot; \r\n    }]\r\n\r\nThe problem is obviously in the &quot;isin&quot; function of the select.jq file, so how to write it correctly to check if an entry contains one of the string of another array?",
        "link": "https://stackoverflow.com/questions/66820040/filter-in-jq-based-on-an-array-of-string",
        "title": "Filter in jq based on an array of string"
    },
    {
        "tags": [
            "json",
            "substring",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1616948127,
                "post_id": 66843336,
                "comment_id": 118156302,
                "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": 1616953352,
                "post_id": 66843336,
                "comment_id": 118157883,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1616954745,
                "post_id": 66843336,
                "comment_id": 118158291,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2906364,
                    "reputation": 315,
                    "user_id": 2491592,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/xkYU5.jpg?s=256",
                    "display_name": "K3it4r0",
                    "link": "https://stackoverflow.com/users/2491592/k3it4r0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1616970719,
                "post_id": 66843336,
                "comment_id": 118162585,
                "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": 1616986234,
                "post_id": 66843336,
                "comment_id": 118164887,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1617005571,
                "last_edit_date": 1617005571,
                "creation_date": 1616960756,
                "answer_id": 66845554,
                "question_id": 66843336,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It would probably be wise not to attempt to `cat` all the files at once; indeed, it would probably be best to avoid `cat` altogether.\r\n\r\nFor example, assuming program.jq contains whichever jq program you decide on (and there is nothing wrong with using `contains` here), you could try:\r\n```\r\nfind . -name &quot;*.json&quot; -exec jq -f program.jq &#39;{}&#39; +\r\n```\r\n\r\nUsing the non-standard + instead of &#39;;&#39; minimizes the number of times jq must be called, though the overhead of invoking jq is actually quite small. If your `find` does not support `+` and you wish to avoid calling jq once per file, then consider using [tag:xargs], or GNU `parallel` with the `—-xargs` option.\r\n\r\nIf you know the JSON files of interest are in the pwd, you could also speed up `find` by specifying `-maxdepth 1`.",
                "title": "jq: filter result by value (contains) is very slow"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1617005571,
        "creation_date": 1616946971,
        "last_edit_date": 1616970526,
        "question_id": 66843336,
        "body_markdown": "I am trying to use jq to filter a large number of JSON files and extract the ids of each object who belong to a specific domain, as well as the full URL within that domain. Here&#39;s a sample of the data:\r\n\r\n\r\n```json\r\n{\r\n    &quot;items&quot;: [\r\n        {\r\n            &quot;completeness&quot;: 5,\r\n            &quot;dcLanguageLangAware&quot;: {\r\n                &quot;def&quot;: [\r\n                    &quot;de&quot;\r\n                ]\r\n            },\r\n            &quot;edmIsShownBy&quot;: [\r\n                &quot;https://gallica.example/image/2IC6BQAEGWUEG4OP7AYBDGIGYAX62KZ6H366KXP2IKVAF4LKY37Q/presentation_images/5591be60-01fc-11e6-8e10-fa163e091926/node-3/image/SBB/Berliner_B&#246;rsenzeitung/1920/02/27/F_065_098_0/F_SBB_00007_19200227_065_098_0_001/full/full/0/default.jpg&quot;\r\n            ],\r\n            &quot;id&quot;: &quot;/9200355/BibliographicResource_3000117730632&quot;,\r\n            &quot;type&quot;: &quot;TEXT&quot;,\r\n            &quot;ugc&quot;: [\r\n                false\r\n            ]\r\n        }\r\n    ]\r\n}\r\n\r\n```\r\n\r\nBigger sample here: https://www.dropbox.com/s/0s0zjtxe01mecjc/AoQhRn%2B56KDm5AJJPwEvOTIwMDUyMC9hcmtfXzEyMTQ4X2JwdDZrMTAyNzY2Nw%3D%3D.json?dl=0\r\n\r\n\r\nI can extract both ids and URL which contains the string &quot;gallica&quot; using the following command: \r\n```bash\r\njq &#39;[ .items[] | select(.edmIsShownBy[] | contains (&quot;gallica&quot;)) |  {id: .id, link: .edmIsShownBy[] }]&#39;\r\n```\r\n\r\nHowever, i have more than 28000 JSON files to process and it is taking a large amount of time (around 1 file per minute). I am processing the files using bash with the command:\r\n\r\n```bash\r\nfind . -name &quot;*.json&quot; -exec cat &#39;{}&#39; &#39;;&#39; | jq &#39;[ .items[] | select(.edmIsShownBy[] | contains (&quot;gallica&quot;)) |  {id: .id, link: .edmIsShownBy[] }]&#39; \r\n``` \r\n\r\n\r\nI was wondering if the slowness is due by the instruction given to jq, and if it is the case, is there a faster way to filter a string contained in a chosen value? Any ideas?",
        "link": "https://stackoverflow.com/questions/66843336/jq-filter-result-by-value-contains-is-very-slow",
        "title": "jq: filter result by value (contains) is very slow"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5900492,
                    "reputation": 73,
                    "user_id": 4644185,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/da8b0b50bd4d917b5c0ed327041e5809?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Win32Sector",
                    "link": "https://stackoverflow.com/users/4644185/win32sector"
                },
                "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": 1617021296,
                "post_id": 66852251,
                "comment_id": 118175897,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1617021615,
                "creation_date": 1617021615,
                "answer_id": 66854363,
                "question_id": 66852251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [`join(&quot;:&quot;)`][1]:\r\n\r\n```\r\njq --raw-output &#39;.dependencies[] | join(&quot;:&quot;)&#39;\r\n```\r\n\r\n```none\r\nname1:10000.1.wew2133\r\nname2:10001.1.wew2133\r\n```\r\n\r\n[JQPlay demo](https://jqplay.org/s/FWETu0x_T2)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#example61",
                "title": "How to parse input with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1617021615,
        "creation_date": 1617012456,
        "last_edit_date": 1617021281,
        "question_id": 66852251,
        "body_markdown": "I have the list of docker images in json, for example:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;chart1&quot;,\r\n      &quot;version&quot;: &quot;1.1.0&quot;,\r\n      &quot;appVersion&quot;: &quot;1.1.0&quot;,\r\n      &quot;dependencies&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;name1&quot;,\r\n        &quot;version&quot;: &quot;10000.1.wew2133&quot;\r\n       },\r\n       {\r\n        &quot;name&quot;: &quot;name2&quot;,\r\n        &quot;version&quot;: &quot;10001.1.wew2133&quot;\r\n       }\r\n      ]\r\n    }\r\n\r\nI need to convert this to list:\r\n\r\n    name1:10000.1.wew2133\r\n    name2:10001.1.wew2133\r\n\r\nHow can I do this? ",
        "link": "https://stackoverflow.com/questions/66852251/how-to-parse-input-with-jq",
        "title": "How to parse input with jq"
    },
    {
        "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": 0,
                "creation_date": 1617024521,
                "post_id": 66854922,
                "comment_id": 118177561,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5616703,
                    "reputation": 8281,
                    "user_id": 4452265,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/08344f2696c085e78dfd375b0a3462ab?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jetchisel",
                    "link": "https://stackoverflow.com/users/4452265/jetchisel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1617024534,
                "post_id": 66854922,
                "comment_id": 118177570,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5616703,
                    "reputation": 8281,
                    "user_id": 4452265,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/08344f2696c085e78dfd375b0a3462ab?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jetchisel",
                    "link": "https://stackoverflow.com/users/4452265/jetchisel"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1617024626,
                "post_id": 66854922,
                "comment_id": 118177614,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10092726,
                    "reputation": 1001,
                    "user_id": 7459181,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://www.gravatar.com/avatar/f0f420fde184d1736363dde9f59b780e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dventi3",
                    "link": "https://stackoverflow.com/users/7459181/dventi3"
                },
                "reply_to_user": {
                    "account_id": 5616703,
                    "reputation": 8281,
                    "user_id": 4452265,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/08344f2696c085e78dfd375b0a3462ab?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jetchisel",
                    "link": "https://stackoverflow.com/users/4452265/jetchisel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1617024888,
                "post_id": 66854922,
                "comment_id": 118177737,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1617024918,
                "post_id": 66854922,
                "comment_id": 118177760,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10092726,
                    "reputation": 1001,
                    "user_id": 7459181,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://www.gravatar.com/avatar/f0f420fde184d1736363dde9f59b780e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dventi3",
                    "link": "https://stackoverflow.com/users/7459181/dventi3"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1617102207,
                "post_id": 66854922,
                "comment_id": 118203649,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3832252,
                    "reputation": 1044,
                    "user_id": 3177532,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://i.sstatic.net/dZcQS.jpg?s=256",
                    "display_name": "solujic",
                    "link": "https://stackoverflow.com/users/3177532/solujic"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680004953,
                "post_id": 66854922,
                "comment_id": 133819377,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1617025096,
                "creation_date": 1617025096,
                "answer_id": 66855256,
                "question_id": 66854922,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just use `jq` it&#39;s a scripting language on it&#39;s own.\r\n\r\n    $ jq -r &#39;.[0].failure_system_out&#39; /tmp/1\r\n    expected 404 Not Found\r\n    Error in test endpoint\r\n    \tat Test._assertStatus\r\n    $ jq -r &#39;.[1].failure_system_out&#39; /tmp/1\r\n    Example fo test\r\n    \tExpect 4 and got 5\r\n    $ jq -r &#39;.[] | .name as $test_name | .failure_system_out as $system_error | $system_error&#39; /tmp/1\r\n    expected 404 Not Found\r\n    Error in test endpoint\r\n    \tat Test._assertStatus\r\n    Example fo test\r\n    \tExpect 4 and got 5\r\n\r\nAs for using bash, first read https://mywiki.wooledge.org/BashFAQ/001 . I like using `base64` to properly transfer context from `jq` to `bash` and handle all corner cases.\r\n\r\n    jq -r &#39;.[] | @base64&#39; /tmp/1 |\r\n    while IFS= read -r line; do\r\n        line=$(&lt;&lt;&lt;&quot;$line&quot; base64 -d);\r\n        test_name=$(&lt;&lt;&lt;&quot;$line&quot; jq -r .name);\r\n        system_error=$(&lt;&lt;&lt;&quot;$line&quot; jq -r .failure_system_out);\r\n        printf &quot;%s\\n&quot; &quot;$system_error&quot;;\r\n    done\r\n\r\nbut it&#39;s not needed here, just a proper `while read` loop should be enough:\r\n\r\n    jq -c &#39;.[]&#39; /tmp/1 |\r\n    while IFS= read -r line; do\r\n        test_name=$(&lt;&lt;&lt;&quot;$line&quot; jq -r .name);\r\n        system_error=$(&lt;&lt;&lt;&quot;$line&quot; jq -r .failure_system_out);\r\n        printf &quot;%s\\n&quot; &quot;$system_error&quot;;\r\n    done\r\n\r\n",
                "title": "Iterate over an array of objects and format the string"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1617025890,
                "creation_date": 1617025890,
                "answer_id": 66855471,
                "question_id": 66854922,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[@KamilCuk&#39;s answer][1] works great and gives quite some more control.\r\n\r\nThought I&#39;d still share this [tag:jq] only solution:\r\n```bash\r\nprintf &quot;%s\\n&quot; &quot;$(jq -r -c &#39;.[] | .failure_system_out&#39; test.json)&quot;\r\n```\r\n\r\nThis will produce:\r\n```\r\nexpected 404 Not Found\r\nError in test endpoint\r\n\tat Test._assertStatus\r\nExample fo test\r\n\tExpect 4 and got 5\r\n```\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/66855256/5625547",
                "title": "Iterate over an array of objects and format the string"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1617041883,
                "creation_date": 1617041883,
                "answer_id": 66859491,
                "question_id": 66854922,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The question seems to weave amongst several goals, but in any case:\r\n\r\n* there is no need for jq to be called more than once, and \r\n\r\n* there should be no need to use base64 conversions, except possibly if the values corresponding to the keys of interest contain NULs. \r\n\r\nIf the goal is simply to emit the values of `.failure_system_out` then:\r\n\r\n     jq -r &#39;.[].failure_system_out&#39; test.json\r\n\r\nwould do it.  \r\n\r\nIf the values of both `.name` and `.failure_system_out` must be made available separately as bash variables, then consider:\r\n```\r\nwhile IFS= read -d $&#39;\\0&#39; system_error ; do\r\n    IFS= read -d $&#39;\\0&#39; test_name\r\n    printf &quot;%s\\n&quot; name=&quot;$test_name&quot;\r\n    printf &quot;%s\\n&quot; fso=&quot;$system_error&quot;\r\n    echo &quot;&quot;\r\ndone &lt; &lt;(jq -rj &#39;.[] | [.name, .failure_system_out, &quot;&quot;] | join(&quot;\\u0000&quot;)&#39; test.json)\r\n```\r\n\r\n`readarray` could also be used -- see e.g.\r\n https://stackoverflow.com/questions/49321015/storing-jq-null-delimited-output-in-bash-array\r\n",
                "title": "Iterate over an array of objects and format the string"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1617041883,
        "creation_date": 1617023792,
        "last_edit_date": 1617025094,
        "question_id": 66854922,
        "body_markdown": "I have a json file like this:\r\n```\r\n[\r\n  {\r\n    &quot;classname&quot;: &quot;Test endpoint&quot;,\r\n    &quot;name&quot;: &quot;expect failure&quot;,\r\n    &quot;failure_system_out&quot;: &quot;expected 404 Not Found\\nError in test endpoint\\n\\tat Test._assertStatus&quot;\r\n  },\r\n  {\r\n    &quot;classname&quot;: &quot;Test inner functions&quot;,\r\n    &quot;name&quot;: &quot;expect failure&quot;,\r\n    &quot;failure_system_out&quot;: &quot;Example fo test\\n\\tExpect 4 and got 5&quot;\r\n  }\r\n]\r\n```\r\n\r\nAs you see the value in &quot;failure_system_out&quot; is a string containing newline chars (\\n) and tab chars (\\t).\r\n\r\nI am trying to read the file, loop around the objects and print them with this code:\r\n\r\n```\r\njq -c &#39;.[]&#39; myfile.json | while read i; do\r\n    test_name=$(echo &quot;$i&quot; | jq -r .name)\r\n    system_error=$(echo &quot;$i&quot; | jq -r .failure_system_out)\r\n    printf &quot;${system_error}&quot;\r\n\r\ndone\r\n```\r\n\r\nThe problem is that using this approach, printf doesn&#39;t print the script according the the new line &amp; tab chars, but It prints something like this `expected 404 Not FoundnError in test endpointntat Test._assertStatus`\r\nBasically, I think that jq -c removes the `\\` char and therefore the printf doesn&#39;t work properly.\r\n\r\nHow can I iterate over an array of object stored in a file and keep the chars using to format the string?\r\n\r\nDesired output for the first item:\r\n```\r\nexpected 404 Not Found\r\nError in test endpoint\r\n   at Test._assertStatus\r\n```\r\n\r\n\r\nDesired output for the second item:\r\n```\r\nExample fo test\r\n    Expect 4 and got 5\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/66854922/iterate-over-an-array-of-objects-and-format-the-string",
        "title": "Iterate over an array of objects and format the string"
    }
]