[
    {
        "tags": [
            "json",
            "shell",
            "sed",
            "jq",
            "edit"
        ],
        "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": 1579290135,
                "post_id": 59791136,
                "comment_id": 105729864,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 923752,
                    "reputation": 56142,
                    "user_id": 954940,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://i.sstatic.net/8VrIO.jpg?s=256",
                    "display_name": "Adam Jenkins",
                    "link": "https://stackoverflow.com/users/954940/adam-jenkins"
                },
                "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": 1579290193,
                "post_id": 59791136,
                "comment_id": 105729885,
                "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": 1579293730,
                "post_id": 59791136,
                "comment_id": 105731225,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 923752,
                    "reputation": 56142,
                    "user_id": 954940,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://i.sstatic.net/8VrIO.jpg?s=256",
                    "display_name": "Adam Jenkins",
                    "link": "https://stackoverflow.com/users/954940/adam-jenkins"
                },
                "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": 1579300444,
                "post_id": 59791136,
                "comment_id": 105733286,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1579285461,
                "last_edit_date": 1579285461,
                "creation_date": 1579284400,
                "answer_id": 59792760,
                "question_id": 59791136,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a bit tricky since replacement string has many lines. You can try this `sed` with a process substitution:\r\n\r\n    sed -i -e &#39;/{{SOME_PATTERN}}/r &#39;&lt;( jq -Rn &#39;[inputs | {(.): env[.]}] | add&#39; /etc/nginx/conf.d/env) -e &#39;//d&#39; somefile\r\n\r\nMake sure you&#39;re using `bash`.\r\n\r\nWith a bit modified `jq` command that produces single line output, you can just do:\r\n\r\n    sed -i &#39;s/{{SOME_PATTERN}}/&#39;&quot;$(jq -nRc &#39;[inputs | {(.): env[.]}] | add&#39; /etc/nginx/conf.d/env)&quot;&#39;/&#39; somefile",
                "title": "sed unterminated `s&#39; command with jq json string"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1579302449,
                "creation_date": 1579302449,
                "answer_id": 59795916,
                "question_id": 59791136,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "@Adam asked:\r\n\r\n&gt; what would that look like? \r\n\r\nIf your jq has the --rawfile option, there should be no need to juggle jq and sed:\r\n\r\n```\r\n&lt; somefile jq -R --rawfile text tmp.txt &#39;\r\n  ($text\r\n   | split(&quot;\\n&quot;)\r\n   | map(select(length&gt;0)\r\n   | {(.): env[.]}) | add) as $json\r\n  | sub(&quot;{{SOME_PATTERN}}&quot;; $json|tostring)&#39;\r\n\r\n",
                "title": "sed unterminated `s&#39; command with jq json string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1579378745,
        "creation_date": 1579277913,
        "last_edit_date": 1579378745,
        "question_id": 59791136,
        "body_markdown": "Piggybacking off of [this question][1] I have a command (running in a Docker container) where I am trying to sed to replace an expression with a JSON string generated by jq.\r\n\r\nTiny backstory:\r\n\r\nI have a whitelist of env vars in a file `tmp.txt`:\r\n\r\n```\r\nENV_VAR_A\r\nENV_VAR_B\r\nENV_VAR_C\r\n```\r\n\r\nI use jq using the answer in the previous thread to generate a JSON string like this:\r\n\r\n```\r\njq -Rn &#39;[inputs | {(.): env[.]}] | add&#39; ./tmp.txt\r\n# GENERATES { &quot;ENV_VAR_A&quot;: &quot;a val&quot;, &quot;ENV_VAR_B&quot;: &quot;a val&quot;, &quot;ENV_VAR_C&quot;: &quot;a val&quot;}\r\n```\r\n\r\nAmazing! Now I am trying to use sed (as a Docker `CMD`) to do replace something:\r\n\r\n```\r\n# CMD sed -i &#39;s@{{SOME_PATTERN}}@&#39;$( jq -Rn &#39;[inputs | {(.): env[.]}] | add&#39; ./etc/nginx/conf.d/env)&#39;@&#39; ./somefile\r\n```\r\n\r\nBut I am getting:\r\n\r\n```\r\nsed: -e expression #1, char 22: unterminated `s&#39; command\r\n```\r\n\r\nSo something went wrong the substitution - but I am not nearly knowledgeable enough in shell to figure out how to fix it, I feel like I have to move some quotes/delimiters around, or maybe pipe my jq to something to &quot;clean up&quot; the json string before I substitute, but I&#39;m not sure what.\r\n\r\nLooking for some sed-fu, can anyone help?\r\n\r\n  [1]: https://stackoverflow.com/questions/59778578/generating-a-json-map-containing-shell-variables-named-in-a-list/59779106?noredirect=1#comment105717845_59779106",
        "link": "https://stackoverflow.com/questions/59791136/sed-unterminated-s-command-with-jq-json-string",
        "title": "sed unterminated `s&#39; command with jq json string"
    },
    {
        "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": 1579279451,
                "post_id": 59791160,
                "comment_id": 105725410,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1579288436,
                "creation_date": 1579288436,
                "answer_id": 59793571,
                "question_id": 59791160,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have 4 `web_url` in your JSON.\r\n\r\nCan check the below results,\r\n\r\n    .[] | .web_url\r\n    .[] | .merged_by.web_url\r\n    .[] | .author.web_url\r\n    .[] | .assignee.web_url",
                "title": "Parse JSON output for particular key fields"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1579619307,
                "last_edit_date": 1579619307,
                "creation_date": 1579289867,
                "answer_id": 59793853,
                "question_id": 59791160,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the question is essentially how to find the needle in the haystack, the answer is: use `paths`; more specifically, in your case:\r\n\r\n```\r\njq -c &#39;paths(. == &quot;https://gitlaboo.tests.com/demo/frog/merge_requests/1&quot;)\r\n             | select(.[-1] == &quot;web_url&quot;)\r\n&#39; file.json\r\n```\r\nThe output gives the path as a JSON array:\r\n\r\n    [0,&quot;web_url&quot;]\r\n\r\nThis can be used directly in jq (using `getpath/1`), or as the basis for a direct query:\r\n\r\n    .[0].web_url\r\n",
                "title": "Parse JSON output for particular key fields"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1579619307,
        "creation_date": 1579277994,
        "last_edit_date": 1579333706,
        "question_id": 59791160,
        "body_markdown": "I have the following JSON content in a file.json. \r\n\r\nI need only a particular key field from all this overwhelming information. \r\n\r\nLet us assume that I need `web_url`,\r\n\r\nThe problem here is there are multiple key field with &quot;web_url&quot;.\r\n\r\nHow do only get the `web_url` field I am after?\r\n\r\n    [{&quot;id&quot;:196,&quot;iid&quot;:1,&quot;project_id&quot;:233,&quot;title&quot;:&quot;DEV to Master&quot;,&quot;description&quot;:&quot;&quot;,&quot;state&quot;:&quot;merged&quot;,&quot;created_at&quot;:&quot;2019-12-04T14:14:35.424-06:00&quot;,&quot;updated_at&quot;:&quot;2019-12-04T14:14:47.310-06:00&quot;,&quot;merged_by&quot;:{&quot;id&quot;:122,&quot;name&quot;:&quot;Sengoku&quot;,&quot;username&quot;:&quot;sengk&quot;,&quot;state&quot;:&quot;active&quot;,&quot;avatar_url&quot;:&quot;https://secure.gravatar.com/avatar/7cvffgfgfgfgf9eb1348d0ba7795a076?s=80\\u0026d=identicon&quot;,&quot;web_url&quot;:&quot;https://gitlaboo.tests.com/sengk&quot;},&quot;merged_at&quot;:&quot;2019-12-04T14:14:47.468-06:00&quot;,&quot;closed_by&quot;:null,&quot;closed_at&quot;:null,&quot;target_branch&quot;:&quot;master&quot;,&quot;source_branch&quot;:&quot;DEV&quot;,&quot;upvotes&quot;:0,&quot;downvotes&quot;:0,&quot;author&quot;:{&quot;id&quot;:122,&quot;name&quot;:&quot;Sengoku&quot;,&quot;username&quot;:&quot;sengk&quot;,&quot;state&quot;:&quot;active&quot;,&quot;avatar_url&quot;:&quot;https://secure.gravatar.com/avatar/7fgdfdgdfgdvfg9eb1348d0ba7795a076?s=80\\u0026d=identicon&quot;,&quot;web_url&quot;:&quot;https://gitlaboo.tests.com/sengk&quot;},&quot;assignee&quot;:{&quot;id&quot;:122,&quot;name&quot;:&quot;Sengoku&quot;,&quot;username&quot;:&quot;sengk&quot;,&quot;state&quot;:&quot;active&quot;,&quot;avatar_url&quot;:&quot;https://secure.gravatar.com/avatar/7afsdfdvdfvfde24f89eb1348d0ba7795a076?s=80\\u0026d=identicon&quot;,&quot;web_url&quot;:&quot;https://gitlaboo.tests.com/sengk&quot;},&quot;source_project_id&quot;:233,&quot;target_project_id&quot;:233,&quot;labels&quot;:[],&quot;work_in_progress&quot;:false,&quot;milestone&quot;:null,&quot;merge_when_pipeline_succeeds&quot;:false,&quot;merge_status&quot;:&quot;can_be_merged&quot;,&quot;sha&quot;:&quot;6318e51ea8czfdfsdvdfvdfbc02988ba62c71e5774107e&quot;,&quot;merge_commit_sha&quot;:&quot;6dc5vdfvdfgdfg5bf14e97dea949b8584c0c68d6&quot;,&quot;user_notes_count&quot;:0,&quot;discussion_locked&quot;:null,&quot;should_remove_source_branch&quot;:null,&quot;force_remove_source_branch&quot;:false,&quot;web_url&quot;:&quot;https://gitlaboo.tests.com/demo/frog/merge_requests/1&quot;,&quot;time_stats&quot;:{&quot;time_estimate&quot;:0,&quot;total_time_spent&quot;:0,&quot;human_time_estimate&quot;:null,&quot;human_total_time_spent&quot;:null},&quot;squash&quot;:false}]",
        "link": "https://stackoverflow.com/questions/59791160/parse-json-output-for-particular-key-fields",
        "title": "Parse JSON output for particular key fields"
    },
    {
        "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": 1579363988,
                "post_id": 59801518,
                "comment_id": 105745323,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15371180,
                    "reputation": 307,
                    "user_id": 11089167,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-eiIFTuzc6i8/AAAAAAAAAAI/AAAAAAAABHs/u0NF4ACZ-HE/s256-rj/photo.jpg",
                    "display_name": "Jalakam Kiran",
                    "link": "https://stackoverflow.com/users/11089167/jalakam-kiran"
                },
                "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": 1579364563,
                "post_id": 59801518,
                "comment_id": 105745473,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1579381052,
                "last_edit_date": 1579381052,
                "creation_date": 1579366384,
                "answer_id": 59802761,
                "question_id": 59801518,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you wanted simply to append the objects in File_1.json to an existing array in (say) output.json, you could write:\r\n\r\n    jq  &#39;. + [inputs]&#39; output.json File_1.json\r\n\r\n\r\nThis presupposes output.json contains exactly one array (or the JSON value `null`).  So to start, you could initialize output.json by running:\r\n\r\n    echo null &gt; output.json\r\n\r\nIf you want to take the risk and overwrite output.json, you might like to use [`sponge`][1]:\r\n\r\n    jq  &#39;. + [inputs]&#39; output.json File_1.json | sponge output.json\r\n\r\nIf you want to remove duplicates and don&#39;t mind sorting the objects, you could simply append `| unique` to the above jq filter.  If retaining the order is important, then see\r\nhttps://github.com/stedolan/jq/wiki/Cookbook#using-bag-to-implement-a-sort-free-version-of-unique\r\n\r\n\r\n  [1]: https://joeyh.name/code/moreutils/",
                "title": "adding json objects from one file to another under single array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1579381052,
        "creation_date": 1579357573,
        "question_id": 59801518,
        "body_markdown": "I am new here so sorry if I do any mistakes while asking the question.\r\n\r\nI have a json file that keeps updating every minute(File_1.json) with json objects. All i want to do is copy these objects to another file under a single array using the jq command. \r\n\r\nSamples of files\r\nFile_1.json:\r\n\r\n            {\r\n              &quot;Id&quot;:&quot;1&quot;,\r\n              &quot;Name&quot;:&quot;Kiran&quot;,\r\n              &quot;Age&quot;:&quot;12&quot;\r\n            }\r\n            {\r\n              &quot;Id&quot;:&quot;2&quot;,\r\n              &quot;Name&quot;:&quot;Dileep&quot;,\r\n              &quot;Age&quot;:&quot;22&quot;\r\n            }\r\n\r\nExpected Output\r\n\r\n         [ \r\n           {\r\n              &quot;Id&quot;:&quot;1&quot;,\r\n              &quot;Name&quot;:&quot;Kiran&quot;,\r\n              &quot;Age&quot;:&quot;12&quot;\r\n            }\r\n            {\r\n              &quot;Id&quot;:&quot;2&quot;,\r\n              &quot;Name&quot;:&quot;Dileep&quot;,\r\n              &quot;Age&quot;:&quot;22&quot;\r\n            }\r\n           ]\r\n\r\nI have tried using -s(slurp) but since the code will be running once for every minute its creating multiple arrays. ",
        "link": "https://stackoverflow.com/questions/59801518/adding-json-objects-from-one-file-to-another-under-single-array-using-jq",
        "title": "adding json objects from one file to another under single array using jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1579405493,
                "last_edit_date": 1579405493,
                "creation_date": 1579405084,
                "answer_id": 59806956,
                "question_id": 59806699,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way:\r\n\r\n    $ jq -r &#39;.data.candles[] | @csv&#39; data.json\r\n    &quot;2015-12-28T09:15:00+0530&quot;,1386.4,1388,1381.05,1385.1,788\r\n    &quot;2015-12-28T09:16:00+0530&quot;,1385.1,1389.1,1383.85,1385.5,609\r\n    &quot;2015-12-28T09:17:00+0530&quot;,1385.5,1387,1385.5,1385.7,212\r\n    &quot;2015-12-28T09:18:00+0530&quot;,1387,1387.95,1385.3,1387.95,1208\r\n    &quot;2015-12-28T09:19:00+0530&quot;,1387,1387.55,1385.6,1386.25,716\r\n    &quot;2015-12-28T09:20:00+0530&quot;,1386.95,1389.95,1386.95,1389,727\r\n    &quot;2015-12-28T09:21:00+0530&quot;,1389,1392.95,1389,1392.95,291\r\n    &quot;2015-12-28T09:22:00+0530&quot;,1392.95,1393,1392,1392.95,180\r\n    &quot;2015-12-28T09:23:00+0530&quot;,1392.95,1393,1392,1392.15,1869\r\n    &quot;2016-01-01T13:22:00+0530&quot;,1386.4,1388,1381.05,1385.1,788\r\n    &quot;2016-01-01T13:23:00+0530&quot;,1385.1,1389.1,1383.85,1385.5,613\r\n    &quot;2016-01-01T13:24:00+0530&quot;,1385.5,1387,1385.5,1385.7,212\r\n    &quot;2016-01-01T13:25:00+0530&quot;,1387,1387.95,1385.3,1387.95,1208\r\n    &quot;2016-01-01T13:26:00+0530&quot;,1387,1387.55,1385.6,1386.25,716\r\n    &quot;2016-01-01T13:27:00+0530&quot;,1386.95,1389.95,1386.95,1389,727\r\n    &quot;2016-01-01T13:28:00+0530&quot;,1389,1392.95,1389,1392.95,291\r\n    &quot;2016-01-01T13:29:00+0530&quot;,1392.95,1393,1392,1392.95,180\r\n    &quot;2016-01-01T13:30:00+0530&quot;,1392.95,1393,1392,1392.15,1869\r\n\r\nIt just sends all the elements of the candles array to the `@csv` output formatter, one at a time, and prints out the raw results instead of treating each output line as a JSON string (The `-r` option).\r\n\r\nTo save results in a file in a script, just use output redirection like normal:\r\n\r\n    jq -r &#39;.data.candles[] | @csv&#39; data.json &gt; output.csv",
                "title": "Json to csv using jq or any other bash command"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1579424878,
                "creation_date": 1579424878,
                "answer_id": 59808662,
                "question_id": 59806699,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I have to parse a big json file to csv in as little a time as\r\n&gt; possible.\r\n\r\nIf the file is of the format you show, you may find a simple `sed` command much faster than `jq`. And, since the resulting format is .csv and not .json, then any json validations provide by `jq` would not be applicable here. An example of using `sed` for this is:\r\n\r\n    $ sed -n &#39;s/^\\s*[[]\\([^]]*\\).*$/\\1/;s/&quot;//g;s/,\\s/,/gp&#39; sample.json\r\n    2015-12-28T09:15:00+0530,1386.4,1388,1381.05,1385.1,788\r\n    2015-12-28T09:16:00+0530,1385.1,1389.1,1383.85,1385.5,609\r\n    2015-12-28T09:17:00+0530,1385.5,1387,1385.5,1385.7,212\r\n    2015-12-28T09:18:00+0530,1387,1387.95,1385.3,1387.95,1208\r\n    2015-12-28T09:19:00+0530,1387,1387.55,1385.6,1386.25,716\r\n    2015-12-28T09:20:00+0530,1386.95,1389.95,1386.95,1389,727\r\n    2015-12-28T09:21:00+0530,1389,1392.95,1389,1392.95,291\r\n    2015-12-28T09:22:00+0530,1392.95,1393,1392,1392.95,180\r\n    2015-12-28T09:23:00+0530,1392.95,1393,1392,1392.15,1869\r\n    2016-01-01T13:22:00+0530,1386.4,1388,1381.05,1385.1,788\r\n    2016-01-01T13:23:00+0530,1385.1,1389.1,1383.85,1385.5,613\r\n    2016-01-01T13:24:00+0530,1385.5,1387,1385.5,1385.7,212\r\n    2016-01-01T13:25:00+0530,1387,1387.95,1385.3,1387.95,1208\r\n    2016-01-01T13:26:00+0530,1387,1387.55,1385.6,1386.25,716\r\n    2016-01-01T13:27:00+0530,1386.95,1389.95,1386.95,1389,727\r\n    2016-01-01T13:28:00+0530,1389,1392.95,1389,1392.95,291\r\n    2016-01-01T13:29:00+0530,1392.95,1393,1392,1392.95,180\r\n    2016-01-01T13:30:00+0530,1392.95,1393,1392,1392.15,1869\r\n\r\n`sed` being a pure stream-editor you may find it an order of magnitude faster than the equivalent operation using `jq`. Further, the `jq` solution in the other answer fails to remove the double-quotation marks around the date and time field. Give it a try...",
                "title": "Json to csv using jq or any other bash command"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1579429721,
        "creation_date": 1579401840,
        "last_edit_date": 1579429721,
        "question_id": 59806699,
        "body_markdown": "I have to parse a big json file to csv in as little a time as possible. I have the following sample json file: \r\n\r\n    {\r\n        &quot;status&quot;: &quot;success&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;candles&quot;: [\r\n                [&quot;2015-12-28T09:15:00+0530&quot;, 1386.4, 1388, 1381.05, 1385.1, 788],\r\n                [&quot;2015-12-28T09:16:00+0530&quot;, 1385.1, 1389.1, 1383.85, 1385.5, 609],\r\n                [&quot;2015-12-28T09:17:00+0530&quot;, 1385.5, 1387, 1385.5, 1385.7, 212],\r\n                [&quot;2015-12-28T09:18:00+0530&quot;, 1387, 1387.95, 1385.3, 1387.95, 1208],\r\n                [&quot;2015-12-28T09:19:00+0530&quot;, 1387, 1387.55, 1385.6, 1386.25, 716],\r\n                [&quot;2015-12-28T09:20:00+0530&quot;, 1386.95, 1389.95, 1386.95, 1389, 727],\r\n                [&quot;2015-12-28T09:21:00+0530&quot;, 1389, 1392.95, 1389, 1392.95, 291],\r\n                [&quot;2015-12-28T09:22:00+0530&quot;, 1392.95, 1393, 1392, 1392.95, 180],\r\n                [&quot;2015-12-28T09:23:00+0530&quot;, 1392.95, 1393, 1392, 1392.15, 1869],\r\n                [&quot;2016-01-01T13:22:00+0530&quot;, 1386.4, 1388, 1381.05, 1385.1, 788],\r\n                [&quot;2016-01-01T13:23:00+0530&quot;, 1385.1, 1389.1, 1383.85, 1385.5, 613],\r\n                [&quot;2016-01-01T13:24:00+0530&quot;, 1385.5, 1387, 1385.5, 1385.7, 212],\r\n                [&quot;2016-01-01T13:25:00+0530&quot;, 1387, 1387.95, 1385.3, 1387.95, 1208],\r\n                [&quot;2016-01-01T13:26:00+0530&quot;, 1387, 1387.55, 1385.6, 1386.25, 716],\r\n                [&quot;2016-01-01T13:27:00+0530&quot;, 1386.95, 1389.95, 1386.95, 1389, 727],\r\n                [&quot;2016-01-01T13:28:00+0530&quot;, 1389, 1392.95, 1389, 1392.95, 291],\r\n                [&quot;2016-01-01T13:29:00+0530&quot;, 1392.95, 1393, 1392, 1392.95, 180],\r\n                [&quot;2016-01-01T13:30:00+0530&quot;, 1392.95, 1393, 1392, 1392.15, 1869]\r\n            ]\r\n        }\r\n    }\r\n\r\nThe data in the above file (say data.json) has to filtered and the candles data has to be saved in csv file (say output.csv). I am unable to get .data.candles data in a csv file. Output expected is:\r\n    \r\n    2015-12-28T09:15:00+0530,1386.4,1388.0,1381.05,1385.1,788\r\n    2015-12-28T09:16:00+0530,1385.1,1389.1,1383.85,1385.5,609\r\n    2015-12-28T09:17:00+0530,1385.5,1387.0,1385.5,1385.7,212\r\n    2015-12-28T09:18:00+0530,1387.0,1387.95,1385.3,1387.95,1208\r\n    2015-12-28T09:19:00+0530,1387.0,1387.55,1385.6,1386.25,716\r\n    2015-12-28T09:20:00+0530,1386.95,1389.95,1386.95,1389.0,727\r\n    2015-12-28T09:21:00+0530,1389.0,1392.95,1389.0,1392.95,291\r\n    2015-12-28T09:22:00+0530,1392.95,1393.0,1392.0,1392.95,180\r\n    2015-12-28T09:23:00+0530,1392.95,1393.0,1392.0,1392.15,1869\r\n    2016-01-01T13:22:00+0530,1386.4,1388.0,1381.05,1385.1,788\r\n    2016-01-01T13:23:00+0530,1385.1,1389.1,1383.85,1385.5,613\r\n    2016-01-01T13:24:00+0530,1385.5,1387.0,1385.5,1385.7,212\r\n    2016-01-01T13:25:00+0530,1387.0,1387.95,1385.3,1387.95,1208\r\n    2016-01-01T13:26:00+0530,1387.0,1387.55,1385.6,1386.25,716\r\n    2016-01-01T13:27:00+0530,1386.95,1389.95,1386.95,1389.0,727\r\n    2016-01-01T13:28:00+0530,1389.0,1392.95,1389.0,1392.95,291\r\n    2016-01-01T13:29:00+0530,1392.95,1393.0,1392.0,1392.95,180\r\n    2016-01-01T13:30:00+0530,1392.95,1393.0,1392.0,1392.15,1869\r\n\r\nI can do it in python, but owing to speed, I have to do it via jq.\r\n\r\nA little help here would be much appreciated. \r\n\r\n",
        "link": "https://stackoverflow.com/questions/59806699/json-to-csv-using-jq-or-any-other-bash-command",
        "title": "Json to csv using jq or any other bash command"
    },
    {
        "tags": [
            "json",
            "jq",
            "tree-traversal"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1579461555,
                "last_edit_date": 1579461555,
                "creation_date": 1579459857,
                "answer_id": 59813288,
                "question_id": 59813234,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you just want to get the element `gb_sibling`, you could use the following:\n\n    jq .gp_sibling &lt;file&gt;\n\nIf you want to get it only if there is the `key` element with it&#39;s value, you could try this:\n\n    jq &#39;select(.&quot;grand-parent&quot;?.parent?[]?.key==&quot;known_value&quot;)|.gp_sibling&#39; &lt;file&gt;\n\nThis, it filters the elements where the content of the attribute `key` inside `parent` inside `grand-parent` equals `known_value`.\n\nFrom that result, `gp_sibling` is selected.\n\n[**NOTE**]\n\n`grand-parent` is quoted because the dash would cause problems otherwise.",
                "title": "JSON parsing [`jq`]: Get value of grandparent’s sibling"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1579463034,
                "creation_date": 1579463034,
                "answer_id": 59813769,
                "question_id": 59813234,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "My reading of the question is that none of the key names except &quot;key&quot; is to be used in the query, and that if there were more than one &quot;grand-parent sibling&quot; that was a string, we&#39;d want them all.\r\n\r\n\r\n``` \r\npaths(.key? == &quot;known_value&quot;) as $p\r\n| getpath($p[0:-4])\r\n| .[]\r\n| select(type==&quot;string&quot;)\r\n```\r\n\r\n",
                "title": "JSON parsing [`jq`]: Get value of grandparent’s sibling"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1579496712,
        "creation_date": 1579459459,
        "last_edit_date": 1579496712,
        "question_id": 59813234,
        "body_markdown": "### Example\r\n\r\n```json\r\n{\r\n  &quot;gp_sibling&quot;: &quot;desired_value&quot;,\r\n  &quot;grand-parent&quot;: {\r\n    &quot;parent&quot;: [\r\n      {\r\n        &quot;key&quot;: &quot;known_value&quot;,\r\n        &quot;sibling&quot;: &quot;asdf&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n### Problem definition\r\n\r\nI have a large JSON. I know that `key` has a unique value. I need to get it’s grand-parent’s sibling key value (the value of `gp_sibling` key).\r\n\r\nNow, I could `grep` the JSON, but I’d like to use `jq`. But I don’t know to achieve this (I use `jq` for simple queries only).\r\n\r\n### Notes\r\n\r\nAlthough I know that `jq` can be used on Windows too, I use it on Linux only.\r\n\r\n### Post updates\r\n\r\n1. Removed commas from the example. Some formatting fixes.",
        "link": "https://stackoverflow.com/questions/59813234/json-parsing-jq-get-value-of-grandparent-s-sibling",
        "title": "JSON parsing [`jq`]: Get value of grandparent’s sibling"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "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": 1579515437,
                "post_id": 59820910,
                "comment_id": 105779343,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16603257,
                    "reputation": 1,
                    "user_id": 11998356,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mB4mHZ1tHpyxBdBIG2Jbis5wXjN5TK7MiFXv2Pb=k-s256",
                    "display_name": "axel",
                    "link": "https://stackoverflow.com/users/11998356/axel"
                },
                "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": 1579516191,
                "post_id": 59820910,
                "comment_id": 105779759,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1579518219,
                "post_id": 59820910,
                "comment_id": 105780926,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16603257,
                    "reputation": 1,
                    "user_id": 11998356,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mB4mHZ1tHpyxBdBIG2Jbis5wXjN5TK7MiFXv2Pb=k-s256",
                    "display_name": "axel",
                    "link": "https://stackoverflow.com/users/11998356/axel"
                },
                "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": 1579522201,
                "post_id": 59820910,
                "comment_id": 105783064,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1579597708,
                "last_edit_date": 1579597708,
                "creation_date": 1579592094,
                "answer_id": 59836164,
                "question_id": 59820910,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For brevity, the following assumes that all the .address objects have the keys in the right order:\r\n```\r\ndef headers: &quot;number,firstName,lastName,gender,age,streetAddress,city,state,postalCode&quot;;\r\n\r\nheaders,\r\n(to_entries[]\r\n | [.key,\r\n    (.value \r\n     | (.firstName, .lastName, .gender, .age, .address[])) ]\r\n | join(&quot;,&quot;) )\r\n```\r\n\r\nHere, `headers`has been defined as a function so you can easily adapt it to yor needs, e.g.  if the header strings should be based on the key names. In that case, though, the detsils will depend on what assumptions if any can be made about the uniformity of the objects.",
                "title": "Converting a nested JSON into csv with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1579597708,
        "creation_date": 1579514700,
        "last_edit_date": 1579521247,
        "question_id": 59820910,
        "body_markdown": "I would like to convert the following JSON into a csv format using jq. I know there are tons of similar questions but I could not figure it out based on them.\r\n```json\r\n{\r\n\t&quot;one&quot;: {\r\n\t\t&quot;firstName&quot;: &quot;John&quot;,\r\n\t\t&quot;lastName&quot;: &quot;Smith&quot;,\r\n\t\t&quot;gender&quot;: &quot;man&quot;,\r\n\t\t&quot;age&quot;: 32,\r\n\t\t&quot;address&quot;: {\r\n\t\t\t&quot;streetAddress&quot;: &quot;21 2nd Street&quot;,\r\n\t\t\t&quot;city&quot;: &quot;New York&quot;,\r\n\t\t\t&quot;state&quot;: &quot;NY&quot;,\r\n\t\t\t&quot;postalCode&quot;: &quot;10021&quot;\r\n\t\t}\r\n\t},\r\n\t&quot;two&quot;: {\r\n\t\t&quot;firstName&quot;: &quot;Johnny&quot;,\r\n\t\t&quot;lastName&quot;: &quot;Smithy&quot;,\r\n\t\t&quot;gender&quot;: &quot;man&quot;,\r\n\t\t&quot;age&quot;: 33,\r\n\t\t&quot;address&quot;: {\r\n\t\t\t&quot;streetAddress&quot;: &quot;22 2nd Street&quot;,\r\n\t\t\t&quot;city&quot;: &quot;New York&quot;,\r\n\t\t\t&quot;state&quot;: &quot;NY&quot;,\r\n\t\t\t&quot;postalCode&quot;: &quot;10021&quot;\r\n\t\t}\r\n\t}\r\n}\r\n```\r\nThe output should look like the following. I&#39;m struggeling with the nested object as value of the address key. \r\n\r\n```none\r\nnumber,firstName,lastName,gender,age,streetAddress,city,state,postalCode\r\none,John, Smith,man, 32, 21 2nd Street, New York, NY, 10021\r\ntwo, Johnny, Smith,man, 33, 22 2nd Street, New York, NY, 10021\r\n```\r\n\r\n\r\nThe Best I could do is the foillowing but it does not come close...\r\nYour help is much apreciated\r\n\r\n```sh\r\njq --raw-output &#39;to_entries | map_values({ job: .key } + .value )&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/59820910/converting-a-nested-json-into-csv-with-jq",
        "title": "Converting a nested JSON into csv with jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "non-linear"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17490175,
                    "reputation": 41,
                    "user_id": 12682487,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mBw2xx_To4xQkcEGCj3zG8bEJVgVHuG0-CBaB80PQ=k-s256",
                    "display_name": "BrandonH",
                    "link": "https://stackoverflow.com/users/12682487/brandonh"
                },
                "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": 1579525086,
                "post_id": 59823154,
                "comment_id": 105784520,
                "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": 1579525255,
                "post_id": 59823154,
                "comment_id": 105784610,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17490175,
                    "reputation": 41,
                    "user_id": 12682487,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mBw2xx_To4xQkcEGCj3zG8bEJVgVHuG0-CBaB80PQ=k-s256",
                    "display_name": "BrandonH",
                    "link": "https://stackoverflow.com/users/12682487/brandonh"
                },
                "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": 1579525660,
                "post_id": 59823154,
                "comment_id": 105784814,
                "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": 1579525906,
                "post_id": 59823154,
                "comment_id": 105784930,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17490175,
                    "reputation": 41,
                    "user_id": 12682487,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mBw2xx_To4xQkcEGCj3zG8bEJVgVHuG0-CBaB80PQ=k-s256",
                    "display_name": "BrandonH",
                    "link": "https://stackoverflow.com/users/12682487/brandonh"
                },
                "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": 1579527404,
                "post_id": 59823154,
                "comment_id": 105785799,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1579627493,
                "post_id": 59823154,
                "comment_id": 105826493,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1580203650,
                "last_edit_date": 1580203650,
                "creation_date": 1579527300,
                "answer_id": 59824433,
                "question_id": 59823154,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `jq` 1.6 you can use the following :\r\n\r\n    jq --arg newPwd &quot;newPassword&quot; \\\r\n         &#39;walk(if type == &quot;object&quot; and .User == &quot;user1&quot; then .password |= $newPwd else . end)  \r\n            | map_values(select(.. | select(type == &quot;object&quot;) and .User == &quot;user1&quot;))&#39; \r\n\r\nThis will recurse over your JSON input and set the `password` field of objects that have a `User : &quot;user1&quot;` key/value pair to your desired value.\r\n\r\nYou can [try it here](https://jqplay.org/s/_7kthu_iRs).\r\n\r\nIn anterior versions you can use this equivalent :\r\n\r\n    jq --arg newPwd &quot;newPassword&quot; \\\r\n       &#39;def rec :\r\n          if type == &quot;object&quot; and .User == &quot;user1&quot; then \r\n            .password = $newPwd\r\n          elif type == &quot;object&quot; then\r\n            map_values(rec)\r\n          elif type == &quot;array&quot; then\r\n            map(rec)\r\n          else\r\n            .\r\n          end\r\n        ; \r\n        rec  | map_values(select(.. | select(type == &quot;object&quot;) and .User == &quot;user1&quot;))&#39;\r\n\r\nYou can [try it here](https://jqplay.org/s/LsKhG5rD_L).",
                "title": "How to parse json with jq where the structure is non-linear"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1579602032,
                "last_edit_date": 1579602032,
                "creation_date": 1579528728,
                "answer_id": 59824835,
                "question_id": 59823154,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Welcome to StackOverflow!\r\n\r\nThe full example was not a valid JSON object, and there is no attempt to solve the problem, or an example of what a desired outcome should look like. So the following answer comes with a bit of guesswork. It would probably increase the odds of getting a good answer greatly if the example was trimmed down to a [minimal, reproducible example](https://stackoverflow.com/help/minimal-reproducible-example) in which all the clutter is removed.\r\n\r\nFor example, `&quot;TargetAgent&quot;: &quot;sqlrptvmjhbpr01&quot;` appears to be irrelevant information. The only effect this line has is to increase the cognitive load of the reader in trying to decipher if it&#39;s relevant to the problem task, which it appears not to be.\r\n\r\n&gt; There can be zero or many of the DualEndPoint or Local objects per file.\r\n\r\nYou don&#39;t say exactly what a `DualEndPoint` or `Local` object is.\r\n\r\nSince the text `DualEndPoint` only occurs in the context of\r\n\r\n```\r\n&quot;Type&quot;: &quot;ConnectionProfile:FileTransfer:DualEndPoint&quot;\r\n```\r\n\r\nI assume that a `DualEndPoint` object is one that contains a key-value pair with the format\r\n\r\n```\r\n&quot;Type&quot;: &quot;...:DualEndPoint&quot;\r\n```\r\n\r\nand that a `Local` object is the same, but with `DualEndPoint` substituted with `Local`. If that interpretation is correct, then there would be three examples of `Local` objects in your first code snippet at two different levels of nesting (which is what I understand as the &quot;non-linear&quot; part).\r\n\r\nOne example of a `Local` object would then be:\r\n\r\n```\r\n{\r\n  &quot;Type&quot;: &quot;Endpoint:Src:Local&quot;,\r\n  &quot;User&quot;: &quot;user1&quot;,\r\n  &quot;Port&quot;: &quot;0&quot;,\r\n  &quot;OsType&quot;: &quot;Windows&quot;,\r\n  &quot;HostName&quot;: &quot;Local&quot;,\r\n  &quot;Password&quot;: &quot;newpassword&quot;,\r\n  &quot;HomeDirectory&quot;: &quot;/user1homedir&quot;\r\n}\r\n```\r\n\r\nThere aren&#39;t any examples of similar objects that, in spite of containing a &quot;User&quot; attribute, should not be updated. So it appears that to answer the question, the distinction between these types of objects is also entirely unnecessary?\r\n\r\n&gt; I need to be able to query for a specific user in the &quot;User&quot; attribute and insert a new password for resubmission back to the api.\r\n\r\nSo a sub-problem to your main problem could be to update an object with a new password if it&#39;s the right `User`. Asuming you&#39;ve scoped the object down to such an object, a sub-part of the program could look like:\r\n\r\n```\r\n$ jq &#39;if .User == &quot;user1&quot; then .Password = &quot;derp&quot; else . end&#39; local1.json\r\n{\r\n  &quot;Type&quot;: &quot;Endpoint:Src:Local&quot;,\r\n  &quot;User&quot;: &quot;user1&quot;,\r\n  &quot;Port&quot;: &quot;0&quot;,\r\n  &quot;OsType&quot;: &quot;Windows&quot;,\r\n  &quot;HostName&quot;: &quot;Local&quot;,\r\n  &quot;Password&quot;: &quot;derp&quot;,\r\n  &quot;HomeDirectory&quot;: &quot;/user1homedir&quot;\r\n}\r\n```\r\n\r\n&gt; For DualEndPoints, the nested object names are variable so one cannot code those values in looking for the &quot;User&quot; attribute.\r\n\r\nSo it sounds like you want to arbitrarily recurse looking for objects with &quot;User&quot; attributes. Some of jq&#39;s recursion combinators are `..`, the more general `recurse` and what appears to be more appropriate in this context, [`walk`](https://stedolan.github.io/jq/manual/#walk%28f%29):\r\n\r\n```\r\n$ jq &#39;walk(if type == &quot;object&quot; and .User == &quot;user1&quot;\r\n           then .Password = &quot;derp&quot;\r\n           else . end)&#39; full.json\r\n```\r\n\r\n(This is also what Aaron posted, except he uses `|=` and I use `=`.)\r\n\r\nSee his jqplay example or [this jqplay example](https://jqplay.org/s/Kw2c_hF1J_).\r\n\r\n&gt; Where a match for a specific user is found, return the entire structure with only that user&#39;s new password inserted. In the example, querying for user1 would return the entire PROFILE1 and PROFILE2, but not PROFILE3 as it doesn&#39;t contain user1 credentials.\r\n\r\nThis sounds like an extra condition in the expression we walk with:\r\n\r\n```\r\n$ jq &#39;walk(if type == &quot;object&quot; and has(&quot;User&quot;)\r\n           then (if .User == &quot;user1&quot;\r\n                 then .Password = &quot;derp&quot;\r\n                 else null end)\r\n           else . end)&#39; full.json\r\n```\r\n\r\nThis appears to almost work (see [this jqplay example](https://jqplay.org/s/EfTTbbARKR)), except it leaves `&quot;foo&quot;: null` values as the result of having walked. This is a by-product of already having recursed down into the object containing the &quot;User&quot; property, which makes it hard to express that the parent key-value pair should be deleted.\r\n\r\nFixing this we need to either look ahead in `walk/1`&#39;s filter or create a placeholder and walk a second time with the perspective of the parent object. The latter of these two strategies is demonstrated here:\r\n\r\n```\r\n$ jq &#39;walk(if type == &quot;object&quot; and has(&quot;User&quot;)\r\n      then (if .User == &quot;user1&quot; then .Password = &quot;derp&quot; else &quot;wat&quot; end)\r\n      else . end)\r\n      | walk(if type == &quot;object&quot;\r\n             then with_entries(select(.value != &quot;wat&quot;))\r\n             else . end)&#39; full.json\r\n```\r\n\r\nThis appears to work. See [this jqplay example](https://jqplay.org/s/Yjhc0hX0tT).",
                "title": "How to parse json with jq where the structure is non-linear"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1579595186,
                "last_edit_date": 1579595186,
                "creation_date": 1579594195,
                "answer_id": 59836622,
                "question_id": 59823154,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the following solution to the stated problem, there are two steps. The first step uses `with_entries` to select the relevant &quot;PROFILE&quot; objects, and the second step uses `walk` to update the password provided there is a password.  It is easy enough to parameterize everything, so for simplicity let&#39;s assume (as in the Q) that the user is &quot;user1&quot;:\r\n\r\n```\r\nwith_entries(select( .value\r\n    | any(paths(. == &quot;user1&quot;);\r\n          .[-1] == &quot;User&quot; )))\r\n| walk( if type == &quot;object&quot; and .User == &quot;user1&quot; and has(&quot;Password&quot;)\r\n        then .Password = &quot;newpassword&quot;\r\n\t    else .end)\r\n\r\n```\r\n\r\nThe use of `any` here complicates things a bit but is for efficiency.\r\n\r\n### Note on `walk/1`\r\nIf your jq does not have `walk/1`, then now would be a good time to update your jq, but if that&#39;s not an option, simply google for its def (search terms: jq def walk builtin.jq) and copy the def to the beginning of your jq program.",
                "title": "How to parse json with jq where the structure is non-linear"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1580203650,
        "creation_date": 1579522735,
        "last_edit_date": 1579525064,
        "question_id": 59823154,
        "body_markdown": "I hope I have represented my problem clearly.\r\nNeed help querying and them parsing multiple json files using JQ where the structure is non-linear within each file. The application produces config data that can look like this example. There can be zero or many of the DualEndPoint or Local objects per file.  I need to be able to query for a specific user in the &quot;User&quot; attribute and insert a new password for resubmission back to the api.  For DualEndPoints, the nested object names are variable so one cannot code those values in looking for the &quot;User&quot; attribute.\r\n\r\nWhere a match for a specific user is found, return the entire structure with only that user&#39;s new password inserted. In the example, querying for user1 would return the entire PROFILE1 and PROFILE2, but not PROFILE3 as it doesn&#39;t contain user1 credentials.\r\n\r\n    {\r\n      &quot;PROFILE1&quot;: {\r\n        &quot;Type&quot;: &quot;ConnectionProfile:FileTransfer:DualEndPoint&quot;,\r\n        &quot;WorkloadAutomationUsers&quot;: [\r\n          &quot;*&quot;\r\n        ],\r\n        &quot;VerifyBytes&quot;: true,\r\n        &quot;TargetAgent&quot;: &quot;sqlrptvmjhbpr01&quot;,\r\n        &quot;TargetCTM&quot;: &quot;Production&quot;,\r\n        &quot;Endpoint:Src:Local_0&quot;: {\r\n          &quot;Type&quot;: &quot;Endpoint:Src:Local&quot;,\r\n          &quot;User&quot;: &quot;user1&quot;,\r\n          &quot;Port&quot;: &quot;0&quot;,\r\n          &quot;OsType&quot;: &quot;Windows&quot;,\r\n          &quot;HostName&quot;: &quot;Local&quot;,\r\n          &quot;Password&quot;: &quot;*****&quot;,\r\n          &quot;HomeDirectory&quot;: &quot;/user1homedir&quot;\r\n        },\r\n        &quot;Endpoint:Dest:SFTP_1&quot;: {\r\n          &quot;Type&quot;: &quot;Endpoint:Dest:SFTP&quot;,\r\n          &quot;User&quot;: &quot;user2&quot;,\r\n          &quot;HostName&quot;: &quot;server2&quot;,\r\n          &quot;Password&quot;: &quot;*****&quot;,\r\n          &quot;HomeDirectory&quot;: &quot;/user2homedir&quot;\r\n        }\r\n      },\r\n      &quot;PROFILE2&quot;: {\r\n        &quot;Type&quot;: &quot;ConnectionProfile:FileTransfer:Local&quot;,\r\n        &quot;WorkloadAutomationUsers&quot;: [\r\n          &quot;*&quot;\r\n        ],\r\n        &quot;VerifyBytes&quot;: true,\r\n        &quot;User&quot;: &quot;user1&quot;,\r\n        &quot;VerifyDestination&quot;: true,\r\n        &quot;OsType&quot;: &quot;Windows&quot;,\r\n        &quot;HostName&quot;: &quot;Local&quot;,\r\n        &quot;Password&quot;: &quot;*****&quot;,\r\n        &quot;TargetAgent&quot;: &quot;server1&quot;,\r\n        &quot;TargetCTM&quot;: &quot;Production&quot;\r\n      },\r\n      &quot;PROFILE3&quot;: {\r\n        &quot;Type&quot;: &quot;ConnectionProfile:FileTransfer:Local&quot;,\r\n        &quot;WorkloadAutomationUsers&quot;: [\r\n          &quot;*&quot;\r\n        ],\r\n        &quot;VerifyBytes&quot;: true,\r\n        &quot;User&quot;: &quot;user3&quot;,\r\n        &quot;OsType&quot;: &quot;Windows&quot;,\r\n        &quot;HostName&quot;: &quot;Local&quot;,\r\n        &quot;Password&quot;: &quot;*****&quot;,\r\n        &quot;HomeDirectory&quot;: &quot;/user3hoemdir&quot;,\r\n        &quot;TargetAgent&quot;: &quot;server2&quot;,\r\n        &quot;TargetCTM&quot;: &quot;Production&quot;\r\n      }\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59823154/how-to-parse-json-with-jq-where-the-structure-is-non-linear",
        "title": "How to parse json with jq where the structure is non-linear"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1579541536,
                "post_id": 59824452,
                "comment_id": 105793327,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1579535863,
                "creation_date": 1579535863,
                "answer_id": 59826866,
                "question_id": 59824452,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is an absolute mess, but it works:\r\n\r\n    $ cat tmp.json\r\n    {&quot;id&quot;: 100, &quot;a&quot;: [{&quot;t&quot; : 1,&quot;c&quot; : 2 }, {&quot;t&quot;: 2, &quot;c&quot; : 3 }] }\r\n    {&quot;id&quot;: 200, &quot;a&quot;: [{&quot;t&quot;: 2, &quot;c&quot; : 3 }] }\r\n    {&quot;id&quot;: 300, &quot;a&quot;: [{&quot;t&quot;: 1, &quot;c&quot; : 3 }] }\r\n    $ cat filter.jq\r\n    def t(id):\r\n      .a |\r\n      map({key: &quot;t\\(.t)&quot;, value: .c}) |\r\n      ({t1:null, t2:null, id:id} | to_entries) + . | from_entries\r\n      ;\r\n\r\n    inputs |\r\n      map(.id as $id | t($id)) |\r\n      (.[0] | keys) as $hdr |\r\n      ([$hdr] + map(to_entries |map(.value)))[]|\r\n      @csv\r\n    $ jq -rn --slurp -f filter.jq tmp.json\r\n    &quot;id&quot;,&quot;t1&quot;,&quot;t2&quot;\r\n    2,3,100\r\n    ,3,200\r\n    3,,300\r\n\r\nIn short, you produce a direct object containing the values from your input, then add it to a &quot;default&quot; object to fill in the missing keys.",
                "title": "JQ - Denormalize nested object"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1579539301,
                "creation_date": 1579539301,
                "answer_id": 59827832,
                "question_id": 59824452,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a simple solution that does not assume anything about the ordering of the items in the .a array, and easily generalizes to arbitrarily many .t values:\r\n\r\n```\r\n# Convert an array of {t, c} to a dictionary:\r\ndef tod: map({(.t|tostring): .c}) | add;\r\n\r\n[&quot;id&quot;, &quot;t1&quot;, &quot;t2&quot;],   # header\r\n(inputs \r\n | (.a | tod) as $dict\r\n | [.id, (range(1;3) as $i | $dict[$i|tostring]) ])\r\n| @csv\r\n```\r\n\r\n### Command-line options\r\nUse the -n option (because `inputs` is being used), and the -r option (to produce CSV). \r\n\r\n",
                "title": "JQ - Denormalize nested object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1579603683,
        "creation_date": 1579527333,
        "last_edit_date": 1579603683,
        "question_id": 59824452,
        "body_markdown": "I&#39;ve been trying to convert some JSON to csv and I have the following problem:\r\n\r\nI have the following input json:\r\n\r\n    {&quot;id&quot;: 100, &quot;a&quot;: [{&quot;t&quot; : 1,&quot;c&quot; : 2 }, {&quot;t&quot;: 2, &quot;c&quot; : 3 }] }\r\n    {&quot;id&quot;: 200, &quot;a&quot;: [{&quot;t&quot;: 2, &quot;c&quot; : 3 }] }\r\n    {&quot;id&quot;: 300, &quot;a&quot;: [{&quot;t&quot;: 1, &quot;c&quot; : 3 }] }\r\n\r\nAnd I expect the following CSV output:\r\n\r\n    id,t1,t2\r\n    100,2,3\r\n    200,,3\r\n    300,3,\r\n\r\n\r\nUnfortunately JQ doesn&#39;t output if one of select has no match.\r\nExample:\r\n\r\n    echo &#39;{ &quot;id&quot;: 100,  &quot;a&quot;: [{&quot;t&quot; : 1,&quot;c&quot; : 2 }, {&quot;t&quot;: 2, &quot;c&quot; : 3 }] }&#39; | jq &#39;{t1: (.a[] | select(.t==1)).c , t2: (.a[] | select(.t==2)).c }&#39;\r\n\r\noutput:\r\n\r\n    { &quot;t1&quot;: 2,  &quot;t2&quot;: 3   }\r\n\r\nbut if one of the objects select returns no match it doesn&#39;t return at all.\r\nExample:\r\n\r\n    echo &#39;{ &quot;id&quot;: 100,  &quot;a&quot;: [{&quot;t&quot; : 1,&quot;c&quot; : 2 }] }&#39; | jq &#39;{t1: (.a[] | select(.t==1)).c , t2: (.a[] | select(.t==2)).c }&#39; \r\n\r\n\r\nExpected output:\r\n\r\n    { &quot;t1&quot;: 2,  &quot;t2&quot;: null   }\r\n\r\n\r\nDoes anyone know how to achieve this with JQ?\r\n\r\nEDIT:\r\n\r\nBased on a comment made by @peak I found the solution that I was looking for.\r\n\r\n    jq -r &#39;[&quot;id&quot;,&quot;t1&quot;,&quot;t2&quot;],[.id, (.a[] | select(.t==1)).c//null, (.a[] | select(.t==2)).c//null ]|@csv&#39;\r\n\r\nThe alternative operator does exactly what I was looking for.\r\n[Alternative Operator][1]\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Alternativeoperator://",
        "link": "https://stackoverflow.com/questions/59824452/jq-denormalize-nested-object",
        "title": "JQ - Denormalize nested object"
    },
    {
        "tags": [
            "json",
            "sorting",
            "unique",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1579647822,
                "last_edit_date": 1579647822,
                "creation_date": 1579644317,
                "answer_id": 59849851,
                "question_id": 59849700,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to preserve the overall structure, you would use the jq filter:\r\n\r\n    .values |= sort_by(.title)\r\n\r\nIf you want to extract .values and sort the array, leave out the &quot;=&quot;:\r\n\r\n    .values | sort_by(.title)\r\n\r\nTo produce the output as shown in the Q:\r\n\r\n    .values | sort_by(.title)[]\r\n\r\n### Uniqueness\r\nThere are several ways in which &quot;uniqueness&quot; can be defined, and also several ways in which uniqueness can be achieved.\r\n\r\nOne option would simply be to use `unique_by` instead of `sort_by`; another (with different semantics) would be to use `(sort_by(.title)|unique)` instead of `sort_by(.title)`.\r\n",
                "title": "How to sort/unique output using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1579648180,
        "creation_date": 1579643478,
        "last_edit_date": 1579648180,
        "question_id": 59849700,
        "body_markdown": "I have json like below:\r\n\r\n    % cat example.json\r\n    {\r\n        &quot;values&quot; : [\r\n            {\r\n                &quot;title&quot;: &quot;B&quot;,\r\n                &quot;url&quot;: &quot;https://B&quot;\r\n            },\r\n            {\r\n                &quot;title&quot;: &quot;A&quot;,\r\n                &quot;url&quot;: &quot;https://A&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nI want to sort the values based on title. i.e. expected output \r\n\r\n    {\r\n      &quot;title&quot;: &quot;A&quot;,\r\n      &quot;url&quot;: &quot;https://A&quot;\r\n    }\r\n    {\r\n      &quot;title&quot;: &quot;B&quot;,\r\n      &quot;url&quot;: &quot;https://B&quot;\r\n    }\r\n\r\nTried the blow. Does not work:\r\n\r\n    % jq &#39;.values[] | sort&#39; example.json           \r\n    jq: error (at example.json:12): object ({&quot;title&quot;:&quot;B...) cannot be sorted, as it is not an array\r\n\r\n    % jq &#39;.values[] | sort_by(.title)&#39; example.json\r\n    jq: error (at example.json:12): Cannot index string with string &quot;title&quot;",
        "link": "https://stackoverflow.com/questions/59849700/how-to-sort-unique-output-using-jq",
        "title": "How to sort/unique output using jq"
    },
    {
        "tags": [
            "json",
            "replace",
            "nested",
            "jq",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1579660110,
                "creation_date": 1579660110,
                "answer_id": 59851801,
                "question_id": 59851383,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    .[&quot;favbox-min-height&quot;] |= (.default = 400)\r\n\r\n",
                "title": "How to find and replace a value with jq in a nested json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1579663968,
        "creation_date": 1579655824,
        "last_edit_date": 1579663968,
        "question_id": 59851383,
        "body_markdown": "How to find and replace a value with jq in a nested json.\r\n\r\nhttps://raw.githubusercontent.com/linuxmint/cinnamon/master/files/usr/share/cinnamon/applets/menu%40cinnamon.org/settings-schema.json\r\n\r\n\r\n    {\r\n        &quot;layout&quot;: {\r\n            &quot;menu-layout&quot;: {\r\n                &quot;type&quot;: &quot;section&quot;,\r\n                &quot;title&quot;: &quot;Layout and content&quot;,\r\n            &quot;keys&quot;: [\r\n                &quot;show-category-icons&quot;,\r\n                &quot;favbox-show&quot;,\r\n                &quot;favbox-min-height&quot;,\r\n                &quot;show-places&quot;,\r\n            ]\r\n            },\r\n            &quot;menu-behave&quot;: {\r\n                &quot;type&quot;: &quot;section&quot;,\r\n                &quot;keys&quot;: [\r\n                    &quot;enable-autoscroll&quot;,\r\n                    &quot;search-filesystem&quot;\r\n                ]\r\n            }\r\n        },\r\n        &quot;favbox-min-height&quot;: {\r\n            &quot;type&quot;: &quot;spinbutton&quot;,\r\n            &quot;default&quot;: 300,\r\n        }\r\n    }\r\n\r\n\r\nFor example, in this file above teste.json:\r\nI want to replace in the item &quot;favbox-min-height&quot;, in the key: value\r\n&quot;default&quot;: 300\r\nfor\r\n&quot;default&quot;: 400\r\n\r\nI&#39;m not able to do this, could someone help me do this?",
        "link": "https://stackoverflow.com/questions/59851383/how-to-find-and-replace-a-value-with-jq-in-a-nested-json",
        "title": "How to find and replace a value with jq in a nested json"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1579676618,
                "post_id": 59854249,
                "comment_id": 105840937,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11474956,
                    "reputation": 113,
                    "user_id": 8410706,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://lh4.googleusercontent.com/-MC4O7HJWU9M/AAAAAAAAAAI/AAAAAAAAAaI/WFBZHuu2m9Y/s256-rj/photo.jpg",
                    "display_name": "harsha rachith",
                    "link": "https://stackoverflow.com/users/8410706/harsha-rachith"
                },
                "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": 1579676832,
                "post_id": 59854249,
                "comment_id": 105841015,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11474956,
                    "reputation": 113,
                    "user_id": 8410706,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://lh4.googleusercontent.com/-MC4O7HJWU9M/AAAAAAAAAAI/AAAAAAAAAaI/WFBZHuu2m9Y/s256-rj/photo.jpg",
                    "display_name": "harsha rachith",
                    "link": "https://stackoverflow.com/users/8410706/harsha-rachith"
                },
                "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": 1579676837,
                "post_id": 59854249,
                "comment_id": 105841016,
                "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": 1579676873,
                "post_id": 59854249,
                "comment_id": 105841025,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11474956,
                    "reputation": 113,
                    "user_id": 8410706,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://lh4.googleusercontent.com/-MC4O7HJWU9M/AAAAAAAAAAI/AAAAAAAAAaI/WFBZHuu2m9Y/s256-rj/photo.jpg",
                    "display_name": "harsha rachith",
                    "link": "https://stackoverflow.com/users/8410706/harsha-rachith"
                },
                "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": 1579676936,
                "post_id": 59854249,
                "comment_id": 105841055,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11474956,
                    "reputation": 113,
                    "user_id": 8410706,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://lh4.googleusercontent.com/-MC4O7HJWU9M/AAAAAAAAAAI/AAAAAAAAAaI/WFBZHuu2m9Y/s256-rj/photo.jpg",
                    "display_name": "harsha rachith",
                    "link": "https://stackoverflow.com/users/8410706/harsha-rachith"
                },
                "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": 1579677577,
                "post_id": 59854249,
                "comment_id": 105841339,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11474956,
                    "reputation": 113,
                    "user_id": 8410706,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://lh4.googleusercontent.com/-MC4O7HJWU9M/AAAAAAAAAAI/AAAAAAAAAaI/WFBZHuu2m9Y/s256-rj/photo.jpg",
                    "display_name": "harsha rachith",
                    "link": "https://stackoverflow.com/users/8410706/harsha-rachith"
                },
                "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": 1579678416,
                "post_id": 59854249,
                "comment_id": 105841680,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1579679233,
                "post_id": 59854249,
                "comment_id": 105841998,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11474956,
                    "reputation": 113,
                    "user_id": 8410706,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://lh4.googleusercontent.com/-MC4O7HJWU9M/AAAAAAAAAAI/AAAAAAAAAaI/WFBZHuu2m9Y/s256-rj/photo.jpg",
                    "display_name": "harsha rachith",
                    "link": "https://stackoverflow.com/users/8410706/harsha-rachith"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1579680023,
                "post_id": 59854249,
                "comment_id": 105842323,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8423,
                    "reputation": 757671,
                    "user_id": 15168,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/WtEI9.png?s=256",
                    "display_name": "Jonathan Leffler",
                    "link": "https://stackoverflow.com/users/15168/jonathan-leffler"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1579681513,
                "post_id": 59854249,
                "comment_id": 105843002,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11474956,
                    "reputation": 113,
                    "user_id": 8410706,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://lh4.googleusercontent.com/-MC4O7HJWU9M/AAAAAAAAAAI/AAAAAAAAAaI/WFBZHuu2m9Y/s256-rj/photo.jpg",
                    "display_name": "harsha rachith",
                    "link": "https://stackoverflow.com/users/8410706/harsha-rachith"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1579693007,
                "post_id": 59854249,
                "comment_id": 105849284,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1581676193,
                "last_edit_date": 1581676193,
                "creation_date": 1579677754,
                "answer_id": 59854574,
                "question_id": 59854249,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The Q does not explicitly say how `$swagger` has been set, but it would seem that rather than using `--arg swagger $swagger` you would be better off using one of the file-oriented command-line options, perhaps along the lines of:\r\n\r\n    --argfile swagger swagger.json\r\n\r\nThere are many alternatives, but to explore these sensibly here, it would be best if you provided at least one complete but very TINY example.  (The example does NOT have to illustrate the &quot;*Argument list too long*&quot; error!)\r\n\r\n## Caveat\r\nIf you are worried that the `--argfile` option is deprecated, then by all means use `--slurpfile` instead if your `jq` has it, but note that the latter option wraps the file contents into a JSON array, so you would have to take that into account.\r\n\r\nThese and other options are all presented succinctly in the official documentation at https://stedolan.github.io/jq/manual/",
                "title": "/usr/bin/jq: Argument list too long error bash"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1603806149,
                "creation_date": 1603806149,
                "answer_id": 64555785,
                "question_id": 59854249,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From your example:\r\n\r\n    jq -r --arg swagger &quot;$swagger&quot; &#39;.apiDefinition = $swagger&#39; &lt;&lt;&lt;&quot;$json&quot;\r\n\r\nI&#39;m assuming you want the output to result in a JSON object with a key &quot;apiDefinition&quot;, and its value being set to the content of swagger.json (which contains valid JSON).\r\n\r\nIn that case this works:\r\n\r\n    jq -n --slurpfile swagger swagger.json &#39;{&quot;apiDefintion&quot;: $swagger[0]}&#39;\r\n\r\nThe first 10 lines of the resulting output:\r\n\r\n    {\r\n      &quot;apiDefintion&quot;: [\r\n        {\r\n          &quot;id&quot;: 1,\r\n          &quot;first_name&quot;: &quot;Samson&quot;,\r\n          &quot;last_name&quot;: &quot;Wandrack&quot;,\r\n          &quot;email&quot;: &quot;swandrack0@hibu.com&quot;,\r\n          &quot;gender&quot;: &quot;Male&quot;,\r\n          &quot;ip_address&quot;: &quot;122.171.218.251&quot;\r\n        },\r\n\r\n\r\n- -n is required in this case, to use the JSON on the command line as the input JSON, rather than reading it from stdin or a file.\r\n- --slurpfile puts the contents of swagger.json into the variable $swagger, as an array.\r\n- -r is not needed, as it has no effect unless the output is just strings (and it&#39;s raw output makes it invalid JSON).\r\n- $swagger[0] is used to only include the first item of the slurped array.\r\n\r\nFrom the documentation at https://stedolan.github.io/jq/manual/:\r\n\r\n&gt;    --null-input/-n:\r\n&gt;\r\n&gt; Don&#39;t read any input at all! Instead, the filter is run once using null as the input. This is useful when using jq as a simple calculator or to construct JSON data from scratch.\r\n&gt; \r\n&gt;    --slurpfile variable-name filename:\r\n&gt;\r\n&gt; This option reads all the JSON texts in the named file and binds an array of the parsed JSON values to the given global variable. If you run jq with --slurpfile foo bar, then $foo is available in the program and has an array whose elements correspond to the texts in the file named bar.\r\n&gt;\r\n&gt;    --raw-output / -r:\r\n&gt;\r\n&gt; With this option, if the filter&#39;s result is a string then it will be written directly to standard output rather than being formatted as a JSON string with quotes. This can be useful for making jq filters talk to non-JSON-based systems.",
                "title": "/usr/bin/jq: Argument list too long error bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 9,
        "last_activity_date": 1603806149,
        "creation_date": 1579676452,
        "last_edit_date": 1579678620,
        "question_id": 59854249,
        "body_markdown": "I want to replace the value in sample json from larger swagger.json file content and it is too large.\r\n\r\n    Error:\r\n    /usr/bin/jq: Argument list too long error bash \r\n\r\nworked to solve this issue for a few days and cannot identify the issue here.\r\nthis is the sample json file:\r\n\r\n\r\n\r\n    \r\n    {\r\n       &quot;name&quot;: &quot;&quot;,\r\n       &quot;description&quot;: &quot;&quot;,\r\n       &quot;context&quot;: &quot;&quot;,\r\n       &quot;version&quot;: &quot;&quot;,\r\n       &quot;provider&quot;: &quot;cbs&quot;,\r\n       &quot;apiDefinition&quot;: &quot;&quot;,\r\n       &quot;wsdlUri&quot;: null,\r\n       &quot;responseCaching&quot;: &quot;Disabled&quot;,\r\n       &quot;cacheTimeout&quot;: 300,\r\n       &quot;destinationStatsEnabled&quot;: false,\r\n       &quot;isDefaultVersion&quot;: true,\r\n       &quot;transport&quot;:    [\r\n          &quot;http&quot;,\r\n          &quot;https&quot;\r\n       ],\r\n       &quot;tags&quot;: [&quot;PROVIDER_&quot;,&quot;MIFE&quot;],\r\n       &quot;tiers&quot;: [&quot;Unlimited&quot;,&quot;Default&quot;,&quot;Silver&quot;,&quot;Subscription&quot;,&quot;Gold&quot;,&quot;Premium&quot;,&quot;Bronze&quot;],\r\n       &quot;maxTps&quot;:    {\r\n          &quot;sandbox&quot;: 5000,\r\n          &quot;production&quot;: 1000\r\n       },\r\n       &quot;visibility&quot;: &quot;PUBLIC&quot;,\r\n       &quot;visibleRoles&quot;: [],\r\n       &quot;endpointConfig&quot;: &quot;&quot;,\r\n       &quot;endpointSecurity&quot;:    {\r\n          &quot;username&quot;: &quot;user&quot;,\r\n          &quot;type&quot;: &quot;basic&quot;,\r\n          &quot;password&quot;: &quot;pass&quot;\r\n       },\r\n       &quot;gatewayEnvironments&quot;: &quot;Production and Sandbox&quot;,\r\n       &quot;sequences&quot;: [],\r\n       &quot;subscriptionAvailability&quot;: null,\r\n       &quot;subscriptionAvailableTenants&quot;: [],\r\n       &quot;businessInformation&quot;:    {\r\n          &quot;businessOwnerEmail&quot;: &quot;BUSINESSOWNEREMAIL_&quot;,\r\n          &quot;technicalOwnerEmail&quot;: &quot;TECHNICALOWNEREMAIL_&quot;,\r\n          &quot;technicalOwner&quot;: &quot;TECHNICALOWNER_&quot;,\r\n          &quot;businessOwner&quot;: &quot;BUSINESSOWNER_&quot;\r\n       },\r\n       &quot;corsConfiguration&quot;:    {\r\n          &quot;accessControlAllowOrigins&quot;: [&quot;*&quot;],\r\n          &quot;accessControlAllowHeaders&quot;:       [\r\n             &quot;authorization&quot;,\r\n             &quot;Access-Control-Allow-Origin&quot;,\r\n             &quot;Content-Type&quot;,\r\n             &quot;SOAPAction&quot;\r\n          ],\r\n          &quot;accessControlAllowMethods&quot;:       [\r\n             &quot;GET&quot;,\r\n             &quot;PUT&quot;,\r\n             &quot;POST&quot;,\r\n             &quot;DELETE&quot;,\r\n             &quot;PATCH&quot;,\r\n             &quot;OPTIONS&quot;\r\n          ],\r\n          &quot;accessControlAllowCredentials&quot;: false,\r\n          &quot;corsConfigurationEnabled&quot;: false\r\n       }\r\n    }\r\n\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n - swagger.json file - [Click here to download swagger.json file][1]\r\n\r\nthis is the command i using and it give me a error which i as arguments too large. \r\n\r\n    swagger = $(cat swagger.json)\r\n\r\n    jq -r --arg swagger &quot;$swagger&quot; &#39;.apiDefinition = $swagger&#39; &lt;&lt;&lt;&quot;$json&quot;\r\n\r\nCan anyone please help!\r\n\r\n\r\n  [1]: https://drive.google.com/file/d/18ol5s7zjtviK73z6-CzRLCROOo_y_ivg/view?usp=sharing\r\n\r\nswagger = $(cat swagger.json)\r\n",
        "link": "https://stackoverflow.com/questions/59854249/usr-bin-jq-argument-list-too-long-error-bash",
        "title": "/usr/bin/jq: Argument list too long error bash"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1579747531,
                "last_edit_date": 1592644375,
                "creation_date": 1579702200,
                "answer_id": 59861598,
                "question_id": 59861501,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You just need to use the `has` attribute which returns a boolean value depending on the presence of the key mentioned\n\n    jq &#39;has(&quot;sys/&quot;)&#39;\n\nNote that you can customize `jq` to return a bool string or even `null`, but none of them can&#39;t be directly used in a shell conditional which only uses exit codes `0` or `1`.\n\nIf you want the result of the `jq` to be used in a shell conditional statement, you can make it return a exit code. There is an option which supports this. From the documentation\n\n&gt; `-e / --exit-status:`\n&gt;\n&gt; Sets the exit status of `jq` to `0` if the last output values was neither `false` nor `null`, `1` if the last output value was either `false` or `null`, or `4` if no valid result was ever produced.\n \nSo using this on your given JSON\n\n    jq -e &#39;has(&quot;sys/&quot;)&#39; json &gt; /dev/null\n    echo $?\n    0\n\nbut for a non-existent key `sys1`, it emits\n\n    jq -e &#39;has(&quot;sys1/&quot;)&#39; json &gt; /dev/null\n    echo $?\n    1\n\nNote that the `&gt; /dev/null` suppress the stdout thrown out on applying the filter, which is the boolean string value. If your `jq` version does not support the option or if you are looking for an alternate way to do this, you can directly match the string returned from the `has()` filter instead of evaluating the exit code i.e.\n  \n    if [ $(jq &#39;has(&quot;sys/&quot;)&#39; json) = &quot;true&quot; ]; then\n        printf &#39;%s\\n&#39; &#39;key present&#39;\n    fi",
                "title": "Verifying existence of a root level element with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -3,
                "last_activity_date": 1579711558,
                "last_edit_date": 1579711558,
                "creation_date": 1579703353,
                "answer_id": 59861929,
                "question_id": 59861501,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Adding to previous answer, this is the way to do this in Python 3, in case someone is not able to install *jq* :\r\n\r\n    #!/usr/local/bin/python3\r\n    \r\n    import json\r\n    \r\n    obj=json.loads(&quot;&quot;&quot;{                                               \r\n      &quot;abc/&quot;: {                                                              \r\n        &quot;uuid&quot;: &quot;fd&quot;\r\n       },\r\n     &quot;sys/&quot;: {                                                                \r\n        &quot;uuid&quot;: &quot;id2&quot;\r\n      }\r\n    }&quot;&quot;&quot;)\r\n    \r\n    if &#39;sys/&#39; in obj:\r\n        exit(0)\r\n    else :\r\n        exit(1)\r\n\r\n",
                "title": "Verifying existence of a root level element with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1579747531,
        "creation_date": 1579701903,
        "last_edit_date": 1579703674,
        "question_id": 59861501,
        "body_markdown": "Given a JSON structure such as below, I want to test for the existence of the `sys/` top-level key.\r\n\r\n\r\n    {                                                                                                                                                             \r\n      &quot;abc/&quot;: {                                                                                                                                             \r\n        &quot;uuid&quot;: &quot;fd&quot;\r\n       },\r\n     &quot;sys/&quot;: {                                                                                                                                                   \r\n        &quot;uuid&quot;: &quot;id2&quot;\r\n      }\r\n    }\r\n\r\nI have tried various constructs such as `jq &quot;sys/&quot;` or `jq &quot;sys/.uuid&quot;` but I get compile errors and/or errors such as &quot;jq: error: sys/0 is not defined at &lt;top-level&gt;, line 1:&quot;\r\n\r\nNote that it is important that the result code (`$?`) from `jq` returns correctly to reflect actual result (becuse this is being used in a config management test).",
        "link": "https://stackoverflow.com/questions/59861501/verifying-existence-of-a-root-level-element-with-jq",
        "title": "Verifying existence of a root level element with jq"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "edit"
        ],
        "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": 1579729795,
                "post_id": 59864629,
                "comment_id": 105868368,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1707399,
                    "reputation": 11184,
                    "user_id": 1566187,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/00cb2ecc49f0f05736dc7c14bbccfeaa?s=256&d=identicon&r=PG",
                    "display_name": "Ely",
                    "link": "https://stackoverflow.com/users/1566187/ely"
                },
                "reply_to_user": {
                    "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": 1579790423,
                "post_id": 59864629,
                "comment_id": 105891197,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1579750790,
                "last_edit_date": 1579750790,
                "creation_date": 1579715833,
                "answer_id": 59865682,
                "question_id": 59864629,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the first part, it helps to have a helper function:\r\n\r\n```\r\ndef insertkv($afterkey; $key; $value):\r\n  def insertafter($ix; $x): .[0:1+$ix] + [$x] + .[1+$ix:];\r\n\r\n  to_entries\r\n  | insertafter( map(.key) | index($afterkey);  {$key, $value})\r\n  | from_entries;\r\n\r\n```\r\n\r\n### Versions\r\nThe above is intended for use with jq 1.5 or later.  Some minor fiddling is required for earlier versions.",
                "title": "Add a new entry to a Json after or before a specified existing entry with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1579750790,
        "creation_date": 1579711977,
        "last_edit_date": 1579727339,
        "question_id": 59864629,
        "body_markdown": "I have the following input and I want to below output using jq.\r\n\r\nI would like to add\r\n\r\n- an entry `&quot;zeiterfassungAktiviert&quot; : true`just after the key `gueltigBis` (or alternatively before the key `inhaltsverzeichnis`)\r\n- add an entry to the end of the object `inhaltsverzeichnis` by adding the entry `&quot;zeiterfassung&quot;: &quot;zeiterfassung&quot;`\r\n\r\nExample input:\r\n\r\n    {\r\n      &quot;fachbereich&quot;: &quot;qp&quot;,\r\n      &quot;produktTyp&quot;: &quot;PRODUKT_ANFRAGE_V1&quot;,\r\n      &quot;name&quot;: &quot;Produkt Anfrage&quot;,\r\n      &quot;kurzName&quot;: &quot;anfrage&quot;,\r\n      &quot;gueltigAb&quot;: &quot;2019-01-01T00:00:00.000&quot;,\r\n      &quot;gueltigBis&quot;: &quot;2022-12-31T00:00:00.000&quot;,\r\n      &quot;inhaltsverzeichnis&quot;: {\r\n        &quot;versandumfang&quot;: &quot;auftragsverwaltung/versandumfang&quot;,\r\n        &quot;dokumentenerzeugung&quot;: &quot;dokumentenerzeugung&quot;\r\n      }\r\n    }\r\n\r\nExample output:\r\n\r\n    {\r\n      &quot;fachbereich&quot;: &quot;qp&quot;,\r\n      &quot;produktTyp&quot;: &quot;PRODUKT_ANFRAGE_V1&quot;,\r\n      &quot;name&quot;: &quot;Produkt Anfrage&quot;,\r\n      &quot;kurzName&quot;: &quot;anfrage&quot;,\r\n      &quot;gueltigAb&quot;: &quot;2019-01-01T00:00:00.000&quot;,\r\n      &quot;gueltigBis&quot;: &quot;2022-12-31T00:00:00.000&quot;,\r\n      &quot;zeiterfassungAktiviert&quot;: true,\r\n      &quot;inhaltsverzeichnis&quot;: {\r\n        &quot;versandumfang&quot;: &quot;auftragsverwaltung/versandumfang&quot;,\r\n        &quot;dokumentenerzeugung&quot;: &quot;dokumentenerzeugung&quot;,\r\n        &quot;zeiterfassung&quot;: &quot;zeiterfassung&quot;\r\n      },\r\n    }\r\n\r\n\r\nI managed to do the second part but am not clear about how to go about the first part.\r\n\r\nCommand: `jq &#39;.zeiterfassungAktiviert += &quot;zeiterfassung&quot; | .inhaltsverzeichnis.zeiterfassung += &quot;zeiterfassung&quot;&#39;`\r\n\r\nThe result is as follows:\r\n\r\n    {\r\n      &quot;fachbereich&quot;: &quot;qp&quot;,\r\n      &quot;produktTyp&quot;: &quot;PRODUKT_ANFRAGE_V1&quot;,\r\n      &quot;name&quot;: &quot;Produkt Anfrage&quot;,\r\n      &quot;kurzName&quot;: &quot;anfrage&quot;,\r\n      &quot;gueltigAb&quot;: &quot;2019-01-01T00:00:00.000&quot;,\r\n      &quot;gueltigBis&quot;: &quot;2022-12-31T00:00:00.000&quot;,\r\n      &quot;inhaltsverzeichnis&quot;: {\r\n        &quot;versandumfang&quot;: &quot;auftragsverwaltung/versandumfang&quot;,\r\n        &quot;dokumentenerzeugung&quot;: &quot;dokumentenerzeugung&quot;,\r\n        &quot;zeiterfassung&quot;: &quot;zeiterfassung&quot;\r\n      },\r\n      &quot;zeiterfassungAktiviert&quot;: true\r\n    }\r\n\r\n\r\nAs you can see it is added to the end of the root object. I would like to specify the position somehow, ideally without having to convert into array and convert back if possible but rather by saying please add entry after/before a specified key.",
        "link": "https://stackoverflow.com/questions/59864629/add-a-new-entry-to-a-json-after-or-before-a-specified-existing-entry-with-jq",
        "title": "Add a new entry to a Json after or before a specified existing entry with jq"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1579785656,
                "post_id": 59879489,
                "comment_id": 105888303,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9500892,
                    "reputation": 298,
                    "user_id": 7062051,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/7Vu50.jpg?s=256",
                    "display_name": "Phillip Hamnett",
                    "link": "https://stackoverflow.com/users/7062051/phillip-hamnett"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1579786157,
                "post_id": 59879489,
                "comment_id": 105888594,
                "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": 1579790444,
                "post_id": 59879489,
                "comment_id": 105891209,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9500892,
                    "reputation": 298,
                    "user_id": 7062051,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/7Vu50.jpg?s=256",
                    "display_name": "Phillip Hamnett",
                    "link": "https://stackoverflow.com/users/7062051/phillip-hamnett"
                },
                "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": 1579792279,
                "post_id": 59879489,
                "comment_id": 105892329,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1579788921,
                "creation_date": 1579788921,
                "answer_id": 59880624,
                "question_id": 59879489,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This would help\r\n\r\nhttps://jqplay.org/s/KLPXwB7Ey_\r\n\r\n    .[].item1 as $item | $item.array1[] | $item.item2 , .item3 , .item4",
                "title": "How to print object element for each internal array element in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1579790812,
                "last_edit_date": 1579790812,
                "creation_date": 1579789519,
                "answer_id": 59880790,
                "question_id": 59879489,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Doing the processing of the output with shell&#39;s `printf()` with `xargs` is not needed as you can do the processing entirely in `jq` itself.\r\n\r\nYou need to iterate over the values of `.item3` and `.item4` each time for one unique value of `.item2`. To have the result in proper CSV format, format the array using `@csv` and for tabular representation you can use `@tsv`\r\n\r\n    jq -r &#39;.[].item1 as $data | $data.array1[] | [ $data.item2 , .item3 , .item4 ] | @csv&#39; json\r\n\r\nAlso it does not make sense to lose quotes around the `.item4` values in your expected output, as they are the expected to be retained in a valid JSON string attribute.\r\n\r\nIf you still need to loose the quotes and represent them as raw strings, you can use `join` on the formed array\r\n\r\n    jq -r &#39;.[].item1 as $data | $data.array1[] | [ ($data.item2|tostring) , (.item3|tostring) , .item4 ]|join(&quot;, &quot;)&#39;",
                "title": "How to print object element for each internal array element in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1579791050,
        "creation_date": 1579785387,
        "last_edit_date": 1579791050,
        "question_id": 59879489,
        "body_markdown": "I have JSON that looks like this:\r\n\r\n**test.json**\r\n```\r\n[\r\n  {\r\n    &quot;item1&quot;: {\r\n      &quot;item2&quot;: 123,\r\n      &quot;array1&quot;: [\r\n        {\r\n          &quot;item3&quot;: 456,\r\n          &quot;item4&quot;: &quot;teststring&quot;\r\n        },\r\n        {\r\n          &quot;item3&quot;: 789,\r\n          &quot;item4&quot;: &quot;teststring2&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nI am trying to print it out in the following format:\r\n\r\n```\r\n123, 456, teststring\r\n123, 789, teststring2\r\n```\r\nI tried to do it like this:\r\n```\r\ncat test.json | jq -r &#39;.[].item1.item2, (.[].item1.array1[] | .item3, .item4)&#39; | xargs printf &quot;%s, %s, %s\\n&quot;\r\n```\r\nBut the result is that `item2` is printed, followed by `item3` and `item4` in the first line, and then only `item3` and `item4` are printed in the next line, like so:\r\n```\r\n123, 456, teststring\r\n789, teststring2, \r\n```\r\n\r\nHow can I make the element on the outside of the array print for every set of elements that are printed from within the array?",
        "link": "https://stackoverflow.com/questions/59879489/how-to-print-object-element-for-each-internal-array-element-in-jq",
        "title": "How to print object element for each internal array element in jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7720836,
                    "reputation": 348,
                    "user_id": 5847124,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://www.gravatar.com/avatar/88eda35fd5557f872b246e620d14c9e1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ekydfejj",
                    "link": "https://stackoverflow.com/users/5847124/ekydfejj"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1579808201,
                "post_id": 59884137,
                "comment_id": 105900578,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1579841578,
                "last_edit_date": 1579841578,
                "creation_date": 1579808027,
                "answer_id": 59885873,
                "question_id": 59884137,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following outputs the correct information (no duplicates) regardless of file order\r\n\r\n    jq -s &#39;reduce .[] as $dot ({}; .logs.logs_collected.files.collect_list += $dot.logs.logs_collected.files.collect_list)&#39; web.json wazuh-agent.json suricata.json\r\n\r\nIf anyone knows why the duplicate occurs in my other command would love to know that.  Though i think `reduce` is a better solution.",
                "title": "jq - duplicate object in list when merging arbitrary number of json arrays from files"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1580105033,
                "last_edit_date": 1580105033,
                "creation_date": 1579841981,
                "answer_id": 59890574,
                "question_id": 59884137,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have a couple of incorrect steps as part of the attempt you have made. Firstly, to convert the array of all &quot;list&quot; arrays\r\n\r\n    [.[].logs.logs_collected.files.collect_list] \r\n\r\nto one single array, you need to use `add` but the way it was invoked was incorrect. The add takes input as an array of objects and produces as output the elements of the array added together. So it should have been\r\n\r\n    [.[].logs.logs_collected.files.collect_list] | add\r\n\r\nfollowed by the `unique` function which again takes as input an array and produces an array of the same elements, in sorted order, with duplicates removed.\r\n\r\n    [.[].logs.logs_collected.files.collect_list] | add | unique\r\n\r\nAs for the duplication of first elements, it is because you were using the append operation `+=` instead of the assignment `=`. Because the code on the right side of the operator, groups the entries from all the objects, using an append merely appends the value in the first object with the rest of the objects combined together. \r\n\r\nAlso group the functions together with `(..)` before accessing the `.[0]` from the resultant object. So putting it together will work as expected irrespective of the order of files.\r\n\r\n    jq -s &#39;.[0].logs.logs_collected.files.collect_list = ([.[].logs.logs_collected.files.collect_list]|add|unique)|.[0]&#39; \r\n\r\n    \r\nAnother variant  using `reduce` without having to use `slurp` mode `-s`, but rather working on the `inputs` i.e. content of the all the files available over standard input\r\n\r\n    jq -n &#39;reduce inputs.logs.logs_collected.files.collect_list as $d (.; .logs.logs_collected.files.collect_list += $d)&#39;\r\n",
                "title": "jq - duplicate object in list when merging arbitrary number of json arrays from files"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1580105033,
        "creation_date": 1579800416,
        "question_id": 59884137,
        "body_markdown": "I&#39;m configuring cloudwatch agent logs, using saltstack (which is why there some odd syntax).  I am trying to merge an arbitrary number of files, containing identical schema&#39;s, but different data into a single file.\r\n\r\n**File 1**\r\n```\r\n{\r\n  &quot;logs&quot;: {\r\n    &quot;logs_collected&quot;: {\r\n      &quot;files&quot;:{\r\n        &quot;collect_list&quot;: [\r\n          {\r\n            &quot;file_name&quot;: &quot;/var/log/suricata/eve-ips.json&quot;,\r\n            &quot;log_group_name&quot;: &quot;{{grains.environment_full}}SuricataIPS&quot;,\r\n            &quot;log_stream_name&quot;: &quot;{{grains.id}}&quot;,\r\n            &quot;timezone&quot;: &quot;UTC&quot;,\r\n            &quot;timestamp_format&quot;: &quot;%Y-%m-%dT%H:%M:%S.%f+0000&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n**File 2**\r\n```\r\n{\r\n  &quot;logs&quot;: {\r\n    &quot;logs_collected&quot;: {\r\n      &quot;files&quot;: {\r\n        &quot;collect_list&quot;: [\r\n          {\r\n            &quot;file_name&quot;: &quot;/var/log/company/company-json.log&quot;,\r\n            &quot;log_group_name&quot;: &quot;{{grains.environment_full}}Play&quot;,\r\n            &quot;log_stream_name&quot;: &quot;{{grains.id}}&quot;,\r\n            &quot;timezone&quot;: &quot;UTC&quot;,\r\n            &quot;timestamp_format&quot;: &quot;%Y-%m-%dT%H:%M:%S.%fZ&quot;\r\n          },\r\n          {\r\n            &quot;file_name&quot;: &quot;/var/log/company/company-notifications.log&quot;,\r\n            &quot;log_group_name&quot;: &quot;{{grains.environment_full}}Notifications&quot;,\r\n            &quot;log_stream_name&quot;: &quot;{{grains.id}}&quot;,\r\n            &quot;timezone&quot;: &quot;UTC&quot;,\r\n            &quot;timestamp_format&quot;: &quot;%Y-%m-%dT%H:%M:%S.%fZ&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n**File 3**\r\n```\r\n{\r\n  &quot;logs&quot;: {\r\n    &quot;logs_collected&quot;: {\r\n      &quot;files&quot;: {\r\n        &quot;collect_list&quot;: [\r\n          {\r\n            &quot;file_name&quot;: &quot;/var/ossec/logs/alerts/alerts.json&quot;,\r\n            &quot;log_group_name&quot;: &quot;{{grains.environment_full}}OSSEC&quot;,\r\n            &quot;log_stream_name&quot;: &quot;{{grains.id}}&quot;,\r\n            &quot;timezone&quot;: &quot;UTC&quot;,\r\n            &quot;timestamp_format&quot;: &quot;%Y-%m-%d %H:%M:%S&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n**jq query** (based on some SO help)\r\n```\r\njq  -s &#39;.[0].logs.logs_collected.files.collect_list += [.[].logs.logs_collected.files.collect_list | add] | unique| .[0]&#39; web.json suricata.json wazuh-agent.json\r\n```\r\n**Output**\r\n```\r\n{\r\n  &quot;logs&quot;: {\r\n    &quot;logs_collected&quot;: {\r\n      &quot;files&quot;: {\r\n        &quot;collect_list&quot;: [\r\n          {\r\n            &quot;file_name&quot;: &quot;/var/log/company/company-json.log&quot;,\r\n            &quot;log_group_name&quot;: &quot;{{grains.environment_full}}Play&quot;,\r\n            &quot;log_stream_name&quot;: &quot;{{grains.id}}&quot;,\r\n            &quot;timezone&quot;: &quot;UTC&quot;,\r\n            &quot;timestamp_format&quot;: &quot;%Y-%m-%dT%H:%M:%S.%fZ&quot;\r\n          },\r\n          {\r\n            &quot;file_name&quot;: &quot;/var/log/company/company-notifications.log&quot;,\r\n            &quot;log_group_name&quot;: &quot;{{grains.environment_full}}Notifications&quot;,\r\n            &quot;log_stream_name&quot;: &quot;{{grains.id}}&quot;,\r\n            &quot;timezone&quot;: &quot;UTC&quot;,\r\n            &quot;timestamp_format&quot;: &quot;%Y-%m-%dT%H:%M:%S.%fZ&quot;\r\n          },\r\n          {\r\n            &quot;file_name&quot;: &quot;/var/log/company/company-notifications.log&quot;,\r\n            &quot;log_group_name&quot;: &quot;{{grains.environment_full}}Notifications&quot;,\r\n            &quot;log_stream_name&quot;: &quot;{{grains.id}}&quot;,\r\n            &quot;timezone&quot;: &quot;UTC&quot;,\r\n            &quot;timestamp_format&quot;: &quot;%Y-%m-%dT%H:%M:%S.%fZ&quot;\r\n          },\r\n          {\r\n            &quot;file_name&quot;: &quot;/var/log/suricata/eve-ips.json&quot;,\r\n            &quot;log_group_name&quot;: &quot;{{grains.environment_full}}SuricataIPS&quot;,\r\n            &quot;log_stream_name&quot;: &quot;{{grains.id}}&quot;,\r\n            &quot;timezone&quot;: &quot;UTC&quot;,\r\n            &quot;timestamp_format&quot;: &quot;%Y-%m-%dT%H:%M:%S.%f+0000&quot;\r\n          },\r\n          {\r\n            &quot;file_name&quot;: &quot;/var/ossec/logs/alerts/alerts.json&quot;,\r\n            &quot;log_group_name&quot;: &quot;{{grains[&#39;environment_full&#39;]}}OSSEC&quot;,\r\n            &quot;log_stream_name&quot;: &quot;{{grains.id}}&quot;,\r\n            &quot;timezone&quot;: &quot;UTC&quot;,\r\n            &quot;timestamp_format&quot;: &quot;%Y-%m-%d %H:%M:%S&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nif you&#39;ve gotten this far, thank you.  One additional point to note, is that if i change the order of the files the first index of `collect_list` is always duplicated and if `web.json` is last (the only one with a length of 2) the second log file is not in the group.",
        "link": "https://stackoverflow.com/questions/59884137/jq-duplicate-object-in-list-when-merging-arbitrary-number-of-json-arrays-from",
        "title": "jq - duplicate object in list when merging arbitrary number of json arrays from files"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1579931998,
                "last_edit_date": 1579931998,
                "creation_date": 1579921951,
                "answer_id": 59906039,
                "question_id": 59904094,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using your approach:\r\n\r\n    [ .[]\r\n      | if .[&quot;@type&quot;] == &quot;Project&quot; \r\n        then .name = &quot;newname&quot; | .version  = &quot;newversion&quot; \r\n        else . end ]\r\n\r\nor if you want to use `select`, you could write:\r\n\r\n    map( (select(.[&quot;@type&quot;] == &quot;Project&quot;) | .name = &quot;newname&quot; | .version  = &quot;newversion&quot; ) // .)\r\n\r\nor more exotically:\r\n\r\n    (.[] | select([&quot;@type&quot;] == &quot;Project&quot;))\r\n    |= (.name = &quot;newname&quot; | .version  = &quot;newversion&quot; )",
                "title": "jq: change multiple values within a select object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1579932445,
                "creation_date": 1579932445,
                "answer_id": 59906803,
                "question_id": 59904094,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Merge an object with the new values.\r\n\r\n    map(select(.[&quot;@type&quot;] == &quot;Project&quot;) * {name: &quot;newname&quot;, version: &quot;newversion&quot;} // .)",
                "title": "jq: change multiple values within a select object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1579932445,
        "creation_date": 1579902347,
        "last_edit_date": 1579922498,
        "question_id": 59904094,
        "body_markdown": "I have an array of JSON objects, and I am trying change the `name` and `version` on the object of a given `@type`, with the following input\r\n```\r\n[\r\n {\r\n    &quot;name&quot;: &quot;oldname&quot;,\r\n    &quot;version&quot;: &quot;oldversion&quot;,\r\n    &quot;@type&quot;: &quot;Project&quot;\r\n },\r\n {\r\n    &quot;name&quot;: &quot;bomname&quot;,\r\n    &quot;version&quot;: &quot;bomversion&quot;,\r\n    &quot;@type&quot;: &quot;BOM&quot;\r\n },\r\n {\r\n    &quot;name&quot;: &quot;componentname&quot;,\r\n    &quot;version&quot;: &quot;componentversion&quot;,\r\n    &quot;@type&quot;: &quot;Component&quot;\r\n }\r\n]\r\n```\r\n\r\nI found many examples for changing a single value, and I can successfully do this by chaining multiple `select` statements together. \r\n\r\n```\r\n$ cat original.json | jq &#39;[ .[] | (select(.[&quot;@type&quot;] == &quot;Project&quot;) | .name ) = &quot;newname&quot; | (select(.[&quot;@type&quot;] == &quot;Project&quot;) | .version ) = &quot;newversion ] &#39; &gt; renamed.json\r\n\r\n```\r\n\r\nBut I was hoping I could condense this so I only have perform the `select` once to change both values.",
        "link": "https://stackoverflow.com/questions/59904094/jq-change-multiple-values-within-a-select-object",
        "title": "jq: change multiple values within a select object"
    },
    {
        "tags": [
            "json",
            "jq",
            "text-processing"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580026359,
                "post_id": 59913240,
                "comment_id": 105957445,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1666859,
                    "reputation": 3179,
                    "user_id": 1534084,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/ef28a37ab34404c23fb91ca55a09ba8a?s=256&d=identicon&r=PG",
                    "display_name": "Martin Mucha",
                    "link": "https://stackoverflow.com/users/1534084/martin-mucha"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580026707,
                "post_id": 59913240,
                "comment_id": 105957507,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1580061951,
                "last_edit_date": 1580061951,
                "creation_date": 1579989953,
                "answer_id": 59913820,
                "question_id": 59913240,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t know about &quot;correctly&quot;, but this is what I&#39;d do:\r\n```bash\r\npacmd list-sink-inputs | awk &#39;\r\n    BEGIN { print &quot;[&quot; }\r\n    function print_record() {\r\n        if (count++) {\r\n            print &quot;  {&quot;\r\n            printf &quot;    %s,\\n&quot;, print_number(&quot;pid&quot;)\r\n            printf &quot;    %s,\\n&quot;, print_number(&quot;index&quot;)\r\n            printf &quot;    %s,\\n&quot;, print_string(&quot;appname&quot;)\r\n            printf &quot;    %s\\n&quot;,  print_string(&quot;medianame&quot;)\r\n            print &quot;  },&quot;\r\n        }\r\n        delete record\r\n    }\r\n    function print_number(key) { return sprintf(&quot;\\&quot;%s\\&quot;: %d&quot;, key, record[key]) }\r\n    function print_string(key) { return sprintf(&quot;\\&quot;%s\\&quot;: \\&quot;%s\\&quot;&quot;, key, record[key]) }\r\n    function get_quoted_value() {\r\n        if (match($0, /[^&quot;]+&quot;$/))\r\n            return substr($0, RSTART, RLENGTH-1)\r\n        else\r\n            return &quot;?&quot;\r\n    }\r\n    $1 == &quot;index:&quot; { print_record(); record[&quot;index&quot;] = $2 }\r\n    $1 == &quot;application.process.id&quot; { record[&quot;pid&quot;]       = get_quoted_value() }\r\n    $1 == &quot;application.name&quot;       { record[&quot;appname&quot;]   = get_quoted_value() }\r\n    $1 == &quot;media.name&quot;             { record[&quot;medianame&quot;] = get_quoted_value() }\r\n    END { print_record(); print &quot;]&quot; }\r\n&#39; | \r\n  tac | awk &#39;/},$/ &amp;&amp; !seen++ {sub(/,$/,&quot;&quot;)} 1&#39; | tac\r\n```\r\nwhere the `tac|awk|tac` line removes the trailing comma from the *last* JSON object in the list.\r\n```\r\n[\r\n  {\r\n    &quot;pid&quot;: 1543,\r\n    &quot;index&quot;: 144,\r\n    &quot;appname&quot;: &quot;MPlayer&quot;,\r\n    &quot;medianame&quot;: &quot;UNREAL! Tetris Theme on Violin and Guitar-TnDIRr9C83w.webm&quot;\r\n  },\r\n  {\r\n    &quot;pid&quot;: 2831,\r\n    &quot;index&quot;: 145,\r\n    &quot;appname&quot;: &quot;MPlayer&quot;,\r\n    &quot;medianame&quot;: &quot;Trombone Shorty At Age 13 - 2nd Line-k9YUi3UhEPQ.webm&quot;\r\n  }\r\n]\r\n```",
                "title": "how to parse more complex human-oriented text output to machine-friently style?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1579990875,
                "creation_date": 1579990875,
                "answer_id": 59913925,
                "question_id": 59913240,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could just pipe your output into:\r\n```bash\r\nsed -E &#39;\r\n  s/pid=([0-9]+) index=([0-9]+) appname=([^ ]+) medianame=(.*)/{&quot;pid&quot;: \\1, &quot;index&quot;: \\2, &quot;appname&quot;: &quot;\\3&quot;, &quot;medianame&quot;: \\4},/\r\n  1s/^/[/\r\n  $s/,$/]/\r\n&#39; | jq .\r\n```",
                "title": "how to parse more complex human-oriented text output to machine-friently style?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1580065537,
                "last_edit_date": 1580065537,
                "creation_date": 1579992625,
                "answer_id": 59914084,
                "question_id": 59913240,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the input is as reasonable as shown in the Q, the following  approach that only uses jq should be possible.\r\n\r\nAn invocation along the following lines is assumed:\r\n\r\n    jq -nR -f parse.jq input.txt\r\n\r\n```\r\ndef parse:\r\n  def interpret:\r\n    if . == null then .\r\n    elif startswith(&quot;\\&quot;&quot;) and endswith(&quot;\\&quot;&quot;)\r\n    then  .[1:-1]\r\n    else tonumber? // .\r\n    end;\r\n  (capture( &quot;(?&lt;key&gt;[^\\t:= ]*)(: | = )(?&lt;value&gt;.*)&quot; ) // null)\r\n  | if . then .value = (.value | interpret) else . end\r\n;\r\n\r\n# Construct one object for each &quot;segment&quot;  \r\ndef construct(s): \r\n  [ foreach (s, 0) as $kv (null;\r\n      if $kv == 0 or $kv.index\r\n      then .complete = .accumulator | .accumulator = $kv\r\n      else .complete = null | .accumulator += $kv\r\n      end;\r\n      .complete // empty ) ]\r\n;\r\n\r\n\r\nconstruct(inputs | parse | select(.) | {(.key):.value})\r\n| map( {pid: .[&quot;application.process.id&quot;],\r\n        index,\r\n        appname: .[&quot;application.name&quot;],\r\n        medianame: .[&quot;media.name&quot;]} )\r\n\r\n```\r\n\r\nWith the example input, the output would be:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;pid&quot;: &quot;1543&quot;,\r\n    &quot;index&quot;: 144,\r\n    &quot;appname&quot;: &quot;MPlayer&quot;,\r\n    &quot;medianame&quot;: &quot;UNREAL! Tetris Theme on Violin and Guitar-TnDIRr9C83w.webm&quot;\r\n  },\r\n  {\r\n    &quot;pid&quot;: &quot;2831&quot;,\r\n    &quot;index&quot;: 145,\r\n    &quot;appname&quot;: &quot;MPlayer&quot;,\r\n    &quot;medianame&quot;: &quot;Trombone Shorty At Age 13 - 2nd Line-k9YUi3UhEPQ.webm&quot;\r\n  }\r\n]\r\n```\r\n\r\n### Brief explanation\r\n\r\n`parse` parses one line. It assumes that whitespace (blank and tab characters) on each line before the key name can be ignored. \r\n\r\n`construct` is responsible for grouping the lines (presented as a stream of key-value single-key objects) corresponding to a particular value of “index”. It produces an array of objects, one for each value of “index”. \r\n\r\n",
                "title": "how to parse more complex human-oriented text output to machine-friently style?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1580065537,
        "creation_date": 1579985056,
        "last_edit_date": 1580060867,
        "question_id": 59913240,
        "body_markdown": "This is the question about how to parse &quot;unparseable&quot; output into json, or to something easily consumable as json. This is &quot;little&quot; bit behind trivial stuff, so I&#39;d like to know, how do you solve these things in principle, it&#39;s not about this specific example only. But example:\r\n\r\nWe have this command, which shows data about audio inputs: \r\n\r\n    pacmd list-sink-inputs\r\n\r\nit prints something like this:\r\n\r\n    2 sink input(s) available.\r\n        index: 144\r\n    \tdriver: &lt;protocol-native.c&gt;\r\n    \tflags: \r\n    \tstate: RUNNING\r\n    \tsink: 4 &lt;alsa_output.pci-0000_05_00.0.analog-stereo&gt;\r\n    \tvolume: front-left: 15728 /  24% / -37.19 dB,   front-right: 15728 /  24% / -37.19 dB\r\n    \t        balance 0.00\r\n    \tmuted: no\r\n    \tcurrent latency: 70.48 ms\r\n    \trequested latency: 210.00 ms\r\n    \tsample spec: float32le 2ch 44100Hz\r\n    \tchannel map: front-left,front-right\r\n    \t             Stereo\r\n    \tresample method: copy\r\n    \tmodule: 13\r\n    \tclient: 245 &lt;MPlayer&gt;\r\n    \tproperties:\r\n    \t\tmedia.name = &quot;UNREAL! Tetris Theme on Violin and Guitar-TnDIRr9C83w.webm&quot;\r\n    \t\tapplication.name = &quot;MPlayer&quot;\r\n    \t\tnative-protocol.peer = &quot;UNIX socket client&quot;\r\n    \t\tnative-protocol.version = &quot;32&quot;\r\n    \t\tapplication.process.id = &quot;1543&quot;\r\n    \t\tapplication.process.user = &quot;mmucha&quot;\r\n    \t\tapplication.process.host = &quot;vbDesktop&quot;\r\n    \t\tapplication.process.binary = &quot;mplayer&quot;\r\n    \t\tapplication.language = &quot;C&quot;\r\n    \t\twindow.x11.display = &quot;:0&quot;\r\n    \t\tapplication.process.machine_id = &quot;720184179caa46f0a3ce25156642f7a0&quot;\r\n    \t\tapplication.process.session_id = &quot;2&quot;\r\n    \t\tmodule-stream-restore.id = &quot;sink-input-by-application-name:MPlayer&quot;\r\n        index: 145\r\n    \tdriver: &lt;protocol-native.c&gt;\r\n    \tflags: \r\n    \tstate: RUNNING\r\n    \tsink: 4 &lt;alsa_output.pci-0000_05_00.0.analog-stereo&gt;\r\n    \tvolume: front-left: 24903 /  38% / -25.21 dB,   front-right: 24903 /  38% / -25.21 dB\r\n    \t        balance 0.00\r\n    \tmuted: no\r\n    \tcurrent latency: 70.50 ms\r\n    \trequested latency: 210.00 ms\r\n    \tsample spec: float32le 2ch 48000Hz\r\n    \tchannel map: front-left,front-right\r\n    \t             Stereo\r\n    \tresample method: speex-float-1\r\n    \tmodule: 13\r\n    \tclient: 251 &lt;MPlayer&gt;\r\n    \tproperties:\r\n    \t\tmedia.name = &quot;Trombone Shorty At Age 13 - 2nd Line-k9YUi3UhEPQ.webm&quot;\r\n    \t\tapplication.name = &quot;MPlayer&quot;\r\n    \t\tnative-protocol.peer = &quot;UNIX socket client&quot;\r\n    \t\tnative-protocol.version = &quot;32&quot;\r\n    \t\tapplication.process.id = &quot;2831&quot;\r\n    \t\tapplication.process.user = &quot;mmucha&quot;\r\n    \t\tapplication.process.host = &quot;vbDesktop&quot;\r\n    \t\tapplication.process.binary = &quot;mplayer&quot;\r\n    \t\tapplication.language = &quot;C&quot;\r\n    \t\twindow.x11.display = &quot;:0&quot;\r\n    \t\tapplication.process.machine_id = &quot;720184179caa46f0a3ce25156642f7a0&quot;\r\n    \t\tapplication.process.session_id = &quot;2&quot;\r\n    \t\tmodule-stream-restore.id = &quot;sink-input-by-application-name:MPlayer&quot;\r\n\r\nvery nice. But we don&#39;t want to show user all of this, we just want to show index (id of input), application.process.id, application.name and media.name, in some reasonable format. It would be great to parse it _somehow_ to json, but even if I preprocess it somehow, the `jq` is way beyond my capabilities and quite complex. I tried multiple approaches using jq, with regex or without, but I wasn&#39;t able to finish it. And I guess we cannot rely on order or presence of all fields.\r\n\r\nI was able to get the work &quot;done&quot;, but it&#39;s messy, inefficient, and namely expects no semicolons in media name or app name. Not acceptable solution, but this is the only thing I was able to bring to the &quot;end&quot;.\r\n\r\nincorrect solution:\r\n\r\n    cat exampleOf2Inputs | \r\n    grep -e &quot;index: \\|application.process.id = \\|application.name = \\|media.name = &quot; | \r\n    sed &quot;s/^[ \\t]*//;s/^\\([^=]*\\) = /\\1: /&quot; | \r\n    tr &quot;\\n&quot; &quot;;&quot; | \r\n    sed &quot;s/$/\\n/;s/index:/\\nindex:/g&quot; | \r\n    tail -n +2 | \r\n    while read A; do \r\n    index=$(echo $A|sed &quot;s/^index: \\([0-9]*\\).*/\\1/&quot;);\r\n    pid=$(echo $A|sed &#39;s/^.*application\\.process\\.id: \\&quot;\\([0-9]*\\)\\&quot;.*$/\\1/&#39;); \r\n    appname=$(echo $A|sed &#39;s/^.*application\\.name: \\&quot;\\([^;]*\\)\\&quot;.*$/\\1/&#39;); \r\n    medianame=$(echo $A|sed &#39;s/^.*media\\.name: \\&quot;\\([^;]*\\)\\&quot;.*$/\\&quot;\\1\\&quot;/&#39;); \r\n    \r\n    echo &quot;pid=$pid index=$index appname=$appname medianame=$medianame&quot;; \r\n    done\r\n\r\n~ I grepped the interessant part, replaced newlines with semicolon, split to multiple lines, and just extract the data multiple times using sed. Crazy.\r\n\r\nHere the output is:\r\n\r\n    pid=1543 index=144 appname=MPlayer medianame=&quot;UNREAL! Tetris Theme on Violin and Guitar-TnDIRr9C83w.webm&quot;\r\n    pid=2831 index=145 appname=MPlayer medianame=&quot;Trombone Shorty At Age 13 - 2nd Line-k9YUi3UhEPQ.webm&quot;\r\n\r\nwhich is easily convertable to any format, but the question was about json, so to:\r\n\r\n    [\r\n      {\r\n        &quot;pid&quot;: 1543,\r\n        &quot;index&quot;: 144,\r\n        &quot;appname&quot;: &quot;MPlayer&quot;,\r\n        &quot;medianame&quot;: &quot;UNREAL! Tetris Theme on Violin and Guitar-TnDIRr9C83w.webm&quot;\r\n      },\r\n      {\r\n        &quot;pid&quot;: 2831,\r\n        &quot;index&quot;: 145,\r\n        &quot;appname&quot;: &quot;MPlayer&quot;,\r\n        &quot;medianame&quot;: &quot;Trombone Shorty At Age 13 - 2nd Line-k9YUi3UhEPQ.webm&quot;\r\n      }\r\n    ]\r\n\r\nNow I&#39;d like to see, please, how are these things done correctly.\r\n   ",
        "link": "https://stackoverflow.com/questions/59913240/how-to-parse-more-complex-human-oriented-text-output-to-machine-friently-style",
        "title": "how to parse more complex human-oriented text output to machine-friently style?"
    },
    {
        "tags": [
            "json",
            "jq",
            "edit",
            "hierarchical-data"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1580009091,
                "last_edit_date": 1580009091,
                "creation_date": 1579988022,
                "answer_id": 59913595,
                "question_id": 59913277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following performs the replacement described in the text.  An invocation along the lines of\r\n\r\n    jq --arg cleartext &quot;clearTextValue&quot; -f decrypt.jq sample.json\r\n\r\nis assumed.  If your jq does not have `walk/1`, then either upgrade to jq 1.6 or include its def before its invocation (google search terms: `jq def walk builtin.jq`).\r\n\r\n```\r\n# input is assumed to be an object\r\ndef decrypt($value):\r\n  with_entries(if .value|type == &quot;object&quot;\r\n    then with_entries(if .value | (type == &quot;object&quot; and has(&quot;$crypto&quot;))\r\n      then .value = $value else . end)\r\n    else . end) ;\r\n    \r\nwalk(if type == &quot;object&quot; then decrypt($cleartext) else . end)\r\n```",
                "title": "Replace JSON objects in unknown positions inside a JSON tree"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1580008856,
                "last_edit_date": 1580008856,
                "creation_date": 1580008564,
                "answer_id": 59915251,
                "question_id": 59913277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As an addition to the accepted answer and if using jq v1.5, use this as `decrypt.jq`\r\n\r\n```\r\n# input is assumed to be an object\r\ndef decrypt($value):\r\n  with_entries(if .value|type == &quot;object&quot;\r\n    then with_entries(if .value | (type == &quot;object&quot; and has(&quot;$crypto&quot;))\r\n      then .value = $value else . end)\r\n    else . end) ;\r\n    \r\n# walk was added after the release of jq@1.5\r\ndef walk(f):\r\n  . as $in\r\n  | if type == &quot;object&quot; then\r\n      reduce keys[] as $key\r\n        ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n  elif type == &quot;array&quot; then map( walk(f) ) | f\r\n  else f\r\n  end;\r\n\r\nwalk(if type == &quot;object&quot; then decrypt($cleartext) else . end)\r\n```",
                "title": "Replace JSON objects in unknown positions inside a JSON tree"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1580009184,
        "creation_date": 1579985341,
        "last_edit_date": 1580009184,
        "question_id": 59913277,
        "body_markdown": "In a JSON file I need to replace encrypted values with their clear text values as an initialization process using the command line tool `jq`. An application will then re-encrypt the values with its own keys, overwriting the clear text values. Encrypted values are represented as &quot;$crypto&quot; objects, containing information about the encryption method and which keys were used, looking like this:\r\n\r\n    {\r\n        &quot;$crypto&quot; : {\r\n            &quot;type&quot; : &quot;x-simple-encryption&quot;,\r\n            &quot;value&quot; : {\r\n                &quot;cipher&quot; : &quot;AES/CBC/PKCS5Padding&quot;,\r\n                &quot;stableId&quot; : &quot;someId&quot;,\r\n                &quot;salt&quot; : &quot;4J5ckE6+JaS8TLqAN4073g==&quot;,\r\n                &quot;data&quot; : &quot;vBeHAPJXLl+X/8Enp9vxMA==&quot;,\r\n                &quot;keySize&quot; : 16,\r\n                &quot;purpose&quot; : &quot;someDescription&quot;,\r\n                &quot;iv&quot; : &quot;N2xCe5RiJibHv9hLY+OduA==&quot;,\r\n                &quot;mac&quot; : &quot;VoOo1BKptwfqIJeSOb/qGA==&quot;\r\n            }\r\n        }\r\n    }\r\n\r\nThese &quot;$crypto&quot; objects can be anywhere in the JSON structure. A sample input document looks like this:\r\n\r\n    {\r\n        &quot;unknownKey1&quot; : {\r\n            &quot;unknownKey2&quot; : {\r\n                &quot;name&quot; : &quot;JWT_SESSION&quot;,\r\n                &quot;properties&quot; : {\r\n                    &quot;maxTokenLifeMinutes&quot; : 120,\r\n                    &quot;tokenIdleTimeMinutes&quot; : 30\r\n                }\r\n            },\r\n            &quot;unknownKey3&quot; : [\r\n                {\r\n                    &quot;unknownKey4&quot; : &quot;STATIC_USER&quot;,\r\n                    &quot;unknownKey5&quot; : {\r\n                        &quot;unknownKey6&quot; : &quot;internal/user&quot;,\r\n                        &quot;unknownKey7&quot; : &quot;anonymous&quot;,\r\n                        &quot;unknownKey8&quot; : {\r\n                            &quot;$crypto&quot; : {\r\n                                &quot;type&quot; : &quot;x-simple-encryption&quot;,\r\n                                &quot;value&quot; : {\r\n                                    &quot;cipher&quot; : &quot;AES/CBC/PKCS5Padding&quot;,\r\n                                    &quot;stableId&quot; : &quot;someId&quot;,\r\n                                    &quot;salt&quot; : &quot;4J5ckE6+JaS8TLqAN4073g==&quot;,\r\n                                    &quot;data&quot; : &quot;vBeHAPJXLl+X/8Enp9vxMA==&quot;,\r\n                                    &quot;keySize&quot; : 16,\r\n                                    &quot;purpose&quot; : &quot;someDescription&quot;,\r\n                                    &quot;iv&quot; : &quot;N2xCe5RiJibHv9hLY+OduA==&quot;,\r\n                                    &quot;mac&quot; : &quot;VoOo1BKptwfqIJeSOb/qGA==&quot;\r\n                                }\r\n                            }\r\n                        }\r\n                    },\r\n                    &quot;enabled&quot; : true\r\n                }\r\n            ]\r\n        }\r\n    }\r\n\r\nSo the value of &quot;unknownKey8&quot; was encrypted. I need that document to look like this:\r\n\r\n    {\r\n        &quot;unknownKey1&quot; : {\r\n            &quot;unknownKey2&quot; : {\r\n                &quot;name&quot; : &quot;JWT_SESSION&quot;,\r\n                &quot;properties&quot; : {\r\n                    &quot;maxTokenLifeMinutes&quot; : 120,\r\n                    &quot;tokenIdleTimeMinutes&quot; : 30\r\n                }\r\n            },\r\n            &quot;unknownKey3&quot; : [\r\n                {\r\n                    &quot;unknownKey4&quot; : &quot;STATIC_USER&quot;,\r\n                    &quot;unknownKey5&quot; : {\r\n                        &quot;unknownKey6&quot; : &quot;internal/user&quot;,\r\n                        &quot;unknownKey7&quot; : &quot;anonymous&quot;,\r\n                        &quot;unknownKey8&quot; : &quot;clearTextValue&quot;\r\n                    },\r\n                    &quot;enabled&quot; : true\r\n                }\r\n            ]\r\n        }\r\n    }\r\n\r\nI have been able to find crypto objects in the input file using the following command:\r\n\r\n    cat input.json | jq &#39;paths | select(.[-1] == &quot;$crypto&quot;)&#39;\r\n    [\r\n      &quot;unknownKey1&quot;,\r\n      &quot;unknownKey3&quot;,\r\n      0,\r\n      &quot;unknownKey5&quot;,\r\n      &quot;unknownKey8&quot;,\r\n      &quot;$crypto&quot;\r\n    ]\r\n\r\nBut I have not been able to make meaningful progress on performing the replacement.",
        "link": "https://stackoverflow.com/questions/59913277/replace-json-objects-in-unknown-positions-inside-a-json-tree",
        "title": "Replace JSON objects in unknown positions inside a JSON tree"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1579987444,
                "post_id": 59913511,
                "comment_id": 105952017,
                "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": 8,
                "creation_date": 1579987810,
                "post_id": 59913511,
                "comment_id": 105952102,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5655219,
                    "reputation": 1575,
                    "user_id": 4474629,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/571ae856757b5f4c745d06d5e3415b5c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Little Code",
                    "link": "https://stackoverflow.com/users/4474629/little-code"
                },
                "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": 1579988665,
                "post_id": 59913511,
                "comment_id": 105952307,
                "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": 2,
                "creation_date": 1579989906,
                "post_id": 59913511,
                "comment_id": 105952602,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1702538712,
                "last_edit_date": 1702538712,
                "creation_date": 1662026461,
                "answer_id": 73567527,
                "question_id": 59913511,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq supports the boolean operations [and/or/not](https://stedolan.github.io/jq/manual/v1.6/#and/or/not). `not` is a builtin function and needs to be called as a filter:\r\n\r\n    jq -r &#39;.sealed | not&#39;\r\n\r\n*****\r\n\r\nOf course, if you like to make simple things more complicated, you can use other tools to do this job for you:\r\n\r\n    jq -r &#39;.sealed&#39; | python -c &#39;print({&quot;false&quot;:&quot;true&quot;,&quot;true&quot;:&quot;false&quot;}[input()])&#39;\r\n\r\nOr with pure shell/bash:\r\n\r\n```\r\nflip() {\r\n  read -r b\r\n  case &quot;$b&quot; in\r\n     true) echo false ;;\r\n    false) echo true  ;;\r\n  esac\r\n}\r\njq -r &#39;.sealed&#39; | flip\r\n```\r\n\r\nAlternatively\r\n\r\n```\r\nflip() {\r\n  read -r b;\r\n  if [ &quot;$b&quot; = true ]; then echo false;\r\n  else echo true; fi\r\n}\r\n```",
                "title": "One-liner way to invert boolean output in bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1702538712,
        "creation_date": 1579987279,
        "question_id": 59913511,
        "body_markdown": "Is there a short and clean one-liner way to invert a boolean in bash ?\r\n\r\nI have a piped command as follows that looks at the sealed status of Hashicorp Vault:\r\n\r\n`vault status -format json -address=&quot;https://127.0.0.1:8200&quot; -tls-skip-verify | jq -r &#39;.sealed&#39;`\r\n\r\nThe problem is that if Vault is in a unsealed state, the value of `sealed` will be *false*, and hence the output from `jq -r &#39;.sealed&#39;` will be false and this will be interpreted as a boolean false in my config management.\r\n\r\nSo therefore I need to invert the output from `jq`, i.e `sealed=false =&gt; true and sealed=true=&gt;false`.\r\n\r\nI would like to do this in a clean manner at the end of the pipe becaue the piped command is being used by a config management system, not by a script.",
        "link": "https://stackoverflow.com/questions/59913511/one-liner-way-to-invert-boolean-output-in-bash",
        "title": "One-liner way to invert boolean output in bash?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1580015970,
                "creation_date": 1580015970,
                "answer_id": 59915780,
                "question_id": 59915712,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Simply tack on `| add` to the end of your jq program.",
                "title": "JQ Transverse List as Map"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1580015970,
        "creation_date": 1580015173,
        "question_id": 59915712,
        "body_markdown": "I want to convert the Below JSON to Map. but its coming as a list.\r\n\r\n\r\n    {\r\n      &quot;_embedded&quot;: {\r\n        &quot;items&quot;: [\r\n          {\r\n             &quot;order&quot;: 1,\r\n            &quot;technical&quot;: {\r\n              &quot;id&quot;: 1,\r\n              &quot;_links&quot;: {\r\n                &quot;self&quot;: {\r\n                  &quot;href&quot;: &quot;/profile/api/v3/service/40/technical&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n           {\r\n            &quot;order&quot;: 2,\r\n            &quot;technical&quot;: {\r\n              &quot;id&quot;: 1,\r\n              &quot;_links&quot;: {\r\n                &quot;self&quot;: {\r\n                  &quot;href&quot;: &quot;/profile/api/v3/service/40/technical&quot;\r\n                }\r\n              }\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nExpected format:\r\n\r\n    {\r\n      &quot;1&quot;: &quot;/profile/api/v3/service/40/technical&quot;,\r\n      &quot;2&quot;: &quot;/profile/api/v3/service/40/technical&quot;\r\n    }\r\n\r\nBut i am getting :::\r\n\r\n    [\r\n      {\r\n        &quot;1&quot;: &quot;/profile/api/v3/service/40/technical&quot;\r\n      },\r\n      {\r\n        &quot;2&quot;: &quot;/profile/api/v3/service/40/technical&quot;\r\n      }\r\n    ]\r\n\r\n\r\nJQ Query:::\r\n\r\n    ._embedded.items | map({(.order| tostring ) : .technical._links.self.href} )\r\n\r\nPlease help, Thanks in Advance.. \r\n\r\nCode Snippet - https://jqplay.org/s/cEzh5_LimP \r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59915712/jq-transverse-list-as-map",
        "title": "JQ Transverse List as Map"
    },
    {
        "tags": [
            "json",
            "jq",
            "string-interpolation"
        ],
        "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": 3,
                "creation_date": 1580148583,
                "post_id": 59936373,
                "comment_id": 105994876,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1580147572,
                "creation_date": 1580147572,
                "answer_id": 59936423,
                "question_id": 59936373,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    echo &#39;[&quot;123&quot;, &quot;456&quot;]&#39; | jq -r &#39;&quot;array=&quot; + join(&quot;,&quot;)&#39;",
                "title": "jq filter expression in string interpolation"
            },
            {
                "up_vote_count": 15,
                "is_accepted": true,
                "score": 15,
                "last_activity_date": 1580147773,
                "creation_date": 1580147773,
                "answer_id": 59936473,
                "question_id": 59936373,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using string interpolation `\\(.)`, you can do something like below. Your idea is almost right, but interpolation using `\\(..)` needs the filter to present be inside a string with the expression to be used defined inside parens after a backslash\r\n\r\n    jq --raw-output &#39;&quot;array=\\(join(&quot;,&quot;))&quot;&#39;\r\n",
                "title": "jq filter expression in string interpolation"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1580169876,
        "creation_date": 1580147351,
        "last_edit_date": 1580169876,
        "question_id": 59936373,
        "body_markdown": "I have been trying to reduce the array to a string to be used in string interpolation.\r\n\r\nFor example. \r\n\r\n```\r\ninput = [&quot;123&quot;, &quot;456&quot;]\r\nexpected output = array=123,456\r\n```\r\n\r\nHere is my try\r\n\r\n```\r\n$ echo &#39;[&quot;123&quot;, &quot;456&quot;]&#39; | jq &#39;array=\\(.|join(&quot;,&quot;))&#39;\r\njq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\narray=\\(.|join(&quot;,&quot;))\r\njq: 1 compile error\r\n```",
        "link": "https://stackoverflow.com/questions/59936373/jq-filter-expression-in-string-interpolation",
        "title": "jq filter expression in string interpolation"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1580478016,
                "last_edit_date": 1580478016,
                "creation_date": 1580208515,
                "answer_id": 59947039,
                "question_id": 59946450,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just use an explicit `if` condition that checks for the attribute `schemes` in the root level of the JSON structure\r\n\r\n    schem=&#39;[&quot;https&quot;]&#39;\r\n\r\nAfter setting the above variable in your shell, run the following filter\r\n\r\n    jq --argjson argval &quot;$schem&quot; &#39;if has(&quot;schemes&quot;)|not then .+= { schemes: $argval } else . end&#39; json\r\n\r\nThe argument immediately after the `--argjson` field is the one that needs to be used in the context of `jq`, but you were trying to use `$schem` in the context which is incorrect.\r\n\r\n\r\nYou can even go one level further and check even if `schemes` is present and if it does _not_ contain the value you expect, then make the overwrite. Modify the filter within `&#39;..&#39;` to\r\n\r\n\r\n    ( has(&quot;schemes&quot;)|not ) or .schemes != $argval )\r\n\r\nwhich can be run as\r\n\r\n    jq --argjson argval &quot;$schem&quot; &#39;if ( (has(&quot;schemes&quot;)|not) or .schemes != $argval) then (.schemes: $argval) else . end&#39;",
                "title": "Conditionally add json array using jq and bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1580478016,
        "creation_date": 1580206491,
        "last_edit_date": 1580294422,
        "question_id": 59946450,
        "body_markdown": "Am trying to add a json array with just one array element to a json. And it has to be added only if it does not already exist. \r\nExample json is below.\r\n\r\n    {\r\n        &quot;lorem&quot;: &quot;2.0&quot;,\r\n        &quot;ipsum&quot;: {\r\n            &quot;key1&quot;: &quot;value1&quot;,\r\n            &quot;key2&quot;: &quot;value2&quot;\r\n        },\r\n        &quot;schemes&quot;: [&quot;https&quot;],\r\n        &quot;dorum&quot; : &quot;value3&quot; \r\n    }\r\nAbove is the json, where `&quot;schemes&quot;: [&quot;https&quot;],` exists. Am trying to add schemes only if it does not exist using the below code.\r\n\r\n    scheme=$( cat rendertest.json | jq -r &#39;. &quot;schemes&quot; &#39;)\r\n    echo $scheme\r\n    schem=&#39;[&quot;https&quot;]&#39;\r\n    echo &quot;Scheme is&quot;\r\n    echo $schem\r\n    if [ -z $scheme ]\r\n    then\r\n    echo &quot;all good&quot;\r\n    else \r\n    jq --argjson argval  &quot;$schem&quot;  &#39;. += { &quot;schemes&quot; : $schem }&#39; rendertest.json &gt; test.json\r\n    fi\r\n\r\nI get the below error in a file when the json array element &#39;schemes&#39; does not exist. It returns a null and errors out. Any idea where am going wrong?\r\n\r\n    null\r\n    Scheme is\r\n    [&quot;https&quot;]\r\n    jq: error: schem/0 is not defined at &lt;top-level&gt;, line 1:\r\n    . += { &quot;schemes&quot; : $schem }                   \r\n    jq: 1 compile error\r\n\r\n\r\nEdit: the question is not about how to pass on bash variables to jq.\r\n",
        "link": "https://stackoverflow.com/questions/59946450/conditionally-add-json-array-using-jq-and-bash",
        "title": "Conditionally add json array using jq and bash"
    },
    {
        "tags": [
            "ruby",
            "curl",
            "grep",
            "sinatra",
            "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": 1580224626,
                "post_id": 59951545,
                "comment_id": 106023140,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17300850,
                    "reputation": 1,
                    "user_id": 12530588,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b644d5ffd684c5ffda7382543195fc49?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "mogul05",
                    "link": "https://stackoverflow.com/users/12530588/mogul05"
                },
                "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": 1580225810,
                "post_id": 59951545,
                "comment_id": 106023728,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17300850,
                    "reputation": 1,
                    "user_id": 12530588,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b644d5ffd684c5ffda7382543195fc49?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "mogul05",
                    "link": "https://stackoverflow.com/users/12530588/mogul05"
                },
                "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": 1580226092,
                "post_id": 59951545,
                "comment_id": 106023876,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1580227604,
                "last_edit_date": 1580227604,
                "creation_date": 1580227140,
                "answer_id": 59952593,
                "question_id": 59951545,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Always it&#39;s better to do stuff in one language. Like:\r\n\r\n    response = HTTParty.get(&#39;https://path/to/json&#39;)\r\n    JSON.parse(response)\r\n    ...\r\n\r\nIf you want mix it with Bash, try:\r\n\r\n    bar = `curl -m 10 -s -H &#39;[...]&#39; &quot;https://example_with_json_file.com&quot; | jq -r .remote | group_by(.name) | map({ (.[0].name): map(.id) }) | &quot;\\(.[])&quot; | grep &#39;3\\|4\\|11&#39;`\r\n    foo = bar.split(/\\n/)\r\n    File.write(&#39;/path/to/file&#39;, bar)\r\n\r\n",
                "title": "Pipe Curl Output with Grep ending o Txt File in Ruby"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1580227604,
        "creation_date": 1580223652,
        "question_id": 59951545,
        "body_markdown": "im encountering problems using curl within ruby. I want to run a ruby script and it should store a JSON type object like this\r\n```\r\n{\r\n    &quot;remote&quot;:  [\r\n        {&quot;name&quot;: &quot;cast-1&quot;,\r\n         &quot;id&quot;: 1212\r\n        },\r\n        {&quot;name&quot;: &quot;cast-1&quot;,\r\n         &quot;id&quot;: 1214\r\n        },\r\n        {&quot;name&quot;: &quot;home-11&quot;,\r\n         &quot;id&quot;: 3212\r\n        },\r\n        {&quot;name&quot;: &quot;cast-3&quot;,\r\n         &quot;id&quot;: 3212\r\n        },\r\n        {&quot;name&quot;: &quot;cast-3&quot;,\r\n         &quot;id&quot;: 3213\r\n        },\r\n        {&quot;name&quot;: &quot;cast-4&quot;,\r\n         &quot;id&quot;: 4211\r\n        }\r\n\r\n    ]\r\n}\r\n```\r\nin a text file. I mapped and grepped the curl input to get the desired entries.\r\nNow when i run the script, my txt file pops out empty.\r\nexample of what i tried\r\n```\r\n#ruby\r\n\r\n`curl -m 10 -s -H &#39;[...]&#39; &quot;https://example_with_json_file.com&quot; | jq -r .remote | group_by(.name) | map({ (.[0].name): map(.id) }) | &quot;\\(.[])&quot; | grep &#39;3\\|4\\|11&#39; &gt; file.txt` \r\n\r\nfoo = []\r\n\r\nFile.open(file.txt) do |file|\r\n  foo = file.readlines\r\nend\r\n[...]\r\n\r\n```\r\nrunning the above input in my temrinal works. I tried using Kernel.system order system within my ruby example. Nothing worked.\r\n\r\nHow can i pipe this output into a txt file\r\n```\r\n{&quot;cast-3&quot;:[3212,3213]}\r\n{&quot;cast-4&quot;:[4211]}\r\n{&quot;home-11&quot;:[3212]}\r\n```\r\n\r\nOr in general, is it possible to run the curl input in a single line, that is executable using ruby? ",
        "link": "https://stackoverflow.com/questions/59951545/pipe-curl-output-with-grep-ending-o-txt-file-in-ruby",
        "title": "Pipe Curl Output with Grep ending o Txt File in Ruby"
    },
    {
        "tags": [
            "json",
            "jq",
            "edit"
        ],
        "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": 1580225793,
                "post_id": 59952122,
                "comment_id": 106023714,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1580226397,
                "creation_date": 1580226397,
                "answer_id": 59952368,
                "question_id": 59952122,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your input, specifically the value of the `cData` key, looks tailor-made to be used with `to_entries` and `from_entries`.\r\n\r\n    $ jq &#39;.items[0].data.cData |= (from_entries | .toModify = &quot;xyz&quot; | to_entries)&#39; tmp.json\r\n    {\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;source&quot;: {\r\n            &quot;id&quot;: &quot;12334&quot;\r\n          },\r\n          &quot;data&quot;: {\r\n            &quot;name&quot;: &quot;test&quot;,\r\n            &quot;value&quot;: &quot;test&quot;,\r\n            &quot;cData&quot;: [\r\n              {\r\n                &quot;key&quot;: &quot;keOne&quot;,\r\n                &quot;value&quot;: &quot;hello&quot;\r\n              },\r\n              {\r\n                &quot;key&quot;: &quot;toModify&quot;,\r\n                &quot;value&quot;: &quot;xyz&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }",
                "title": "Jq to replace a word with in the json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1580259191,
                "creation_date": 1580259191,
                "answer_id": 59959195,
                "question_id": 59952122,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The requirements are a bit sketchy, but the following produces the desired result in this particular case, and illustrates one approach:\r\n \r\n\r\n    .items[].data.cData\r\n      |= map(if .key == &quot;toModify&quot; then .key = &quot;MODIFIED&quot; else . end)",
                "title": "Jq to replace a word with in the json"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1580268644,
        "creation_date": 1580225656,
        "last_edit_date": 1580268644,
        "question_id": 59952122,
        "body_markdown": "I have a json below and i need to fetch the value of the key &quot;toModify&quot; in data section. And also wanted to modify the key(toModify) value with another value Ex: hello1234567 to xyz. How can we do that using jq.\r\n\r\n    {\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;source&quot;: {\r\n            &quot;id&quot;: &quot;12334&quot;        \r\n          },\r\n          &quot;data&quot;: {\r\n            &quot;name&quot;: &quot;test&quot;,\r\n            &quot;value&quot;: &quot;test&quot;,        \r\n            &quot;cData&quot;: [\r\n              {\r\n                &quot;key&quot;: &quot;keOne&quot;,\r\n                &quot;value&quot;: &quot;hello&quot;\r\n              },\r\n              {\r\n                &quot;key&quot;: &quot;toModify&quot;,\r\n                &quot;value&quot;: &quot;hello1234567&quot;\r\n              }\r\n            ]\r\n          } \r\n        }\r\n      ]\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/59952122/jq-to-replace-a-word-with-in-the-json",
        "title": "Jq to replace a word with in the json"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1580326731,
                "last_edit_date": 1580326731,
                "creation_date": 1580268586,
                "answer_id": 59960122,
                "question_id": 59959364,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could simply use the filter:\r\n\r\n    .Systems[&quot;@odata.id&quot;]\r\n\r\nThat is, at a bash or bash-like prompt, you&#39;d type something like:\r\n\r\n    jq &#39;.Systems[&quot;@odata.id&quot;]&#39; redfish.txt",
                "title": "Retrieve value of @odata.id with jq in Redfish output"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641927565,
                "creation_date": 1641927565,
                "answer_id": 70672079,
                "question_id": 59959364,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "i stumbled across this, as this is the highest rated site for a duckduckgo query of &quot;jq&quot; and &quot;@odata.id&quot;\r\n\r\nUnfortunately the answer is incorrect ... after some messing around I have got the correct answer: \r\n\r\n    jq &#39;.Systems.[]&quot;@odata.id&quot;&#39;\r\n\r\nSince the things in the square brackets [] are an array that are a 0 indexed (start at zero) numeric array, you&#39;ll get an error trying to reference an element called &quot;`@odata.id`&quot; (i.e. `.Systems[&quot;@odata.id&quot;]`), while `.Systems[1]` would work (if there are two elements in the array)\r\n\r\nIf you want all the elements ... use the above, if you want a specific element, you can use:\r\n\r\n    jq &#39;.Systems[#].&quot;odata.id&quot;&#39; \r\n\r\nThere should be an earlier component (in the output) that will tell you how many elements (hopefully), something like `&quot;Members@odata.count&quot;`\r\n\r\n***BUT*** ... after i typed this and checked your data i realized i was solving my case, that looked like yours, but wasn&#39;t.  In actually looking at your data, what you need is ...\r\n\r\n    jq &#39;.Systems.&quot;@odata.id&quot;&#39;\r\n\r\nBecause you DON&#39;T have an array, you have have normal key that just needs proper quoting ...\r\n\r\nHopefully this helps",
                "title": "Retrieve value of @odata.id with jq in Redfish output"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1641927565,
        "creation_date": 1580260852,
        "question_id": 59959364,
        "body_markdown": "I&#39;m parsing some json Redfish data using jq. \r\n\r\nTrying to pull value for @odata.id from redfish.txt file below.\r\n\r\nInvoking with recommended jq .[&quot;@odata.id&quot;] doesn&#39;t seem to quite work to pull just value itself which is: /redfish/v1/Systems\r\n\r\nAny suggestions welcomed. Output below... :)\r\n\r\nThanks,\r\nNick\r\n\r\n    root@ubuntu-xenial:/var/opt# cat redfish.txt\r\n    {&quot;@odata.context&quot;:&quot;/redfish/v1/$metadata#ServiceRoot.ServiceRoot&quot;,&quot;@odata.id&quot;:&quot;/redfish/v1&quot;,&quot;@odata.type&quot;:&quot;#ServiceRoot.v1_2_0.ServiceRoot&quot;,&quot;AccountService&quot;:{&quot;@odata.id&quot;:&quot;/redfish/v1/Managers/iDRAC.Embedded.1/AccountService&quot;},&quot;Chassis&quot;:{&quot;@odata.id&quot;:&quot;/redfish/v1/Chassis&quot;},&quot;Description&quot;:&quot;Root Service&quot;,&quot;EventService&quot;:{&quot;@odata.id&quot;:&quot;/redfish/v1/EventService&quot;},&quot;Id&quot;:&quot;RootService&quot;,&quot;JsonSchemas&quot;:{&quot;@odata.id&quot;:&quot;/redfish/v1/JSONSchemas&quot;},&quot;Links&quot;:{&quot;Sessions&quot;:{&quot;@odata.id&quot;:&quot;/redfish/v1/Sessions&quot;}},&quot;Managers&quot;:{&quot;@odata.id&quot;:&quot;/redfish/v1/Managers&quot;},&quot;Name&quot;:&quot;Root Service&quot;,&quot;Oem&quot;:{&quot;Dell&quot;:{&quot;@odata.type&quot;:&quot;#DellServiceRoot.v1_0_0.ServiceRootSummary&quot;,&quot;IsBranded&quot;:0,&quot;ManagerMACAddress&quot;:&quot;d0:96:69:51:d4:70&quot;,&quot;ServiceTag&quot;:&quot;XXXX&quot;}},&quot;RedfishVersion&quot;:&quot;1.2.0&quot;,&quot;Registries&quot;:{&quot;@odata.id&quot;:&quot;/redfish/v1/Registries&quot;},&quot;SessionService&quot;:{&quot;@odata.id&quot;:&quot;/redfish/v1/SessionService&quot;},&quot;Systems&quot;:{&quot;@odata.id&quot;:&quot;/redfish/v1/Systems&quot;},&quot;Tasks&quot;:{&quot;@odata.id&quot;:&quot;/redfish/v1/TaskService&quot;},&quot;UpdateService&quot;:{&quot;@odata.id&quot;:&quot;/redfish/v1/UpdateService&quot;}}\r\n    root@ubuntu-xenial:/var/opt# cat redfish.txt | jq .Systems\r\n    {\r\n      &quot;@odata.id&quot;: &quot;/redfish/v1/Systems&quot;\r\n    }\r\n    root@ubuntu-xenial:/var/opt# cat redfish.txt | jq .Systems | jq .@odata.id\r\n    jq: error: syntax error, unexpected FIELD, expecting QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .@odata.id\r\n    jq: error: try .[&quot;field&quot;] instead of .field for unusually named fields at &lt;top-level&gt;, line 1:\r\n    .@odata.id\r\n    jq: 2 compile errors\r\n    root@ubuntu-xenial:/var/opt# cat redfish.txt | jq .Systems | jq .[&quot;@odata.id&quot;]\r\n    {\r\n      &quot;@odata.id&quot;: &quot;/redfish/v1/Systems&quot;\r\n    }\r\n    &quot;/redfish/v1/Systems&quot;\r\n    root@ubuntu-xenial:/var/opt# cat redfish.txt | jq .Systems | jq .[&quot;odata.id&quot;]\r\n    {\r\n      &quot;@odata.id&quot;: &quot;/redfish/v1/Systems&quot;\r\n    }\r\n    &quot;/redfish/v1/Systems&quot;\r\n    root@ubuntu-xenial:/var/opt#\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59959364/retrieve-value-of-odata-id-with-jq-in-redfish-output",
        "title": "Retrieve value of @odata.id with jq in Redfish output"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "yq"
        ],
        "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": 1580269418,
                "post_id": 59960188,
                "comment_id": 106038473,
                "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": 1580269459,
                "post_id": 59960188,
                "comment_id": 106038480,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13125667,
                    "reputation": 1822,
                    "user_id": 9481731,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/s256-rj/photo.jpg",
                    "display_name": "AhmFM",
                    "link": "https://stackoverflow.com/users/9481731/ahmfm"
                },
                "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": 1580273783,
                "post_id": 59960188,
                "comment_id": 106039243,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1580305017,
                "post_id": 59960188,
                "comment_id": 106053244,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1580269265,
                "creation_date": 1580269265,
                "answer_id": 59960199,
                "question_id": 59960188,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "aah: just figured out but is this the right way?\r\n\r\n```\r\n-o json | jq &#39;.items[] | .metadata.name, .metadata.labels.&quot;test.com/cordon-reason&quot;&#39; | awk &#39;{print $1}&#39; | paste - - | xargs -l1 -- sh -c &#39;echo $1 https://jira.test.com/$2&#39; --\r\n```\r\noutput\r\n```\r\nnode1 https://jira.test.com/testing\r\nnode2 https://jira.test.com/null\r\n```",
                "title": "prefix url to output from json jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1580305366,
                "last_edit_date": 1580305366,
                "creation_date": 1580269589,
                "answer_id": 59960224,
                "question_id": 59960188,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Looks to me like you want:\r\n\r\n```\r\njq -r &#39;.items[] | [.metadata.name, &quot;https://jira.test.com/\\(.metadata.labels[&quot;test.com/cordon-reason&quot;])&quot;] | @tsv&#39;\r\n```",
                "title": "prefix url to output from json jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1580305366,
        "creation_date": 1580269072,
        "last_edit_date": 1580269329,
        "question_id": 59960188,
        "body_markdown": "Team,\r\nI have output and I want to prefix it with a url. \r\n\r\n```\r\nkubectl get nodes -l nodeGroup=gpu -o wide --no-headers -o json | jq &#39;.items[] | .metadata.name, .metadata.labels.&quot;team.com/cordon-reason&quot;&#39; | awk &#39;{print $1}&#39; | paste - -\r\n```\r\n\r\noutput\r\n```\r\n&quot;node1&quot;\t&quot;testing&quot;\r\n&quot;node2&quot;\tnull\r\n```\r\n\r\n\r\nexpected output\r\n```\r\n&quot;node1&quot;\t&quot;https://jira.test.com/testing&quot;\r\n&quot;node2&quot;\t&quot;https://jira.test.com/null&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/59960188/prefix-url-to-output-from-json-jq",
        "title": "prefix url to output from json jq"
    },
    {
        "tags": [
            "json",
            "stream",
            "export-to-csv",
            "jq",
            "missing-data"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1580287809,
                "last_edit_date": 1580287809,
                "creation_date": 1580278132,
                "answer_id": 59961356,
                "question_id": 59960742,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In `jq` you can use the alternate operator `//` that can be used to return default values. E.g.  `.foo // 1` will evaluate to `1` if there&#39;s no `.foo` element in the input\r\n\r\nUsing that and appending an empty string `&quot;&quot;` if the key is not present, you can do\r\n\r\n    jq -r &#39;[.id // &quot;&quot;, .deviceName // &quot;&quot;, .total // &quot;&quot;, .master // &quot;&quot;] | @csv&#39;\r\n\r\n**Note**: The alternate operator ` .foo // 1` causes the evaluation to `1` for case when the value of `foo` is `null` or `false`. You may wish to modify the above program if your data contains `null` or `false` values.\r\n",
                "title": "Print empty string for a missing key and converting the result to CSV"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1580331122,
                "last_edit_date": 1580331122,
                "creation_date": 1580278852,
                "answer_id": 59961481,
                "question_id": 59960742,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can take the first object as a reference for a full record, like\r\n```\r\nkeys_unsorted as $k | (., inputs) | [.[$k[]]] | @csv\r\n```\r\nFor your sample this produces following\r\n```\r\n&quot;ABC&quot;,&quot;&quot;,100,20\r\n&quot;ABC&quot;,,100,20\r\n```",
                "title": "Print empty string for a missing key and converting the result to CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1580331122,
        "creation_date": 1580274198,
        "last_edit_date": 1580304417,
        "question_id": 59960742,
        "body_markdown": "I am trying to convert belowJSON to CSV using jq command but the final CSV is unable to place deviceName field properly as it&#39;s missing in some JSON lines.\r\n\r\n    {\r\n      &quot;id&quot;: &quot;ABC&quot;,\r\n      &quot;deviceName&quot;: &quot;&quot;,\r\n      &quot;total&quot;: 100,\r\n      &quot;master&quot;: 20\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;ABC&quot;,\r\n      &quot;total&quot;: 100,\r\n      &quot;master&quot;: 20\r\n    }\r\n\r\n\r\nHow can i make sure empty value gets when Key is missing ?.\r\n\r\nI Tried below command to generate CSV\r\n\r\n    ./jq -r &#39;[.[]] | @csv&#39; &gt; final.csv\r\n\r\nBut it gives CSV like below as you can see when deviceName key is missing in JSON it&#39;s cell shifting left side.\r\n\r\n    &quot;ABC&quot;,&quot;&quot;,100,20\r\n    &quot;ABC&quot;,100,20\r\n\r\nI want output something like below which adds empty value if deviceName is missing.\r\n\r\n    &quot;ABC&quot;,&quot;&quot;,100,20\r\n    &quot;ABC&quot;,&quot;&quot;,100,20",
        "link": "https://stackoverflow.com/questions/59960742/print-empty-string-for-a-missing-key-and-converting-the-result-to-csv",
        "title": "Print empty string for a missing key and converting the result to CSV"
    },
    {
        "tags": [
            "python",
            "json",
            "bash",
            "jq",
            "large-files"
        ],
        "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": 1580284843,
                "post_id": 59962659,
                "comment_id": 106042591,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6759085,
                    "reputation": 3560,
                    "user_id": 5223223,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-QFGa11QGfIg/AAAAAAAAAAI/AAAAAAAAAB0/1HgxEcgjlSg/s256-rj/photo.jpg",
                    "display_name": "dibery",
                    "link": "https://stackoverflow.com/users/5223223/dibery"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1580285114,
                "post_id": 59962659,
                "comment_id": 106042681,
                "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": 1580288205,
                "post_id": 59962659,
                "comment_id": 106044101,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13286748,
                    "reputation": 343,
                    "user_id": 9592585,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/s256-rj/photo.jpg",
                    "display_name": "Shubhankar Agrawal",
                    "link": "https://stackoverflow.com/users/9592585/shubhankar-agrawal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580315550,
                "post_id": 59962659,
                "comment_id": 106059617,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1580304155,
                "last_edit_date": 1580304155,
                "creation_date": 1580286993,
                "answer_id": 59963220,
                "question_id": 59962659,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One of the major advantages of jq is that it is stream-oriented, so there should be no need to convert your stream of JSON entities to an array of those entities, unless that is the goal.  All processing should be done using `input` and/or `inputs`, most likely with the -n command-line option.\r\n\r\nIn other words, it might be advisable to perform all the processing in jq rather than converting the stream to a single, unmanageably large JSON entity for some tool that cannot deal with a stream.  \r\n\r\nAlternatively, if you wish to use a tool that requires JSONL input, then use `jq -cn inputs` (or `jq -c .` as suggested above).",
                "title": "How to parse extremely large file of json stream to valid JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1580315488,
        "creation_date": 1580284574,
        "last_edit_date": 1580315488,
        "question_id": 59962659,
        "body_markdown": "I&#39;m working on a CS course project where I&#39;ve to perform sentiment analysis of Twitter data on an Ubuntu VM. I was able to build a crawler to obtain the data but I have the output in the format of a file of JSON stream which is a very large file which is of the style:\r\n\r\n    {\r\n      &quot;query&quot;: &quot;#India_since_2019&quot;,\r\n      &quot;username&quot;: &quot;user_1&quot;,\r\n      &quot;ID&quot;: &quot;123455&quot;,\r\n      &quot;tweet&quot;: &quot;This is the tweet&quot;,\r\n      &quot;datetime&quot;: &quot;2019-04-05&quot;\r\n    }\r\n    {\r\n      &quot;query&quot;: &quot;#India_since_2019&quot;,\r\n      &quot;username&quot;: &quot;user_1&quot;,\r\n      &quot;ID&quot;: &quot;123455&quot;,\r\n      &quot;tweet&quot;: &quot;This is the tweet&quot;,\r\n      &quot;datetime&quot;: &quot;2019-04-05&quot;\r\n    }\r\n\r\nand so on.\r\n\r\nI essentially have to filter results based on year and store the resultant json file.\r\n\r\nThe output I&#39;m looking to get is\r\n```\r\n[\r\n{\r\n      &quot;query&quot;: &quot;#India_since_2019&quot;,\r\n      &quot;username&quot;: &quot;user_1&quot;,\r\n      &quot;ID&quot;: &quot;123455&quot;,\r\n      &quot;tweet&quot;: &quot;This is the tweet&quot;,\r\n      &quot;datetime&quot;: &quot;2019-04-05&quot;\r\n    },\r\n    {\r\n      &quot;query&quot;: &quot;#India_since_2019&quot;,\r\n      &quot;username&quot;: &quot;user_1&quot;,\r\n      &quot;ID&quot;: &quot;123455&quot;,\r\n      &quot;tweet&quot;: &quot;This is the tweet&quot;,\r\n      &quot;datetime&quot;: &quot;2019-04-05&quot;\r\n    }\r\n]\r\n```\r\n\r\nThis prevents me from reading the file line by line as all the data is appended thus not creating any new lines. \r\n\r\nI tried using jq to parse the data but the file was too large and thus created errors.\r\n\r\nWould you guys have any suggestions for how I can convert this easily to a valid JSON and write to another file?\r\n\r\nI&#39;d be open to solutions in any script as I&#39;m flexible with those, although I&#39;d prefer an idea I can work with in Python/Shell.\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/59962659/how-to-parse-extremely-large-file-of-json-stream-to-valid-json",
        "title": "How to parse extremely large file of json stream to valid JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1580310597,
                "last_edit_date": 1580310597,
                "creation_date": 1580310200,
                "answer_id": 59969916,
                "question_id": 59969841,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t really need regexp for this.\r\n```\r\nselect(.value | ascii_downcase == &quot;myemail@domain.com&quot;) .id\r\n```\r\nBut if you insist on it, below is how you perform a case-insensitive match using `test/2`.\r\n```\r\nselect(.value | test(&quot;MyEmail@domain.com&quot;; &quot;i&quot;)) .id\r\n```",
                "title": "Get key value of matching case insensitive string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1598331315,
        "creation_date": 1580309953,
        "last_edit_date": 1598331315,
        "question_id": 59969841,
        "body_markdown": "I&#39;m attempting to pull some specific data from the &quot;id&quot; field but `jq` matches are being case sensitive and creating an issue with the searches (not matching, basically, so returning 0 results).\r\n\r\nJSON Example:\r\n\r\n```\r\n{\r\n  &quot;created_at&quot;: &quot;2020-01-17T12:54:02Z&quot;,\r\n  &quot;primary&quot;: true,\r\n  &quot;verified&quot;: true,\r\n  &quot;deliverable_state&quot;: &quot;deliverable&quot;,\r\n  &quot;undeliverable_count&quot;: 0,\r\n  &quot;updated_at&quot;: &quot;2020-01-17T12:54:03Z&quot;,\r\n  &quot;url&quot;: &quot;http://www.website.com&quot;,\r\n  &quot;id&quot;: 376062709553,\r\n  &quot;user_id&quot;: 374002305374,\r\n  &quot;type&quot;: &quot;email&quot;,\r\n  &quot;value&quot;: &quot;test-1234567@domain.com&quot;\r\n}\r\n{\r\n  &quot;created_at&quot;: &quot;2019-02-07T20:49:41Z&quot;,\r\n  &quot;primary&quot;: false,\r\n  &quot;verified&quot;: true,\r\n  &quot;deliverable_state&quot;: &quot;deliverable&quot;,\r\n  &quot;undeliverable_count&quot;: 0,\r\n  &quot;updated_at&quot;: &quot;2019-02-07T20:49:41Z&quot;,\r\n  &quot;url&quot;: &quot;http://www.website.com&quot;,\r\n  &quot;id&quot;: 366235941554,\r\n  &quot;user_id&quot;: 374002305374,\r\n  &quot;type&quot;: &quot;email&quot;,\r\n  &quot;value&quot;: &quot;MyEmail@domain.com&quot;\r\n}\r\n```\r\n\r\nWhen running `jq` against the following, I get the correct return:\r\n\r\n```\r\n$ jq -r &#39;. | select(.value==&quot;MyEmail@domain.com&quot;) .id&#39; sample.json\r\n366235941554\r\n```\r\n\r\nBut if I run with the incorrect case, eg.\r\n\r\n```\r\n$ jq -r &#39;. | select(.value==&quot;Myemail@domain.com&quot;) .id&#39; sample.json\r\n```\r\n\r\n...I do not get a result.  I&#39;ve read through some of the documentation but unfortunately, I do not understand the test/match/capture flags for insensitive search (https://stedolan.github.io/jq/manual/#RegularexpressionsPCRE) or how to get it to operate with this &quot;locate and give me the value&quot; request.\r\n\r\nI&#39;ve searched seemingly everywhere but I&#39;m unable to find any examples of this being used.",
        "link": "https://stackoverflow.com/questions/59969841/get-key-value-of-matching-case-insensitive-string",
        "title": "Get key value of matching case insensitive string"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "export-to-csv",
            "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": 1580323737,
                "post_id": 59973594,
                "comment_id": 106063668,
                "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": 1580323872,
                "post_id": 59973594,
                "comment_id": 106063732,
                "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": 1580323943,
                "post_id": 59973594,
                "comment_id": 106063756,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1580324666,
                "last_edit_date": 1580324666,
                "creation_date": 1580324335,
                "answer_id": 59973830,
                "question_id": 59973594,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A fixed version might look like:\r\n\r\n```\r\njq -rn &#39;\r\n# Assign the list of fields to a variable\r\n[&quot;NAME&quot;,&quot;NODE&quot;,&quot;SOURCE IP&quot;,&quot;SOURCE PORT&quot;,&quot;DESTINATION IP&quot;,&quot;DESTINATION PORT&quot;,&quot;GATEWAY IP&quot;,&quot;GATEWAY PORT&quot;] as $fields |\r\n(\r\n  $fields,                        # emit the list as a header\r\n  ($fields | map(length*&quot;-&quot;)),    # print separators below each header\r\n  (inputs | .[] | [.name, .node, .s_ip, .s_port, .d_ip, .d_port, .pif_ip, .pif_port])\r\n) | @tsv&#39; &lt;&lt;&lt;&quot;$s&quot; # where s is a string with your JSON content.\r\n```\r\n\r\n...which emits as output, for your input (without any reformatting to align the tabs):\r\n\r\n```none\r\nNAME\tNODE\tSOURCE IP\tSOURCE PORT\tDESTINATION IP\tDESTINATION PORT\tGATEWAY IP\tGATEWAY PORT\r\n----\t----\t---------\t-----------\t--------------\t----------------\t----------\t------------\r\nmike1\tc04\t10.244.7.235\t38558\t129.12.34.567\t22\t129.23.45.678\t11019\r\nfhlb-test\tc04\t10.244.7.20\t49846\t129.98.76.543\t22\t129.87.65.432\t23698\r\n```\r\n\r\nThe immediate bug was the inclusion of `.[]` in `(.[], map(length*&quot;-&quot;))` -- the first part of that is pointless, and does nothing but insert your map contents (which isn&#39;t valid in TSV content, not being a list) into the data stream.",
                "title": "jq &quot;object cannot be tsv-formatted, only array&quot; error when making table from json data"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1580330834,
        "creation_date": 1580323314,
        "last_edit_date": 1580330834,
        "question_id": 59973594,
        "body_markdown": "My script creates a json data set and then tries to present it as a table. \r\n\r\nIn the output for the first line of code, you can see an example data set:\r\n\r\n&gt; echo ${conn_list[@]} | jq &#39;.&#39;\r\n\r\n```\r\n{\r\n  &quot;host&quot;: {\r\n    &quot;name&quot;: &quot;mike1&quot;,\r\n    &quot;node&quot;: &quot;c04&quot;,\r\n    &quot;s_ip&quot;: &quot;10.244.7.235&quot;,\r\n    &quot;s_port&quot;: &quot;38558&quot;,\r\n    &quot;d_ip&quot;: &quot;129.12.34.567&quot;,\r\n    &quot;d_port&quot;: &quot;22&quot;,\r\n    &quot;pif_ip&quot;: &quot;129.23.45.678&quot;,\r\n    &quot;pif_port&quot;: &quot;11019&quot;\r\n  }\r\n}\r\n{\r\n  &quot;host&quot;: {\r\n    &quot;name&quot;: &quot;fhlb-test&quot;,\r\n    &quot;node&quot;: &quot;c04&quot;,\r\n    &quot;s_ip&quot;: &quot;10.244.7.20&quot;,\r\n    &quot;s_port&quot;: &quot;49846&quot;,\r\n    &quot;d_ip&quot;: &quot;129.98.76.543&quot;,\r\n    &quot;d_port&quot;: &quot;22&quot;,\r\n    &quot;pif_ip&quot;: &quot;129.87.65.432&quot;,\r\n    &quot;pif_port&quot;: &quot;23698&quot;\r\n  }\r\n}\r\n```\r\n\r\nI use the following jq command with @tsv to try to build and fill the table but run into this error:\r\n\r\n&gt; echo ${conn_list[@]} | jq -r &#39;[&quot;NAME&quot;,&quot;NODE&quot;,&quot;SOURCE IP&quot;,&quot;SOURCE PORT&quot;,&quot;DESTINATION IP&quot;,&quot;DESTINATION PORT&quot;,&quot;GATEWAY IP&quot;,&quot;GATEWAY PORT&quot;], (.[], map(length*&quot;-&quot;)), (.[] | [.name, .node, .s_ip, .s_port, .d_ip, .d_port, .pif_ip, .pif_port]) | @tsv&#39;\r\n\r\n```\r\nNAME    NODE    SOURCE IP       SOURCE PORT     DESTINATION IP  DESTINATION PORT        GATEWAY IP      GATEWAY PORT\r\njq: error (at &lt;stdin&gt;:1): object ({&quot;name&quot;:&quot;mi...) cannot be tsv-formatted, only array\r\nNAME    NODE    SOURCE IP       SOURCE PORT     DESTINATION IP  DESTINATION PORT        GATEWAY IP      GATEWAY PORT\r\njq: error (at &lt;stdin&gt;:1): object ({&quot;name&quot;:&quot;fh...) cannot be tsv-formatted, only array\r\n```\r\n\r\nMy goal is to have only one column title row in the table instead of one for each entry, and of course to display the data instead of the error. The &#39;(.[], map(length*&quot;-&quot;))&#39; bit is meant to automatically generate right size dashes to separate the column titles from the data. Anyone see what I&#39;m doing wrong? :) ",
        "link": "https://stackoverflow.com/questions/59973594/jq-object-cannot-be-tsv-formatted-only-array-error-when-making-table-from-jso",
        "title": "jq &quot;object cannot be tsv-formatted, only array&quot; error when making table from json data"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1580329117,
                "creation_date": 1580329117,
                "answer_id": 59974947,
                "question_id": 59974811,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to perform the conversion on all the objects you don&#39;t need to specify every one of them; following should do the trick.\r\n```\r\nmap_values(if type == &quot;object&quot; then to_entries else . end)\r\n```\r\n&lt;sup&gt;[REPL demo](https://jqplay.org/s/jSO7M1gpOa)&lt;/sup&gt;",
                "title": "Convert objects to arrays of key-value pairs"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1580330503,
                "creation_date": 1580330503,
                "answer_id": 59975251,
                "question_id": 59974811,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your initial filter can be shortened to\r\n\r\n    (.userAgent |= to_entries) |\r\n    (.userKeyDetails |= to_entries) | \r\n    (.params |= to_entries) | \r\n    (.httpReq |= to_entries)\r\n\r\nand we can abstract the common behavior to a function:\r\n\r\n    def f(key):\r\n      .[key] |= to_entries\r\n    ;\r\n    f(&quot;userAgent&quot;) | f(&quot;userKeyDetails&quot;) | f(&quot;params&quot;) | f(&quot;httpReq&quot;)\r\n\r\nNow we just need to update `f` so that it doesn&#39;t fail if the requested key doesn&#39;t exist. To do that, we can replace `.` with `select(has(key))`.\r\n\r\n&lt;pre&gt;&lt;code&gt;def f(key):\r\n    &lt;b&gt;select(has(key))&lt;/b&gt;[key] |= to_entries\r\n;\r\nf(&quot;userAgent&quot;) | f(&quot;userKeyDetails&quot;) | f(&quot;params&quot;) | f(&quot;httpReq&quot;)&lt;/code&gt;&lt;/pre&gt;",
                "title": "Convert objects to arrays of key-value pairs"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1580331174,
        "creation_date": 1580328463,
        "last_edit_date": 1580331174,
        "question_id": 59974811,
        "body_markdown": "I have a file where every line is a json (not formatted) as follows:\r\n```\r\n{\r\n  &quot;callID&quot;: &quot;xxxxxxxxxxxxxx&quot;,\r\n  &quot;authType&quot;: &quot;xxxxxxxxxxxxxx&quot;,\r\n  &quot;timestamp&quot;: &quot;xxxxxxxxxxxxxx&quot;,\r\n  &quot;errCode&quot;: &quot;0&quot;,\r\n  &quot;errMessage&quot;: &quot;xxxxxxxxxxxxxx&quot;,\r\n  &quot;endpoint&quot;: &quot;xxxxxxxxxxxxxx&quot;,\r\n  &quot;userKey&quot;: &quot;xxxxxxxxxxxxxx&quot;,\r\n  &quot;httpReq&quot;: {\r\n    &quot;key1&quot;: &quot;value1&quot;,\r\n    &quot;key2&quot;: &quot;value2&quot;,\r\n    &quot;key3&quot;: &quot;value3&quot;\r\n  },\r\n  &quot;ip&quot;: &quot;xxxxxxxxxxxxxx&quot;,\r\n  &quot;params&quot;: {\r\n    &quot;key1&quot;: &quot;value1&quot;,\r\n    &quot;key2&quot;: &quot;value2&quot;,\r\n    &quot;key3&quot;: &quot;value3&quot;\r\n  },\r\n  &quot;uid&quot;: &quot;xxxxxxxxxxxxxx&quot;,\r\n  &quot;apikey&quot;: &quot;xxxxxxxxxxxxxx&quot;,\r\n  &quot;userAgent&quot;: {\r\n    &quot;key1&quot;: &quot;value1&quot;,\r\n    &quot;key2&quot;: &quot;value2&quot;,\r\n    &quot;key3&quot;: &quot;value3&quot;\r\n  },\r\n  &quot;userKeyDetails&quot;: {\r\n    &quot;name&quot;: &quot;xxxxxxxxxxxxxx&quot;\r\n  }\r\n}\r\n```\r\n\r\nI need to perform a conversion where every object (`httpReq`, `params`, `userAgent`, `userKeyDetails`) need to be converted as array of objects, with `key` and `value` properties. Every key is not mandatory, a single json may NOT have all given keys.\r\n\r\nHere is a partial output of the structure:\r\n```\r\n{\r\n  &quot;httpReq&quot;: [\r\n    {\r\n      &quot;key&quot;: &quot;key1&quot;,\r\n      &quot;value&quot;: &quot;value1&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;key2&quot;,\r\n      &quot;value&quot;: &quot;value2&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nUsing `jq` command line I understand that `to_entries` operator is the one I&#39;m looking for, so I created this command\r\n```\r\ncat test.json | jq -c &#39;.userAgent = (.userAgent | to_entries) | .userKeyDetails = (.userKeyDetails | to_entries) | .params = (.params | to_entries) | .httpReq= (.\r\nhttpReq | to_entries)&#39; &gt; out.json\r\n```\r\nIt works, but it&#39;s failing on rows where one of the given key is missing, with following error:\r\n```\r\njq: error (at &lt;stdin&gt;:2): null (null) has no keys\r\njq: error (at &lt;stdin&gt;:3): null (null) has no keys\r\njq: error (at &lt;stdin&gt;:4): null (null) has no keys\r\njq: error (at &lt;stdin&gt;:5): null (null) has no keys\r\n```\r\n\r\nSo I need a selector which works handling the possibility of a key to be missing, can this be obtained directly with a jq selector?",
        "link": "https://stackoverflow.com/questions/59974811/convert-objects-to-arrays-of-key-value-pairs",
        "title": "Convert objects to arrays of key-value pairs"
    },
    {
        "tags": [
            "json",
            "bash",
            "merge",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1580332763,
                "post_id": 59975714,
                "comment_id": 106067308,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7615814,
                    "reputation": 217,
                    "user_id": 8871635,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ca727dba7b14945b2a4d32ed44f67636?s=256&d=identicon&r=PG",
                    "display_name": "Abraham",
                    "link": "https://stackoverflow.com/users/8871635/abraham"
                },
                "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": 1580335164,
                "post_id": 59975714,
                "comment_id": 106068178,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7615814,
                    "reputation": 217,
                    "user_id": 8871635,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ca727dba7b14945b2a4d32ed44f67636?s=256&d=identicon&r=PG",
                    "display_name": "Abraham",
                    "link": "https://stackoverflow.com/users/8871635/abraham"
                },
                "reply_to_user": {
                    "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": 1580335585,
                "post_id": 59975714,
                "comment_id": 106068324,
                "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": 1580338267,
                "post_id": 59975714,
                "comment_id": 106069141,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7615814,
                    "reputation": 217,
                    "user_id": 8871635,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ca727dba7b14945b2a4d32ed44f67636?s=256&d=identicon&r=PG",
                    "display_name": "Abraham",
                    "link": "https://stackoverflow.com/users/8871635/abraham"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1580340133,
                "post_id": 59975714,
                "comment_id": 106069639,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1580350833,
                "last_edit_date": 1580350833,
                "creation_date": 1580349618,
                "answer_id": 59978113,
                "question_id": 59975714,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way, using slurp mode, which puts all the JSON files contents into a single array and then processes it by appending all the other object&#39;s messages to the first one in that array:\r\n\r\n    $  jq -s &#39;reduce .[1:][] as $m (.[0]; .messages += $m.messages)&#39; message_*.json\r\n    {\r\n      &quot;participants&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Person One&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Person Two&quot;\r\n        }\r\n      ],\r\n      &quot;messages&quot;: [\r\n        {\r\n          &quot;sender_name&quot;: &quot;Person One&quot;,\r\n          &quot;timestamp_ms&quot;: 2,\r\n          &quot;content&quot;: &quot;Text2.&quot;,\r\n          &quot;type&quot;: &quot;Generic&quot;\r\n        },\r\n        {\r\n          &quot;sender_name&quot;: &quot;Person Two&quot;,\r\n          &quot;timestamp_ms&quot;: 1,\r\n          &quot;content&quot;: &quot;Text1.&quot;,\r\n          &quot;type&quot;: &quot;Generic&quot;\r\n        },\r\n        {\r\n          &quot;sender_name&quot;: &quot;Person Two&quot;,\r\n          &quot;timestamp_ms&quot;: 4,\r\n          &quot;content&quot;: &quot;Text4.&quot;,\r\n          &quot;type&quot;: &quot;Generic&quot;\r\n        },\r\n        {\r\n          &quot;sender_name&quot;: &quot;Person One&quot;,\r\n          &quot;timestamp_ms&quot;: 3,\r\n          &quot;content&quot;: &quot;Text3.&quot;,\r\n          &quot;type&quot;: &quot;Generic&quot;\r\n        }\r\n      ],\r\n      &quot;title&quot;: &quot;Person One&quot;,\r\n      &quot;is_still_participant&quot;: true,\r\n      &quot;thread_type&quot;: &quot;Regular&quot;,\r\n      &quot;thread_path&quot;: &quot;inbox/SomeString&quot;\r\n    }",
                "title": "Concatenating one attribute of JSON from multiple into one file using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1580354055,
                "last_edit_date": 1580354055,
                "creation_date": 1580352406,
                "answer_id": 59978414,
                "question_id": 59975714,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one approach, which has the advantage of not requiring the -s option, which would consume more memory than necessary:\r\n\r\n    jq &#39;reduce inputs as $in (.;\r\n      .messages += $in.messages)\r\n    &#39; $(for i in $(seq 1 11); do echo message_$i.json ; done)\r\n\r\nNotice that in this case, jq should be invoked *without* the -n option.",
                "title": "Concatenating one attribute of JSON from multiple into one file using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1640041739,
                "creation_date": 1640041739,
                "answer_id": 70428992,
                "question_id": 59975714,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way using [spyql][1] together with jq:\r\n\r\n    $ jq -c . message_*.json | spyql -Oindent=2 &quot;SELECT first_agg(json-&gt;participants) AS participants, list_agg(json-&gt;messages) AS messages FROM json EXPLODE json-&gt;messages TO json&quot;\r\n\r\njq is transforming the jsons into json lines format (1 json per line) and then spyql outputs a single json with the first occurrence of participants and all occurrences of messages concatenated into a single array.\r\n\r\nDisclaimer: I am the author of spyql.\r\n\r\n\r\n  [1]: https://github.com/dcmoura/spyql",
                "title": "Concatenating one attribute of JSON from multiple into one file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1640041739,
        "creation_date": 1580332645,
        "last_edit_date": 1580355329,
        "question_id": 59975714,
        "body_markdown": "I have multiple JSON files that are of similar form, here are two examples:\r\n\r\nmessage_1.json\r\n```\r\n{\r\n  &quot;participants&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Person One&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Person Two&quot;\r\n    }\r\n  ],\r\n\r\n  &quot;messages&quot;: [\r\n    {\r\n      &quot;sender_name&quot;: &quot;Person One&quot;,\r\n      &quot;timestamp_ms&quot;: 0002,\r\n      &quot;content&quot;: &quot;Text2.&quot;,\r\n      &quot;type&quot;: &quot;Generic&quot;\r\n    },\r\n    {\r\n      &quot;sender_name&quot;: &quot;Person Two&quot;,\r\n      &quot;timestamp_ms&quot;: 0001,\r\n      &quot;content&quot;: &quot;Text1.&quot;,\r\n      &quot;type&quot;: &quot;Generic&quot;\r\n    }\r\n  ],\r\n  &quot;title&quot;: &quot;Person One&quot;,\r\n  &quot;is_still_participant&quot;: true,\r\n  &quot;thread_type&quot;: &quot;Regular&quot;,\r\n  &quot;thread_path&quot;: &quot;inbox/SomeString&quot;\r\n}\r\n```\r\nmessage_2.json\r\n```\r\n{\r\n  &quot;participants&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Person One&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Person Two&quot;\r\n    }\r\n  ],\r\n\r\n  &quot;messages&quot;: [\r\n    {\r\n      &quot;sender_name&quot;: &quot;Person Two&quot;,\r\n      &quot;timestamp_ms&quot;: 0004,\r\n      &quot;content&quot;: &quot;Text4.&quot;,\r\n      &quot;type&quot;: &quot;Generic&quot;\r\n    },\r\n    {\r\n      &quot;sender_name&quot;: &quot;Person One&quot;,\r\n      &quot;timestamp_ms&quot;: 0003,\r\n      &quot;content&quot;: &quot;Text3.&quot;,\r\n      &quot;type&quot;: &quot;Generic&quot;\r\n    }\r\n  ],\r\n  &quot;title&quot;: &quot;Person One&quot;,\r\n  &quot;is_still_participant&quot;: true,\r\n  &quot;thread_type&quot;: &quot;Regular&quot;,\r\n  &quot;thread_path&quot;: &quot;inbox/SomeString&quot;\r\n}\r\n```\r\n\r\n\r\nIs there a way I can use ```jq``` to merge the JSON files so that the ```messages``` attribute is concatenated (order doesn&#39;t matter) and the others are left alone?\r\n\r\nThe result from merging message_1.json and message_2.json would look like this:\r\n\r\nmessages.json\r\n```\r\n{\r\n  &quot;participants&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Person One&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Person Two&quot;\r\n    }\r\n  ],\r\n\r\n  &quot;messages&quot;: [\r\n    {\r\n      &quot;sender_name&quot;: &quot;Person One&quot;,\r\n      &quot;timestamp_ms&quot;: 0002,\r\n      &quot;content&quot;: &quot;Text2.&quot;,\r\n      &quot;type&quot;: &quot;Generic&quot;\r\n    },\r\n    {\r\n      &quot;sender_name&quot;: &quot;Person Two&quot;,\r\n      &quot;timestamp_ms&quot;: 0001,\r\n      &quot;content&quot;: &quot;Text1.&quot;,\r\n      &quot;type&quot;: &quot;Generic&quot;\r\n    },\r\n    {\r\n      &quot;sender_name&quot;: &quot;Person Two&quot;,\r\n      &quot;timestamp_ms&quot;: 0004,\r\n      &quot;content&quot;: &quot;Text4.&quot;,\r\n      &quot;type&quot;: &quot;Generic&quot;\r\n    },\r\n    {\r\n      &quot;sender_name&quot;: &quot;Person One&quot;,\r\n      &quot;timestamp_ms&quot;: 0003,\r\n      &quot;content&quot;: &quot;Text3.&quot;,\r\n      &quot;type&quot;: &quot;Generic&quot;\r\n    }\r\n  ],\r\n  &quot;title&quot;: &quot;Person One&quot;,\r\n  &quot;is_still_participant&quot;: true,\r\n  &quot;thread_type&quot;: &quot;Regular&quot;,\r\n  &quot;thread_path&quot;: &quot;inbox/SomeString&quot;\r\n}\r\n```\r\n\r\nI have 11 JSON files, message_1.json, ..., message_11.json. I would like to merge them all into one ```messages.json``` file of this form containing **all of the messages** across the JSON files. How can I do this using ```jq``` via bash?",
        "link": "https://stackoverflow.com/questions/59975714/concatenating-one-attribute-of-json-from-multiple-into-one-file-using-jq",
        "title": "Concatenating one attribute of JSON from multiple into one file using jq"
    },
    {
        "tags": [
            "json",
            "object",
            "key",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1580387574,
                "last_edit_date": 1580387574,
                "creation_date": 1580387268,
                "answer_id": 59986058,
                "question_id": 59985760,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Split `$regions` and `$kmskeys` by commas into two separate arrays, transpose them to pair each region with corresponding kms key and make objects out of them, then add them together to form a single object. E.g:\r\n```\r\n.builders[].region_kms_key_ids = (\r\n    [ $regions/&quot;,&quot;, $kmskeys/&quot;,&quot; ] | transpose | map({(.[0]):.[1]}) | add\r\n)\r\n```",
                "title": "jq - Create JSON object map from environment variables"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1580387574,
        "creation_date": 1580386257,
        "question_id": 59985760,
        "body_markdown": "I am using jq 1.5 and trying to pass two environment variables via jq to create a json object:\r\n\r\n```\r\nexport REGIONS=&quot;region1,region2&quot;\r\nexport KMS_KEYS=&quot;key1,key2&quot;\r\n```\r\n\r\ntest.json\r\n```\r\n{\r\n    &quot;builders&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;aws&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\nusing the following command:\r\n```\r\njq --arg regions $REGIONS --arg kmskeys $KMS_KEYS &#39;.builders[].region_kms_key_ids={$regions}&#39; test.json\r\n```\r\n\r\ncurrent outcome:\r\n```\r\n{\r\n  &quot;builders&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;aws&quot;,\r\n      &quot;region_kms_key_ids&quot;: {\r\n        &quot;regions&quot;: &quot;region1,region2&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\ndesired outcome:\r\n```\r\n{\r\n    &quot;builders&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;aws&quot;,\r\n      &quot;region_kms_key_ids&quot;: {\r\n        &quot;region1&quot;: &quot;key1&quot;,\r\n        &quot;region2&quot;: &quot;key2&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI&#39;m stuck on how to use my REGIONS variable content as the keys and KMS_KEYS variable as the values. Any advice would be appreciated",
        "link": "https://stackoverflow.com/questions/59985760/jq-create-json-object-map-from-environment-variables",
        "title": "jq - Create JSON object map from environment variables"
    },
    {
        "tags": [
            "bash",
            "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": 1580396158,
                "post_id": 59986903,
                "comment_id": 106090784,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6893347,
                    "reputation": 31,
                    "user_id": 5296058,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/eadc1855bfa3dfcc97eed10bba593acc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "XOR",
                    "link": "https://stackoverflow.com/users/5296058/xor"
                },
                "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": 1580454510,
                "post_id": 59986903,
                "comment_id": 106110005,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1580465841,
                "post_id": 59986903,
                "comment_id": 106114597,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1591362389,
                "last_edit_date": 1591362389,
                "creation_date": 1580400556,
                "answer_id": 59990075,
                "question_id": 59986903,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t give a separate filter to each `--arg` option; it just defines *a* variable which can be used in the *single* filter argument. You just want to add new object to your input. `jq` doesn&#39;t do in-place file editing, so you&#39;ll have to write to a temporary file and replace your original after the fact.\r\n\r\n\r\n    jq --arg transactionId &quot;$TRANSACTION_ID_METRIC&quot; \\\r\n       --arg name &quot;$REALPBPODDEFNAME&quot; \\\r\n       --arg lintruntime &quot;$Cloudlintruntime&quot; \\\r\n       --arg status &quot;$EXITCODE&quot; \\\r\n       --arg buildtime &quot;$totaltime&quot; \\\r\n       &#39;.ServiceData.ServiceInfo += [ {transactionID: $transactionId,\r\n                                       name: $name,\r\n                                       lintruntime: $lintruntime,\r\n                                       status: $status,\r\n                                       buildtime: $buildtime\r\n                                       }]&#39; \\\r\n        Test.json &gt; tmp.json &amp;&amp;\r\n     mv tmp.json Test.json\r\n\r\n\r\nHere&#39;s the same command, but using an array to store all the `--arg` options and a variable to store the filter so the command line is a little simpler. (You also don&#39;t need explicit line continuations inside an array definition.)\r\n\r\n    args=(\r\n       --arg transactionId &quot;$TRANSACTION_ID_METRIC&quot;\r\n       --arg name &quot;$REALPBPODDEFNAME&quot;\r\n       --arg lintruntime &quot;$Cloudlintruntime&quot;\r\n       --arg status &quot;$EXITCODE&quot;\r\n       --arg buildtime &quot;$totaltime&quot;\r\n    )\r\n\r\n    filter=&#39;.ServiceData.ServiceInfo += [\r\n        {\r\n          transactionID: $transactionId,\r\n          name: $name,\r\n          lintruntime: $lintruntime,\r\n          status: $status,\r\n          buildtime: $buildtime\r\n        }\r\n    ]&#39;\r\n\r\n    jq &quot;${args[@]}&quot; &quot;$filter&quot; Test.json &gt; tmp.json &amp;&amp; mv tmp.json Test.json",
                "title": "jq: create array of object in json and insert the new object each time bash scripts executes"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1591362389,
        "creation_date": 1580390135,
        "last_edit_date": 1580457901,
        "question_id": 59986903,
        "body_markdown": "I want to create valid json using jq in bash.\r\neach time when bash script will execute &quot;Add new element to existing JSON array&quot;  and if file is empty create new file.\r\n\r\nI am using following jq command to create my json (which is incomplete, please help me to complete it)\r\n\r\n```\r\n$jq -n -s &#39;{service: $ARGS.named}&#39; \\\r\n         --arg transcationId $TRANSACTION_ID_METRIC &#39;{&quot;transcationId&quot;:&quot;\\($transcationId)&quot;}&#39; \\\r\n         --arg name $REALPBPODDEFNAME &#39;{&quot;name &quot;:&quot;\\($name )&quot;}&#39;\\\r\n\t\t --arg lintruntime $Cloudlintruntime &#39;{&quot;lintruntime&quot;:&quot;\\($lintruntime)&quot;}&#39; \\\r\n         --arg status $EXITCODE &#39;{&quot;status&quot;:&quot;\\($status)&quot;}&#39; \\\r\n         --arg buildtime $totaltime &#39;{&quot;buildtime&quot;:&quot;\\($buildtime)&quot;}&#39; &gt;&gt; Test.json\r\n```\r\n\r\nwhich is producing output like \r\n```\r\n\r\n{\r\n  &quot;service&quot;: {\r\n    &quot;transcationId&quot;: &quot;12345&quot;,\r\n    &quot;name&quot;: &quot;sdsjkdjsk&quot;,\r\n    &quot;lintruntime&quot;: &quot;09&quot;,   \r\n    &quot;status&quot;: &quot;0&quot;,\r\n    &quot;buildtime&quot;: &quot;9876&quot;\r\n  }\r\n}\r\n{\r\n  &quot;service&quot;: {\r\n    &quot;transcationId&quot;: &quot;123457&quot;,\r\n    &quot;servicename&quot;: &quot;sdsjkdjsk&quot;,\r\n    &quot;lintruntime&quot;: &quot;09&quot;,   \r\n    &quot;status&quot;: &quot;0&quot;,\r\n    &quot;buildtime&quot;: &quot;9877&quot;\r\n  }\r\n}\r\n\r\n```\r\n\r\nbut I don&#39;t want output in this format \r\n\r\njson should be created first time like \r\n\r\nwhat should be jq command for  creating below jason\r\n\r\n```\r\n{ \r\n   &quot;ServiceData&quot;:{ \r\n      &quot;date&quot;:&quot;30/1/2020&quot;,\r\n      &quot;ServiceInfo&quot;:[ \r\n         { \r\n            &quot;transcationId&quot;:&quot;20200129T130718Z&quot;,\r\n            &quot;name&quot;:&quot;MyService&quot;,\r\n            &quot;lintruntime&quot;:&quot;178&quot;,\r\n            &quot;status&quot;:&quot;0&quot;,\r\n            &quot;buildtime&quot;:&quot;3298&quot;\r\n         }\r\n      ]\r\n   }\r\n}\r\n```\r\n\r\n\r\nand when I next time execute the bash script element should be added into the array like \r\n\r\nwhat is the jq command for getting json in this format \r\n```\r\n{ \r\n   &quot;ServiceData&quot;:{ \r\n      &quot;date&quot;:&quot;30/1/2020&quot;,\r\n      &quot;ServiceInfo&quot;:[ \r\n         { \r\n            &quot;transcationId&quot;:&quot;20200129T130718Z&quot;,\r\n            &quot;name&quot;:&quot;MyService&quot;,\r\n            &quot;lintruntime&quot;:&quot;16&quot;,\r\n            &quot;status&quot;:&quot;0&quot;,\r\n            &quot;buildtime&quot;:&quot;3256&quot;\r\n         },\r\n         { \r\n            &quot;transcationId&quot;:&quot;20200129T130717Z&quot;,\r\n            &quot;name&quot;:&quot;MyService&quot;,\r\n            &quot;lintruntime&quot;:&quot;16&quot;,\r\n            &quot;status&quot;:&quot;0&quot;,\r\n            &quot;buildtime&quot;:&quot;3256&quot;\r\n         }\r\n      ]\r\n   }\r\n}\r\n```\r\n\r\nalso I want &quot;date &quot; , &quot;service data&quot; , &quot;service info&quot;  \r\nfields in my json which are missing in my current one\r\n\r\n\r\n \r\n\r\n",
        "link": "https://stackoverflow.com/questions/59986903/jq-create-array-of-object-in-json-and-insert-the-new-object-each-time-bash-scri",
        "title": "jq: create array of object in json and insert the new object each time bash scripts executes"
    },
    {
        "tags": [
            "syntax",
            "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": 1580439227,
                "post_id": 59995900,
                "comment_id": 106106487,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1580439062,
                "last_edit_date": 1580439062,
                "creation_date": 1580426653,
                "answer_id": 59995993,
                "question_id": 59995900,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[This response answers the Q as originally posted.  Before the modification, the input was a stream of JSON objects.]\r\n\r\nThe reason you&#39;re seeing multiple outputs is that your input is a stream, and your filter is applied to each item in the stream.\r\n\r\nSo it looks like you should modify your filter, e.g.\r\n\r\n    .apple.color // empty\r\n\r\nRegarding the key &quot;apple-cider&quot; -- since it has a special character (&quot;-&quot;), you cannot use the abbreviated syntax.  Whichever version of jq you have, you can use the unabbreviated form: `.[&quot;apple-cider&quot;]`; you might also be able to use the form:\r\n\r\n    .&quot;apple-cider&quot;\r\n\r\n",
                "title": "JQ getting compile error response from query"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1580443309,
                "creation_date": 1580443309,
                "answer_id": 59997688,
                "question_id": 59995900,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "it worked with this command\r\n\r\n    jq -r &#39;.lambda.&quot;apple-cider&quot;[].type&#39; test.json ",
                "title": "JQ getting compile error response from query"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1580443309,
        "creation_date": 1580425992,
        "last_edit_date": 1580430757,
        "question_id": 59995900,
        "body_markdown": "I would like to ask for your guidance for newbie like me on testing query on a sample file. I&#39;m getting  compile error while testing it. Please advice on what is needed to adjust.\r\n\r\nJSON FILE --&gt; sample.json\r\n\r\n        {\r\n        &quot;lambda&quot;: {\r\n            &quot;apple&quot;: [\r\n                {\r\n                    &quot;type&quot;: &quot;fruit&quot;,\r\n                    &quot;color&quot;: &quot;red&quot;,\r\n                    &quot;shape&quot;: &quot;round&quot;,\r\n                    &quot;cron&quot;: &quot;0/10 * * * ? *&quot;\r\n                }\r\n            ],\r\n            &quot;orange&quot;: [\r\n                {\r\n                    &quot;type&quot;: &quot;fruit&quot;,\r\n                    &quot;color&quot;: &quot;orange&quot;,\r\n                    &quot;shape&quot;: &quot;round&quot;,\r\n                    &quot;cron&quot;: &quot;0/15 * * * ? *&quot;\r\n                }\r\n            ],\r\n            &quot;apple-cider&quot;: [\r\n                {\r\n                    &quot;type&quot;: &quot;juice&quot;,\r\n                    &quot;color&quot;: &quot;pink&quot;,\r\n                    &quot;shape&quot;: &quot;none&quot;,\r\n                    &quot;cron&quot;: &quot;0/30 * * * ? *&quot;\r\n                }\r\n            ]\r\n        }\r\n    }\r\n\r\nI&#39;m getting this *jq: 1 compile error* message when I tried to get data from **apple-cider**\r\n\r\n    # jq -r &quot;.lambda.&quot;apple-cider&quot;[].shape&quot; test.json\r\n    jq: error: cider/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .lambda.apple-cider[].shape\r\n    jq: 1 compile error",
        "link": "https://stackoverflow.com/questions/59995900/jq-getting-compile-error-response-from-query",
        "title": "JQ getting compile error response from query"
    },
    {
        "tags": [
            "json",
            "linux",
            "group-by",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1086939,
                    "reputation": 5297,
                    "user_id": 1082435,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dabf934f0410ba655b67db795b2e1ff8?s=256&d=identicon&r=PG",
                    "display_name": "wibeasley",
                    "link": "https://stackoverflow.com/users/1082435/wibeasley"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580510784,
                "post_id": 60011507,
                "comment_id": 106134631,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1580509165,
                "last_edit_date": 1580509165,
                "creation_date": 1580508387,
                "answer_id": 60011871,
                "question_id": 60011507,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    cat doc.json | jq &#39;[group_by(.clusterName)[] | { clusterName: .[0].clusterName, &quot;buckets&quot;: [.[] | { name: .name } ]}]&#39;\r\n\r\nShould do what you want.\r\nNow with an array around as well.",
                "title": "How to group by in jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1580525351,
                "creation_date": 1580525351,
                "answer_id": 60013574,
                "question_id": 60011507,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `map` makes for quite a tidy answer:\r\n\r\n```\r\ngroup_by(.clusterName)\r\n| map( {clusterName: .[0].clusterName,\r\n        buckets: map( {name} ) } )\r\n```",
                "title": "How to group by in jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1692616652,
                "creation_date": 1692616652,
                "answer_id": 76944795,
                "question_id": 60011507,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `map` and based on [peak](https://stackoverflow.com/a/60013574/1037626)&#39;s answer, I needed all the bucket names in an array:\r\n\r\n    jq &#39;group_by(.clusterName) | map( { clusterName : .[0].clusterName, buckets: [ .[].name ] } )&#39;\r\n\r\ngives:\r\n\r\n    [\r\n      {\r\n        &quot;clusterName&quot;: &quot;cluster1&quot;,\r\n        &quot;buckets&quot;: [\r\n          &quot;bucket1&quot;,\r\n          &quot;bucket2&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;clusterName&quot;: &quot;cluster2&quot;,\r\n        &quot;buckets&quot;: [\r\n          &quot;bucket3&quot;,\r\n          &quot;bucket4&quot;\r\n        ]\r\n      }\r\n    ]",
                "title": "How to group by in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 7,
        "last_activity_date": 1692616652,
        "creation_date": 1580506369,
        "last_edit_date": 1580525598,
        "question_id": 60011507,
        "body_markdown": "Here&#39;s the json document\r\n\r\n    [\r\n        {&quot;name&quot;: &quot;bucket1&quot;,&quot;clusterName&quot;:&quot;cluster1&quot;},\r\n        {&quot;name&quot;: &quot;bucket2&quot;,&quot;clusterName&quot;:&quot;cluster1&quot;},\r\n        {&quot;name&quot;: &quot;bucket3&quot;,&quot;clusterName&quot;:&quot;cluster2&quot;},\r\n        {&quot;name&quot;: &quot;bucket4&quot;,&quot;clusterName&quot;:&quot;cluster2&quot;}\r\n    ]\r\n\r\nAnd I want to convert it to\r\n\r\n    [\r\n    {&quot;clusterName&quot;: &quot;cluster1&quot;, buckets:[{&quot;name&quot;: &quot;bucket1&quot;}, {&quot;name&quot;: &quot;bucket2&quot;}]},\r\n    {&quot;clusterName&quot;: &quot;cluster2&quot;, buckets:[{&quot;name&quot;: &quot;bucket1&quot;}, {&quot;name&quot;: &quot;bucket2&quot;}]},\r\n    ]\r\n\r\nHow do I do that in jq?\r\n",
        "link": "https://stackoverflow.com/questions/60011507/how-to-group-by-in-jq",
        "title": "How to group by in jq?"
    },
    {
        "tags": [
            "python",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1580606131,
                "creation_date": 1580606131,
                "answer_id": 60022501,
                "question_id": 60022403,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    &gt;&gt;&gt; payload = &quot;{\\&quot;username\\&quot;: \\&quot;test\\&quot;, \\&quot;password\\&quot;: \\&quot;test\\&quot;}&quot;\r\n    &gt;&gt;&gt; q = json.loads(payload)\r\n    &gt;&gt;&gt; q[&#39;username&#39;]\r\n\r\nOutput: \r\n&#39;test&#39;",
                "title": "Parse simple python JSON output through command line using jq - &quot;cannot index string with string&quot;"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1580615761,
                "creation_date": 1580615761,
                "answer_id": 60023116,
                "question_id": 60022403,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could also use `fromjson`, e.g.:\r\n\r\n```\r\necho &#39;&quot;{\\&quot;username\\&quot;: \\&quot;test\\&quot;, \\&quot;password\\&quot;: \\&quot;test\\&quot;}&quot;&#39; | jq &#39;fromjson&#39;\r\n{\r\n  &quot;username&quot;: &quot;test&quot;,\r\n  &quot;password&quot;: &quot;test&quot;\r\n}\r\n```\r\n\r\n  ",
                "title": "Parse simple python JSON output through command line using jq - &quot;cannot index string with string&quot;"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1580706262,
                "creation_date": 1580706262,
                "answer_id": 60033348,
                "question_id": 60022403,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The string `&quot;{\\&quot;username\\&quot;: \\&quot;test\\&quot;, \\&quot;password\\&quot;: \\&quot;test\\&quot;}&quot;` is just a\r\nstring, not a valid json object.\r\nYou need to `decode` it before using it as a json oboject:\r\n\r\n**test.py**\r\n```\r\nimport json\r\npayload = &quot;{\\&quot;username\\&quot;: \\&quot;test\\&quot;, \\&quot;password\\&quot;: \\&quot;test\\&quot;}&quot;\r\njd = json.loads(payload)\r\nprint(json.dumps(jd))\r\n```\r\nThen the test script\r\n```\r\n#!/bin/bash\r\ncredentials=$(python test.py)\r\necho &quot;$credentials&quot;\r\necho &quot;$credentials&quot; | jq &#39;.&#39;\r\necho &quot;$credentials&quot; | jq -r &#39;.username&#39;\r\n```\r\nwill output\r\n```\r\n{&quot;username&quot;: &quot;test&quot;, &quot;password&quot;: &quot;test&quot;}\r\n{\r\n  &quot;password&quot;: &quot;test&quot;,\r\n  &quot;username&quot;: &quot;test&quot;\r\n}\r\ntest\r\n```\r\nAs a side note I wonder why your test command `echo $(credentials)` *does not* cause an error `credentials: command not found`.",
                "title": "Parse simple python JSON output through command line using jq - &quot;cannot index string with string&quot;"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1580706262,
        "creation_date": 1580604631,
        "last_edit_date": 1592644375,
        "question_id": 60022403,
        "body_markdown": "I&#39;ve been dancing around with this problem for a few hours and I haven&#39;t had any luck resolving it by looking up similar posts. Hopefully it&#39;s simple enough for a quick fix.\n\nEssentially, I have a python script that retrieves a secret, dumps it as a json object to stdout.\nThere is a bash script that calls this python script, retrieves the output from the script and is intended to parse the username and password from the json output for use.\n\nSimplified python code:\n```\n# test.py\npayload = response.payload.data.decode(&#39;UTF-8&#39;).replace(&#39;\\n&#39;, &#39;&#39;)\n# ^ equates to:\n# payload = &quot;{\\&quot;username: \\&quot;test\\&quot;, \\&quot;password\\&quot;: \\&quot;test\\&quot;}&quot;\nsys.stdout.write(json.dumps(payload))\n```\n\nSimplified bash code:\n```\n#!/bin/bash\ncredentials=$(python test.py)\necho $(credentials)\necho $(credentials) | jq .\necho $(credentials) | jq .username\n```\n\nOutput:\n```\n&quot;{\\&quot;username: \\&quot;test\\&quot;, \\&quot;password\\&quot;: \\&quot;test\\&quot;}&quot;                         # for echo #1\n&quot;{\\&quot;username: \\&quot;test\\&quot;, \\&quot;password\\&quot;: \\&quot;test\\&quot;}&quot;                         # for echo #2 with | jq .\njq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;username&quot;     # for echo #3\n```\n\nInstead of the error, I am expecting the third output to be:\n```\ntest\n```\n\n# UPDATE\nI was able to finally resolve this by doing something that feels a little hacky.\nThe modified bash code which fixes this issue is:\n```\n#!/bin/bash\ncredentials=$(python test.py | jq -r .)\necho $(credentials)\necho $(credentials) | jq .\necho $(credentials) | jq .username\n```",
        "link": "https://stackoverflow.com/questions/60022403/parse-simple-python-json-output-through-command-line-using-jq-cannot-index-st",
        "title": "Parse simple python JSON output through command line using jq - &quot;cannot index string with string&quot;"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580642076,
                "post_id": 60025451,
                "comment_id": 106157366,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1043994,
                    "reputation": 786,
                    "user_id": 10477460,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/32d94138611c4c0dbc6fd1a5ab438631?s=256&d=identicon&r=PG",
                    "display_name": "farp332",
                    "link": "https://stackoverflow.com/users/10477460/farp332"
                },
                "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": 1580642489,
                "post_id": 60025451,
                "comment_id": 106157445,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580642666,
                "post_id": 60025451,
                "comment_id": 106157485,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1043994,
                    "reputation": 786,
                    "user_id": 10477460,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/32d94138611c4c0dbc6fd1a5ab438631?s=256&d=identicon&r=PG",
                    "display_name": "farp332",
                    "link": "https://stackoverflow.com/users/10477460/farp332"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1580644654,
                "post_id": 60025451,
                "comment_id": 106157887,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1580743869,
                "last_edit_date": 1580743869,
                "creation_date": 1580672373,
                "answer_id": 60029845,
                "question_id": 60025451,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can accomplish the task with just one invocation of jq, and without using the shell&#39;s support for string interpolation, which is error-prone.  For example:\r\n\r\n\r\n    jq --arg group my_grup --arg region eu-west-2 --arg prefix ecsx &#39;\r\n      .containerDefinitions[0].logConfiguration.options\r\n        = {&quot;awslogs-group&quot;: $group,\r\n           &quot;awslog-region&quot;: $region,\r\n           &quot;awslogs-stream-prefix&quot;: $prefix}&#39; input.json\r\n\r\n\r\nYou can add .logDriver similarly (in the one invocation of jq).",
                "title": "Issue when creating AWS fargate task definition json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1580743869,
        "creation_date": 1580641487,
        "last_edit_date": 1580644767,
        "question_id": 60025451,
        "body_markdown": "I&#39;m trying to create a json file (task definiton for AWS fargate) using jq from my gitlab pipeline.\r\n\r\nI want to achieve this configuration building a block with &quot;logConfiguration&quot; and &quot;logDriver&quot;, see right below:\r\n```\r\n&quot;logConfiguration&quot;: {\r\n                &quot;logDriver&quot;: &quot;awslogs&quot;,\r\n                &quot;options&quot;: {\r\n                    &quot;awslogs-group&quot;: &quot;awslogs-wordpress&quot;,\r\n                    &quot;awslogs-region&quot;: &quot;us-west-2&quot;,\r\n                    &quot;awslogs-stream-prefix&quot;: &quot;awslogs-example&quot;\r\n                }\r\n            },\r\n```\r\n1) I have my initial json file below, where I introduce some values with commands on point #2:\r\n\r\n\r\n```\r\n{\r\n  &quot;family&quot;: &quot;&quot;,\r\n  &quot;networkMode&quot;: &quot;awsvpc&quot;,\r\n  &quot;executionRoleArn&quot;: &quot;arn:aws:iam::XXXXXXXXX:role/ecsTaskExecutionRole&quot;,\r\n  &quot;containerDefinitions&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;&quot;,\r\n      &quot;image&quot;: &quot;:&quot;,\r\n      &quot;portMappings&quot;: [\r\n        {\r\n          &quot;containerPort&quot;: 3091,\r\n          &quot;hostPort&quot;: 3091,\r\n          &quot;protocol&quot;: &quot;tcp&quot;\r\n        }\r\n      ],\r\n      &quot;essential&quot;: true\r\n    }\r\n  ],\r\n  &quot;requiresCompatibilities&quot;: [\r\n    &quot;FARGATE&quot;\r\n  ],\r\n  &quot;cpu&quot;: &quot;256&quot;,\r\n  &quot;memory&quot;: &quot;512&quot;\r\n}\r\n```\r\n\r\n2) When I do these commands with jq on my gitlab pipeline I achieve part of what I want, it seems fine, and I get the json on point #2.A but **I realized it output 3 times &quot;LogDriver&quot;** which is not right:\r\n\r\n\r\n\r\n```\r\njq &#39;.containerDefinitions[0].logConfiguration.options.&quot;awslogs-group&quot;=&quot;&#39;my_grup&#39;&quot;&#39; tmp_task &gt; ejm.json &amp;&amp;\r\njq &#39;.containerDefinitions[0].logConfiguration.options.&quot;awslogs-region&quot;=&quot;&#39;eu-west-2&#39;&quot;&#39; ejm.json &gt; tmp_task &amp;&amp;\r\njq &#39;.containerDefinitions[0].logConfiguration.options.&quot;awslogs-stream-prefix&quot;=&quot;&#39;ecsx&#39;&quot;&#39; tmp_task &gt; ejm.json\r\n```\r\n\r\n2.A)\r\n```\r\n{\r\n  &quot;family&quot;: &quot;my_branch&quot;,\r\n  &quot;networkMode&quot;: &quot;awsvpc&quot;,\r\n  &quot;executionRoleArn&quot;: &quot;arn:aws:iam::235907124541:role/ecsTaskExecutionRole&quot;,\r\n  &quot;containerDefinitions&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;&quot;,\r\n      &quot;image&quot;: &quot;:&quot;,\r\n      &quot;portMappings&quot;: [\r\n        {\r\n          &quot;containerPort&quot;: 3091,\r\n          &quot;hostPort&quot;: 3091,\r\n          &quot;protocol&quot;: &quot;tcp&quot;\r\n        }\r\n      ],\r\n      &quot;essential&quot;: true,\r\n      &quot;logConfiguration&quot;: {\r\n        &quot;options&quot;: {\r\n          &quot;awslogs-group&quot;: &quot;my_grup&quot;,\r\n          &quot;awslogs-region&quot;: &quot;eu-west-2&quot;,\r\n          &quot;awslogs-stream-prefix&quot;: &quot;ecsx&quot;\r\n        },\r\n        &quot;logDriver&quot;: &quot;awslogs&quot;\r\n      },\r\n      &quot;logDriver&quot;: &quot;awslogs&quot;\r\n    },\r\n    {\r\n      &quot;logConfiguration&quot;: {\r\n        &quot;logDriver&quot;: &quot;awslogs&quot;\r\n      }\r\n    }\r\n  ],\r\n  &quot;requiresCompatibilities&quot;: [\r\n    &quot;FARGATE&quot;\r\n  ],\r\n  &quot;cpu&quot;: &quot;256&quot;,\r\n  &quot;memory&quot;: &quot;512&quot;\r\n}\r\n```\r\n\r\nAs you can see on point #2.A above, the config &quot;logDriver&quot; is written few times, and when the task definition is created within AWS fargate no logs are available in CloudWatch, because it is not picking the &quot;logDriver&quot; configuration, yes there is a log group in CloudWatch, but neither stdout nor stderr is captured from the container because &quot;logDriver&quot; is not being correctly introduced in the json task.\r\n\r\nTHE RIGHT JSON TASK DEFINITION SHOULD BE AS THE ONE IN THE LINK BELOW.\r\n\r\nhttps://docs.aws.amazon.com/AmazonECS/latest/userguide/using_awslogs.html\r\n\r\nPotential solution is to understand how to correctly write into the json file, or if someone has a better idea of how to put this json task in a pipeline.\r\n\r\nLooking forward to get some ideas from you, and thanks a lot in advanced.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60025451/issue-when-creating-aws-fargate-task-definition-json",
        "title": "Issue when creating AWS fargate task definition json"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 482148,
                    "reputation": 11662,
                    "user_id": 896358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df545d088c90710377af844a60d1f7ac?s=256&d=identicon&r=PG",
                    "display_name": "ROOT",
                    "link": "https://stackoverflow.com/users/896358/root"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580755529,
                "post_id": 60045218,
                "comment_id": 106193976,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580755597,
                "post_id": 60045218,
                "comment_id": 106193994,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1580755675,
                "creation_date": 1580755675,
                "answer_id": 60045346,
                "question_id": 60045218,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**The solution is the following:**\r\n\r\n    {&quot;buckets&quot;:.}\r\n\r\n**In the Command line:**\r\n\r\n    jq &#39;{&quot;buckets&quot;:.}&#39;\r\n\r\nSee:https://jqplay.org/s/MJ-GoLOBX2 \r\n\r\n\r\n----------\r\n\r\n\r\nThere is more documentation available at:\r\n\r\nhttps://programminghistorian.org/en/lessons/json-and-jq#the-dot-\r\n\r\nAlso see the hints below [jqplay][1] at the bottom.\r\n\r\n\r\n  [1]: https://jqplay.org/s/MJ-GoLOBX2",
                "title": "How to jq to copy array inside the dictionary?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1580755745,
        "creation_date": 1580755129,
        "last_edit_date": 1580755745,
        "question_id": 60045218,
        "body_markdown": "I have the following json\r\n\r\n       [ \r\n           { \r\n              &quot;name&quot;:&quot;bucket1&quot;\r\n           },\r\n           { \r\n              &quot;name&quot;:&quot;bucket1&quot;\r\n           }\r\n        ]\r\nI want to convert it to\r\n\r\n    { \r\n       &quot;buckets&quot;:[ \r\n          { \r\n             &quot;name&quot;:&quot;bucket1&quot;\r\n          },\r\n          { \r\n             &quot;name&quot;:&quot;bucket1&quot;\r\n          }\r\n       ]\r\n    }\r\n\r\nHow do I do this with jq?\r\n",
        "link": "https://stackoverflow.com/questions/60045218/how-to-jq-to-copy-array-inside-the-dictionary",
        "title": "How to jq to copy array inside the dictionary?"
    },
    {
        "tags": [
            "json",
            "yaml",
            "jq",
            "home-assistant"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1580757427,
                "post_id": 60045283,
                "comment_id": 106194819,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17680700,
                    "reputation": 11,
                    "user_id": 12834709,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fc903c6a8e5989859fda5d596ae2e000?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "TheStigh",
                    "link": "https://stackoverflow.com/users/12834709/thestigh"
                },
                "reply_to_user": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580763188,
                "post_id": 60045283,
                "comment_id": 106197411,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1580757709,
                "creation_date": 1580757709,
                "answer_id": 60045829,
                "question_id": 60045283,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A solution to your problem using `awk` and `date` command:\r\n\r\n    awk -v ref=$(date &quot;+%s&quot; -d &quot;3 days ago&quot;) &#39;\r\n        /^- date: /{t=mktime(gensub(/[-&quot;T:]|\\.[0-9+:&quot;]*/,&quot; &quot;,&quot;G&quot;,$3));} t&gt;ref&#39; file\r\n\r\nThis relies on awk `mktime` function that converts the string date into the unix timestamp.  \r\nThe `gensub` function formats the date into the format needed by `mktime`.\r\n\r\nThe variable `ref` is set to the date reference given by the `date` command.\r\n\r\n    ",
                "title": "Trying to find date based on jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1580768320,
                "last_edit_date": 1580768320,
                "creation_date": 1580758098,
                "answer_id": 60045907,
                "question_id": 60045283,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input, using the Python-based yq (https://kislyuk.github.io/yq):\r\n\r\n```\r\nyq &#39;.[].date&#39; \r\n```\r\nproduces:\r\n``` \r\n&quot;2019-12-10T03:00:01.313293+00:00&quot;\r\n&quot;2020-02-03T16:25:55.265219+00:00&quot;\r\n&quot;2020-02-03T15:00:11.584836+00:00&quot;\r\n&quot;2020-01-24T03:00:01.169351+00:00&quot;\r\n\r\n```\r\n\r\nYou can also run the (reverse) sorting and selection in the same run of yq, e.g.\r\n```\r\nyq &#39;map(.date) | sort | reverse[-2] | .[0:10]&#39; hassio.txt \r\n&quot;2020-01-24&quot;\r\n``` \r\n\r\n### Alternatives\r\n\r\n - yaml2json with jq\r\n\r\n  `yaml2json hassio.txt | jq &#39;map(.date) | sort | reverse[-2] | .[0:10]&#39;`\r\n\r\n - Go version of yq\r\n\r\n  `yq r hassio.txt &#39;[*].date&#39;`\r\n\r\n  produces a listing of the &quot;date&quot; fields.\r\n",
                "title": "Trying to find date based on jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1580768426,
                "creation_date": 1580768426,
                "answer_id": 60047964,
                "question_id": 60045283,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an only-jq solution, which of course comes with the kinds of caveats as any proposed solution that views that YAML as text:\r\n\r\n```\r\n&lt; hassio.txt jq -nR &#39;\r\n  [inputs | select(test(&quot;^- date&quot;)) | sub(&quot;.*date: &quot;;&quot;&quot;) | fromjson]\r\n  | sort | reverse[-2] | sub(&quot;\\\\..*&quot;;&quot;&quot;)&#39;\r\n&quot;2020-01-24T03:00:01&quot;\r\n```",
                "title": "Trying to find date based on jq"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1580768426,
        "creation_date": 1580755375,
        "last_edit_date": 1580767943,
        "question_id": 60045283,
        "body_markdown": "In Home Assistant CLI, running `hassio snapshots list`, the output is as below, where I&#39;m trying to locate the last date to keep in this output looking back 3 days (in the example list below this should be the date of 2020-01-24):\r\n\r\n    - date: &quot;2019-12-10T03:00:01.313293+00:00&quot;\r\n      name: Automated backup 2019-12-10 04:00\r\n      protected: false\r\n      slug: a0d3f958\r\n      type: full\r\n    - date: &quot;2020-02-03T16:25:55.265219+00:00&quot;\r\n      name: Automated backup 2020-02-03 17:25\r\n      protected: false\r\n      slug: acb7907b\r\n      type: full\r\n    - date: &quot;2020-02-03T15:00:11.584836+00:00&quot;\r\n      name: Automated backup 2020-02-03 16:00\r\n      protected: false\r\n      slug: 6284d707\r\n      type: full\r\n    - date: &quot;2020-01-24T03:00:01.169351+00:00&quot;\r\n      name: Automated backup 2020-01-24 04:00\r\n      protected: false\r\n      slug: 53d10566\r\n      type: full\r\n\r\n\r\n\r\nEarlier this worked, but there has been a change and I can&#39;t resolve what is wrong now:\r\n\r\n    last_date_to_keep=$(hassio snapshots list | jq .data.snapshots[].date | sort -r | head -n &quot;3&quot; | tail -n 1 | xargs date -D &quot;%Y-%m-%dT%T&quot; +%s --date )\r\n\r\nThe output is:\r\n\r\n    zsh: no matches found: .data.snapshots[].date\r\n    date: option requires an argument: date\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60045283/trying-to-find-date-based-on-jq",
        "title": "Trying to find date based on jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580800560,
                "post_id": 60052195,
                "comment_id": 106206838,
                "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": 1580810669,
                "post_id": 60052195,
                "comment_id": 106211510,
                "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": 1580810676,
                "post_id": 60052195,
                "comment_id": 106211516,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6900354,
                    "reputation": 422,
                    "user_id": 5300197,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/ce50562935fa552cf9f4d18397178c1a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "sergei",
                    "link": "https://stackoverflow.com/users/5300197/sergei"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581090167,
                "post_id": 60052195,
                "comment_id": 106325254,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1580825297,
                "last_edit_date": 1580825297,
                "creation_date": 1580824243,
                "answer_id": 60058855,
                "question_id": 60052195,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "yes, when you assign to an array, bash has to escape all its special characters and then split the arguments with the default separator, which is space. There&#39;s no matter of quoting of arguments or spaces per se in the source JSON that would help here.\r\n\r\nThus, to work-around that you&#39;d need to set `IFS` to the delimiter which is unique enough for your JSON data - for the sake of the example, let it be comma (assuming your JSON is in `curl.json` for brevity):\r\n```\r\nbash $ ifs=&quot;$IFS&quot;; IFS=&#39;,&#39;; array=($(&lt;curl.json jq -r &#39;[.id, .status] | @csv&#39;)); IFS=&quot;$ifs&quot;\r\nbash $ echo ${#array[@]}\r\n2\r\nbash $ echo ${array[1]}\r\n&quot;In Queue&quot;\r\nbash $ \r\n```",
                "title": "Assign jq output to bash array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1580825297,
        "creation_date": 1580799920,
        "last_edit_date": 1580801716,
        "question_id": 60052195,
        "body_markdown": "I have a problem to assign value to bash array correctly which was parsed by `jq`. I have a JSON output from `curl`: \r\n\r\n    {\r\n      &quot;id&quot;: 6442,\r\n      &quot;name&quot;: &quot;Execute Workflow&quot;,\r\n      &quot;description&quot;: &quot;Plan: data&quot;,\r\n      &quot;status&quot;: &quot;In Queue&quot;,\r\n      &quot;start_date&quot;: 0,\r\n      &quot;end_date&quot;: 0,\r\n      &quot;job_type&quot;: &quot;Execute Workflow&quot;,\r\n      &quot;created_by_name&quot;: null,\r\n      &quot;creation_date&quot;: 1580762385615,\r\n      &quot;creation_date_str&quot;: &quot;02/03/2020 09:39:45 PM&quot;,\r\n      &quot;last_updated_date&quot;: 1580762385615,\r\n      &quot;last_updated_date_str&quot;: &quot;02/03/2020 09:39:45 PM&quot;,\r\n      &quot;last_updated_by_name&quot;: null,\r\n      &quot;schedule_on&quot;: 0,\r\n      &quot;paused_at_step&quot;: 0,\r\n      &quot;percent_complete&quot;: 0,\r\n      &quot;job_action_type&quot;: null,\r\n      &quot;child_job_id&quot;: -1\r\n    }\r\n\r\nI want to save two key values `.id` and `.status` into bash array.\r\n\r\nI am doing it this way:\r\n\r\n    array=( $(echo &#39;{ &quot;id&quot;: 6442, &quot;name&quot;: &quot;Execute Workflow&quot;, &quot;description&quot;: &quot;Plan: data&quot;, &quot;status&quot;: &quot;In Queue&quot;, &quot;start_date&quot;: 0, &quot;end_date&quot;: 0, &quot;job_type&quot;: &quot;Execute Workflow&quot;, &quot;created_by_name&quot;: null, &quot;creation_date&quot;: 1580762385615, &quot;creation_date_str&quot;: &quot;02/03/2020 09:39:45 PM&quot;, &quot;last_updated_date&quot;: 1580762385615, &quot;last_updated_date_str&quot;: &quot;02/03/2020 09:39:45 PM&quot;, &quot;last_updated_by_name&quot;: null, &quot;schedule_on&quot;: 0, &quot;paused_at_step&quot;: 0, &quot;percent_complete&quot;: 0, &quot;job_action_type&quot;: null, &quot;child_job_id&quot;: -1}&#39; | jq &#39;.id, .status&#39;) ) \r\n\r\nAll seems OK until I try to get second element of that array: `echo ${array[1]}` and I get\r\n`&quot;In` not `&quot;In Queue&quot;`. \r\n\r\nMy array is 3 elements long `echo ${#array[@]}` returns `3` but I want it to be 2 elements long.\r\nCan someone help me please?\r\n\r\nMy next steps in bash script is to assign `job_status=&quot;=${array[1]}&quot;` and I want to get variable `job_status=&quot;In Queue&quot;`.",
        "link": "https://stackoverflow.com/questions/60052195/assign-jq-output-to-bash-array",
        "title": "Assign jq output to bash array"
    },
    {
        "tags": [
            "json",
            "bash",
            "iteration",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1580831115,
                "post_id": 60060802,
                "comment_id": 106223077,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1580831474,
                "last_edit_date": 1580831474,
                "creation_date": 1580831078,
                "answer_id": 60060906,
                "question_id": 60060802,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What about using the `-c` option:\r\n\r\n    $ jq -c &#39;.[]&#39; file | sed &#39;s/^/loop /&#39;\r\n\r\n&lt;!--IFS--&gt;\r\n\r\n    loop {&quot;foo1&quot;:&quot;bar1&quot;,&quot;baz1&quot;:&quot;fizz1&quot;}\r\n    loop {&quot;foo2&quot;:&quot;bar2&quot;,&quot;baz2&quot;:&quot;fizz2&quot;}",
                "title": "jq - iterate through dictionaries"
            },
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1580831167,
                "creation_date": 1580831167,
                "answer_id": 60060930,
                "question_id": 60060802,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "No need to use `bash`, you can do this in `jq` itself:\r\n\r\n    jq -r &#39;keys[] as $k | &quot;loop: \\(.[$k])&quot;&#39; file.json\r\n\r\n&lt;p/&gt;\r\n\r\n    loop: {&quot;foo1&quot;:&quot;bar1&quot;,&quot;baz1&quot;:&quot;fizz1&quot;}\r\n    loop: {&quot;foo2&quot;:&quot;bar2&quot;,&quot;baz2&quot;:&quot;fizz2&quot;}\r\n",
                "title": "jq - iterate through dictionaries"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1580833572,
                "last_edit_date": 1580833572,
                "creation_date": 1580831196,
                "answer_id": 60060939,
                "question_id": 60060802,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming **response** is a variable containing your data :\r\n\r\n    echo &quot;$response&quot; | jq --raw-output &#39;.[] | &quot;loop &quot; + tostring&#39;\r\n    loop {&quot;foo1&quot;:&quot;bar1&quot;,&quot;baz1&quot;:&quot;fizz1&quot;}\r\n    loop {&quot;foo2&quot;:&quot;bar2&quot;,&quot;baz2&quot;:&quot;fizz2&quot;}\r\n\r\nHope it helps!",
                "title": "jq - iterate through dictionaries"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1580889129,
        "creation_date": 1580830725,
        "last_edit_date": 1580889129,
        "question_id": 60060802,
        "body_markdown": "My json knowledge is shaky, so pardon me if I use the wrong terminology.\r\n\r\nI have `input.txt` which can be simplified down to this:\r\n\r\n    [\r\n      {\r\n        &quot;foo1&quot;: &quot;bar1&quot;,\r\n        &quot;baz1&quot;: &quot;fizz1&quot;\r\n      },\r\n      {\r\n        &quot;foo2&quot;: &quot;bar2&quot;,\r\n        &quot;baz2&quot;: &quot;fizz2&quot;\r\n      }\r\n    ]\r\n\r\nI want to iterate through each object via a loop, so I&#39;m essentially hoping to tackle just the 1&#39;s first, then loop through the 2&#39;s, etc. \r\n\r\nI thought it was something like:\r\n\r\n    jq &#39;keys[]&#39; input.json | while read key ; do\r\n        echo &quot;loop --$(jq &quot;[$key]&quot; input.json)&quot;\r\n    done\r\n\r\nbut that&#39;s giving me\r\n\r\n    loop 0\r\n    loop 1\r\n\r\nwhere I would expect to see (spacing here is optional, not sure how jq would parse it):\r\n\r\n    loop { &quot;foo1&quot;: &quot;bar1&quot;, &quot;baz1&quot;: &quot;fizz1&quot; }\r\n    loop { &quot;foo2&quot;: &quot;bar2&quot;, &quot;baz2&quot;: &quot;fizz2&quot; }\r\n\r\nWhat am I missing?",
        "link": "https://stackoverflow.com/questions/60060802/jq-iterate-through-dictionaries",
        "title": "jq - iterate through dictionaries"
    },
    {
        "tags": [
            "json",
            "templates",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1580835707,
                "last_edit_date": 1580835707,
                "creation_date": 1580835389,
                "answer_id": 60062118,
                "question_id": 60061905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `--argjson`; essentially, you are just going to ignore the attempt at parameterizing the JSON and simply replace the values unconditionally.\r\n\r\n    jq --argjson x &quot;$SUBSCRIPTION_ID&quot; \\\r\n       --argjson y &quot;$TOPIC_NAME&quot; \\\r\n       &#39;.parameters.subscriptionId.value = $x; .parameters.topicName.value = $y&#39; \\\r\n       config.json",
                "title": "Use jq to replace many values with variable values"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1627626032,
                "last_edit_date": 1627626032,
                "creation_date": 1580837301,
                "answer_id": 60062615,
                "question_id": 60061905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Export those variables so that you can access them from within jq.\r\n```\r\nexport SUBSCRIPTION_ID TOPIC_NAME\r\njq &#39;.parameters[].value |= (env[.[1:]] // .)&#39; file\r\n```\r\n`//.` part is for leaving variables absent in the environment as is, you can drop it if not necessary",
                "title": "Use jq to replace many values with variable values"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1580888966,
                "last_edit_date": 1580888966,
                "creation_date": 1580841360,
                "answer_id": 60063617,
                "question_id": 60061905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a &quot;data-driven&quot; approach based on the contents of the schema and the available environment variables:\r\n\r\n```\r\nexport SUBSCRIPTION_ID=&quot;abc-123&quot;\r\nexport TOPIC_NAME=&quot;SomeTopic&quot;\r\n\r\n&lt; schema.json jq &#39;.parameters \r\n    |= map_values(if .value | (startswith(&quot;$&quot;) and env[.[1:]]) \r\n                  then .value |= env[.[1:]] else . end)&#39;\r\n```\r\n\r\nNotice that none of the template names appear in the jq program.\r\n\r\nIf your shell supports it, you could avoid the &quot;export&quot; commands by prefacing the jq command with the variable assignments along the lines of:\r\n```\r\nSUBSCRIPTION_ID=&quot;abc-123&quot; TOPIC_NAME=&quot;SomeTopic&quot; jq -f program.jq schema.json\r\n```\r\n## Caveat\r\nUsing environment variables to pass in the parameter values may not be such a great idea.  Two alternatives would be to provide the name-value pairs in a text file or as a JSON object.  See also [Using jq as a template engine\r\n][1]\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/Cookbook#using-jq-as-a-template-engine",
                "title": "Use jq to replace many values with variable values"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 5,
        "last_activity_date": 1627626032,
        "creation_date": 1580834575,
        "last_edit_date": 1580843755,
        "question_id": 60061905,
        "body_markdown": "Using `jq`, is it possible to replace the value of each parameter in the sample JSON with the value of the variable that is the initial value?\r\n\r\nIn my scenario, Azure DevOps does not carryout any kind of variable substitution on the JSON file, so I need to do it manually. So for example, say `$SUBSCRIPTION_ID` is set to `abc-123`, I&#39;d like to use `jq` to update the JSON file.\r\n\r\nI can pull out the values using `.parameters[].value`, but I can&#39;t seem to find a way of setting each individual value.\r\n\r\nThe main challenge here is that the solution should be reusable, and different JSON files will have different `parameters`, so I don&#39;t think I can use `--argjson`.\r\n\r\n# Example\r\n\r\n### Original JSON\r\n\r\n    {\r\n        &quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2015-01-01/parametersTemplate.json#&quot;,\r\n        &quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n        &quot;parameters&quot;: {\r\n            &quot;subscriptionId&quot;: {\r\n                &quot;value&quot;: &quot;$SUBSCRIPTION_ID&quot;\r\n            },\r\n            &quot;topicName&quot;: {\r\n                &quot;value&quot;: &quot;$TOPIC_NAME&quot;\r\n            }\r\n        }\r\n    }\r\n\r\n### Variables\r\n\r\n    SUBSCRIPTION_ID=&quot;abc-123&quot;\r\n    TOPIC_NAME=&quot;SomeTopic&quot;\r\n\r\n### Desired JSON\r\n\r\n    {\r\n        &quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2015-01-01/parametersTemplate.json#&quot;,\r\n        &quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n        &quot;parameters&quot;: {\r\n            &quot;subscriptionId&quot;: {\r\n                &quot;value&quot;: &quot;abc-123&quot;\r\n            },\r\n            &quot;topicName&quot;: {\r\n                &quot;value&quot;: &quot;SomeTopic&quot;\r\n            }\r\n        }\r\n    }",
        "link": "https://stackoverflow.com/questions/60061905/use-jq-to-replace-many-values-with-variable-values",
        "title": "Use jq to replace many values with variable values"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1580899324,
                "creation_date": 1580899324,
                "answer_id": 60073977,
                "question_id": 60073976,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[This answer](https://stackoverflow.com/a/50745045/400068 &quot;modify nested JSON array with JQ&quot;) helped me in the right direction. The important learnings were to use `|=` in the right place, and have the filters wrapped in `if p then f else .` to keep the unchanged elements.\r\n\r\nThe following jq script solves the task:\r\n\r\n```\r\nmap(.name as $name |\r\n    if has(&quot;list&quot;)\r\n    then .list |= map(if .key | contains(&quot;keep&quot;) | not\r\n                      then .key = &quot;generated_value_for_&quot; + $name + &quot;_&quot; + .id\r\n                      else .\r\n                      end)\r\n    else .\r\n    end)\r\n```",
                "title": "How to use jq to selectively update JSON array, referring to parent properties"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1580900331,
        "creation_date": 1580899324,
        "last_edit_date": 1580900331,
        "question_id": 60073976,
        "body_markdown": "I&#39;m trying to use [jq](https://stedolan.github.io/jq/) to selectively change a single property of an object nested in an array, keeping the rest of the array intact. The generated property value needs to refer up to a property of the parent object.\r\n\r\nAs an example, take this array:\r\n\r\n``` lang-json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;keep_me&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;leave_unchanged&quot;,\r\n    &quot;list&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;1&quot;,\r\n        &quot;key&quot;: &quot;keep_this&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;a&quot;,\r\n    &quot;list&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;2&quot;,\r\n        &quot;key&quot;: &quot;also_keep_this&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;42&quot;,\r\n        &quot;key&quot;: &quot;replace_this&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI want to change the value of the last key (`replace_this`), using the `name` property of the parent object to generate a value like `generated_value_for_a_42`.\r\n\r\nThe key problem here seems to be leaving the rest of the array unmodified, while updating specific elements. But the need to refer &#39;up the tree&#39; to a parent property complicates matters.\r\nI tried wrapping changes in parentheses to keep untouched elements, but then had trouble with variable binding (using `as`) to the right scope, for accessing the parent property. So I either ended up discarding parts of the array or objects, or getting errors about the variable binding.",
        "link": "https://stackoverflow.com/questions/60073976/how-to-use-jq-to-selectively-update-json-array-referring-to-parent-properties",
        "title": "How to use jq to selectively update JSON array, referring to parent properties"
    },
    {
        "tags": [
            "shell",
            "curl",
            "jq",
            "apache-kafka-connect"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1580906608,
                "post_id": 60075893,
                "comment_id": 106250828,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1580906683,
                "post_id": 60075893,
                "comment_id": 106250867,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1580906957,
                "post_id": 60075893,
                "comment_id": 106250998,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1580906887,
                "creation_date": 1580906887,
                "answer_id": 60076210,
                "question_id": 60075893,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are abusing `\\`. Use:\r\n\r\n    curl -s &quot;http://localhost:8083/connectors&quot; | \r\n    jq &#39;.[]&#39; |\r\n    xargs -I mysql-connector curl -s &quot;http://localhost:8083/connectors/mysql-connector/status&quot; |\r\n    jq -c -M &#39;[.name,.connector.state,.tasks[].state] |\r\n    join(&quot;:|:&quot;)&#39; |\r\n    column -s : -t |\r\n    tr -d \\&quot; |\r\n    sort\r\n\r\nIt might be cleaner to put the `jq` all on one line, but the key point is that if you try to escape the newline inside single quotes, you end up with a literal backslash in the `jq` command that does not belong there.",
                "title": "jq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?) at &lt;top-level&gt;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1632231080,
        "creation_date": 1580905834,
        "last_edit_date": 1632231080,
        "question_id": 60075893,
        "body_markdown": "I was following this [link][1] to stream data from mysql to kafka topic in my ubuntu machine.  There, in \r\n**Kafka Connect setup** topic, when I run to check if my connectors are running with this(as suggested there):\r\n\r\n    curl -s &quot;http://localhost:8083/connectors&quot; | jq &#39;.[]&#39; | xargs -I mysql-connector curl -s &quot;http://localhost:8083/connectors/mysql-connector/status&quot; | jq -c -M &#39;[.name,.connector.state,.tasks[].state] | \\\r\n    join(&quot;:|:&quot;)&#39;| column -s : -t| sed &#39;s/\\&quot;//g&#39;| sort\r\n\r\nI got this error:\r\n\r\n&gt; jq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell\r\n&gt; quoting issues?) at &lt;top-level&gt;, line 1:\r\n&gt; [.name,.connector.state,.tasks[].state] | \\                           \r\n&gt; jq: 1 compile error (23) Failed writing body (23) Failed writing body\r\n\r\nI am totally stuck. Anyone please help if possible.&lt;br&gt;\r\n**N.B.:** This is not duplicate question, though question with similar headline exists but problem is different and I have checked them well.\r\n\r\n  [1]: https://rmoff.net/2018/03/24/streaming-data-from-mysql-into-kafka-with-kafka-connect-and-debezium/",
        "link": "https://stackoverflow.com/questions/60075893/jq-error-syntax-error-unexpected-invalid-character-unix-shell-quoting-issues",
        "title": "jq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?) at &lt;top-level&gt;"
    },
    {
        "tags": [
            "json",
            "linux",
            "group-by",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1580916973,
                "creation_date": 1580916973,
                "answer_id": 60079207,
                "question_id": 60078795,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following is a commented jq script. Feel free to use it as is, or strip out the newlines and comments and use it as is.\r\n```\r\n# First, we construct an object that maps each `$certname` to `{certname: $certname}`. We name it $init.\r\n\r\n(map({key:.certname, value: {certname}}) | unique | from_entries) as $init |\r\n\r\n# Next, we take each object of the input in turn (name it $attr) and assign its\r\n# `name:value` into one of the objects.\r\n# $init is the dictionary above\r\n# Reduce will pass the current dictionary as . for each invocation, and the assignment\r\n# returns the input object.\r\n\r\nreduce .[] as $attr ($init; .[$attr.certname][$attr.name] = $attr.value) |\r\n\r\n# Our initial dictionary has now been expanded with attributes.\r\n# Map it back to an array of objects. .[] is a stream of objects,\r\n# we capture that in an outer array.\r\n\r\n[.[]]",
                "title": "How to group by based on value in json using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1580967975,
        "creation_date": 1580915532,
        "last_edit_date": 1580967975,
        "question_id": 60078795,
        "body_markdown": "I have the following json\r\n\r\n    [\r\n          {\r\n            &quot;certname&quot;: &quot;server1&quot;,\r\n            &quot;environment&quot;: &quot;production&quot;,\r\n            &quot;name&quot;: &quot;memorysize&quot;,\r\n            &quot;value&quot;: &quot;62.76 GiB&quot;\r\n          },\r\n          {\r\n            &quot;certname&quot;: &quot;server1&quot;,\r\n            &quot;environment&quot;: &quot;production&quot;,\r\n            &quot;name&quot;: &quot;processorcount&quot;,\r\n            &quot;value&quot;: 12\r\n          },\r\n          {\r\n            &quot;certname&quot;: &quot;server2&quot;,\r\n            &quot;environment&quot;: &quot;production&quot;,\r\n            &quot;name&quot;: &quot;memorysize&quot;,\r\n            &quot;value&quot;: &quot;62.76 GiB&quot;\r\n          },\r\n          {\r\n            &quot;certname&quot;: &quot;server2&quot;,\r\n            &quot;environment&quot;: &quot;production&quot;,\r\n            &quot;name&quot;: &quot;processorcount&quot;,\r\n            &quot;value&quot;: 10\r\n          }\r\n        ]\r\n    \r\nAnd I want to convert to this format where it&#39;s grouped by the certname. The challenge is I need to use value for to make it as the key as follow \r\n    \r\n        [\r\n          {\r\n            &quot;certname&quot;: &quot;server1&quot;,\r\n            &quot;memorysize&quot;: &quot;62.76 GiB&quot;,\r\n            &quot;processorcount&quot;: 12\r\n          },\r\n          {\r\n            &quot;certname&quot;: &quot;server2&quot;,\r\n            &quot;memorysize&quot;: &quot;62.76 GiB&quot;,\r\n            &quot;processorcount&quot;: 10\r\n          }\r\n        ]\r\n\r\nHow do I do this using jq? I have tried to_entries but it doesn&#39;t help either.\r\n\r\nThanks\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60078795/how-to-group-by-based-on-value-in-json-using-jq",
        "title": "How to group by based on value in json using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1732983,
                    "reputation": 24986,
                    "user_id": 1586174,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/4aa4d9e7b30a8bddace165e4c33abd85?s=256&d=identicon&r=PG",
                    "display_name": "Taplar",
                    "link": "https://stackoverflow.com/users/1586174/taplar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580917158,
                "post_id": 60079244,
                "comment_id": 106256893,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "reply_to_user": {
                    "account_id": 1732983,
                    "reputation": 24986,
                    "user_id": 1586174,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/4aa4d9e7b30a8bddace165e4c33abd85?s=256&d=identicon&r=PG",
                    "display_name": "Taplar",
                    "link": "https://stackoverflow.com/users/1586174/taplar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580921498,
                "post_id": 60079244,
                "comment_id": 106259457,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1732983,
                    "reputation": 24986,
                    "user_id": 1586174,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/4aa4d9e7b30a8bddace165e4c33abd85?s=256&d=identicon&r=PG",
                    "display_name": "Taplar",
                    "link": "https://stackoverflow.com/users/1586174/taplar"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580924148,
                "post_id": 60079244,
                "comment_id": 106260694,
                "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": 1580937233,
                "post_id": 60079244,
                "comment_id": 106266437,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1581417112,
                "last_edit_date": 1581417112,
                "creation_date": 1580918158,
                "answer_id": 60079554,
                "question_id": 60079244,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your current try has the following problems :\r\n\r\n- `jsonfile.json` isn&#39;t a command, so you can&#39;t use it as the first token of a command line. You could `cat jsonfile.json | jq ...`, but the prefered way to have `jq` work on a file is to use `jq &#39;command&#39; file`\r\n\r\n- you define a variable `a` in your shell, but you try to reference it inside a single-quoted string, which prevents the shell from expanding it to its actual value. A shell based solution is to use double-quotes to have the variable expanded, but it&#39;s preferable to define the variable in the context of `jq` itself, using a `--arg varname value` option\r\n\r\n- `09800214851900C3` isn&#39;t considered a &quot;simple, identifier-like key&quot; by `jq` (because it starts with a digit), so the standard way of accessing the value associated to this key (`.key`) doesn&#39;t work and you need to use `.&quot;09800214851900C3&quot;` or `.[&quot;09800214851900C3&quot;]` instead\r\n\r\nIn conclusion I believe you will want to use the following command :\r\n\r\n    jq --arg a 09800214851900C3 &#39;.[$a].label&#39; jsonfile.json",
                "title": "How to Parse / substitute value in jq for json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1581417112,
        "creation_date": 1580917096,
        "last_edit_date": 1580917150,
        "question_id": 60079244,
        "body_markdown": "How to parse / substitute value in jquery.\r\n\r\nJson file as below:\r\n\r\n```\r\n{\r\n  &quot;09800214851900C3&quot;: {\r\n    &quot;label&quot;: &quot;P7-R1-R16:S2&quot;,\r\n    &quot;name&quot;: &quot;Geist Upgradable rPDU&quot;,\r\n    &quot;state&quot;: &quot;normal&quot;,\r\n    &quot;order&quot;: 0,\r\n    &quot;type&quot;: &quot;i03&quot;,\r\n    &quot;snmpInstance&quot;: 1,\r\n    &quot;lifetimeEnergy&quot;: &quot;20155338&quot;,\r\n    &quot;outlet&quot;: {},\r\n    &quot;alarm&quot;: {\r\n      &quot;severity&quot;: &quot;&quot;,\r\n      &quot;state&quot;: &quot;none&quot;\r\n    },\r\n    &quot;layout&quot;: {\r\n      &quot;0&quot;: [\r\n        &quot;entity/total0&quot;,\r\n        &quot;entity/phase0&quot;,\r\n        &quot;entity/phase1&quot;,\r\n        &quot;entity/phase2&quot;\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI want to do like below, But this is not working. Any idea/leads on this will be appreciated.\r\n\r\n```\r\na=09800214851900C3\r\n\r\njsonfile.json | jq &#39;.${a}.label&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/60079244/how-to-parse-substitute-value-in-jq-for-json-file",
        "title": "How to Parse / substitute value in jq for json file"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580918761,
                "post_id": 60079530,
                "comment_id": 106257844,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8344031,
                    "reputation": 2835,
                    "user_id": 6268432,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/pnLBv.png?s=256",
                    "display_name": "Alex",
                    "link": "https://stackoverflow.com/users/6268432/alex"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580919139,
                "post_id": 60079530,
                "comment_id": 106258090,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580919806,
                "post_id": 60079530,
                "comment_id": 106258481,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1580930709,
                "creation_date": 1580930709,
                "answer_id": 60082792,
                "question_id": 60079530,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One possible solution would be to use jq in conjunction with `sponge`, e.g.\r\n\r\n    &lt; input.json jq &#39;.deleteMe[0]&#39; | sponge input.json\r\n\r\nThere are several other eminently reasonable solutions, depending in part on the detailed requirements, e.g.\r\n\r\n    &lt; input.json jq &#39;.deleteMe[]&#39; &gt; input.tmp &amp;&amp; mv input.tmp input.json\r\n",
                "title": "jq - delete parent without deleting children"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1580930709,
        "creation_date": 1580918120,
        "question_id": 60079530,
        "body_markdown": "Let&#39;s say `input.json` is:\r\n\r\n    {\r\n        &quot;useless&quot;: &quot;stuff&quot;,\r\n        &quot;deleteMe&quot;: [\r\n            {\r\n                &quot;foo&quot;: &quot;bar&quot;,\r\n                &quot;baz&quot;: &quot;fizz&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nI want it to look like\r\n\r\n    {\r\n        &quot;foo&quot;: &quot;bar&quot;,\r\n        &quot;baz&quot;: &quot;fizz&quot;\r\n    }\r\n\r\nIn other words, I want to delete the parent(s) but preserve the children. I&#39;m seeing a lot about `jq &#39;del()&#39;` but that seems to delete the children as well in my testing. If I knew all the names of the child elements I could extract them into a new object, but the list of keys varies so I&#39;m hoping for a more global approach. How do I remove everything but the children?",
        "link": "https://stackoverflow.com/questions/60079530/jq-delete-parent-without-deleting-children",
        "title": "jq - delete parent without deleting children"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580921923,
                "post_id": 60080554,
                "comment_id": 106259648,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4482585,
                    "reputation": 383,
                    "user_id": 3646265,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b788306af3e0d42ab5eab402d30d4c78?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "developthou",
                    "link": "https://stackoverflow.com/users/3646265/developthou"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580922554,
                "post_id": 60080554,
                "comment_id": 106259928,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 47502,
                    "reputation": 213658,
                    "user_id": 140750,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/4c7af12cad08c95bc206a9636d164224?s=256&d=identicon&r=PG",
                    "display_name": "William Pursell",
                    "link": "https://stackoverflow.com/users/140750/william-pursell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580924280,
                "post_id": 60080554,
                "comment_id": 106260763,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12678745,
                    "reputation": 5869,
                    "user_id": 9213345,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/qmZfB.png?s=256",
                    "display_name": "Henke",
                    "link": "https://stackoverflow.com/users/9213345/henke"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615112664,
                "post_id": 60080554,
                "comment_id": 117586039,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4482585,
                    "reputation": 383,
                    "user_id": 3646265,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b788306af3e0d42ab5eab402d30d4c78?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "developthou",
                    "link": "https://stackoverflow.com/users/3646265/developthou"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1615300196,
                "post_id": 60080554,
                "comment_id": 117644387,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1580928921,
                "last_edit_date": 1580928921,
                "creation_date": 1580924589,
                "answer_id": 60081326,
                "question_id": 60080554,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A solution using `jq`:\r\n\r\n    &lt;file1 jq --slurpfile f file2 &#39;\r\n      {\r\n         clusterName:.[].clusterName,\r\n         nodes:map($f[],.nodes)|add|group_by(.hostname)|map(add)\r\n      }&#39;\r\n\r\nThis build an object using both files.   \r\nThe first field `clusterName` is taken from same field of the second file.  \r\nThe second field `nodes` is the combination of objects of both based on `hostname` (done with `group_by` command)\r\n\r\n--- \r\n*A tentative answer to the below comment:*  \r\nI don&#39;t think that `-s` has any advantages here since you need both files in memory (instead of 1 with `--slurpfile`).   \r\nIn order not to play with indexes, the idea is to test if the field exists or not before using it. You can do this with `?` and `//` operator. Together they from a sort of `if not ... then ...`.\r\nHere is a possible solution:\r\n\r\n    jq -s &#39;{\r\n       clusterName:(.[][].clusterName?//empty),\r\n       nodes:map(.[].nodes[]?//.[])|group_by(.hostname)|map(add)\r\n    }&#39; file1 file2\r\n\r\nAs you can see, the difficulty in both scripts is to &quot;normalize&quot; the objects in order to perform the `group_by` operation.",
                "title": "How to join json files using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1580950956,
                "creation_date": 1580950956,
                "answer_id": 60086292,
                "question_id": 60080554,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I accomplished this using python instead\r\n\r\n```\r\nfor cluster in clusters:\r\n    for node in cluster[&quot;nodes&quot;]:\r\n        node.update(list(filter(lambda nodes: nodes[&#39;hostname&#39;] == node[&#39;hostname&#39;],nodes))[0])\r\n```",
                "title": "How to join json files using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1580960006,
                "last_edit_date": 1580960006,
                "creation_date": 1580959644,
                "answer_id": 60087300,
                "question_id": 60080554,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; the invocation looks more like cat file1 file2 | jq ...\r\n\r\nHere&#39;s a solution that assumes all the inputs are presented as a stream. This solution also avoids using the -s command-line option.\r\n\r\n```\r\ncat master.json hostnames.json | jq &#39;\r\n  # input: an array of objects, each with a &quot;nodes&quot; key\r\n  def mergeNode($node): \r\n    map(if .hostname == $node.hostname then . + $node else . end);\r\n  reduce inputs[] as $n (.; map_values( .nodes |= mergeNode($n) ))&#39;\r\n```\r\n\r\nNotice that the -n command-line option has NOT been specified. \r\n\r\nThis solution also allows more than one &quot;hostnames&quot; file.",
                "title": "How to join json files using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1615300163,
        "creation_date": 1580921587,
        "last_edit_date": 1615300163,
        "question_id": 60080554,
        "body_markdown": "I have the following json file\r\n\r\n    [\r\n      {\r\n        &quot;clusterName&quot;: &quot;cluster1&quot;,\r\n        &quot;nodes&quot;: [\r\n          {\r\n            &quot;hostname&quot;: &quot;server1&quot;,\r\n            &quot;dse&quot;: &quot;6.7.5&quot;\r\n          },\r\n          {\r\n            &quot;hostname&quot;: &quot;server2&quot;,\r\n            &quot;dse&quot;: &quot;6.7.5&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;clusterName&quot;: &quot;cluster2&quot;,\r\n        &quot;nodes&quot;: [\r\n          {\r\n            &quot;hostname&quot;: &quot;server3&quot;,\r\n            &quot;dse&quot;: &quot;6.7.5&quot;\r\n          },\r\n          {\r\n            &quot;hostname&quot;: &quot;server4&quot;,\r\n            &quot;dse&quot;: &quot;6.7.5&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nAnd I have another json\r\n\r\n    [\r\n      {\r\n        &quot;hostname&quot;: &quot;server1&quot;,\r\n        &quot;memorysize&quot;: &quot;47.01 GiB&quot;,\r\n        &quot;processorcount&quot;: 12\r\n      },\r\n      {\r\n        &quot;hostname&quot;: &quot;server2&quot;,\r\n        &quot;memorysize&quot;: &quot;47.01 GiB&quot;,\r\n        &quot;processorcount&quot;: 12\r\n      },\r\n      {\r\n        &quot;hostname&quot;: &quot;server3&quot;,\r\n        &quot;memorysize&quot;: &quot;47.01 GiB&quot;,\r\n        &quot;processorcount&quot;: 10\r\n      },\r\n      {\r\n        &quot;hostname&quot;: &quot;server4&quot;,\r\n        &quot;memorysize&quot;: &quot;47.01 GiB&quot;,\r\n        &quot;processorcount&quot;: 11\r\n      },\r\n      {\r\n        &quot;hostname&quot;: &quot;server5&quot;,\r\n        &quot;memorysize&quot;: &quot;47.01 GiB&quot;,\r\n        &quot;processorcount&quot;: 12\r\n      },\r\n      {\r\n        &quot;hostname&quot;: &quot;server6&quot;,\r\n        &quot;memorysize&quot;: &quot;47.01 GiB&quot;,\r\n        &quot;processorcount&quot;: 12\r\n      }\r\n    ]\r\n\r\nI want to join these two jsons to produce the following output\r\n\r\n    [\r\n      {\r\n        &quot;clusterName&quot;: &quot;cluster1&quot;,\r\n        &quot;nodes&quot;: [\r\n          {\r\n            &quot;hostname&quot;: &quot;server1&quot;,\r\n            &quot;dse&quot;: &quot;6.7.5&quot;,\r\n            &quot;memorysize&quot;: &quot;47.01 GiB&quot;,\r\n            &quot;processorcount&quot;: 12\r\n          },\r\n          {\r\n            &quot;hostname&quot;: &quot;server2&quot;,\r\n            &quot;dse&quot;: &quot;6.7.5&quot;,\r\n            &quot;memorysize&quot;: &quot;47.01 GiB&quot;,\r\n            &quot;processorcount&quot;: 12\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;clusterName&quot;: &quot;cluster2&quot;,\r\n        &quot;nodes&quot;: [\r\n          {\r\n            &quot;hostname&quot;: &quot;server3&quot;,\r\n            &quot;dse&quot;: &quot;6.7.5&quot;,\r\n            &quot;memorysize&quot;: &quot;47.01 GiB&quot;,\r\n            &quot;processorcount&quot;: 10\r\n          },\r\n          {\r\n            &quot;hostname&quot;: &quot;server4&quot;,\r\n            &quot;dse&quot;: &quot;6.7.5&quot;,\r\n            &quot;memorysize&quot;: &quot;47.01 GiB&quot;,\r\n            &quot;processorcount&quot;: 11\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nBasically the first file has the list of clusters dictionary. with nodes and I have a second file with the list of nodes dictionary.\r\n\r\nThe solution mentioned didn&#39;t work with multiple clusters.\r\n\r\nIs there a better to do this in python instead? \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60080554/how-to-join-json-files-using-jq",
        "title": "How to join json files using jq?"
    },
    {
        "tags": [
            "google-cloud-platform",
            "installation",
            "airflow",
            "jq",
            "google-cloud-composer"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9542433,
                    "reputation": 3923,
                    "user_id": 7090016,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/64279d834a2fcf469bfe78fbca3be073?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "aga",
                    "link": "https://stackoverflow.com/users/7090016/aga"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1580982581,
                "post_id": 60087392,
                "comment_id": 106279800,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8649320,
                    "reputation": 1097,
                    "user_id": 6475558,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://lh4.googleusercontent.com/-bfFEV0GSEdI/AAAAAAAAAAI/AAAAAAAAAz4/IbBPYX3h0II/s256-rj/photo.jpg",
                    "display_name": "Balajee Venkatesh",
                    "link": "https://stackoverflow.com/users/6475558/balajee-venkatesh"
                },
                "reply_to_user": {
                    "account_id": 9542433,
                    "reputation": 3923,
                    "user_id": 7090016,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/64279d834a2fcf469bfe78fbca3be073?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "aga",
                    "link": "https://stackoverflow.com/users/7090016/aga"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581004983,
                "post_id": 60087392,
                "comment_id": 106292985,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1581338721,
                "creation_date": 1581338721,
                "answer_id": 60150729,
                "question_id": 60087392,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Some Python libraries that implement bindings fail at runtime if the libraries don&#39;t exist on the system. `jq` fails at installation time (breaking the build) if the libraries are missing. This means it is incompatible with Cloud Composer, because getting shared libraries into the build environment is not currently supported.\r\n\r\nYou won&#39;t be able to install `jq` from `PyPI`, but you can still install it as a [local Python library][1]. Note that this will require you to install the shared libraries yourself in your `/dags` folder, or your `/plugins` folder, please refer to [documentation][2]. You will also need to set `LD_LIBRARY_PATH` to that directory (example: `/home/airflow/gcs/dags`), depending on which directory path you chose.\r\n\r\nI hope you find the above pieces of information useful.\r\n\r\n  [1]: https://cloud.google.com/composer/docs/how-to/using/installing-python-dependencies#install-local\r\n  [2]: https://cloud.google.com/composer/docs/concepts/cloud-storage",
                "title": "How to install jq in Cloud Composer environment"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1581338721,
        "creation_date": 1580960362,
        "last_edit_date": 1580989855,
        "question_id": 60087392,
        "body_markdown": "I&#39;m trying to install `jq` package in Cloud Composer environment but it is getting failed.\r\n\r\nhttps://pypi.org/project/jq/\r\n\r\nI understand that it requires some additional dependencies to get resolved. Is there any way to install those pieces (e.g. autoconf) in composer environment?",
        "link": "https://stackoverflow.com/questions/60087392/how-to-install-jq-in-cloud-composer-environment",
        "title": "How to install jq in Cloud Composer environment"
    },
    {
        "tags": [
            "json",
            "jq",
            "json-rpc"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1580982339,
                "last_edit_date": 1580982339,
                "creation_date": 1580982039,
                "answer_id": 60091828,
                "question_id": 60091657,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In `jq` you can use the alternate operator `//` that can be used to return default values. E.g. A filter of the form `a // b` produces the same results as `a`, if `a` produces results other than `false` and `null`. Otherwise, `a // b` produces the same results as `b`.\r\n\r\nAlso useful for providing defaults: `.foo // 1` will evaluate to `1` if there’s no `.foo` element in the input.\r\n\r\n\r\n    jq &#39;.result? // .error.data.message?&#39;\r\n\r\nNote that this will _only_ work when the the value of `.result` isn&#39;t `null` or `false` in which case also the execution goes the alternate condition.",
                "title": "json-rpc response jq filtering with multiple possible values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1580995888,
                "creation_date": 1580995888,
                "answer_id": 60096152,
                "question_id": 60091657,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In both cases, the result is a JSON object, so you could avoid the null/false issue that arises using // by checking whether the object has an &quot;error&quot; key, along the lines of:\r\n\r\n    if has(&quot;error&quot;) then ... else ... end\r\n\r\nOf course this approach can also incorporate the use of `//` and `?`, etc.",
                "title": "json-rpc response jq filtering with multiple possible values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1580999118,
        "creation_date": 1580981515,
        "last_edit_date": 1580999118,
        "question_id": 60091657,
        "body_markdown": "Can&#39;t figure how to filter jq output to show only result or error message from json-rpc response. Example response looks like this:\r\n\r\nNormal:\r\n\r\n    {\r\n      &quot;result&quot;: &quot;0001&quot;,\r\n      &quot;id&quot;: 1,\r\n      &quot;jsonrpc&quot;: &quot;2.0&quot;\r\n    }\r\n\r\nError:\r\n\r\n    {\r\n      &quot;error&quot;: {\r\n        &quot;code&quot;: -32000,\r\n        &quot;message&quot;: &quot;Server error&quot;,\r\n        &quot;data&quot;: {\r\n          &quot;type&quot;: &quot;TypeError&quot;,\r\n          &quot;args&quot;: [\r\n            &quot;&#39;NoneType&#39; object is not subscriptable&quot;\r\n          ],\r\n          &quot;message&quot;: &quot;&#39;NoneType&#39; object is not subscriptable&quot;\r\n        }\r\n      },\r\n      &quot;id&quot;: 1,\r\n      &quot;jsonrpc&quot;: &quot;2.0&quot;\r\n    }\r\n\r\nI can access both of them alone, but don&#39;t know how to get &#39;or&#39; function\r\n\r\n    $ ./reqok | jq .result\r\n    &quot;0001&quot;\r\n    $ ./reqbad | jq .error.data.message\r\n    &quot;&#39;NoneType&#39; object is not subscriptable&quot;\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60091657/json-rpc-response-jq-filtering-with-multiple-possible-values",
        "title": "json-rpc response jq filtering with multiple possible values"
    },
    {
        "tags": [
            "arrays",
            "file",
            "nested",
            "addition",
            "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": 1581001470,
                "post_id": 60097821,
                "comment_id": 106290794,
                "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": 1581099168,
                "post_id": 60097821,
                "comment_id": 106329611,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17703780,
                    "reputation": 11,
                    "user_id": 12852875,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mBVRvX0Alq7vl64X-FDmTqBN-gTk1aIdUlRuZXL=k-s256",
                    "display_name": "Daena Dreyfuss",
                    "link": "https://stackoverflow.com/users/12852875/daena-dreyfuss"
                },
                "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": 1581182410,
                "post_id": 60097821,
                "comment_id": 106348285,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1663592666,
                "creation_date": 1663592666,
                "answer_id": 73773793,
                "question_id": 60097821,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you only need to merge both arrays (and take all other property of `f1.json` as is):\r\n\r\n```\r\njq -s &#39;.[0].&quot;a.b&quot;.c += .[1].&quot;a.b&quot;.c | .[0]&#39; f1.json f2.json\r\n```\r\n\r\nThis will append array of f2 to the array of f1 and then select f1 only.\r\n\r\nIf your merging rules are more complex than outlined in your question, leave a comment and edit your question with clarification (and better example inputs).\r\n\r\n*****\r\n\r\nOr with using `--slurpfile`:\r\n\r\n```\r\njq --slurpfile f2 f2.json &#39;.&quot;a.b&quot;.c += $f2[0].&quot;a.b&quot;.c&#39; f1.json\r\n```\r\n\r\nThe idea is the same, but the input is only a single file, while the second file&#39;s content can be accessed via `$f2` in your filter.",
                "title": "JQ push data from 1 file into nested array in another file"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1663592768,
        "creation_date": 1581001033,
        "last_edit_date": 1663592768,
        "question_id": 60097821,
        "body_markdown": "I have 2 files:\r\n\r\n**f1.json**\r\n\r\n    {\r\n      &quot;a.b&quot;: {\r\n        &quot;c&quot;: [ 1, 2 ]\r\n      },\r\n      &quot;d&quot;: &quot;other data&quot;\r\n    }\r\n\r\n**f2.json**\r\n\r\n    {\r\n      &quot;a.b&quot;: {\r\n        &quot;c&quot;: [ 3, 4 ]\r\n      }\r\n    }\r\n\r\nAll details of the nested array in *f2.json* should be merged into *f1.json* as seen below\r\n\r\n**f1.json:**\r\n\r\n    {\r\n      &quot;a.b&quot;: {\r\n        &quot;c&quot;: [ 1, 2, 3, 4 ]\r\n      },\r\n      &quot;d&quot;: &quot;other data&quot;\r\n    }\r\n\r\nLocating the array in **f1.json**:\r\n\r\n    jq -s &#39;.[0][&quot;a.b&quot;].c f1.json\r\n\r\n\r\nAccessing the array in **f2.json** (as this is going to be a static file, we don&#39;t need to rely on the specific name of a.b):\r\n\r\n    jq .[].c f2.json",
        "link": "https://stackoverflow.com/questions/60097821/jq-push-data-from-1-file-into-nested-array-in-another-file",
        "title": "JQ push data from 1 file into nested array in another file"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 539738,
                    "reputation": 1425,
                    "user_id": 907692,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/5edb9493e0c164ca80b44c0d225c6b5a?s=256&d=identicon&r=PG",
                    "display_name": "igrek",
                    "link": "https://stackoverflow.com/users/907692/igrek"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581004012,
                "post_id": 60098468,
                "comment_id": 106292349,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17703901,
                    "reputation": 1,
                    "user_id": 12852983,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-o48yX3hYNMw/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3renb-rRW91M_-R0VrrIuF1c3QIqqw/s256-rj/photo.jpg",
                    "display_name": "jackemma",
                    "link": "https://stackoverflow.com/users/12852983/jackemma"
                },
                "reply_to_user": {
                    "account_id": 539738,
                    "reputation": 1425,
                    "user_id": 907692,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/5edb9493e0c164ca80b44c0d225c6b5a?s=256&d=identicon&r=PG",
                    "display_name": "igrek",
                    "link": "https://stackoverflow.com/users/907692/igrek"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581004874,
                "post_id": 60098468,
                "comment_id": 106292913,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1581007081,
                "post_id": 60098468,
                "comment_id": 106294313,
                "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": 1581048611,
                "post_id": 60098468,
                "comment_id": 106307441,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662829672,
                "last_edit_date": 1662829672,
                "creation_date": 1662026308,
                "answer_id": 73567484,
                "question_id": 60098468,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The straight-forward way would be to use the [`select` filter](https://stedolan.github.io/jq/manual/v1.6/#select(boolean_expression)) (either standalone on multiple values or with `map` on an array) and filter all objects matching your criterion (e.g. equal to `&quot;123456&quot;`) and then transform into your required output format (e.g. using string interpolation).\r\n\r\n```\r\njq -r &#39;.[]\r\n| select(.data.tls.result.handshake_log.server_certificates.certificate.parsed.unique_number==&quot;123456&quot;)\r\n| &quot;\\(.ip), \\(.data.tls.result.handshake_log.server_certificates.certificate.parsed.unique_number)&quot;&#39;\r\n```\r\n\r\nBecause the `unique_number` property is nested quite deeply and cumbersome to write twice, it makes sense to first transform your object into something simpler, then filter, and finally output in the desired format:\r\n\r\n```\r\njq -r &#39;.[]\r\n| { ip, unique_number: .data.tls.result.handshake_log.server_certificates.certificate.parsed.unique_number }\r\n| select(.unique_number==&quot;123456&quot;)\r\n| &quot;\\(.ip), \\(.unique_number)&quot;&#39;\r\n```\r\n\r\nAlternatively using `join`:\r\n\r\n```\r\n.[]\r\n| { ip, unique_number: .data.tls.result.handshake_log.server_certificates.certificate.parsed.unique_number }\r\n| select(.unique_number==&quot;123456&quot;)\r\n| [.ip, .unique_number]\r\n| join(&quot;, &quot;)\r\n```",
                "title": "Using jq to search value of a property and return another value"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1662829672,
        "creation_date": 1581002931,
        "question_id": 60098468,
        "body_markdown": "Sorry if this sounds too simple but I am still learning and have spent few hours to get a solution. I have a large json file and I would like to search a specific value from an object and return value from other object.\r\n\r\nExample, from the below data, I would like to search the json file for all objects that have value in unique_number that match &quot;123456&quot; and return this value along with the IP address. \r\njq should return something like - ```123456, 127.0.0.1```\r\nSince the file is going to be about 300 MB with many IP addresses will there be any performace issues?\r\n\r\nPartial json -\r\n```\r\n{\r\n  &quot;ip&quot;: &quot;127.0.0.1&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;tls&quot;: {\r\n      &quot;status&quot;: &quot;success&quot;,\r\n      &quot;protocol&quot;: &quot;tls&quot;,\r\n      &quot;result&quot;: {\r\n        &quot;handshake_log&quot;: {\r\n          &quot;server_hello&quot;: {\r\n            &quot;version&quot;: {\r\n              &quot;name&quot;: &quot;TLSv1.2&quot;,\r\n              &quot;value&quot;: 1111\r\n            },\r\n            &quot;random&quot;: &quot;dGVzdA==&quot;,\r\n            &quot;session_id&quot;: &quot;dGVzdA==&quot;,\r\n            &quot;cipher_suite&quot;: {\r\n              &quot;name&quot;: &quot;TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256&quot;,\r\n              &quot;value&quot;: 1122\r\n            },\r\n            &quot;compression_method&quot;: 0,\r\n\r\n          },\r\n          &quot;server_certificates&quot;: {\r\n            &quot;certificate&quot;: {\r\n              &quot;raw&quot;: &quot;dGVzdA==&quot;,\r\n              &quot;parsed&quot;: {\r\n                &quot;version&quot;: 3,\r\n                &quot;unique_number&quot;: &quot;123456&quot;,\r\n                &quot;signature_algorithm&quot;: {\r\n                  &quot;name&quot;: &quot;SHA256-RSA&quot;,\r\n                  &quot;oid&quot;: &quot;1.2.4.5.6&quot;\r\n                },\r\n```",
        "link": "https://stackoverflow.com/questions/60098468/using-jq-to-search-value-of-a-property-and-return-another-value",
        "title": "Using jq to search value of a property and return another value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3044347,
                    "reputation": 347,
                    "user_id": 2580443,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/279e424d07a3dfe2c25fd2cfa4e1a587?s=256&d=identicon&r=PG",
                    "display_name": "klimenkov",
                    "link": "https://stackoverflow.com/users/2580443/klimenkov"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676817815,
                "post_id": 60099083,
                "comment_id": 133209600,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1581005223,
                "creation_date": 1581005223,
                "answer_id": 60099166,
                "question_id": 60099083,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to use `--slurp` so that `jq` will apply its filter on the aggregation of all inputs rather than on each input. When using this option, `jq`&#39;s input will be an array of the inputs which you need to account for.\r\n\r\nI would use the following :\r\n\r\n    jq --slurp &#39;map(.records | map(.a)) | add&#39; f?.json\r\n\r\nWe apply your current transformation to each elements of the slurped array of inputs (your previous individual inputs), then we merge those transformed arrays into one with `add`.\r\n\r\n    ",
                "title": "Use jq to concatenate JSON arrays in multiple files"
            },
            {
                "up_vote_count": 14,
                "is_accepted": true,
                "score": 14,
                "last_activity_date": 1581005446,
                "creation_date": 1581005446,
                "answer_id": 60099238,
                "question_id": 60099083,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `-s` (or `--slurp`):\r\n\r\n    jq -s &#39;map(.records[].a)&#39; f?.json",
                "title": "Use jq to concatenate JSON arrays in multiple files"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1581007426,
                "last_edit_date": 1581007426,
                "creation_date": 1581006239,
                "answer_id": 60099456,
                "question_id": 60099083,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your input files are large, slurping the file could eat up lots of memory in which you case you can `reduce` which works in iterative manner, appending the contents of the array `.a` one object at a time\r\n\r\n    jq -n &#39;reduce inputs.records[].a as $d (.; . += [$d])&#39; f?.json\r\n\r\nThe `-n` flag is to ensure to construct the output JSON from scratch with the data available from `inputs`. The `reduce` function takes the initial value of `.` which because of the null input would be just `null`. Then for each of the input objects `. += [$d]` ensures that the array contents of `.a` are appended together.",
                "title": "Use jq to concatenate JSON arrays in multiple files"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1581008515,
                "creation_date": 1581008515,
                "answer_id": 60100097,
                "question_id": 60099083,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As a compromise between the readability of `--slurp` and the efficiency of `reduce`, you can run `jq` twice. The first is a slightly altered version of your original command, the second slurps the undifferentiated output into a single array.\r\n\r\n&lt;pre&gt;&lt;code&gt;$ jq &#39;.records&lt;b&gt;[]&lt;/b&gt; | .a&#39; f?.json | jq -s\r\n[\r\n  1,\r\n  3,\r\n  2\r\n]&lt;/code&gt;&lt;/pre&gt;\r\n\r\n",
                "title": "Use jq to concatenate JSON arrays in multiple files"
            },
            {
                "up_vote_count": 14,
                "is_accepted": false,
                "score": 14,
                "last_activity_date": 1581012806,
                "creation_date": 1581012806,
                "answer_id": 60101201,
                "question_id": 60099083,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming your jq has `inputs` (which is true of jq 1.5 and later), it would be most efficient to use it, e.g. along the lines of:\r\n\r\n    jq -n &#39;[inputs.records[].a]&#39; f*.json",
                "title": "Use jq to concatenate JSON arrays in multiple files"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1629900308,
                "creation_date": 1629900308,
                "answer_id": 68924413,
                "question_id": 60099083,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`--slurp` (`-s`) key is needed and `map()` to do so in one shot\r\n\r\n    $ cat f1.json\r\n    {\r\n      &quot;records&quot;: [\r\n        {&quot;a&quot;: 1},\r\n        {&quot;a&quot;: 3}\r\n      ]\r\n    }\r\n\r\n    $ cat f2.json\r\n    {\r\n      &quot;records&quot;: [\r\n        {&quot;a&quot;: 2}\r\n      ]\r\n    }\r\n\r\n    $ jq -s &#39;map(.records[].a)&#39; f?.json\r\n    [\r\n      1,\r\n      3,\r\n      2\r\n    ]",
                "title": "Use jq to concatenate JSON arrays in multiple files"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 19,
        "last_activity_date": 1629900308,
        "creation_date": 1581004905,
        "question_id": 60099083,
        "body_markdown": "I have a series of JSON files containing an array of records, e.g.\r\n```\r\n$ cat f1.json\r\n{\r\n  &quot;records&quot;: [\r\n    {&quot;a&quot;: 1},\r\n    {&quot;a&quot;: 3}\r\n  ]\r\n}\r\n\r\n$ cat f2.json\r\n{\r\n  &quot;records&quot;: [\r\n    {&quot;a&quot;: 2}\r\n  ]\r\n}\r\n```\r\n\r\nI want to 1) extract a single field from each record and 2) output a single array containing all the field values from all input files.\r\n\r\nThe first part is easy:\r\n```\r\njq &#39;.records | map(.a)&#39; f?.json\r\n[\r\n  1,\r\n  3\r\n]\r\n[\r\n  2\r\n]\r\n```\r\n\r\nBut I cannot figure out how to get `jq` to concatenate those output arrays into a single array!\r\n\r\nI&#39;m not married to `jq`; I&#39;ll happily use another tool if necessary. But I would love to know how to do this with `jq`, because it&#39;s something I have been trying to figure out for _years_.",
        "link": "https://stackoverflow.com/questions/60099083/use-jq-to-concatenate-json-arrays-in-multiple-files",
        "title": "Use jq to concatenate JSON arrays in multiple files"
    },
    {
        "tags": [
            "json",
            "iteration",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1581041750,
                "last_edit_date": 1581041750,
                "creation_date": 1581038882,
                "answer_id": 60105912,
                "question_id": 60105691,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Because you&#39;re iterating over `profiles[]` more than once, you&#39;re combining the results of one such iteration with the results of another. To avoid that, iterate only once, and get both `title` and `results` from the same `controls` list entry.\r\n\r\n```\r\njq  &#39;\r\n.platform.target_id as $target |\r\n.profiles[].controls[] |\r\n{ Host: $target,\r\n  Title: .title,\r\n  Status: .results[].status }\r\n&#39;\r\n```\r\n\r\nSee this running against your input data at https://jqplay.org/s/_6KVDfIn3m",
                "title": "jq query returning too many records (unwanted permutations)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1581042824,
        "creation_date": 1581036580,
        "last_edit_date": 1581042824,
        "question_id": 60105691,
        "body_markdown": "I have a complex JSON file and I am trying to get the below result using JQ.\r\n\r\n**Expected Result:**\r\n  \r\n```\r\n{\r\n  &quot;Host&quot;: &quot;Test.example.com&quot;,\r\n  &quot;Title&quot;: &quot;Ensure message of the day is configured properly&quot;,\r\n  &quot;Status&quot;: &quot;passed&quot;\r\n}\r\n{\r\n  &quot;Host&quot;: &quot;Test.example.com&quot;,\r\n  &quot;Title&quot;: &quot;Ensure bond0 is present&quot;,\r\n  &quot;Status&quot;: &quot;passed&quot;\r\n}\r\n{\r\n  &quot;Host&quot;: &quot;Test.example.com&quot;,\r\n  &quot;Title&quot;: &quot;Ensure the SELinux state is disabled&quot;,\r\n  &quot;Status&quot;: &quot;passed&quot;\r\n}\r\n```\r\n\r\nBelow is the JSON file that I get as a result of running an Chef Inspec profile.\r\n\r\n**JSON FILE:**\r\n\r\n```\r\n{\r\n  &quot;platform&quot;: {\r\n    &quot;name&quot;: &quot;redhat&quot;,\r\n    &quot;release&quot;: &quot;7.7&quot;,\r\n    &quot;target_id&quot;: &quot;Test.example.com&quot;\r\n  },\r\n  &quot;profiles&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;my-test&quot;,\r\n      &quot;version&quot;: &quot;0.1.0&quot;,\r\n      &quot;sha256&quot;: &quot;6fea36d6c12b21cd51274774edb4200d983db45c4cfa8172eebb897b6f3db8fe&quot;,\r\n      &quot;title&quot;: &quot;InSpec Profile&quot;,\r\n      &quot;maintainer&quot;: &quot;The Authors&quot;,\r\n      &quot;summary&quot;: &quot;An InSpec Compliance Profile&quot;,\r\n      &quot;license&quot;: &quot;Apache-2.0&quot;,\r\n      &quot;copyright&quot;: &quot;The Authors&quot;,\r\n      &quot;copyright_email&quot;: &quot;you@example.com&quot;,\r\n      &quot;supports&quot;: [\r\n        {\r\n          &quot;platform&quot;: &quot;os&quot;\r\n        }\r\n      ],\r\n      &quot;attributes&quot;: [],\r\n      &quot;groups&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;controls/1_motd.rb&quot;,\r\n          &quot;controls&quot;: [\r\n            &quot;1.1 motd check&quot;\r\n          ],\r\n          &quot;title&quot;: &quot;Warning Banners&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;controls/6_network.rb&quot;,\r\n          &quot;controls&quot;: [\r\n            &quot;6.1 Bonding&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;controls/12_selinux.rb&quot;,\r\n          &quot;controls&quot;: [\r\n            &quot;Selinux Config&quot;\r\n          ]\r\n        }\r\n      ],\r\n      &quot;controls&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;1.1 motd check&quot;,\r\n          &quot;title&quot;: &quot;Ensure message of the day is configured properly&quot;,\r\n          &quot;desc&quot;: &quot;Ensure message of the day is configured properly&quot;,\r\n          &quot;descriptions&quot;: [\r\n            {\r\n              &quot;label&quot;: &quot;default&quot;,\r\n              &quot;data&quot;: &quot;Ensure message of the day is configured properly&quot;\r\n            }\r\n          ],\r\n          &quot;impact&quot;: 1,\r\n          &quot;refs&quot;: [],\r\n          &quot;tags&quot;: {},\r\n          &quot;code&quot;: &quot;control &#39;1.1 motd check&#39; do\\n  title &#39;Ensure message of the day is configured properly&#39;\\n  desc  \\&quot;The contents of the /etc/motd file are displayed to users after login and function as a message of the day for authenticated users.\\&quot;\\n  desc \\&quot;Ensure message of the day is configured properly\\&quot;\\n  impact 1.0\\n  \\n  describe file(&#39;/etc/motd&#39;) do\\n    its(&#39;content&#39;) { should_not be_empty }\\n  end\\nend\\n&quot;,\r\n          &quot;source_location&quot;: {\r\n            &quot;line&quot;: 3,\r\n            &quot;ref&quot;: &quot;my-test/controls/1_motd.rb&quot;\r\n          },\r\n          &quot;waiver_data&quot;: {},\r\n          &quot;results&quot;: [\r\n            {\r\n              &quot;status&quot;: &quot;passed&quot;,\r\n              &quot;code_desc&quot;: &quot;File /etc/motd content should not be empty&quot;,\r\n              &quot;run_time&quot;: 0.099938054,\r\n              &quot;start_time&quot;: &quot;2020-02-07T11:31:47+11:00&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;6.1 Bonding&quot;,\r\n          &quot;title&quot;: &quot;Ensure bond0 is present&quot;,\r\n          &quot;desc&quot;: &quot;Check bonding is present&quot;,\r\n          &quot;descriptions&quot;: [\r\n            {\r\n              &quot;label&quot;: &quot;default&quot;,\r\n              &quot;data&quot;: &quot;Check bonding is present&quot;\r\n            }\r\n          ],\r\n          &quot;impact&quot;: 1,\r\n          &quot;refs&quot;: [],\r\n          &quot;tags&quot;: {},\r\n          &quot;code&quot;: &quot;control &#39;6.1 Bonding&#39; do\\n  title &#39;Ensure bond0 is present&#39;\\n  desc  \\&quot;Check bonding is present\\&quot;\\n  impact 1.0\\n  \\n  only_if { sys_info.manufacturer != \\&quot;VMware, Inc.\\&quot; } \\n\\n  describe bond(&#39;bond0&#39;) do\\n    it { should exist }\\n    its(&#39;mode&#39;) { should eq &#39;IEEE 802.3ad Dynamic link aggregation&#39; }\\n  end\\nend\\n&quot;,\r\n          &quot;source_location&quot;: {\r\n            &quot;line&quot;: 1,\r\n            &quot;ref&quot;: &quot;my-test/controls/6_network.rb&quot;\r\n          },\r\n          &quot;waiver_data&quot;: {},\r\n          &quot;results&quot;: [\r\n            {\r\n              &quot;status&quot;: &quot;skipped&quot;,\r\n              &quot;code_desc&quot;: &quot;No-op&quot;,\r\n              &quot;run_time&quot;: 9.02e-06,\r\n              &quot;start_time&quot;: &quot;2020-02-07T11:31:47+11:00&quot;,\r\n              &quot;resource&quot;: &quot;No-op&quot;,\r\n              &quot;skip_message&quot;: &quot;Skipped control due to only_if condition.&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;Selinux Config&quot;,\r\n          &quot;title&quot;: &quot;Ensure the SELinux state is disabled&quot;,\r\n          &quot;desc&quot;: &quot;Set SELinux to diabled&quot;,\r\n          &quot;descriptions&quot;: [\r\n            {\r\n              &quot;label&quot;: &quot;default&quot;,\r\n              &quot;data&quot;: &quot;Set SELinux to diabled&quot;\r\n            }\r\n          ],\r\n          &quot;impact&quot;: 1,\r\n          &quot;refs&quot;: [],\r\n          &quot;tags&quot;: {},\r\n          &quot;code&quot;: &quot;control &#39;Selinux Config&#39; do\\n  title &#39;Ensure the SELinux state is disabled&#39;\\n  desc  \\&quot;Set SELinux to diabled\\&quot;\\n  impact 1.0\\n\\n    describe file(&#39;/etc/selinux/config&#39;) do\\n    its(:content) { should match(/^SELINUX=disabled\\\\s*(?:#.*)?$/) }\\n  end\\nend\\n&quot;,\r\n          &quot;source_location&quot;: {\r\n            &quot;line&quot;: 1,\r\n            &quot;ref&quot;: &quot;my-test/controls/12_selinux.rb&quot;\r\n          },\r\n          &quot;waiver_data&quot;: {},\r\n          &quot;results&quot;: [\r\n            {\r\n              &quot;status&quot;: &quot;passed&quot;,\r\n              &quot;code_desc&quot;: &quot;File /etc/selinux/config content should match /^SELINUX=disabled\\\\s*(?:#.*)?$/&quot;,\r\n              &quot;run_time&quot;: 0.120881444,\r\n              &quot;start_time&quot;: &quot;2020-02-07T11:31:47+11:00&quot;\r\n            }\r\n          ]\r\n        }\r\n      ],\r\n      &quot;status&quot;: &quot;loaded&quot;\r\n    }\r\n  ],\r\n  &quot;statistics&quot;: {\r\n    &quot;duration&quot;: 0.223533139\r\n  },\r\n  &quot;version&quot;: &quot;4.18.24&quot;\r\n}\r\n```\r\nI used the following JQ code to extract the fields , but the extracted values are repeating.\r\n\r\n**JQ Code:**\r\n```\r\njq  &#39;{Host: .platform.target_id,Title: .profiles[].controls[].title,Status: .profiles[].controls[].results[].status}&#39;\r\n```\r\n\r\nThe result which I got from above JQ filter \r\n\r\n**Actual Result:**\r\n\r\n```\r\n{\r\n  &quot;Host&quot;: &quot;Test.example.com&quot;,\r\n  &quot;Title&quot;: &quot;Ensure message of the day is configured properly&quot;,\r\n  &quot;Status&quot;: &quot;passed&quot;\r\n}\r\n{\r\n  &quot;Host&quot;: &quot;Test.example.com&quot;,\r\n  &quot;Title&quot;: &quot;Ensure message of the day is configured properly&quot;,\r\n  &quot;Status&quot;: &quot;skipped&quot;\r\n}\r\n{\r\n  &quot;Host&quot;: &quot;Test.example.com&quot;,\r\n  &quot;Title&quot;: &quot;Ensure message of the day is configured properly&quot;,\r\n  &quot;Status&quot;: &quot;passed&quot;\r\n}\r\n{\r\n  &quot;Host&quot;: &quot;Test.example.com&quot;,\r\n  &quot;Title&quot;: &quot;Ensure bond0 is present&quot;,\r\n  &quot;Status&quot;: &quot;passed&quot;\r\n}\r\n{\r\n  &quot;Host&quot;: &quot;Test.example.com&quot;,\r\n  &quot;Title&quot;: &quot;Ensure bond0 is present&quot;,\r\n  &quot;Status&quot;: &quot;skipped&quot;\r\n}\r\n{\r\n  &quot;Host&quot;: &quot;Test.example.com&quot;,\r\n  &quot;Title&quot;: &quot;Ensure bond0 is present&quot;,\r\n  &quot;Status&quot;: &quot;passed&quot;\r\n}\r\n{\r\n  &quot;Host&quot;: &quot;Test.example.com&quot;,\r\n  &quot;Title&quot;: &quot;Ensure the SELinux state is disabled&quot;,\r\n  &quot;Status&quot;: &quot;passed&quot;\r\n}\r\n{\r\n  &quot;Host&quot;: &quot;Test.example.com&quot;,\r\n  &quot;Title&quot;: &quot;Ensure the SELinux state is disabled&quot;,\r\n  &quot;Status&quot;: &quot;skipped&quot;\r\n}\r\n{\r\n  &quot;Host&quot;: &quot;Test.example.com&quot;,\r\n  &quot;Title&quot;: &quot;Ensure the SELinux state is disabled&quot;,\r\n  &quot;Status&quot;: &quot;passed&quot;\r\n}\r\n```\r\n\r\nHow can I get the expected results. Any help would be appreciated.",
        "link": "https://stackoverflow.com/questions/60105691/jq-query-returning-too-many-records-unwanted-permutations",
        "title": "jq query returning too many records (unwanted permutations)"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1581083856,
                "creation_date": 1581083856,
                "answer_id": 60114905,
                "question_id": 60114720,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Of course there is.\r\n```\r\n$ jq &#39;.prof.Sma00K279a[.redundant_removed.Sma00K279a|keys[]]&#39; file\r\nnull\r\n{\r\n  &quot;Sma00K279a&quot;: {\r\n    &quot;Smlt3938&quot;: 1\r\n  }\r\n}\r\nnull\r\n```\r\nOr a bit more generic one:\r\n```\r\n$ jq &#39;(.prof|keys[]) as $k | .prof[$k][.redundant_removed[$k]|keys[]]&#39; file\r\nnull\r\n{\r\n  &quot;Sma00K279a&quot;: {\r\n    &quot;Smlt3938&quot;: 1\r\n  }\r\n}\r\nnull\r\n```",
                "title": "jq include results of a filter inside a new filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1581099649,
        "creation_date": 1581083095,
        "last_edit_date": 1581099649,
        "question_id": 60114720,
        "body_markdown": "I want to use the results of a `jq` filter inside another `jq` filter. I&#39;ve done it with `xargs` but I feel It has to be a better way with a simple `jq` run. \r\n#Example:\r\n\r\n    ]$ cat test.json \r\n    {\r\n       &quot;prof&quot; : {\r\n          &quot;Sma00K279a&quot; : {\r\n             &quot;SMLT_RS00075&quot; : {\r\n                &quot;Sma00K279a&quot; : {\r\n                   &quot;SMLT_RS00075&quot; : 1.0\r\n                }\r\n             },\r\n             &quot;SMLT_RS00180#&quot; : {\r\n                &quot;Sma00K279a&quot; : {\r\n                   &quot;SMLT_RS00180#&quot; : 1.0\r\n                }\r\n             },\r\n             &quot;Smlt0558&quot; : {\r\n                &quot;Sma00K279a&quot; : {\r\n                   &quot;Smlt3938&quot; : 1.0\r\n                }\r\n             }\r\n          }\r\n       },\r\n       &quot;redundant_removed&quot; : {\r\n          &quot;Sma00K279a&quot; : {\r\n             &quot;SMLT_RS22460&quot; : &quot;SMLT_RS22690&quot;,\r\n             &quot;Smlt0558&quot; : &quot;Smlt3938&quot;,\r\n             &quot;Smlt3573&quot; : &quot;Smlt1093&quot;\r\n          }\r\n       }\r\n    }\r\n\r\n#My solution:\r\n\r\n    ]$ jq &#39;.redundant_removed.Sma00K279a|keys[]&#39; test.json |tr -d \\&quot;|xargs -tI% jq &#39;.prof.Sma00K279a.%&#39; test.json \r\n    jq .prof.Sma00K279a.SMLT_RS22460 test.json \r\n    null\r\n    jq .prof.Sma00K279a.Smlt0558 test.json \r\n    {\r\n      &quot;Sma00K279a&quot;: {\r\n        &quot;Smlt3938&quot;: 1\r\n      }\r\n    }\r\n    jq .prof.Sma00K279a.Smlt3573 test.json \r\n    null\r\n\r\n#My question:\r\nIs there a better way to do this with a single `jq` run?\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60114720/jq-include-results-of-a-filter-inside-a-new-filter",
        "title": "jq include results of a filter inside a new filter"
    },
    {
        "tags": [
            "json",
            "jq",
            "scalar"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1632311831,
                "last_edit_date": 1632311831,
                "creation_date": 1581091899,
                "answer_id": 60117187,
                "question_id": 60117127,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Recurse, selecting only the scalar values:\r\n\r\n    $ cat tmp.json\r\n    {\r\n      &quot;a&quot;: 10,\r\n      &quot;b&quot;: {&quot;d&quot;: 20, &quot;e&quot;: &quot;hello&quot;},\r\n      &quot;c&quot;: {&quot;z&quot;: {&quot;f&quot;: true}}\r\n    }\r\n    $ jq &#39;recurse | scalars&#39; tmp.json\r\n    10\r\n    20\r\n    &quot;hello&quot;\r\n    true\r\n",
                "title": "JQ get all simple values in json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1632311831,
        "creation_date": 1581091703,
        "last_edit_date": 1581266239,
        "question_id": 60117127,
        "body_markdown": "I have a json structure which contains nested dictionaries and I want to fetch all the simple values in it (String, Int, bool etc but not dict and lists).\r\n\r\nHow can I achieve this using JQ.\r\n\r\nExample:\r\n\r\n```\r\n{\r\n\t&quot;a&quot;: 10,\r\n\t&quot;b&quot;: {\r\n\t\t&quot;d&quot;: 20,\r\n\t\t&quot;e&quot;: &quot;hello&quot;\r\n\t},\r\n\t&quot;c&quot;: {\r\n\t\t&quot;z&quot;: {\r\n\t\t\t&quot;f&quot;: true\r\n\t\t}\r\n\t}\r\n}\r\n```\r\n\r\nExpected output not necessarily in this order:\r\n```\r\n10\r\n20\r\n&quot;hello&quot;\r\ntrue\r\n```",
        "link": "https://stackoverflow.com/questions/60117127/jq-get-all-simple-values-in-json",
        "title": "JQ get all simple values in json"
    },
    {
        "tags": [
            "jq",
            "aws-codebuild"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1581115722,
                "last_edit_date": 1581115722,
                "creation_date": 1581099013,
                "answer_id": 60118936,
                "question_id": 60118935,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can approach the problem in two steps:\r\n\r\n 1. Get the id of the most recent build with [`list-builds-for-project`][1]\r\n 2. Select the relevant field from the output of [`batch-get-builds`][2]\r\n\r\nAssuming you have `aws` CLI and `jq` installed, and are receiving CLI results in JSON format:\r\n```\r\nid=$(aws codebuild list-builds-for-project --project-name myproject | jq -r &#39;.ids[0]&#39;)\r\n```\r\nThe default sort order puts the most recently completed build at the top of the list. Then use `$id` from the prior step:\r\n```\r\naws codebuild batch-get-builds --ids &quot;$id&quot; | jq &#39;.builds[].phases[] | select (.phaseType==&quot;BUILD&quot;) | .phaseStatus&#39;\r\n```\r\nSee [select objects based on value of variable in object using jq][3] for a discussion of the jq syntax.\r\n\r\n\r\n  [1]: https://docs.aws.amazon.com/cli/latest/reference/codebuild/list-builds-for-project.html\r\n  [2]: https://docs.aws.amazon.com/cli/latest/reference/codebuild/batch-get-builds.html\r\n  [3]: https://stackoverflow.com/questions/18592173/select-objects-based-on-value-of-variable-in-object-using-jq",
                "title": "How do I check the status of my most recently completed Codebuild build projects?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1621833917,
                "last_edit_date": 1621833917,
                "creation_date": 1621559641,
                "answer_id": 67629721,
                "question_id": 60118935,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I may have reinvented or over-engineered the wheel, but wrote a little node program to do this that might be of use to you.\r\n```javascript\r\nconst { exec } = require(&quot;child_process&quot;);\r\nconst { promisify } = require(&quot;util&quot;);\r\n\r\nconst asyncExec = promisify(exec);\r\n\r\nconst getLatestBuildId = async () =&gt; {\r\n  const listBuildsCommand = &quot;aws codebuild list-builds&quot;;\r\n  const { stdout } = await asyncExec(listBuildsCommand);\r\n  const { ids } = JSON.parse(stdout);\r\n  const [latestBuildId] = ids;\r\n  return latestBuildId;\r\n};\r\n\r\nconst getBuildStatus = async (latestBuildId) =&gt; {\r\n  const batchGetBuildsCommand = `aws codebuild  batch-get-builds --ids ${latestBuildId}`;\r\n  const { stdout } = await asyncExec(batchGetBuildsCommand);\r\n  const { builds } = JSON.parse(stdout);\r\n  const [latestBuild] = builds;\r\n  const { id, currentPhase, buildStatus, startTime, endTime } = latestBuild;\r\n  return {\r\n    id,\r\n    currentPhase,\r\n    buildStatus,\r\n    start: new Date(startTime * 1000).toLocaleTimeString(),\r\n    end: new Date(endTime * 1000).toLocaleTimeString(),\r\n  };\r\n};\r\n\r\nconst reportBuildStatus = async () =&gt; {\r\n  const latestBuildId = await getLatestBuildId();\r\n  const latestBuild = await getBuildStatus(latestBuildId);\r\n  console.log(latestBuild);\r\n};\r\n\r\nreportBuildStatus();\r\n```",
                "title": "How do I check the status of my most recently completed Codebuild build projects?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1621833917,
        "creation_date": 1581099013,
        "question_id": 60118935,
        "body_markdown": "How do I check the status of my most recent AWS Codebuild build projects using the CLI? I see that you can [view the build details][1], but it requires a specific build-id, and the [summarized build information][2] does not give any details on which build phase is correlated to the status that appears in the console.\r\n\r\n\r\n  [1]: https://docs.aws.amazon.com/codebuild/latest/userguide/view-build-details.html#view-build-details-cli\r\n  [2]: https://docs.aws.amazon.com/codebuild/latest/userguide/getting-started-cli-monitor-build.html#getting-started-cli-monitor-build-cli",
        "link": "https://stackoverflow.com/questions/60118935/how-do-i-check-the-status-of-my-most-recently-completed-codebuild-build-projects",
        "title": "How do I check the status of my most recently completed Codebuild build projects?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1581124131,
                "creation_date": 1581124131,
                "answer_id": 60123065,
                "question_id": 60122643,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This works for your original input, assuming you chose `|` as the delimiter because none of your fields can contain `|`.\r\n\r\n    jq -r &#39;map([&quot;HDR&quot;]+.HDR, [&quot;DTL&quot;] + .DTL[])[] | join(&quot;|&quot;)&#39; data.json\r\n\r\n * `map` produces multiple array elements per object.\r\n * `.DTL[]` ensures `&quot;DTL&quot;` is prefixed to each sublist\r\n * `[]` flattens the result of the `map`",
                "title": "How can I use jq to create a CSV with multiple headers and detail lines?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1581139342,
        "creation_date": 1581119909,
        "last_edit_date": 1581139342,
        "question_id": 60122643,
        "body_markdown": "I&#39;d like to use jq to output in CSV format, but for multiple headers, followed by multiple details. The solutions that I&#39;ve already seen on Stack Overflow provide a way to insert a single header, but I haven&#39;t found anything for multiple headers.\r\n\r\nTo give you an idea of what I&#39;m talking about, here is some sample JSON input:\r\n```\r\n[\r\n  {\r\n  &quot;HDR&quot;: [1, &quot;abc&quot;],\r\n  &quot;DTL&quot;: [ [101,&quot;Descr A&quot;], [102,&quot;Descr B&quot;] ]\r\n  }, {\r\n  &quot;HDR&quot;: [2, &quot;def&quot;],\r\n  &quot;DTL&quot;: [ [103,&quot;Descr C&quot;], [104,&quot;Descr D&quot;] ]\r\n  }\r\n]\r\n```\r\n\r\nDesired output:\r\n\r\n```\r\nHDR|1|abc\r\nDTL|101|Descr A\r\nDTL|102|Descr B\r\nHDR|2|def\r\nDTL|103|Descr C\r\nDTL|104|Descr D\r\n```\r\n\r\nI don&#39;t know if it&#39;s possible, but my approach so far has been to try to create a filter to give me the following, since transforming this to what I need would be trivial:\r\n\r\n```\r\n[&quot;HDR&quot;, 1, &quot;abc&quot;]\r\n[&quot;DTL&quot;, 101, &quot;Descr A&quot;]\r\n[&quot;DTL&quot;, 102, &quot;Descr B&quot;]\r\n[&quot;HDR&quot;, 2, &quot;def&quot;]\r\n[&quot;DTL&quot;, 103, &quot;Descr C&quot;]\r\n[&quot;DTL&quot;, 104, &quot;Descr D&quot;]\r\n```\r\n\r\nTo be clear, I know how to do this in any number of scripting languages, but I&#39;m really trying to stick with a single jq filter, if it&#39;s at all possible.\r\n\r\nEdit: I should clarify that I don&#39;t necessarily need to copy the &quot;HDR&quot; and &quot;DTL&quot; keys into the CSV (I can hard-code those), so the sample JSON could look like this, if it makes the problem easier.\r\n\r\n```\r\n[\r\n  [\r\n    [1, &quot;abc&quot;],\r\n    [[101,&quot;Descr A&quot;], [102,&quot;Descr B&quot;]]\r\n  ], [\r\n    [2, &quot;def&quot;],\r\n    [[103,&quot;Descr C&quot;], [104,&quot;Descr D&quot;]]\r\n  ]\r\n]\r\n````\r\n\r\nEdit: This filter technically answers the question with the second sample data I provided (the last one, that&#39;s only arrays and no objects), but I would still appreciate a better answer, if for no other reasons than the header length has to be hard-coded, and putting the HDR into two sets of arrays so that it can be flatten()&#39;d later feels wrong. But I&#39;ll leave it here for reference.\r\n\r\n`.[] | flatten(1) | [[[&quot;HDR&quot;] + .[0:2]]] as $hdr | .[2:] as $dtl | $dtl | map([[&quot;DTL&quot;] + .]) as $dtl | $hdr + $dtl | flatten(1) | .[]  | join(&quot;|&quot;)`",
        "link": "https://stackoverflow.com/questions/60122643/how-can-i-use-jq-to-create-a-csv-with-multiple-headers-and-detail-lines",
        "title": "How can I use jq to create a CSV with multiple headers and detail lines?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581162810,
                "post_id": 60125581,
                "comment_id": 106343346,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4677143,
                    "reputation": 15627,
                    "user_id": 3787051,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/k2G2V.png?s=256",
                    "display_name": "Alex Harvey",
                    "link": "https://stackoverflow.com/users/3787051/alex-harvey"
                },
                "reply_to_user": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581163085,
                "post_id": 60125581,
                "comment_id": 106343407,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1581175027,
                "last_edit_date": 1581175027,
                "creation_date": 1581162724,
                "answer_id": 60126509,
                "question_id": 60125581,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes there is:\r\n\r\n    &lt;file jq -r &#39;[.foo,(.bar|join(&quot;,&quot;))]|join(&quot; &quot;)&#39;\r\n\r\nIt only joins twice the both `.foo` and `.bar` field in order have them in the same line.\r\n\r\n--- \r\n\r\nIf you don&#39;t know the key names, you could use this:\r\n\r\n    &lt;file jq -r &#39;to_entries|map(.value|[strings?//.[]]|join(&quot;,&quot;))|join(&quot; &quot;)&#39;\r\n\r\nThat is close to your solution, except that it uses `strings` builtin function and the operator `//` and `?` to avoid using a `if ... then ...`.\r\n\r\n",
                "title": "Convert map of strings or lists into string of values or comma-separate values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1581183283,
                "creation_date": 1581183283,
                "answer_id": 60129345,
                "question_id": 60125581,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that is agnostic both about the key names and their order, and is fairly robust in other respects:\r\n\r\n    jq -r &#39;to_entries\r\n      | sort_by(.value|type) \r\n      | reverse .  # &quot;string&quot; before &quot;array&quot;\r\n      | map(.value | if type == &quot;array&quot; then join(&quot;,&quot;) else tostring end)\r\n      | join(&quot; &quot;)&#39;",
                "title": "Convert map of strings or lists into string of values or comma-separate values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1581183283,
        "creation_date": 1581154783,
        "last_edit_date": 1581162973,
        "question_id": 60125581,
        "body_markdown": "I have a JSON file:\r\n\r\n```lang-json\r\n{\r\n  &quot;foo&quot;: &quot;xxx&quot;,\r\n  &quot;bar&quot;: [&quot;yyy&quot;,&quot;zzz&quot;]\r\n}\r\n```\r\n\r\nI want to use JQ to convert this to:\r\n\r\n```lang-text\r\nxxx yyy,zzz\r\n```\r\n\r\nI have tried various things and the closest I can get is:\r\n\r\n```lang-none\r\n▶ cat xx.json | jq -r &#39;to_entries[] | if (.value | type)==&quot;string&quot; then (.value) else (.value | join(&quot;,&quot;)) end&#39; \r\nxxx\r\nyyy,zzz\r\n```\r\n\r\nNote that I do not know the names of the keys in the JSON file in advance, and I am relying on the behaviour of `to_entries` to output the entries in order sorted by key (just in case someone is thinking of a way to do this that would result in the output being non-deterministically ordered).\r\n\r\nIs there any concise way to do this using a JQ one-liner?",
        "link": "https://stackoverflow.com/questions/60125581/convert-map-of-strings-or-lists-into-string-of-values-or-comma-separate-values",
        "title": "Convert map of strings or lists into string of values or comma-separate values"
    },
    {
        "tags": [
            "json",
            "command-line",
            "command-line-arguments",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1581229198,
                "last_edit_date": 1581229198,
                "creation_date": 1581218046,
                "answer_id": 60133153,
                "question_id": 60132920,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using [jq](https://stedolan.github.io/jq/):\r\n\r\n    jq -r &#39;&quot;A_B: \\(.A_B[&quot;Field2&quot;])&quot;, &quot;A_C: \\(.A_C[&quot;Field2&quot;])&quot;&#39; test &gt; test2\r\n\r\nExplanation: Command \r\n\r\n    jq -r &#39;.A_B[&quot;Field2&quot;]&#39; test\r\n\r\nextracts the value `0.00000580` of `Field2` of `A_B` and `&quot;A_B: \\(…)&quot;` adds the literal string `A_B: ` as prefix. The same happens with the `A_C` field which is printed on the next line. The output is redirected to file `test2`.\r\n\r\nThe equivalent command for `field5` and output file `test3` is\r\n\r\n    jq -r &#39;&quot;A_B: \\(.A_B[&quot;Field5&quot;])&quot;, &quot;A_C: \\(.A_C[&quot;Field5&quot;])&quot;&#39; test &gt; test3\r\n\r\n",
                "title": "How can I get specific fields from within fields in a JSON file?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1581229198,
        "creation_date": 1581214112,
        "last_edit_date": 1581217799,
        "question_id": 60132920,
        "body_markdown": "I have a file called test that I create by fetching info with cURL like this:\r\n```\r\ncurl &quot;https://example.com/public?command=getInfo&quot; &gt; test | python -m json.tool &gt; test\r\n```\r\nand it results in something like this:\r\n```\r\n{\r\n    &quot;A_B&quot;: {\r\n        &quot;Field1&quot;: &quot;0.36564104&quot;,\r\n        &quot;Field2&quot;: &quot;0.00000580&quot;,\r\n        &quot;Field3&quot;: &quot;0.00000558&quot;,\r\n        &quot;Field4&quot;: 177,\r\n        &quot;Field5&quot;: &quot;0&quot;\r\n    },\r\n    &quot;B_A&quot;: {\r\n        &quot;Field1&quot;: &quot;19.02374743&quot;,\r\n        &quot;Field2&quot;: &quot;0.00049000&quot;,\r\n        &quot;Field3&quot;: &quot;0.00047179&quot;,\r\n        &quot;Field4&quot;: 253,\r\n        &quot;Field5&quot;: &quot;0&quot;\r\n    },\r\n    &quot;A_C&quot;: {\r\n        &quot;Field1&quot;: &quot;19.02374743&quot;,\r\n        &quot;Field2&quot;: &quot;0.00049000&quot;,\r\n        &quot;Field3&quot;: &quot;0.00047179&quot;,\r\n        &quot;Field4&quot;: 253,\r\n        &quot;Field5&quot;: &quot;0&quot;\r\n    }\r\n    ...\r\n}\r\n```\r\nI need to get from A_B and A_C Field2 and Field5. Therefore I tried using an AWK live editor but so far the best I&#39;ve managed is \r\n\r\n```\r\n-F &quot;[, ]+&quot; &#39;/A_B/{print $2,$5}&#39;\r\n```\r\nWhich is to say, I haven&#39;t made any real progress, and of course, it doesn&#39;t work.\r\n\r\nMy goal is to save into two files called test2 and test3 which would look something like this:\r\n\r\ntest2:\r\n```\r\nA_B: 0.00000580\r\nA_C: 0.00049000\r\n```\r\n\r\ntest3:\r\n```\r\nA_B: 0\r\nA_C: 0\r\n```\r\n\r\ncontaining the values of Field2 in test2 and Field5 in test3, but so far, I&#39;m stuck.\r\n\r\nAny help is appreciated!",
        "link": "https://stackoverflow.com/questions/60132920/how-can-i-get-specific-fields-from-within-fields-in-a-json-file",
        "title": "How can I get specific fields from within fields in a JSON file?"
    },
    {
        "tags": [
            "environment-variables",
            "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": 1581222126,
                "post_id": 60133307,
                "comment_id": 106355917,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1581222241,
                "creation_date": 1581222241,
                "answer_id": 60133437,
                "question_id": 60133307,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try \r\n\r\n    ENV=&quot;dev-cc1&quot; jq &#39;.[env.ENV]&#39; envs.json\r\n\r\nor \r\n\r\n    export ENV=&quot;dev-cc1&quot;\r\n    jq &#39;.[env.ENV]&#39; envs.json\r\n\r\nor using a jq variable:\r\n\r\n    ENV=&quot;dev-cc1&quot;\r\n    jq --arg ENV &quot;$ENV&quot; &#39;.[$ENV]&#39; envs.json\r\n\r\n",
                "title": "jq: not using environment variable correctly"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1581239062,
        "creation_date": 1581220275,
        "last_edit_date": 1581239062,
        "question_id": 60133307,
        "body_markdown": "I have an `envs.json` file with content:\r\n```\r\n{ \r\n  &quot;dev-cc1&quot;: { &quot;url&quot;: &quot;https://my-url.com&quot; }, \r\n  &quot;dev-cc2&quot;: { &quot;url&quot;: &quot;https://my-url.com&quot; }\r\n}\r\n```\r\n\r\nI would like to fetch urls based on an environment variable `$ENV`, but every other related article I came across didn&#39;t seem to work, or I just read it wrong. I think I&#39;m missing something super trivial... \r\n\r\nThings I tried:\r\n\r\n```\r\nexport ENV=&quot;dev-cc1&quot;\r\njq --arg ENV &quot;$ENV&quot; -n &#39;.&quot;env.ENV&quot;&#39; envs.json\r\n```\r\nBecause my env variable has a dash in it, I quoted around it, and then tried to reference it inside. However jq returns back `null`. \r\n\r\nThe hardcoded query works (`jq --arg ENV &quot;$ENV&quot; &#39;.&quot;dev-cc1&quot;&#39; envs.json`), and I&#39;ve also confirmed that the environment variable is passed in correctly `jq --arg ENV &quot;$ENV&quot; -n &#39;env.ENV&#39;`.\r\n\r\nI tried a ton of different ways to substitute this env var in but none worked.. Could anyone please give this a second pair of eyes?",
        "link": "https://stackoverflow.com/questions/60133307/jq-not-using-environment-variable-correctly",
        "title": "jq: not using environment variable correctly"
    },
    {
        "tags": [
            "json",
            "bash",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1581269671,
                "creation_date": 1581269671,
                "answer_id": 60139368,
                "question_id": 60138878,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `.` inside the `select` does not reference a row from you input array  , but `$arg` because of the inside `|`\r\n\r\nThis is your working example\r\n\r\n    $ echo  &#39;[{&quot;c&quot;:&quot;a&quot;},{&quot;c&quot;:&quot;d&quot;},{&quot;c&quot;:&quot;g&quot;},{&quot;c&quot;:&quot;j&quot;}]&#39; | \\\r\n            jq &#39;.[] | .c as $c | select( [&quot;a&quot;,&quot;g&quot;] | index($c) ) &#39;\r\n    {\r\n      &quot;c&quot;: &quot;a&quot;\r\n    }\r\n    {\r\n      &quot;c&quot;: &quot;g&quot;\r\n    }\r\n\r\nNow we `replace` select by `map`\r\n\r\n    $ echo  &#39;[{&quot;c&quot;:&quot;a&quot;},{&quot;c&quot;:&quot;d&quot;},{&quot;c&quot;:&quot;g&quot;},{&quot;c&quot;:&quot;j&quot;}]&#39; | \\\r\n                 jq &#39;.[] | .c as $c | map( [&quot;a&quot;,&quot;g&quot;] | index($c) ) &#39;\r\n    [\r\n      0\r\n    ]\r\n    [\r\n      null\r\n    ]\r\n    [\r\n      1\r\n    ]\r\n    [\r\n      null\r\n    ]\r\n\r\nNow instead of `index($c)` we replace by `.`\r\n\r\n    $ echo  &#39;[{&quot;c&quot;:&quot;a&quot;},{&quot;c&quot;:&quot;d&quot;},{&quot;c&quot;:&quot;g&quot;},{&quot;c&quot;:&quot;j&quot;}]&#39; | \\\r\n                 jq &#39;.[] | .c as $c | map( [&quot;a&quot;,&quot;g&quot;] | . ) &#39;\r\n    [\r\n      [\r\n        &quot;abc&quot;,\r\n        &quot;ghi&quot;\r\n      ]\r\n    ]\r\n    [\r\n      [\r\n        &quot;abc&quot;,\r\n        &quot;ghi&quot;\r\n      ]\r\n    ]\r\n    [\r\n      [\r\n        &quot;abc&quot;,\r\n        &quot;ghi&quot;\r\n      ]\r\n    ]\r\n    [\r\n      [\r\n        &quot;abc&quot;,\r\n        &quot;ghi&quot;\r\n      ]\r\n    ]\r\n\r\n",
                "title": "How to filter a big JSON with a small JSON using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1581296822,
                "last_edit_date": 1581296822,
                "creation_date": 1581269690,
                "answer_id": 60139372,
                "question_id": 60138878,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you already have a working solution, let me first mention that if you want the results as an array, you could write:\r\n\r\n    jq --argfile array json-b.json &#39;\r\n      map(select( .city as $city | $array | index($city)))\r\n    &#39; json-a.json\r\n\r\n\r\nHowever, it would probably be better to put the jq program into a file and invoke jq with the -f option:\r\n\r\n    jq -f program.jq --argfile array json-b.json json-a.json\r\n\r\n## Explanations for the unsuccessful attempts\r\n### `$arg|index(.city)`\r\n\r\nThe reason why your first attempt cannot work in the way intended is that\r\n`$arg|index(.city)` is exactly equivalent to `$arg|index($arg.city)`, which is obviously not what&#39;s needed.\r\n\r\n### `index( \\(.city) )`\r\n\r\nThis expression is just syntactically invalid.  Perhaps you had string interpolation in mind; if so, the expression would be `index(&quot;\\(.city)&quot;)`, but that has the same problem as noted in the previous section.",
                "title": "How to filter a big JSON with a small JSON using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1581279398,
                "last_edit_date": 1581279398,
                "creation_date": 1581277026,
                "answer_id": 60140563,
                "question_id": 60138878,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; is there better way?\r\n\r\nHere&#39;s a solution that has a number of potential advantages as outlined below:\r\n```\r\n&lt; json-a.json jq --argfile array json-b.json &#39;\r\n  INDEX(.city)[$array[]]&#39;\r\n```\r\nNotice that the time-complexity of this algorithm is approximately O(n) + O(m) where n and m are the lengths of the two arrays.  By contrast, naively iterating through the array of objects and checking against the array of relevant cities has time-complexity O(n)*O(m).\r\n\r\nAnother advantage is that this solution does not use `index/1`, the implementation of which is currently suboptimal.\r\n\r\n## Caveat\r\nIf there is more than one object in the main array with the same value of .city, then the results may or may not be as wanted.",
                "title": "How to filter a big JSON with a small JSON using jq?"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1581296822,
        "creation_date": 1581266424,
        "last_edit_date": 1581279469,
        "question_id": 60138878,
        "body_markdown": "I hava a big JSON and I want to filter the content whith multiple conditions, in other words, fetch the specific items which specific values.\r\n\r\nThis process is based on `jq(v1.5)` and `bash`.\r\n\r\njson-a (just a example):\r\n\r\n    [\r\n       {\r\n        &quot;city&quot;: &quot;abc&quot;\r\n       },\r\n       {\r\n        &quot;city&quot;: &quot;def&quot;\r\n       },\r\n       {\r\n        &quot;city&quot;: &quot;ghi&quot;\r\n       },\r\n      {\r\n        &quot;city&quot;: &quot;jkl&quot;\r\n       }\r\n    ]\r\n\r\nNow, I want to get {&quot;city&quot;: &quot;abc&quot;} and {&quot;city&quot;: &quot;ghi&quot;} but don&#39;t want to pass for-loop with bash (i think `jq` is a great tool with its own loop function).\r\n\r\nSo I built a small json contains specific values.\r\n\r\njson-b(just a example):\r\n```\r\n[&quot;abc&quot;,&quot;ghi&quot;]\r\n```\r\n\r\nand execute jq command:\r\n```\r\n$ json-b=&#39;[&quot;abc&quot;,&quot;ghi&quot;]&#39;\r\n$ cat json-a | jq --argjson arg ${json-b} &#39;.[] | select( ($arg|index(.city)) )&#39; # return error\r\nerror: Cannot index array with string &quot;city&quot;\r\n\r\n$ cat json-a | jq --argjson arg ${json-b} &#39;.[] | select( ($arg|index( \\(.city) )) )&#39; # return error\r\nerror: compile error\r\n\r\n# BUT\r\n$ cat json-a | jq --argjson arg ${json} &#39;.[] | .city as $c | select( ($arg|index($c)) )&#39; # It&#39;s work\r\n```\r\n&gt; So, the output Object cannot be called by builtin funciton? I tried `in`,`contains` does not work too.\r\n&gt; Did I do something wrong there? Or is there better way?\r\n\r\nThanks.\r\n",
        "link": "https://stackoverflow.com/questions/60138878/how-to-filter-a-big-json-with-a-small-json-using-jq",
        "title": "How to filter a big JSON with a small JSON using jq?"
    },
    {
        "tags": [
            "json",
            "formatting",
            "integer",
            "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": 1581335905,
                "post_id": 60148441,
                "comment_id": 106385544,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 338272,
                    "reputation": 3419,
                    "user_id": 667049,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/01f04a3bb55ef948a186620fa5d5ea29?s=256&d=identicon&r=PG",
                    "display_name": "GutenYe",
                    "link": "https://stackoverflow.com/users/667049/gutenye"
                },
                "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": 1581561733,
                "post_id": 60148441,
                "comment_id": 106479317,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1581364880,
                "creation_date": 1581364880,
                "answer_id": 60157559,
                "question_id": 60148441,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` doesn&#39;t have (yet) a `printf` function to format according locale settings.\r\nIf that&#39;s an option for you can pass the number to the shell using `printf`:\r\n\r\n    echo &#39;{&quot;a&quot;: 12345}&#39; | jq &#39;.a&#39; | xargs printf &quot;%&#39;.f\\n&quot;\r\n    12,345\r\n\r\nNote that the printf conversion relies on the format `%&#39;.f` that is explained in `man 3 printf` ",
                "title": "Format number in thousands separators with jq json cli"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1581408530,
                "creation_date": 1581408530,
                "answer_id": 60164419,
                "question_id": 60148441,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a generic solution for integers or integer-valued strings:\r\n```\r\n# &quot;h&quot; for &quot;human-readable&quot;\r\ndef h:\r\n  def hh: .[0] as $s | .[1] as $answer\r\n    | if ($s|length) == 0 then $answer\r\n      else ((if $answer == &quot;&quot; then &quot;&quot; else &quot;,&quot; end) + $answer ) as $a\r\n      | [$s[0:-3], $s[-3:] + $a] | hh\r\n      end;\r\n   [ tostring, &quot;&quot;] | hh;\r\n```\r\n## Example\r\n```\r\n12, 123, 1234, 12345678 | h\r\n```\r\n## Result (using -r option):\r\n```\r\n12\r\n123\r\n1,234\r\n12,345,678\r\n```",
                "title": "Format number in thousands separators with jq json cli"
            },
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1581463086,
                "last_edit_date": 1592644375,
                "creation_date": 1581463086,
                "answer_id": 60178790,
                "question_id": 60148441,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an idiomatic one-liner definition:\n\n    def h: tostring | [while(length&gt;0; .[:-3]) | .[-3:]] | reverse | join(&quot;,&quot;);\n\n## Example\n```\n12, 123, 1234, 12345678 | h\n```\n### Output (using -r option):\n```\n12\n123\n1,234\n12,345,678\n```",
                "title": "Format number in thousands separators with jq json cli"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1718808765,
                "creation_date": 1718808765,
                "answer_id": 78643232,
                "question_id": 60148441,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Building on @peak&#39;s excellent answer from Feb 2020, I offer this version which also correctly handles negative numbers and numbers with digits after the decimal point (which are not supposed to have separators).\r\n\r\n    def commas:\r\n    \tif type == &quot;number&quot; then\r\n            (. &lt; 0) as $neg |\r\n            abs |\r\n            tostring |\r\n            split(&quot;.&quot;) |\r\n            .[0] |= ([while (length &gt; 0; .[:-3]) | .[-3:]] | reverse | join(&quot;,&quot;)) |\r\n            join(&quot;.&quot;) |\r\n            if $neg then &quot;-&quot; + . end\r\n    \tend\r\n    ;\r\n\r\nExample:\r\n\r\n    $ jq -nr &#39;-1234567.8901, -123, 1234 | commas&#39;\r\n    -1,234,567.8901\r\n    -123\r\n    1,234",
                "title": "Format number in thousands separators with jq json cli"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 7,
        "last_activity_date": 1718808765,
        "creation_date": 1581330574,
        "last_edit_date": 1581563099,
        "question_id": 60148441,
        "body_markdown": "Given `{&quot;a&quot;: 1234567890}`, I want `1,234,567,890` in the result, how this can be done with jq \r\n\r\n```\r\necho &#39;{&quot;a&quot;: 1234567890}&#39; | jq &#39;.a | FORMAT?&#39;\r\n```\r\n\r\nThanks for @peak&#39;s answer, the solution is\r\n\r\n```\r\necho &#39;{&quot;a&quot;: 1234567890}&#39; | jq -r &#39;def h: [while(length&gt;0; .[:-3]) | .[-3:]] | reverse | join(&quot;,&quot;); .a | tostring | h&#39;\r\n//-&gt; 1,234,567,890\r\n```",
        "link": "https://stackoverflow.com/questions/60148441/format-number-in-thousands-separators-with-jq-json-cli",
        "title": "Format number in thousands separators with jq json cli"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1581372439,
                "last_edit_date": 1581372439,
                "creation_date": 1581371789,
                "answer_id": 60159046,
                "question_id": 60158308,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following constructive solution using jq has the advantage of being simple and efficient:\r\n\r\n```\r\n. as $in\r\n| reduce (keys_unsorted[] | select(endswith(&quot;-release&quot;)|not)) as $k ({};\r\n    . + {($k) : (($k + &quot;-release&quot;) as $kr\r\n                 | $in\r\n                 | if has($kr) then .[$kr] else .[$k] end) } )\r\n    \r\n```",
                "title": "Replace some keys in json by jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1587414245,
        "creation_date": 1581368280,
        "last_edit_date": 1587414245,
        "question_id": 60158308,
        "body_markdown": "I have json file like this one:\r\n\r\n    {\r\n        &quot;abc&quot;: &quot;A&quot;,\r\n        &quot;abc-release&quot;: &quot;B&quot;,\r\n        &quot;bcd&quot;:&quot;C&quot;,\r\n        &quot;cde-release&quot;:&quot;D&quot;,\r\n        &quot;cde&quot;:&quot;E&quot;\r\n    }\r\n\r\nand would like to get resulting file like this:\r\n\r\n    {\r\n        &quot;abc&quot;: &quot;B&quot;,\r\n        &quot;bcd&quot;:&quot;C&quot;,\r\n        &quot;cde&quot;:&quot;D&quot;\r\n    }\r\n\r\nThat is:\r\n\r\n1. remove all elements with key X if we also have key X-release;\r\n2. rename elements with key X-release as X;\r\n\r\nNeed to make this work by using Linux commands like `jq` and `sed`. Preferably as one-liner with pipes.\r\n\r\nI have spent multiple hours trying to implement this and best I could do is this jq command which returns array of keys which i need to delete.\r\n\r\n    jq &quot;with_entries(select(.key|endswith(\\&quot;-release\\&quot;))) | keys | map(split(\\&quot;-\\&quot;)[0])&quot;\r\n\r\n    [\r\n        &quot;abc&quot;,\r\n        &quot;cde&quot;\r\n    ]\r\n\r\nBut how to feed this array in jq `del` method or some other way to get result what I need?\r\n\r\nSecond step (renaming elements) is easy. That can be done by jq but also can be done at the end simply by sed:\r\n\r\n    // simply like this\r\n    sed &#39;s/-release//&#39;\r\n    // or\r\n    sed &#39;s/(.*)-release/$1/&#39;\r\n",
        "link": "https://stackoverflow.com/questions/60158308/replace-some-keys-in-json-by-jq",
        "title": "Replace some keys in json by jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1581434476,
                "creation_date": 1581434476,
                "answer_id": 60172180,
                "question_id": 60170239,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This must be a bug as it seems to work perfectly on `jq` 1.6 ([try it here](https://jqplay.org/s/ZOSKY8kr--)).\r\n\r\nIf you&#39;re unable to update to `jq` 1.6 you should be able to use the following command instead, which I&#39;ve successfully tested on `jq` 1.5 :\r\n\r\n    jq &#39;.entries |= map(select(.var | contains(&quot;foo&quot;) | not))&#39; file.json",
                "title": "Using jq with &#39;contains&#39; in a &#39;select&#39; inside a &#39;del&#39; is not working"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1581434476,
        "creation_date": 1581428604,
        "question_id": 60170239,
        "body_markdown": "i try to remove some entries from a dict in a json. It works by using == but with contains it doesn&#39;t work.\r\n\r\nJq call working:\r\n\r\n    jq &#39;del(.entries[] | select(.var == &quot;foo&quot;))&#39; input.json\r\n\r\nJq call not working:\r\n\r\n    jq &#39;del(.entries[] | select(.var | contains(&quot;foo&quot;)))&#39; input.json\r\n    \r\n\r\ninput.json:\r\n\r\n    {\r\n      &quot;entries&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;test1&quot;,\r\n          &quot;var&quot;: &quot;foo&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;test2&quot;,\r\n          &quot;var&quot;: &quot;bar&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;entries&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;test2&quot;,\r\n          &quot;var&quot;: &quot;bar&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nThe result of `jq &#39;.entries[] | select(.var == &quot;foo&quot;)&#39; input.json` and `jq &#39;.entries[] | select(.var | contains(&quot;foo&quot;))&#39; input.json` is the same, so I think the two `del`-calls should also work.\r\n\r\nIs this a bug in jq or did I something wrong?",
        "link": "https://stackoverflow.com/questions/60170239/using-jq-with-contains-in-a-select-inside-a-del-is-not-working",
        "title": "Using jq with &#39;contains&#39; in a &#39;select&#39; inside a &#39;del&#39; is not working"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "substr"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1581441952,
                "creation_date": 1581441952,
                "answer_id": 60174358,
                "question_id": 60174153,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Apply the substring filter on the &quot;short_description&quot; string:\r\n\r\n    jq -r &#39;.result[].short_description[:250]&#39; test.json\r\n",
                "title": "jq select substring from a column"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1581492277,
        "creation_date": 1581441184,
        "last_edit_date": 1581492277,
        "question_id": 60174153,
        "body_markdown": "I have file test.json containing the following:\r\n\r\n    {\r\n      &quot;result&quot;: [\r\n        {\r\n          &quot;short_description&quot;: &quot;The Net Energy Metering (NEM) Customer Application Database is used to track Customer Applications for a Net Energy Metering Interconnection Application. In almost all cases, the driver of these applications is prompted by the customer installing solar panels on the roof or his or her residence. There are numerous steps required in order to process the NEM applications. The Net Energy Metering Database facilitates this process and allows ACME to keep track of the current status of each customer application.&quot;,\r\n          &quot;managed_by&quot;: &quot;Bill Anderson&quot;,\r\n          &quot;u_storm_impact_flag&quot;: &quot;&quot;,\r\n          &quot;business_criticality&quot;: &quot;Medium&quot;,\r\n          &quot;u_compliance_flag&quot;: &quot;&quot;,\r\n          &quot;active&quot;: &quot;true&quot;,\r\n          &quot;emergency_tier&quot;: &quot;Tier 3&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI can successfully do this:\r\n\r\n    cat test.json|jq -r &#39;.result[].short_description&#39;\r\n\r\n    The Net Energy Metering (NEM) Customer Application Database is used to track Customer Applications for a Net Energy Metering Interconnection Application. In almost all cases, the driver of these applications is prompted by the customer installing solar panels on the roof or his or her residence. There are numerous steps required in order to process the NEM applications. The Net Energy Metering Database facilitates this process and allows PHI to keep track of the current status of each customer application.\r\n\r\nHowever, if I just try to extract the first 250 characters of the &quot;short_description&quot; column i get the following error:\r\n\r\n    cat test.json|jq -r &#39;.result[0:249].short_description&#39;\r\n\r\n    jq: error (at &lt;stdin&gt;:13): Cannot index array with string &quot;short_description&quot;\r\n\r\nCan you please tell me what i&#39;m doing wrong ?\r\n\r\nThanks!\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60174153/jq-select-substring-from-a-column",
        "title": "jq select substring from a column"
    },
    {
        "tags": [
            "json",
            "jq",
            "maxby"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1581485798,
                "creation_date": 1581485798,
                "answer_id": 60181777,
                "question_id": 60180892,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`max_by` requires an array as input, so in the spirit of your attempt, you might wish to consider:\r\n\r\n    .files\r\n    | map( select(.uri | contains(&quot;RELEASE&quot;)\r\n                         and contains(&quot;.jar&quot;)))\r\n    | max_by(.lastModified)\r\n\r\n\r\n\r\n## p.s.\r\nIn future, please follow the guidelines at\r\nhttp://stackoverflow.com/help/mcve",
                "title": "Get newest Jar in Artifactory using JQ API"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1581491761,
        "creation_date": 1581479824,
        "last_edit_date": 1581491761,
        "question_id": 60180892,
        "body_markdown": "I need to download application JAR for execution, and I managed to figure it out up to this step part in my script:\r\n\r\n`jq &#39;.files[] | select(.uri | contains(&quot;RELEASE&quot;) and contains(&quot;.jar&quot;))&#39;`\r\n\r\nThis gives me a bunch of results that looks like multiple blocks of this:\r\n\r\n    {\r\n      other versions\r\n    }\r\n    {\r\n      &quot;uri&quot;: &quot;/2.0.6-RELEASE/app-name-2.0.6-RELEASE.jar&quot;,\r\n      &quot;size&quot;: 32981192,\r\n      &quot;lastModified&quot;: &quot;2020-02-05T14:21:06.728-05:00&quot;,\r\n      &quot;folder&quot;: false,\r\n      &quot;sha1&quot;: &quot;whatever&quot;,\r\n      &quot;sha2&quot;: &quot;whatever2&quot;,\r\n      &quot;mdTimestamps&quot;: {\r\n        &quot;properties&quot;: &quot;2020-02-05T14:21:13.468-05:00&quot;\r\n      }\r\n    }\r\n\r\nBased on the documentation, I tried to extend this to:\r\n\r\n`jq &#39;.files[] | select(.uri | contains(&quot;RELEASE&quot;) and contains(&quot;.jar&quot;)) | max_by(.lastModified)&#39;`\r\nBut it returns error\r\n`jq: error (at &lt;stdin&gt;:3284): Cannot index string with string &quot;lastModified&quot;`\r\n\r\nDocumentation is vague on combining all the different search filters together.. I am not sure what is the correct syntax, please.\r\n\r\nMy goal: Retrieve only one element, ideally just the URI string so that I can use that to fetch the JAR directly on my next command without further processing.\r\n\r\nI also tried the documented syntax for max_by with suffix: ` | {uri}` - same error.",
        "link": "https://stackoverflow.com/questions/60180892/get-newest-jar-in-artifactory-using-jq-api",
        "title": "Get newest Jar in Artifactory using JQ API"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1581490585,
                "last_edit_date": 1581490585,
                "creation_date": 1581485368,
                "answer_id": 60181694,
                "question_id": 60181242,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.edges` is an array, so using your approach, you would have to take that into account, e.g. by writing:\r\n\r\n    .data.allBlocks.edges[].node.date.epoch.lastBlock.id\r\n\r\nAnother of many alternatives you might wish to consider would be to use `..`, e.g.:\r\n\r\n    .. | try (.lastBlock.id) // empty\r\n\r\nOr:\r\n\r\n    .. | objects | .lastBlock.id // empty",
                "title": "cant get past 3rd level of json with jq query"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1581490585,
        "creation_date": 1581482351,
        "question_id": 60181242,
        "body_markdown": "this is a snippet of json. i am trying to get the value of: \r\n\r\n&gt; [data][allBlocks][edges][node][date][epoch][lastBlock][id]\r\n\r\nusing jq from the command line. i can query as far as [edges] but for some reason I cant get the data for [nodes] or anything past that.\r\n\r\n`jq .data.allBlocks.edges` is as far as I can get down the tree. ive looked at the jq manual and i dont really understand the query parameters. nothing i put after edges results in any output its always some kind of error. \r\n\r\n    Formatted JSON Data\r\n    { \r\n       &quot;data&quot;:{ \r\n          &quot;allBlocks&quot;:{ \r\n             &quot;pageInfo&quot;:{ \r\n                &quot;hasNextPage&quot;:false,\r\n                &quot;hasPreviousPage&quot;:true,\r\n                &quot;startCursor&quot;:&quot;190519&quot;,\r\n                &quot;endCursor&quot;:&quot;190521&quot;\r\n             },\r\n             &quot;totalCount&quot;:&quot;190522&quot;,\r\n             &quot;edges&quot;:[ \r\n                { \r\n                   &quot;node&quot;:{ \r\n                      &quot;id&quot;:&quot;27921be509a1336ceaa164cee00cda91c2719a1c0148239433e233ae1bb09c9b&quot;,\r\n                      &quot;date&quot;:{ \r\n                         &quot;slot&quot;:&quot;16338&quot;,\r\n                         &quot;epoch&quot;:{ \r\n                            &quot;id&quot;:&quot;60&quot;,\r\n                            &quot;firstBlock&quot;:{ \r\n                               &quot;id&quot;:&quot;917927a503ed3d9be307dd18f27680c11cb0c405a834c316e3920c7ed8b4e2e8&quot;\r\n                            },\r\n                            &quot;lastBlock&quot;:{ \r\n                               &quot;id&quot;:&quot;27ee50d49eacef10d9ccbfd3c29d09a1aea8268901776085c835ba34f607185b&quot;\r\n                            },\r\n                            &quot;totalBlocks&quot;:&quot;1475&quot;\r\n                         }\r\n                      },",
        "link": "https://stackoverflow.com/questions/60181242/cant-get-past-3rd-level-of-json-with-jq-query",
        "title": "cant get past 3rd level of json with jq query"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581514433,
                "post_id": 60189520,
                "comment_id": 106459494,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6629988,
                    "reputation": 3,
                    "user_id": 5341386,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/861d7a5e29bf001cb5283752f4ce4c0d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Onelifetgo",
                    "link": "https://stackoverflow.com/users/5341386/onelifetgo"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581514614,
                "post_id": 60189520,
                "comment_id": 106459596,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1581514745,
                "creation_date": 1581514745,
                "answer_id": 60189665,
                "question_id": 60189520,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following :\r\n\r\n    jq --raw-output &#39;map_values(select(.state == &quot;ACTIVE&quot;)) | keys[]&#39;\r\n\r\n[Try it here!](https://jqplay.org/s/z2RRLqpmAj)",
                "title": "extract data using jq (keys with specific values)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1581515747,
        "creation_date": 1581514247,
        "last_edit_date": 1581515747,
        "question_id": 60189520,
        "body_markdown": "I have output of repositories in below json format. \r\n```\r\n &quot;test/repo1&quot;: {\r\n    &quot;id&quot;: &quot;Repo1&quot;,\r\n    &quot;description&quot;: &quot;Repo1 Repository&quot;,\r\n    &quot;state&quot;: &quot;ACTIVE&quot;,\r\n    &quot;web_links&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;gitweb&quot;,\r\n        &quot;url&quot;: &quot;/web/repo1/summary&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;gitiles&quot;,\r\n        &quot;url&quot;: &quot;/plugins/repo1&quot;,\r\n        &quot;target&quot;: &quot;_blank&quot;\r\n      }\r\n    ]\r\n  },\r\n   &quot;test/repo2&quot;: {\r\n    &quot;id&quot;: &quot;Repo1&quot;,\r\n    &quot;description&quot;: &quot;Repo2 Repository&quot;,\r\n    &quot;state&quot;: &quot;READ_ONLY&quot;,\r\n    &quot;web_links&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;gitweb&quot;,\r\n        &quot;url&quot;: &quot;/web/repo2/summary&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;gitiles&quot;,\r\n        &quot;url&quot;: &quot;/plugins/repo2&quot;,\r\n        &quot;target&quot;: &quot;_blank&quot;\r\n      }\r\n    ]\r\n  },\r\n   &quot;test/repo3&quot;: {\r\n    &quot;id&quot;: &quot;Repo1&quot;,\r\n    &quot;description&quot;: &quot;Repo3 Repository&quot;,\r\n    &quot;state&quot;: &quot;ACTIVE&quot;,\r\n    &quot;web_links&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;gitweb&quot;,\r\n        &quot;url&quot;: &quot;/web/repo2/summary&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;gitiles&quot;,\r\n        &quot;url&quot;: &quot;/plugins/repo3&quot;,\r\n        &quot;target&quot;: &quot;_blank&quot;\r\n      }\r\n    ]\r\n  }\r\n```\r\nNow I want parse and extract keys which have state as &quot;ACTIVE&quot; so that my final output looks like below. That output should not include repos with &quot;READ_ONLY&quot; state. How to achieve this?\r\n```\r\ntest/repo1\r\ntest/repo3\r\n```",
        "link": "https://stackoverflow.com/questions/60189520/extract-data-using-jq-keys-with-specific-values",
        "title": "extract data using jq (keys with specific values)"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581542620,
                "post_id": 60197036,
                "comment_id": 106474347,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1581542810,
                "post_id": 60197036,
                "comment_id": 106474440,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15704831,
                    "reputation": 93,
                    "user_id": 11331862,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/10219876636453292/picture?type=large",
                    "display_name": "Aaron Etheridge",
                    "link": "https://stackoverflow.com/users/11331862/aaron-etheridge"
                },
                "reply_to_user": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581627656,
                "post_id": 60197036,
                "comment_id": 106510451,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581627738,
                "post_id": 60197036,
                "comment_id": 106510484,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581627768,
                "post_id": 60197036,
                "comment_id": 106510496,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1581542461,
        "creation_date": 1581542461,
        "question_id": 60197036,
        "body_markdown": "This works\r\n\r\n    jq -s   &#39;.[0] * {&quot;channel_group&quot;:{&quot;groups&quot;:{&quot;Application&quot;:{&quot;groups&quot;: {&quot;RobsMSP&quot;:.[1]}}}}}&#39; config.json ./channel-artifacts/${ORG_NAME}.json &gt; modified_config.json\r\n\r\nThis doesn&#39;t work\r\n\r\n    ORG_NAME=&quot;Robs&quot;\r\n    jq -s --arg ORG &quot;${ORG_NAME}MSP&quot;  &#39;.[0] * {&quot;channel_group&quot;:{&quot;groups&quot;:{&quot;Application&quot;:{&quot;groups&quot;: {&quot;$ORG&quot;:.[1]}}}}}&#39; config.json ./channel-artifacts/${ORG_NAME}.json &gt; modified_config.json\r\n\r\nI have looked at other stackoverflow pages regarding a similar issue and have tried env.ORG_NAME but nothing seems to do what I&#39;m asking. I just want to pass ORG_NAME from my environment, append &quot;MSP&quot; to the end of &quot;ORG_NAME&quot; and then pass that to my jq command.`enter code here`\r\n",
        "link": "https://stackoverflow.com/questions/60197036/passing-environment-variables-to-a-jq-command",
        "title": "Passing Environment variables to a jq command"
    },
    {
        "tags": [
            "bash",
            "scripting",
            "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": 1581615043,
                "post_id": 60213193,
                "comment_id": 106504883,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1581615440,
                "last_edit_date": 1581615440,
                "creation_date": 1581614905,
                "answer_id": 60213459,
                "question_id": 60213193,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the `select` function, e.g.:\r\n\r\n&lt;!-- language-all: sh --&gt;\r\n\r\n```\r\ndata=&#39;[{&quot;id&quot;:100000004,&quot;name&quot;:&quot;Customs Clearance Requested&quot;},{&quot;id&quot;:100000005,&quot;name&quot;:&quot;Customs Cleared&quot;},{&quot;id&quot;:100000006,&quot;name&quot;:&quot;Cargo Loaded to Vessel&quot;}]&#39;\r\njq &#39;map(select(.[&quot;name&quot;] == &quot;Customs Clearance Requested&quot;))&#39; &lt;&lt;&lt; $data\r\n```\r\n\r\nIt will get all elements which *name* equals `&quot;Customs Clearance Requested&quot;`, e.g.:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: 100000004,\r\n    &quot;name&quot;: &quot;Customs Clearance Requested&quot;\r\n  }\r\n]\r\n```\r\n\r\nIf you want to get the *id* field:\r\n\r\n`jq &#39;map(select(.[&quot;name&quot;] == &quot;Customs Clearance Requested&quot;)[&quot;id&quot;])&#39; &lt;&lt;&lt; $data`\r\n\r\nThis will output:\r\n\r\n```\r\n[\r\n  100000004\r\n]\r\n```\r\n\r\nPlease note that it will return an *array* and not a single element because the search does not know how many results will be found.\r\n\r\nIf you want to generalize this in a shell function, you could write:\r\n\r\n```\r\nfunction get_id_from_name\r\n{\r\n  # $1=name to search for\r\n  local filter=$(printf &#39;map(select(.[&quot;name&quot;] == &quot;%s&quot;)[&quot;id&quot;])&#39; &quot;$1&quot;)\r\n  jq &quot;$filter&quot;\r\n}\r\n```\r\n\r\nThen call it like that:\r\n\r\n`get_id_from_name &quot;Customs Clearance Requested&quot; &lt;&lt;&lt; $data`\r\n\r\nIf your data is stored in a file, you could call it this way:\r\n\r\n`get_id_from_name &quot;Customs Clearance Requested&quot; &lt; /path/to/file.json`",
                "title": "Converting JSON response to key value pair using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1581615664,
                "last_edit_date": 1581615664,
                "creation_date": 1581615362,
                "answer_id": 60213581,
                "question_id": 60213193,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njson=&#39;[{&quot;id&quot;:100000004,&quot;name&quot;:&quot;Customs Clearance Requested&quot;},{&quot;id&quot;:100000005,&quot;name&quot;:&quot;Customs Cleared&quot;},{&quot;id&quot;:100000006,&quot;name&quot;:&quot;Cargo Loaded to Vessel&quot;}]&#39;\r\n\r\ndeclare -A map\r\nwhile IFS= read -r -d &#39;&#39; name &amp;&amp; IFS= read -r -d &#39;&#39; value; do\r\n  map[$name]=$value\r\ndone &lt; &lt;(jq -j &#39;.[] | &quot;\\(.name)\\u0000\\(.id)\\u0000&quot;&#39; &lt;&lt;&lt;&quot;$json&quot;)\r\n\r\ndeclare -p map  # demo purposes: print the map we created as output\r\n```\r\n\r\n...emits as output:\r\n\r\n```\r\ndeclare -A map=([&quot;Cargo Loaded to Vessel&quot;]=&quot;100000006&quot; [&quot;Customs Clearance Requested&quot;]=&quot;100000004&quot; [&quot;Customs Cleared&quot;]=&quot;100000005&quot; )\r\n```\r\n\r\n...which you can query exactly as requested:\r\n\r\n```\r\n$ echo &quot;${map[&#39;Cargo Loaded to Vessel&#39;]}&quot;\r\n100000006\r\n```",
                "title": "Converting JSON response to key value pair using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1581634944,
                "last_edit_date": 1581634944,
                "creation_date": 1581621748,
                "answer_id": 60215084,
                "question_id": 60213193,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following is very similar to @CharlesDuffy&#39;s excellent answer but does not assume that the `.name` and `.id` values are NUL-free (i.e., do not have any &quot;\\u0000&quot; characters):\r\n\r\n```\r\ndeclare -A map\r\nwhile read -r name\r\ndo\r\n    name=$(sed -e &#39;s/^&quot;//&#39; -e &#39;s/&quot;$//&#39; &lt;&lt;&lt; &quot;$name&quot;)\r\n    read -r id\r\n    map[$name]=&quot;$id&quot;\r\ndone &lt; &lt;(echo &quot;$json&quot; | jq -c &#39;.[]|.name,.id&#39;)\r\n```\r\n\r\nThe point is that the -j option is like -r (i.e., produces &quot;raw output&quot;), whereas the -c option produces JSON.  \r\n\r\nThis means that if you don&#39;t want the .id values as JSON strings, then the above won&#39;t be a solution; also, if the .name values contain double-quotes, then you might want to deal with the occurrences of `\\&quot;`.",
                "title": "Converting JSON response to key value pair using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1581634944,
        "creation_date": 1581613778,
        "question_id": 60213193,
        "body_markdown": "So, I am getting a response from an API that I am calling in a shell script in the following form\r\n\r\n    [{&quot;id&quot;:100000004,&quot;name&quot;:&quot;Customs Clearance Requested&quot;},{&quot;id&quot;:100000005,&quot;name&quot;:&quot;Customs Cleared&quot;},{&quot;id&quot;:100000006,&quot;name&quot;:&quot;Cargo Loaded to Vessel&quot;}]\r\n\r\nI want to create a map out of it that will help me lookup the id&#39;s from a name and use it in the shell script. So something like map[&quot;Customs Clearance Requested&quot;] would give me 100000004 which I can use further. Can this be done using jq? I am pretty new to shell scripting and jq and got stuck with above thing\r\n",
        "link": "https://stackoverflow.com/questions/60213193/converting-json-response-to-key-value-pair-using-jq",
        "title": "Converting JSON response to key value pair using jq"
    },
    {
        "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": 1581646953,
                "post_id": 60219101,
                "comment_id": 106515678,
                "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": 1581647112,
                "post_id": 60219101,
                "comment_id": 106515716,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user7138342"
                },
                "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": 1581658024,
                "post_id": 60219101,
                "comment_id": 106517785,
                "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": 1581658833,
                "post_id": 60219101,
                "comment_id": 106517970,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user7138342"
                },
                "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": 1581659807,
                "post_id": 60219101,
                "comment_id": 106518256,
                "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": 1581687547,
                "post_id": 60219101,
                "comment_id": 106530102,
                "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": 1581687601,
                "post_id": 60219101,
                "comment_id": 106530142,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user7138342"
                },
                "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": 1582000972,
                "post_id": 60219101,
                "comment_id": 106615574,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user7138342"
                },
                "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": 1582005521,
                "post_id": 60219101,
                "comment_id": 106616661,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1582001470,
        "creation_date": 1581646735,
        "last_edit_date": 1582001470,
        "question_id": 60219101,
        "body_markdown": "I am trying to select the groups(groupsMatch) with the following filter conditions but the dynamic variables(userGivenName and userSurname) are going as empty. Any idea?\r\n\r\nSample code with data \r\n\r\n```\r\n#!/bin/bash\r\n# requires jq: https://stedolan.github.io/jq/\r\n\r\ndefaultIFS=$IFS\r\nIFS=$&#39;\\n&#39;\r\n\r\nusers=&#39;[{&quot;id&quot;:&quot;123&quot;,&quot;givenName&quot;:&quot;jose&quot;,&quot;surname&quot;:&quot;sam&quot;},{&quot;id&quot;:&quot;456&quot;,&quot;givenName&quot;:&quot;anbu&quot;,&quot;surname&quot;:&quot;velliah&quot;},{&quot;id&quot;:&quot;789&quot;,&quot;givenName&quot;:&quot;test&quot;,&quot;surname&quot;:&quot;user&quot;}]&#39;\r\ngroups=&#39;[{&quot;id&quot;:&quot;1&quot;,&quot;mail&quot;:&quot;orphangroup@test.com&quot;},{&quot;id&quot;:&quot;2&quot;,&quot;mail&quot;:&quot;josegroup@test.com&quot;},{&quot;id&quot;:&quot;3&quot;,&quot;mail&quot;:&quot;grp-velliah@test.com&quot;}]&#39;\r\n\r\nfor user in `echo $users | jq -c &#39;.[]&#39;`; do\r\n\r\n    userGivenName=`echo $user | jq &#39;.givenName&#39;`\r\n    userSurname=`echo $user | jq &#39;.surname&#39;`\r\n\r\n    groupsMatch=$(echo $groups | jq -c --arg GivenName &quot;$userGivenName&quot; --arg Surname &quot;$userSurname&quot; &#39;map(select((.mail|contains($GivenName)) or (.mail|contains($Surname))))&#39;)\r\n\r\n    for group in `echo $groupsMatch | jq -c &#39;.[]&#39;`; do \r\n        groupId=`echo $group | jq &#39;.id&#39;`\r\n        groupMail=`echo $group | jq &#39;.mail&#39;`\r\n        groupObject=$(jq -n -c \\\r\n                --arg id ${groupId} \\\r\n                --arg gm ${groupMail} \\\r\n                --arg gn ${userGivenName} \\\r\n                --arg sn ${userSurname} \\\r\n                &#39;{groupId: $id, groupMail: $gm, userGivenName: $gn, userSurname: $sn}&#39;)\r\n\r\n        groupsToFlag+=($groupObject)\r\n    done\r\n    \r\ndone\r\n\r\necho ${groupsToFlag[@]} | jq -csr &#39;(.[0] |keys_unsorted | @tsv), (.[]|.|map(.) |@tsv)&#39; | column -s$&#39;\\t&#39; -t\r\n\r\nIFS=defaultIFS\r\nexit 1 \r\n```",
        "link": "https://stackoverflow.com/questions/60219101/unable-to-filter-by-passing-dynamic-value-bash-script",
        "title": "Unable to filter by passing dynamic value bash script"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17124629,
                    "reputation": 2248,
                    "user_id": 12396017,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Nk8xz.png?s=256",
                    "display_name": "Maxim Sagaydachny",
                    "link": "https://stackoverflow.com/users/12396017/maxim-sagaydachny"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581685722,
                "post_id": 60226618,
                "comment_id": 106529107,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 119964,
                    "reputation": 4302,
                    "user_id": 312072,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://www.gravatar.com/avatar/c1f51fb3fe2306ae35f8456a5cc092ec?s=256&d=identicon&r=PG",
                    "display_name": "chrisan",
                    "link": "https://stackoverflow.com/users/312072/chrisan"
                },
                "reply_to_user": {
                    "account_id": 17124629,
                    "reputation": 2248,
                    "user_id": 12396017,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Nk8xz.png?s=256",
                    "display_name": "Maxim Sagaydachny",
                    "link": "https://stackoverflow.com/users/12396017/maxim-sagaydachny"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581686937,
                "post_id": 60226618,
                "comment_id": 106529772,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581687517,
                "post_id": 60226618,
                "comment_id": 106530080,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1581692176,
                "last_edit_date": 1581692176,
                "creation_date": 1581686447,
                "answer_id": 60227182,
                "question_id": 60226618,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Works with change &#39; &#39; to &#39;_&#39; and back\r\n\r\n    messages=$( jq -rc &#39;[.[].message] | unique | @sh&#39; &lt;&lt;&lt;&quot;${commits}&quot; )\r\n    messages=&quot;${messages// /_}&quot;\r\n    messages=(${messages//&quot;&#39;_&#39;&quot;/&quot;&#39; &#39;&quot;})\r\n    echo &quot;messages: ${messages[@]//_/ }&quot;\r\n    for message in &quot;${messages[@]//_/ }&quot;\r\n    do\r\n      echo &quot; message: $message&quot;\r\n    done\r\n\r\nOr like this\r\n\r\n    IFS=$&#39;\\n&#39; messages=( $(jq -rc &#39;.[].message&#39; &lt;&lt;&lt;&quot;${commits}&quot;) )\r\n    printf   &quot;messages: &quot;; printf &quot;&#39;%s&#39; &quot; &quot;${messages[@]}&quot;; echo\r\n    printf   &quot; message: &#39;%s&#39; \\n&quot;          &quot;${messages[@]}&quot;\r\n\r\nAnd we could do something like that\r\n\r\n         IFS=$&#39;\\n&#39;\r\n     authors=($(jq -rc &#39;.[].author.name&#39; &lt;&lt;&lt;&quot;${commits}&quot;))\r\n    messages=($(jq -rc &#39;.[].message&#39;     &lt;&lt;&lt;&quot;${commits}&quot;))\r\n    printf &quot; authors | &quot;; printf &quot;&#39;%s&#39; &quot; &quot;${authors[@]}&quot; ; echo\r\n    printf &quot;  author | &#39;%s&#39; \\n&quot;          &quot;${authors[@]}&quot;\r\n    echo   &quot;---------+---------&quot;\r\n    printf &quot;messages | &quot;; printf &quot;&#39;%s&#39; &quot; &quot;${messages[@]}&quot;; echo\r\n    printf &quot; message | &#39;%s&#39; \\n&quot;          &quot;${messages[@]}&quot;\r\n\r\nTo output like this\r\n\r\n     authors | &#39;Chris&#39; &#39;John&#39; &#39;John&#39; \r\n      author | &#39;Chris&#39; \r\n      author | &#39;John&#39; \r\n      author | &#39;John&#39; \r\n    ---------+---------\r\n    messages | &#39;commit message 1&#39; &#39;commit message 2&#39; &#39;commit message 3&#39; \r\n     message | &#39;commit message 1&#39; \r\n     message | &#39;commit message 2&#39; \r\n     message | &#39;commit message 3&#39; ",
                "title": "How to loop over jq unique array in bash?"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1581695746,
                "last_edit_date": 1581695746,
                "creation_date": 1581687979,
                "answer_id": 60227587,
                "question_id": 60226618,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `readarray` (Bash 4+) to map null delimited output from `jq`:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\ncommits=&#39;[\r\n  {\r\n    &quot;author&quot;: {\r\n      &quot;email&quot;: &quot;email@example.com&quot;,\r\n      &quot;name&quot;: &quot;Chris&quot;,\r\n      &quot;username&quot;: &quot;chris&quot;\r\n    },\r\n    &quot;committer&quot;: {\r\n      &quot;email&quot;: &quot;email@example.com&quot;,\r\n      &quot;name&quot;: &quot;Chris&quot;,\r\n      &quot;username&quot;: &quot;chris&quot;\r\n    },\r\n    &quot;message&quot;: &quot;commit message 1&quot;\r\n  },\r\n  {\r\n    &quot;author&quot;: {\r\n      &quot;email&quot;: &quot;email@example.com&quot;,\r\n      &quot;name&quot;: &quot;John&quot;,\r\n      &quot;username&quot;: &quot;jdoe&quot;\r\n    },\r\n    &quot;committer&quot;: {\r\n      &quot;email&quot;: &quot;email@example.com&quot;,\r\n      &quot;name&quot;: &quot;John&quot;,\r\n      &quot;username&quot;: &quot;jdoe&quot;\r\n    },\r\n    &quot;message&quot;: &quot;commit message 2&quot;\r\n  },\r\n    {\r\n    &quot;author&quot;: {\r\n      &quot;email&quot;: &quot;email@example.com&quot;,\r\n      &quot;name&quot;: &quot;John&quot;,\r\n      &quot;username&quot;: &quot;jdoe&quot;\r\n    },\r\n    &quot;committer&quot;: {\r\n      &quot;email&quot;: &quot;email@example.com&quot;,\r\n      &quot;name&quot;: &quot;John&quot;,\r\n      &quot;username&quot;: &quot;jdoe&quot;\r\n    },\r\n    &quot;message&quot;: &quot;commit message 3&quot;\r\n  }\r\n]&#39;\r\n\r\nreadarray -d &#39;&#39; authors &lt; &lt;(jq -j &#39;.[].author.name + &quot;\\u0000&quot;&#39; &lt;&lt;&lt;&quot;${commits}&quot;)\r\n\r\nfor author in &quot;${authors[@]}&quot;\r\ndo\r\n  echo &quot;author: $author&quot;\r\ndone\r\n\r\necho &quot;------------&quot;\r\n\r\nreadarray -d &#39;&#39; messages &lt; &lt;(jq -j &#39;.[].message + &quot;\\u0000&quot;&#39; &lt;&lt;&lt;&quot;${commits}&quot;)\r\n\r\nfor message in &quot;${messages[@]}&quot;\r\ndo\r\n  echo &quot;message: $message&quot;\r\ndone\r\n```\r\n\r\nAlternatively, if you have an older Bash version without `readarray` or `mapfile` you may separate the strings with the ASCII control character ETX (End of TeXt `03`) and use `read` instead like this:\r\n\r\n```sh\r\nIFS=$&#39;\\03&#39; read -d &#39;&#39; -ra authors &lt; &lt;(jq -j &#39;.[].author.name + &quot;\\u0003&quot;&#39; &lt;&lt;&lt;&quot;${commits}&quot;)\r\n\r\nIFS=$&#39;\\03&#39; read -d &#39;&#39; -ra messages &lt; &lt;(jq -j &#39;.[].message + &quot;\\u0003&quot;&#39; &lt;&lt;&lt;&quot;${commits}&quot;)\r\n```\r\n\r\nIt is also possible to populate both arrays from a single `jq` call:\r\n\r\n```sh\r\n# Populates both arrays from a single jq call\r\n{\r\n  IFS=$&#39;\\03&#39; read -r -d &#39;&#39; -a authors\r\n  IFS=$&#39;\\03&#39; read -r -d &#39;&#39; -a messages\r\n} &lt; &lt;(jq -j &#39;([.[].author.name] | unique | .[] + &quot;\\u0003&quot;), &quot;\\u0000&quot;,  ([.[].message] | unique | .[] + &quot;\\u0003&quot;)&#39; &lt;&lt;&lt;&quot;${commits}&quot;)\r\n```\r\n\r\nExplanation:\r\n\r\n- `[.[].author.name] | unique | .[] + &quot;\\u0003&quot;`:  \r\n  Output an `ETX (03)` delimited list of unique author names.\r\n\r\n- `&quot;\\u0000&quot;`: insert a null delimiter\r\n- `[.[].message] | unique | .[] + &quot;\\u0003&quot;`:  \r\n  Output an `ETX (03)` delimited list of unique messages.\r\n\r\n- Feeds the whole output of `jq` to a command group with two `read` commands.  \r\n  Each `read` will stop at the null delimiter or end of the stream.  \r\n```sh\r\n{\r\n  IFS=$&#39;\\03&#39; read -r -d &#39;&#39; -a authors\r\n  IFS=$&#39;\\03&#39; read -r -d &#39;&#39; -a messages\r\n}\r\n```",
                "title": "How to loop over jq unique array in bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1581695746,
        "creation_date": 1581684260,
        "question_id": 60226618,
        "body_markdown": "I&#39;m trying to loop over unique names and commit messages from a github json object.  However when there are spaces in the arrays bash will treat them as individual array items\r\n\r\n    #!/usr/bin/env bash\r\n    \r\n    commits=&#39;[\r\n      {\r\n        &quot;author&quot;: {\r\n          &quot;email&quot;: &quot;email@example.com&quot;,\r\n          &quot;name&quot;: &quot;Chris&quot;,\r\n          &quot;username&quot;: &quot;chris&quot;\r\n        },\r\n        &quot;committer&quot;: {\r\n          &quot;email&quot;: &quot;email@example.com&quot;,\r\n          &quot;name&quot;: &quot;Chris&quot;,\r\n          &quot;username&quot;: &quot;chris&quot;\r\n        },\r\n        &quot;message&quot;: &quot;commit message 1&quot;\r\n      },\r\n      {\r\n        &quot;author&quot;: {\r\n          &quot;email&quot;: &quot;email@example.com&quot;,\r\n          &quot;name&quot;: &quot;John&quot;,\r\n          &quot;username&quot;: &quot;jdoe&quot;\r\n        },\r\n        &quot;committer&quot;: {\r\n          &quot;email&quot;: &quot;email@example.com&quot;,\r\n          &quot;name&quot;: &quot;John&quot;,\r\n          &quot;username&quot;: &quot;jdoe&quot;\r\n        },\r\n        &quot;message&quot;: &quot;commit message 2&quot;\r\n      },\r\n        {\r\n        &quot;author&quot;: {\r\n          &quot;email&quot;: &quot;email@example.com&quot;,\r\n          &quot;name&quot;: &quot;John&quot;,\r\n          &quot;username&quot;: &quot;jdoe&quot;\r\n        },\r\n        &quot;committer&quot;: {\r\n          &quot;email&quot;: &quot;email@example.com&quot;,\r\n          &quot;name&quot;: &quot;John&quot;,\r\n          &quot;username&quot;: &quot;jdoe&quot;\r\n        },\r\n        &quot;message&quot;: &quot;commit message 3&quot;\r\n      }\r\n    ]&#39;\r\n    \r\n    authors=$( jq -rc &#39;[.[].author.name] | unique | @sh&#39; &lt;&lt;&lt;&quot;${commits}&quot; )\r\n    echo &quot;authors: $authors&quot;\r\n    \r\n    # this works\r\n    for author in $authors\r\n    do\r\n      echo &quot;author: $author&quot;\r\n    done\r\n    \r\n    echo &quot;------------&quot;\r\n    \r\n    # this does not\r\n    messages=$( jq -rc &#39;[.[].message] | unique | @sh&#39; &lt;&lt;&lt;&quot;${commits}&quot; )\r\n    echo &quot;messages: $messages&quot;\r\n    \r\n    for message in $messages\r\n    do\r\n      echo &quot;message: $message&quot;\r\n    done\r\n\r\nWhich outputs\r\n\r\n    authors: &#39;Chris&#39; &#39;John&#39;\r\n    author: &#39;Chris&#39;\r\n    author: &#39;John&#39;\r\n    ------------\r\n    messages: &#39;commit message 1&#39; &#39;commit message 2&#39; &#39;commit message 3&#39;\r\n    message: &#39;commit\r\n    message: message\r\n    message: 1&#39;\r\n    message: &#39;commit\r\n    message: message\r\n    message: 2&#39;\r\n    message: &#39;commit\r\n    message: message\r\n    message: 3&#39;\r\n    \r\nWhile I expect:    \r\n    \r\n    authors: &#39;Chris&#39; &#39;John&#39;\r\n    author: &#39;Chris&#39;\r\n    author: &#39;John&#39;\r\n    ------------\r\n    messages: &#39;commit message 1&#39; &#39;commit message 2&#39; &#39;commit message 3&#39;\r\n    message: &#39;commit message 1&#39;\r\n    message: &#39;commit message 2&#39;\r\n    message: &#39;commit message 3&#39;",
        "link": "https://stackoverflow.com/questions/60226618/how-to-loop-over-jq-unique-array-in-bash",
        "title": "How to loop over jq unique array in bash?"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4711502,
                    "reputation": 8121,
                    "user_id": 3811887,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/y4noo.png?s=256",
                    "display_name": "Andy",
                    "link": "https://stackoverflow.com/users/3811887/andy"
                },
                "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": 1581693884,
                "post_id": 60228327,
                "comment_id": 106533528,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581709700,
                "post_id": 60228327,
                "comment_id": 106540294,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4711502,
                    "reputation": 8121,
                    "user_id": 3811887,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/y4noo.png?s=256",
                    "display_name": "Andy",
                    "link": "https://stackoverflow.com/users/3811887/andy"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1581781175,
                "post_id": 60228327,
                "comment_id": 106554139,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1581790729,
                "last_edit_date": 1581790729,
                "creation_date": 1581715606,
                "answer_id": 60233748,
                "question_id": 60228327,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one of several possibilities that use `INDEX/2`. If your jq does not have this as a built-in, see below.\r\n```\r\njq --argfile a a.json &#39;\r\n  INDEX($a[]; .id) as $dict\r\n  | map( (.id|tostring) as $id\r\n         | if ($dict|has($id)) then .foo = $dict[$id].foo \r\n           else . end)&#39; b.json\r\n```\r\nThere are other ways to pass in the contents of a.json and b.json. \r\n\r\n## Caveat\r\nThe above use of INDEX assumes there are no &quot;collisions&quot;, which would happen if, for example, one of the objects has .id equal to 1 and another has .id equal to &quot;1&quot;.  If there is a possibility of such a collision, then a more complex definition of INDEX could be used.\r\n\r\n## `INDEX/2`\r\nStraight from builtin.jq:\r\n\r\n```\r\ndef INDEX(stream; idx_expr):\r\n  reduce stream as $row ({}; .[$row|idx_expr|tostring] = $row);\r\n```",
                "title": "Use jq to merge keys with common id"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1581718574,
                "creation_date": 1581718574,
                "answer_id": 60234189,
                "question_id": 60228327,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a generic answer that makes no assumptions about the values of the .id keys except that they are distinct JSON values.\r\n\r\n### Generalization of INDEX/2\r\n```\r\ndef type2: [type, if type == &quot;string&quot; then . else tojson end];\r\n\r\ndef dictionary(stream; f):\r\n  reduce stream as $s ({}; setpath($s|f|type2; $s));\r\n\r\ndef lookup(value):\r\n  getpath(value|type2);\r\n\r\ndef indictionary(value):\r\n  (value|type2) as $t\r\n  | has($t[0]) and (.[$t[0]] | has($t[1]));\r\n```\r\n## Invocation\r\n\r\n    jq --argfile a a.json -f program.jq b.json \r\n\r\n## main \r\n\r\n```\r\ndictionary($a[]; .id) as $dict\r\n| b\r\n| map( .id as $id \r\n       | if ($dict|indictionary($id)) \r\n         then .foo = ($dict|lookup($id).foo) \r\n         else . end)\r\n```\r\n\r\n\r\n\r\n",
                "title": "Use jq to merge keys with common id"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1581852282,
        "creation_date": 1581690720,
        "last_edit_date": 1581852282,
        "question_id": 60228327,
        "body_markdown": "consider a file &#39;b.json&#39;:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 3,\r\n        &quot;foo&quot;: &quot;cannot be replaced, id isn&#39;t in a.json, stay untouched&quot;,\r\n        &quot;baz&quot;: &quot;do not touch3&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;foo&quot;: &quot;should be replaced with &#39;foo new2&#39;&quot;,\r\n        &quot;baz&quot;: &quot;do not touch2&quot;\r\n      }\r\n    ]\r\n\r\nand &#39;a.json&#39;:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;foo&quot;: &quot;foo new2&quot;,\r\n        &quot;baz&quot;: &quot;don&#39;t care&quot;\r\n      }\r\n    ]\r\n\r\nI want to update the key &quot;foo&quot; in b.json using jq with the matching value from a.json. It should also work with more than one entry in a.json.\r\n\r\nThus the desired output is:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 3,\r\n        &quot;foo&quot;: &quot;cannot be replaced, id isn&#39;t in a.json, stay untouched&quot;,\r\n        &quot;baz&quot;: &quot;do not touch3&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;foo&quot;: &quot;foo new2&quot;,\r\n        &quot;baz&quot;: &quot;do not touch2&quot;\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/60228327/use-jq-to-merge-keys-with-common-id",
        "title": "Use jq to merge keys with common id"
    },
    {
        "tags": [
            "json",
            "ansible",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1676371349,
                "last_edit_date": 1676371349,
                "creation_date": 1581694263,
                "answer_id": 60229226,
                "question_id": 60228560,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I assume you want to get a loop over all key-values attributes in the `ansible_facts.packages`, so it&#39;s recommended to use a Bash loop to iterate over it. Also the sample contents of the JSON you provided don&#39;t compile, I removed the comma 3 rows from the end.\r\n\r\nYou need one jq to get all the keys of the `ansible_facts.packages` and then in each iteration to get the version of the given key (package).\r\n\r\nTo get all the keys:\r\n\r\n    [http_offline@greenhat-30 tmp]$ cat file.json | jq &#39;.&quot;ansible_facts.packages&quot; | keys[]&#39;\r\n    &quot;GConf2&quot;\r\n    &quot;GeoIP&quot;\r\n    &quot;ImageMagick&quot;\r\n    [http_offline@greenhat-30 tmp]$ \r\n\r\nLoop:\r\n\r\n    for package in `cat file.json | jq &#39;.&quot;ansible_facts.packages&quot; | keys[]&#39;`\r\n    do\r\n    VERSION=`cat file.json | jq &quot;.\\&quot;ansible_facts.packages\\&quot;.$package[0].version&quot;`\r\n    echo &quot;$package,$VERSION&quot;\r\n    done\r\n\r\n\r\nSample run:\r\n\r\n    [http_offline@greenhat-30 tmp]$ for package in `cat file.json | jq &#39;.&quot;ansible_facts.packages&quot; | keys[]&#39;`\r\n    &gt; do\r\n    &gt; VERSION=`cat file.json | jq &quot;.\\&quot;ansible_facts.packages\\&quot;.$package[0].version&quot;`\r\n    &gt; echo &quot;$package,$VERSION&quot;\r\n    &gt; done\r\n    &quot;GConf2&quot;,&quot;3.2.6&quot;\r\n    &quot;GeoIP&quot;,&quot;1.5.0&quot;\r\n    &quot;ImageMagick&quot;,&quot;6.7.8.9&quot;\r\n    [http_offline@greenhat-30 tmp]$ \r\n",
                "title": "Ansible output extract package version using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1581979259,
                "last_edit_date": 1581979259,
                "creation_date": 1581699807,
                "answer_id": 60230679,
                "question_id": 60228560,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt;Q: *&quot;How can I use jq to get the version number for matching package name?&quot;*\r\n\r\nA: Try the script below\r\n```\r\n$ cat print-version.sh\r\n#!/bin/sh\r\ncat output.json | jq &quot;.ansible_facts.packages.$1 | .[].version&quot;\r\n```\r\nFor example\r\n```\r\n$ print-version.sh GeoIP\r\n&quot;1.5.0&quot;\r\n```\r\n&lt;hr&gt;\r\nImproved version of the script\r\n\r\nQuoting the comment: *`&quot;Using the shell&#39;s string interpolation as done here is risky and generally regarded as an &quot;anti-pattern&quot;. – peak&quot;`*\r\n\r\nThe improved script below does the job\r\n```\r\n$ cat print-version.sh\r\n#!/bin/sh\r\ncat output.json | jq &quot;.ansible_facts.packages.$1[].version&quot;\r\n```\r\n&lt;hr&gt;\r\noutput.json\r\n```\r\n{\r\n    &quot;ansible_facts&quot;: {\r\n        &quot;packages&quot;: {\r\n            &quot;GConf2&quot;: [\r\n                {\r\n                    &quot;arch&quot;: &quot;x86_64&quot;,\r\n                    &quot;epoch&quot;: null,\r\n                    &quot;name&quot;: &quot;GConf2&quot;,\r\n                    &quot;release&quot;: &quot;8.el7&quot;,\r\n                    &quot;source&quot;: &quot;rpm&quot;,\r\n                    &quot;version&quot;: &quot;3.2.6&quot;\r\n                }\r\n            ],\r\n            &quot;GeoIP&quot;: [\r\n                {\r\n                    &quot;arch&quot;: &quot;x86_64&quot;,\r\n                    &quot;epoch&quot;: null,\r\n                    &quot;name&quot;: &quot;GeoIP&quot;,\r\n                    &quot;release&quot;: &quot;14.el7&quot;,\r\n                    &quot;source&quot;: &quot;rpm&quot;,\r\n                    &quot;version&quot;: &quot;1.5.0&quot;\r\n                }\r\n            ],\r\n            &quot;ImageMagick&quot;: [\r\n                {\r\n                    &quot;arch&quot;: &quot;x86_64&quot;,\r\n                    &quot;epoch&quot;: null,\r\n                    &quot;name&quot;: &quot;ImageMagick&quot;,\r\n                    &quot;release&quot;: &quot;18.el7&quot;,\r\n                    &quot;source&quot;: &quot;rpm&quot;,\r\n                    &quot;version&quot;: &quot;6.7.8.9&quot;\r\n                }\r\n            ]\r\n        }\r\n    }\r\n}\r\n```\r\n",
                "title": "Ansible output extract package version using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1581706425,
                "last_edit_date": 1581706425,
                "creation_date": 1581702641,
                "answer_id": 60231263,
                "question_id": 60228560,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, make the source valid json by removing the comma in the third to last row.\r\n\r\nWith that done, we can start at the end and work back. The desired output can be produced using jq&#39;s @csv format. That, in turn, requires that the output is in an array. (See the section of the [manual](https://stedolan.github.io/jq/manual/v1.6/#Builtinoperatorsandfunctions) titled &quot;Format strings and escaping&quot;.) So we need to get the data to look like this. \r\n\r\n    jq -r &#39;[&quot;GeoIP&quot;,&quot;1.5.0&quot;] | @csv&#39;\r\n\r\nOne way to do that is to put each item in its own array and add the arrays together. (See [the section](https://stedolan.github.io/jq/manual/v1.6/#Builtinoperatorsandfunctions) titled &quot;Addition&quot;.)\r\n\r\n    jq -r &#39;[&quot;GeoIP&quot;] + [.[] | .GeoIP[].version] | @csv&#39;\r\n\r\nSince `map(x)` is defined as `[.[] | x]`, you can say this instead.\r\n\r\n    jq -r &#39;[&quot;GeoIP&quot;] + map(.GeoIP[].version) | @csv&#39;\r\n\r\nYou can use a variable to specify the package name you want like this.\r\n\r\n    jq -r --arg &quot;package&quot; &quot;GeoIP&quot; &#39;[$package] + map(.[$package][].version) | @csv&#39;\r\n\r\n\r\n**Update**\r\n\r\nMy original solution has unnecessary steps. The array can be made like this.\r\n\r\n    jq -r &#39;[ &quot;GeoIP&quot;, .[].GeoIP[].version ] | @csv&#39;\r\n\r\nOr, using a variable\r\n\r\n    jq -r --arg &quot;package&quot; &quot;GeoIP&quot; &#39;[$package,(.[] | .[$package][].version)]| @csv&#39;",
                "title": "Ansible output extract package version using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1676371349,
        "creation_date": 1581691663,
        "last_edit_date": 1581832478,
        "question_id": 60228560,
        "body_markdown": "I have below json output from ansible, I want to parse this file using `jq`.  I want to match packages name `GeoIP` and print version number.\r\n\r\nHow can I use `jq` to get this version number for matching package name? looking output like this\r\n\r\n    &quot;GeoIP&quot;,&quot;1.5.0&quot;\r\n\r\n\r\n**sample ansible output**\r\n\r\n    {\r\n        &quot;ansible_facts.packages&quot;: {\r\n            &quot;GConf2&quot;: [\r\n                {\r\n                    &quot;arch&quot;: &quot;x86_64&quot;,\r\n                    &quot;epoch&quot;: null,\r\n                    &quot;name&quot;: &quot;GConf2&quot;,\r\n                    &quot;release&quot;: &quot;8.el7&quot;,\r\n                    &quot;source&quot;: &quot;rpm&quot;,\r\n                    &quot;version&quot;: &quot;3.2.6&quot;\r\n                }\r\n            ],\r\n            &quot;GeoIP&quot;: [\r\n                {\r\n                    &quot;arch&quot;: &quot;x86_64&quot;,\r\n                    &quot;epoch&quot;: null,\r\n                    &quot;name&quot;: &quot;GeoIP&quot;,\r\n                    &quot;release&quot;: &quot;14.el7&quot;,\r\n                    &quot;source&quot;: &quot;rpm&quot;,\r\n                    &quot;version&quot;: &quot;1.5.0&quot;\r\n                }\r\n            ],\r\n            &quot;ImageMagick&quot;: [\r\n                {\r\n                    &quot;arch&quot;: &quot;x86_64&quot;,\r\n                    &quot;epoch&quot;: null,\r\n                    &quot;name&quot;: &quot;ImageMagick&quot;,\r\n                    &quot;release&quot;: &quot;18.el7&quot;,\r\n                    &quot;source&quot;: &quot;rpm&quot;,\r\n                    &quot;version&quot;: &quot;6.7.8.9&quot;\r\n                }\r\n            ],\r\n    \t}\r\n    }",
        "link": "https://stackoverflow.com/questions/60228560/ansible-output-extract-package-version-using-jq",
        "title": "Ansible output extract package version using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1581701697,
                "last_edit_date": 1581701697,
                "creation_date": 1581700491,
                "answer_id": 60230818,
                "question_id": 60230332,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With some help from a coworker I was able to figure it out:\r\n```\r\n$ export ASSET_ID=12123121\r\n$ cat input.json | jq -r &quot;to_entries[] | .value.to_compute[] + {job: .key} | select(.asset_id==$ASSET_ID) | .job&quot;\r\n27852380038\r\n```",
                "title": "Print key if any nested value matches a set value"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1581749819,
                "last_edit_date": 1581749819,
                "creation_date": 1581749452,
                "answer_id": 60236558,
                "question_id": 60230332,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The task can be accomplished without using environment variables, e.g.\r\n\r\n    &lt; input.json jq -r --argjson ASSET_ID 12123121 &#39;\r\n      to_entries[]\r\n      | {key, asset_id: .value.to_compute[].asset_id}\r\n      | select(.asset_id==$ASSET_ID)\r\n      | .key&#39;\r\n\r\nor more efficiently, using the filter:\r\n\r\n    to_entries[]\r\n    | select( any( .value.to_compute[]; .asset_id==$ASSET_ID) )\r\n    | .key\r\n",
                "title": "Print key if any nested value matches a set value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1581749819,
        "creation_date": 1581698417,
        "question_id": 60230332,
        "body_markdown": "This is best explained with expected input and output.\r\n\r\nGiven this input:\r\n```\r\n{\r\n  &quot;27852380038&quot;: {\r\n    &quot;compute_id&quot;: 34234234,\r\n    &quot;to_compute&quot;: [\r\n      {\r\n        &quot;asset_id&quot;: 304221854,\r\n        &quot;new_scheme&quot;: &quot;mynewscheme&quot;,\r\n        &quot;original_host&quot;: &quot;oldscheme1234.location.com&quot;\r\n      },\r\n      {\r\n        &quot;asset_id&quot;: 12123121,\r\n        &quot;new_scheme&quot;: &quot;myotherscheme&quot;,\r\n        &quot;original_host&quot;: &quot;olderscheme1234.location.com&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;31352333022&quot;: {\r\n    &quot;compute_id&quot;: 43888877,\r\n    &quot;to_compute&quot;: [\r\n      {\r\n        &quot;asset_id&quot;: 404221555,\r\n        &quot;new_scheme&quot;: &quot;mynewscheme&quot;,\r\n        &quot;original_host&quot;: &quot;oldscheme1234.location.com&quot;\r\n      },\r\n      {\r\n        &quot;asset_id&quot;: 52123444,\r\n        &quot;new_scheme&quot;: &quot;myotherscheme&quot;,\r\n        &quot;original_host&quot;: &quot;olderscheme1234.location.com&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\nAnd the `asset_id` that I&#39;m searching for, 12123121, the output should be:\r\n\r\n```\r\n27852380038\r\n```\r\n\r\nSo I want the top level keys where any of the `asset_id`s in `to_compute` match my input `asset_id`.\r\n\r\nI haven&#39;t seen any jq example so far that combines nested access with an any test / if else.",
        "link": "https://stackoverflow.com/questions/60230332/print-key-if-any-nested-value-matches-a-set-value",
        "title": "Print key if any nested value matches a set value"
    },
    {
        "tags": [
            "json",
            "iterator",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1581764304,
                "creation_date": 1581764304,
                "answer_id": 60238081,
                "question_id": 60237816,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for `|=` operator.\r\n```\r\n.[].slots[].instances[].services[] |= (.status = .unhealthy + .healthy)\r\n```",
                "title": "jq: Add field to collection deep in nested structure, calculated from other fields at the same level"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1581799277,
        "creation_date": 1581762145,
        "last_edit_date": 1581799277,
        "question_id": 60237816,
        "body_markdown": "I&#39;m looking for someone who can give me a hint with jq here - it seems I&#39;m missing out on something.\r\n\r\nMy JSON source would be similar to this:\r\n\r\n```\r\n[\r\n\t{\r\n\t\t&quot;cluster&quot;: &quot;one&quot;,\r\n\t\t&quot;slots&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;instances&quot;: [\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;number&quot;: 0,\r\n\t\t\t\t\t\t&quot;services&quot;: [\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;A&quot;,\r\n\t\t\t\t\t\t\t\t&quot;unhealthy&quot;: 0,\r\n\t\t\t\t\t\t\t\t&quot;healthy&quot;: 4\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;B&quot;,\r\n\t\t\t\t\t\t\t\t&quot;unhealthy&quot;: 2,\r\n\t\t\t\t\t\t\t\t&quot;healthy&quot;: 2\r\n\t\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\t{\r\n\t\t\t\t\t\t&quot;number&quot;: 1,\r\n\t\t\t\t\t\t&quot;services&quot;: [\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;B&quot;,\r\n\t\t\t\t\t\t\t\t&quot;unhealthy&quot;: 0,\r\n\t\t\t\t\t\t\t\t&quot;healthy&quot;: 6\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;C&quot;,\r\n\t\t\t\t\t\t\t\t&quot;unhealthy&quot;: 0,\r\n\t\t\t\t\t\t\t\t&quot;healthy&quot;: 2\r\n\t\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\t{\r\n\t\t&quot;cluster&quot;: &quot;two&quot;,\r\n\t\t&quot;slots&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;instances&quot;: [\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;number&quot;: 1,\r\n\t\t\t\t\t\t&quot;services&quot;: [\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;A&quot;,\r\n\t\t\t\t\t\t\t\t&quot;unhealthy&quot;: 1,\r\n\t\t\t\t\t\t\t\t&quot;healthy&quot;: 9\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;C&quot;,\r\n\t\t\t\t\t\t\t\t&quot;unhealthy&quot;: 0,\r\n\t\t\t\t\t\t\t\t&quot;healthy&quot;: 10\r\n\t\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\t{\r\n\t\t\t\t\t\t&quot;number&quot;: 0,\r\n\t\t\t\t\t\t&quot;services&quot;: [\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;B&quot;,\r\n\t\t\t\t\t\t\t\t&quot;unhealthy&quot;: 0,\r\n\t\t\t\t\t\t\t\t&quot;healthy&quot;: 9\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;D&quot;,\r\n\t\t\t\t\t\t\t\t&quot;unhealthy&quot;: 0,\r\n\t\t\t\t\t\t\t\t&quot;healthy&quot;: 14\r\n\t\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\nWhat I need would be a new &quot;status&quot; field in each innermost collection as the sum of the &quot;healthy&quot; and &quot;unhealthy&quot; states, like this:\r\n\r\n```\r\n[\r\n\t{\r\n\t\t&quot;cluster&quot;: &quot;one&quot;,\r\n\t\t&quot;slots&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;instances&quot;: [\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;number&quot;: 0,\r\n\t\t\t\t\t\t&quot;services&quot;: [\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;A&quot;,\r\n\t\t\t\t\t\t\t\t&quot;unhealthy&quot;: 0,\r\n\t\t\t\t\t\t\t\t&quot;healthy&quot;: 4,\r\n\t\t\t\t\t\t\t\t&quot;status&quot;: 4\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;B&quot;,\r\n\t\t\t\t\t\t\t\t&quot;unhealthy&quot;: 2,\r\n\t\t\t\t\t\t\t\t&quot;healthy&quot;: 2,\r\n\t\t\t\t\t\t\t\t&quot;status&quot;: 4\r\n\t\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\t{\r\n\t\t\t\t\t\t&quot;number&quot;: 1,\r\n\t\t\t\t\t\t&quot;services&quot;: [\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;B&quot;,\r\n\t\t\t\t\t\t\t\t&quot;unhealthy&quot;: 0,\r\n\t\t\t\t\t\t\t\t&quot;healthy&quot;: 6,\r\n\t\t\t\t\t\t\t\t&quot;status&quot;: 6\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;C&quot;,\r\n\t\t\t\t\t\t\t\t&quot;unhealthy&quot;: 0,\r\n\t\t\t\t\t\t\t\t&quot;healthy&quot;: 2,\r\n\t\t\t\t\t\t\t\t&quot;status&quot;: 2\r\n\t\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\t{\r\n\t\t&quot;cluster&quot;: &quot;two&quot;,\r\n\t\t&quot;slots&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;instances&quot;: [\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;number&quot;: 1,\r\n\t\t\t\t\t\t&quot;services&quot;: [\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;A&quot;,\r\n\t\t\t\t\t\t\t\t&quot;unhealthy&quot;: 1,\r\n\t\t\t\t\t\t\t\t&quot;healthy&quot;: 9,\r\n\t\t\t\t\t\t\t\t&quot;status&quot;: 10\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;C&quot;,\r\n\t\t\t\t\t\t\t\t&quot;unhealthy&quot;: 0,\r\n\t\t\t\t\t\t\t\t&quot;healthy&quot;: 10,\r\n\t\t\t\t\t\t\t\t&quot;status&quot;: 10\r\n\t\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\t{\r\n\t\t\t\t\t\t&quot;number&quot;: 0,\r\n\t\t\t\t\t\t&quot;services&quot;: [\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;B&quot;,\r\n\t\t\t\t\t\t\t\t&quot;unhealthy&quot;: 0,\r\n\t\t\t\t\t\t\t\t&quot;healthy&quot;: 9,\r\n\t\t\t\t\t\t\t\t&quot;status&quot;: 9\r\n\t\t\t\t\t\t\t},\r\n\t\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t\t&quot;name&quot;: &quot;D&quot;,\r\n\t\t\t\t\t\t\t\t&quot;unhealthy&quot;: 0,\r\n\t\t\t\t\t\t\t\t&quot;healthy&quot;: 14,\r\n\t\t\t\t\t\t\t\t&quot;status&quot;: 14\r\n\t\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\nIs there a way to iterate in this manner:\r\n\r\n`jq &#39;.[].slots[].instances[].services[] += { &quot;status&quot;: ($iterator.healthy + $iterator.unhealthy) }&#39;`\r\n\r\nIn all my attempts so far, I either couldn&#39;t access the elements at the same level for the calculation... or the rest of my data got dumped.",
        "link": "https://stackoverflow.com/questions/60237816/jq-add-field-to-collection-deep-in-nested-structure-calculated-from-other-fiel",
        "title": "jq: Add field to collection deep in nested structure, calculated from other fields at the same level"
    },
    {
        "tags": [
            "json",
            "duplicates",
            "key",
            "jq",
            "tshark"
        ],
        "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": 1581808769,
                "post_id": 60241245,
                "comment_id": 106561115,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1581812300,
                "last_edit_date": 1581812300,
                "creation_date": 1581808613,
                "answer_id": 60244033,
                "question_id": 60241245,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following assumes that if a JSON object in the file has a specific key more than once, then only the last one is relevant. If this assumption is not valid, then one option would be to use jq&#39;s streaming parser.\r\n\r\nThe following shows that a simple application of jq to retrieve the named key requires about 26MB RAM. Is that a problem in this day and age?\r\n```\r\n/usr/bin/time -lp jq &#39;.. | objects | .[&quot;tls.handshake.certificate_raw&quot;] // empty&#39;  Tshark.json\r\n```\r\n### Output:\r\n```\r\n[\r\n  &quot;308204633082034ba00302010202100182f8098ea2e626b91a3b27841fb9af300d06092a864886f70d01010b0500305a310b300906035504061302494531123010060355040a130942616c74696d6f726531133011060355040b130a43796265725472757374312230200603550403131942616c74696d6f7265204379626572547275737420526f6f74301e170d3135313230383132303530375a170d3235303531303132303030305a3064310b300906035504061302555331153013060355040a130c446967694365727420496e6331193017060355040b13107777772e64696769636572742e636f6d312330210603550403131a44696769436572742042616c74696d6f72652043412d3220473230820122300d06092a864886f70d01010105000382010f003082010a0282010100bbe700fe000173ef9b88f05c0875f05c70731fffb57a1f8d0823fdc7c1133fb12106bd4dccdb2db8871931deda6b0dc15dd251d5b05e72d4f066d484f2911841b50926b2039604699553fa074f3ebe863a432bb259b5abd1baf45940725a67b6cde655fc092ba498b2bfcca91fd4bf878f8225fd4580a9ec9d8cf97490cf1cf86550afcdf845abc82f8d8e361ddeea89cdb252d9e509cd36712bdac6d09bc6f6a45b5b39b61f001f19a4fbd3be0ce6fb8fdd0e80e6a4e75ac4c02f72ee91f38367c9cdcace4ab02081fde472af0918e74f42ec4d27424d07a0ddd50d75f73660cc265498a18837f083f7ad295920cfbb25e1d59ee6f3aec101ebb50689e20a8f0203010001a382011930820115301d0603551d0e04160414c012b22874684667e97025741a00455b067d5c44301f0603551d23041830168014e59d5930824758ccacfa085436867b3ab5044df030120603551d130101ff040830060101ff020100300e0603551d0f0101ff040403020186303406082b0601050507010104283026302406082b060105050730018618687474703a2f2f6f6373702e64696769636572742e636f6d303a0603551d1f04333031302fa02da02b8629687474703a2f2f63726c332e64696769636572742e636f6d2f4f6d6e69726f6f74323032352e63726c303d0603551d200436303430320604551d2000302a302806082b06010505070201161c68747470733a2f2f7777772e64696769636572742e636f6d2f435053300d06092a864886f70d01010b050003820101002fe23766c31acf9155ee2914fa5010be998de228f1741607693b44303df5b949f56836feb7308da9e0074942634652b569c69b49f21a0f57c6f6b7beab758d0da2ab33e462854354ab63940ca353a0ea1de4a6a6ac950e6578ec338cbe943ed870abeac7e178ce3395bbfb2c58e08a40a66d41d8d8d9b3f92f02c51b706be23a857b1d18b0d14b9ac16f171029e80ec3e1549654a5919508208d692c9e2f3f50b42ee5571fafa473d2a124bb0d90fe45131da7a129d8660bc3d16cb34fb42b844c4790ec8be2418913b607467742fdbb1e17faff254b8e5057eb8ecc4e153fb125dd410ca09c626d6fba97078bd9f30610c529d4f7ba1690a8d054e14b49c798&quot;,\r\n  1778,\r\n  1127,\r\n  0,\r\n  30\r\n]\r\nreal         1.42\r\nuser         1.34\r\nsys          0.03\r\n  26693632  maximum resident set size\r\n```\r\n",
                "title": "Filter specific value from Tshark JSON output"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1581828439,
                "last_edit_date": 1581828439,
                "creation_date": 1581810401,
                "answer_id": 60244206,
                "question_id": 60241245,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the JSON has objects with duplicate keys, an approach that does not use jq&#39;s normal object semantics is warranted.\r\n\r\njq&#39;s streaming parser (invoked with the --stream option) allows one to handle objects with duplicate keys:\r\n\r\n```\r\njq --stream -c &#39;(.[0]|index(&quot;tls.handshake.certificate_raw&quot;)) as $ix\r\n                | select($ix) | .[0] |= .[$ix+1:]&#39; Tshark.json |\r\n    jq -nc &#39;fromstream(inputs)&#39;\r\n\r\n```\r\nThis produces 503 entities, the first of which is:\r\n\r\n\r\n```\r\n[&quot;308208df308206c7a00302010202132d000491fc30ee99b24196c0d30000000491fc300d06092a864886f70d01010b050030818b310b3009060355040613025553311330110603550408130a57617368696e67746f6e3110300e060355040713075265646d6f6e64311e301c060355040a13154d6963726f736f667420436f72706f726174696f6e31153013060355040b130c4d6963726f736f6674204954311e301c060355040313154d6963726f736f667420495420544c532043412035301e170d3138313130323139353233375a170d3230313130323139353233375a3021311f301d06035504030c162a2e636c6f2e666f6f747072696e74646e732e636f6d30820122300d06092a864886f70d01010105000382010f003082010a0282010100ab93c55b9e948806364d71adf61ed1ae88c3f3531d8c03df279da3c618391d59636aaeaf9981ac75aaf95e98a97b5bf0fcbc4d819a6c896b29d12652ffa2b603a7edb61eb921a02e2c6730275f3ec23998aab45c5dd4d00cb91ac0cbae0dd8f897cd0b34d81056429c4d854d45b309644df10e7d7fe5a99643eb935263d862a5f4d6750b8202d16c0f89a6b888e8361dcd5314bdb3093b7d6b55106f874824c4a220657f72f8a8ab0c3da27f3f76d343ef85482c88f5423b88cc008c2d9e4ea3b3c373ff22e881491ad2922b6cf5076786b886b1c0e8c603d28d014dd0cd1216c59657c9806b2f1d34795286f729ce712728c12b80197df61790fe629d4732490203010001a38204a33082049f308201f7060a2b06010401d679020402048201e7048201e301e1007600a4b90990b418581487bb13a2cc67700a3c359804f91bdfb8e377cd0ec80ddc1000000166d6053ea50000040300473045022100865c52fbcc0846f7826de85fe28ee5192c706671e208359cc884ef8f862c384a022003dfd681fb2488ccbd8452733eaa7defafe80e1b834fe2a1bb8810cf492883b8007700bbd9dfbc1f8a71b593942397aa927b473857950aab52e81a909664368e1ed18500000166d6053f9a0000040300483046022100d0d6894ad6c1c2ff24a426483e354f21a2172ed4d2c3e544d887d2021f16b6e6022100eb61a67dd9e1b00c244750d43acac412ef9bd47ce77e85db86a6f83ee656c47e0077005ea773f9df56c0e7b536487dd049e0327a919a0c84a11212841875968171455800000166d6053eb20000040300483046022100f81aae0caef665d9071e5ebb949ccfc4033038c9df3227f3e90d46d77ed43574022100f76f1a30eb8b7ff4175cba86e07f46b6f625d1698c91b348a8e8ede7752c2456007500f095a459f200d18240102d2f93888ead4bfe1d47e399e1d034a6b0a8aa8eb27300000166d6053ebd0000040300463044022038393db91d24a1a0121f64446fdb7297406f89ae6d1abe39714073d8dd6bf79202203fec31afceb6a00663f7e3b5e4d9930c0b533dd938bc2ce82117502e97a30863302706092b060104018237150a041a3018300a06082b06010505070302300a06082b06010505070301303e06092b06010401823715070431302f06272b060104018237150887da867583eed90182c9851b81b59e6185f4eb60815d84d2df4282e7937a02016402011d30818506082b0601050507010104793077305106082b060105050730028645687474703a2f2f7777772e6d6963726f736f66742e636f6d2f706b692f6d73636f72702f4d6963726f736f66742532304954253230544c532532304341253230352e637274302206082b060105050730018616687474703a2f2f6f6373702e6d736f6373702e636f6d301d0603551d0e04160414e8e1323d172500a9588138faa2d310619350ac06300b0603551d0f0404030204b030470603551d110440303e82162a2e636c6f2e666f6f747072696e74646e732e636f6d8211632d72696e672e6d73656467652e6e65748211712d72696e672e6d73656467652e6e65743081ac0603551d1f0481a43081a130819ea0819ba08198864b687474703a2f2f6d7363726c2e6d6963726f736f66742e636f6d2f706b692f6d73636f72702f63726c2f4d6963726f736f66742532304954253230544c532532304341253230352e63726c8649687474703a2f2f63726c2e6d6963726f736f66742e636f6d2f706b692f6d73636f72702f63726c2f4d6963726f736f66742532304954253230544c532532304341253230352e63726c304d0603551d2004463044304206092b0601040182372a013035303306082b060105050702011627687474703a2f2f7777772e6d6963726f736f66742e636f6d2f706b692f6d73636f72702f637073301f0603551d2304183016801408fe259f74ea8704c2bcbb8ea8385f33c6d16c65301d0603551d250416301406082b0601050507030206082b06010505070301300d06092a864886f70d01010b050003820201007873266ca28f9b88b653ce3d9eff1d8d61f3cd6513b10228b4c9ea7276f8bca602812c10b45d7055b593880b632bbd8853b945b62033b159c4ad521304f5c2d55edbc027ce3d45aff48fa0c02d4f1b935ae1f2e3633c40bdaa0e618f08ec58996a52b2e0e1a6beb94d481255f5ee70a459ffb5f0dad8b9f739fcc6a7cb97a70229190864a70100e39e0e1c33383413a2e527aab47d1c9930a7f43082478e644ed6e4a3d4625a0fe8bda7fb731e569b38ec1fb75a5b7a51535af0bc96280da67d775fb9131027a13242a39d62e93fc140b7bcf201483d8d6a3ad1326386738dd8c707982bf5003da56a9c096b90d0d3827150e2b1d66393016bbb5b180aba7d98098fbf63ed9b8c85c64cd6414689e684424c68514bbb9f6da3d73165fbd58d972a7fba91fccda255b88c421b30d0961bb431bd2c6bfcb7b5a680acff3777ad911f030af3d552d69a7a6f27ca10ebbcab7195d6a363e769c872da596fd0641889c47f881b155df2ac045a5a016ac769d611e6c0cfcfcbaf9039d13ff6d321fff5abd5f922e8623162192eed42170eb090356549fa0867fa890bdbaf82f2fc41028494a133ccc97e7b6b4a21f6ad1aba032bfb1aa67b9247c97065dcd171270ea387862d92d8acd22994efdf03247d17c8b033f68d88231b655e4d22f30696aaf9e5667cebeb6ed001a3ea0e48a6231d1488a46755828c93a746e4c33a645db0d4&quot;,109,2275,0,30]\r\n\r\n```\r\n\r\n### Explanation\r\nThe first invocation of jq uses jq&#39;s streaming parser to extract the [path, atomicValue] pairs of interest. The second invocation reconstructs the relevant entities.\r\n\r\n## Resources\r\n\r\nHere are the main stats from a run using `/usr/bin/time -lp` on a Mac Mini:\r\n\r\n\r\n```\r\nreal         5.35\r\nuser         5.31\r\nsys          0.05\r\n  13279232  maximum resident set size\r\n```\r\n",
                "title": "Filter specific value from Tshark JSON output"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1581835827,
                "creation_date": 1581835827,
                "answer_id": 60246103,
                "question_id": 60241245,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "My final command:\r\n\r\n    jq --stream -c &#39;(.[0]|index(&quot;tls.handshake.certificate_raw&quot;)) as $ix\r\n                | select($ix) | .[0] |= .[$ix+1:]&#39; Tshark.json |\r\n    jq -r -nc &#39;fromstream(inputs)[0]&#39; | sort -u &gt; Certificates.txt\r\n\r\nI grab only the first value from the array and remove the double quotes. After a sort uniq I write the SSL certificates line by line into a file.\r\n\r\nThanks a lot for your great assistance!",
                "title": "Filter specific value from Tshark JSON output"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1581835827,
        "creation_date": 1581787407,
        "last_edit_date": 1581832350,
        "question_id": 60241245,
        "body_markdown": "I would like to extract the &quot;tls.handshake.certificate_raw&quot; values, but without success so far. The big JSON is killing me.\r\n\r\nHere&#39;s my JSON file: [Download][1]\r\n\r\n\r\n  [1]: https://gofile.io/?c=1dCkxL\r\n\r\nThanks in advance!",
        "link": "https://stackoverflow.com/questions/60241245/filter-specific-value-from-tshark-json-output",
        "title": "Filter specific value from Tshark JSON output"
    },
    {
        "tags": [
            "json",
            "string",
            "jq",
            "nul"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1581911420,
                "creation_date": 1581911420,
                "answer_id": 60255713,
                "question_id": 60255414,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following produces the output you&#39;ve specified:\r\n\r\n    find . -type f -print0 | jq -Rs &#39;split(&quot;\\u0000&quot;)[]&#39;",
                "title": "Converting null-terminated lines to JSON strings with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1581944090,
        "creation_date": 1581908682,
        "last_edit_date": 1581944090,
        "question_id": 60255414,
        "body_markdown": "I&#39;ve come up with a `jq`-based one-liner that converts a sequence of null-terminated strings to a sequence of JSON strings:\r\n\r\n```\r\nxargs -0 dash -c &#39;for i in &quot;$@&quot;; do printf %s &quot;$i&quot; | jq -Rs . ; done&#39; _dummy_\r\n```\r\n\r\nI&#39;d like to cut `xargs` and/or `dash` out of it if possible. Is there a way to do the same thing with just `jq`?\r\n\r\nExample usage:\r\n\r\n```\r\n# Create a new dir with some funny-named files\r\nmkdir funny\r\ncd funny\r\ntouch $&#39;ABC\\nDEF&#39; $&#39; GHI\\nJKL &#39; &#39; - はじめまして - &#39;\r\n# Use find -print0 to list the files\r\nfind -type f -print0 |\r\n# Convert the null-terminated lines to JSON strings\r\nxargs -0 dash -c &#39;for i in &quot;$@&quot;; do printf %s &quot;$i&quot; | jq -Rs . ; done&#39; _dummy_\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n&quot;./ - はじめまして - &quot;\r\n&quot;./ GHI\\nJKL &quot;\r\n&quot;./ABC\\nDEF&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/60255414/converting-null-terminated-lines-to-json-strings-with-jq",
        "title": "Converting null-terminated lines to JSON strings with jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1581970390,
                "post_id": 60269591,
                "comment_id": 106607818,
                "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": 1581970498,
                "post_id": 60269591,
                "comment_id": 106607864,
                "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": 1581972029,
                "post_id": 60269591,
                "comment_id": 106608481,
                "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": 1581972171,
                "post_id": 60269591,
                "comment_id": 106608528,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1581971776,
                "creation_date": 1581971776,
                "answer_id": 60270036,
                "question_id": 60269591,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you haven&#39;t provided sample data, I&#39;ve had to make my own:\r\n\r\n```\r\njson=&#39;\r\n{ &quot;vendors&quot;:\r\n  { &quot;vendorA&quot;:\r\n    { &quot;products&quot;:\r\n      { &quot;productA&quot;:\r\n        { &quot;images&quot;:\r\n          { &quot;imageA&quot;:\r\n            { &quot;tags&quot;:\r\n              { &quot;2019-01-01&quot;:\r\n                { &quot;pgpSignature&quot;:  &quot;productA-imageA-20190101-sig&quot;,\r\n                  &quot;imageManifest&quot;: &quot;productA-imageA-20190101-manifest&quot;,\r\n                  &quot;image&quot;:         &quot;productA-imageA-20190101-image&quot;\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n&#39;\r\n\r\nbuildJsonStream() {\r\n  jq -j &#39;\r\n    .vendors[]|.products[]|.images | to_entries[] |\r\n    .key as $key |\r\n    .value.tags[] |\r\n    ($key, &quot;\\u0000&quot;,\r\n     ({ pgpSignature, imageManifest, image } | tojson), &quot;\\n&quot;, &quot;\\u0000&quot;\r\n    )&#39; &quot;$@&quot;\r\n}\r\n\r\ndeclare -A alreadyCreated=( )\r\nwhile IFS= read -r -d &#39;&#39; key &amp;&amp; IFS= read -r -d &#39;&#39; content; do\r\n  if ! [[ ${alreadyCreated[$key]} ]]; then\r\n    printf &#39;%s&#39; &quot;$content&quot; &gt;&quot;$key.json&quot;\r\n    alreadyCreated[$key]=1\r\n  else\r\n    printf &#39;%s&#39; &quot;$content&quot; &gt;&gt;&quot;$key.json&quot;\r\n  fi\r\ndone &lt; &lt;(buildJsonStream &lt;&lt;&lt;&quot;$json&quot;)\r\n```\r\n\r\n...will write, to `imageA.json`, the text:\r\n\r\n```json\r\n{&quot;pgpSignature&quot;:&quot;productA-imageA-20190101-sig&quot;,&quot;imageManifest&quot;:&quot;productA-imageA-20190101-manifest&quot;,&quot;image&quot;:&quot;productA-imageA-20190101-image&quot;}\r\n```\r\n\r\nThe important thing to note here is that we&#39;re having `jq` write alternating, NUL-separated `key`/`content` pairs, and then having bash be responsible for actually writing to the (key-name-derived) files.",
                "title": "How can I use Jq to help me make &quot;individual&quot; json files with specific values?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1581971776,
        "creation_date": 1581969609,
        "last_edit_date": 1581970168,
        "question_id": 60269591,
        "body_markdown": "I want to use jq to help me make a file for every key, with the 3 specific values pertaining to that key, formatted in json.\r\n\r\nI know how to get my keys, and I know how to get my values. But how can I do all this in one command so that I have the info I want, in different files, per key with the keys respective values?\r\n\r\nHere is how I get keys:\r\n\r\n```cat $DCAR_API | jq .vendors[].products[].images | jq -r &#39;keys[]&#39;```\r\n\r\nHere is the info I want to be in every json file:\r\n\r\n```\r\ncat &quot;$DCAR_API&quot; \\\r\n| jq -r &#39;.vendors[]|.products[]|.images[].tags[].pgpSignature&#39; \r\n\r\ncat &quot;$DCAR_API&quot; \\\r\n| jq -r &#39;.vendors[]|.products[]|.images[].tags[].imageManifest&#39;\r\n\r\ncat &quot;$DCAR_API&quot; \\\r\n| jq -r &#39;.vendors[]|.products[]|.images[].tags[].image&#39;\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60269591/how-can-i-use-jq-to-help-me-make-individual-json-files-with-specific-values",
        "title": "How can I use Jq to help me make &quot;individual&quot; json files with specific values?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7253321,
                    "reputation": 539,
                    "user_id": 5671644,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2c0b68c5ca33cb9a9a15ec598ad565f8?s=256&d=identicon&r=PG",
                    "display_name": "Mohammad Fahim Abrar",
                    "link": "https://stackoverflow.com/users/5671644/mohammad-fahim-abrar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582002260,
                "post_id": 60273959,
                "comment_id": 106615874,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 216950,
                    "reputation": 20400,
                    "user_id": 472495,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/4rtxd.png?s=256",
                    "display_name": "halfer",
                    "link": "https://stackoverflow.com/users/472495/halfer"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1582054353,
                "post_id": 60273959,
                "comment_id": 106642234,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 43866,
                    "reputation": 160771,
                    "user_id": 128421,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/71770d043c0f7e3c7bc5f74190015c26?s=256&d=identicon&r=PG",
                    "display_name": "the Tin Man",
                    "link": "https://stackoverflow.com/users/128421/the-tin-man"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1584655658,
                "post_id": 60273959,
                "comment_id": 107511269,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1582012051,
                "creation_date": 1582012051,
                "answer_id": 60276066,
                "question_id": 60273959,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the object you want to add is in a file, you should be using `--slurpfile` instead of trying to read it into a shell variable and then pass that to `jq`:\r\n\r\n    $ jq --slurpfile obj ruleGroup.json &#39;. + $obj&#39; newFile.json \r\n    [\r\n      {\r\n        &quot;groupId&quot;: 11,\r\n        &quot;lowerThreshold&quot;: 33,\r\n        &quot;target&quot;: {\r\n          &quot;alarm_id&quot;: 22\r\n        },\r\n        &quot;thresholdPeriod&quot;: 3,\r\n        &quot;upperThreshold&quot;: 44\r\n      },\r\n      {\r\n        &quot;groupId&quot;: 31,\r\n        &quot;lowerThreshold&quot;: 33,\r\n        &quot;target&quot;: {\r\n          &quot;alarm_id&quot;: 122\r\n        },\r\n        &quot;thresholdPeriod&quot;: 3,\r\n        &quot;upperThreshold&quot;: 44\r\n      },\r\n      {\r\n        &quot;groupId&quot;: &quot;0&quot;,\r\n        &quot;target&quot;: {\r\n          &quot;alarm_id&quot;: &quot;69&quot;\r\n        },\r\n        &quot;upperThreshold&quot;: &quot;20&quot;,\r\n        &quot;lowerThreshold&quot;: &quot;10&quot;,\r\n        &quot;thresholdPeriod&quot;: &quot;5&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "Add new key to json array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1584656078,
        "creation_date": 1582001649,
        "last_edit_date": 1584656078,
        "question_id": 60273959,
        "body_markdown": "Why is the accepted answer in &quot;https://stackoverflow.com/questions/42817889/append-new-keypair-to-json-file-with-jq&quot; not working in my case?\r\n\r\nI have a file `newFile.json` which contains:\r\n\r\n    [ { &quot;groupId&quot;: 11, &quot;lowerThreshold&quot;: 33, &quot;target&quot;: { &quot;alarm_id&quot;: 22 },\r\n    &quot;thresholdPeriod&quot;: 3, &quot;upperThreshold&quot;: 44 }, { &quot;groupId&quot;: 31,\r\n    &quot;lowerThreshold&quot;: 33, &quot;target&quot;: { &quot;alarm_id&quot;: 122 },\r\n    &quot;thresholdPeriod&quot;: 3, &quot;upperThreshold&quot;: 44 } ]\r\n\r\nI want to insert another value to the array in ruleGroup.json which has:\r\n\r\n    { &quot;groupId&quot;: &quot;0&quot;, &quot;target&quot;: { &quot;alarm_id&quot;: &quot;69&quot; }, &quot;upperThreshold&quot;:\r\n    &quot;20&quot;, &quot;lowerThreshold&quot;: &quot;10&quot;, &quot;thresholdPeriod&quot;: &quot;5&quot; }\r\n\r\nAs per the accepted answer, I saved `ruleGroup.json` to `obj`.\r\n\r\nWhen I run\r\n\r\n    jq --argjson obj &#39;$obj&#39; &#39;. + [$obj]&#39; &lt; newFile.json\r\n\r\nit returns:\r\n\r\n    [ &quot;{\\n \\&quot;groupId\\&quot;: \\&quot;0\\&quot;,\\n \\&quot;target\\&quot;: {\\n \\&quot;alarm_id\\&quot;: \\&quot;69\\&quot;\\n\r\n    },\\n \\&quot;upperThreshold\\&quot;: \\&quot;20\\&quot;,\\n \\&quot;lowerThreshold\\&quot;: \\&quot;10\\&quot;,\\n\r\n    \\&quot;thresholdPeriod\\&quot;: \\&quot;5\\&quot;\\n}&quot; ]\r\n\r\nWhich is similar to the `$obj` value itself. It didn&#39;t create the expected result which was to append this value to the array:\r\n\r\n    [ { &quot;groupId&quot;: 11, &quot;lowerThreshold&quot;: 33, &quot;target&quot;: { &quot;alarm_id&quot;: 22 },\r\n    &quot;thresholdPeriod&quot;: 3, &quot;upperThreshold&quot;: 44 }, { &quot;groupId&quot;: 31,\r\n    &quot;lowerThreshold&quot;: 33, &quot;target&quot;: { &quot;alarm_id&quot;: 122 },\r\n    &quot;thresholdPeriod&quot;: 3, &quot;upperThreshold&quot;: 44 }, { &quot;groupId&quot;: &quot;0&quot;,\r\n    &quot;target&quot;: { &quot;alarm_id&quot;: &quot;69&quot; }, &quot;upperThreshold&quot;: &quot;20&quot;,\r\n    &quot;lowerThreshold&quot;: &quot;10&quot;, &quot;thresholdPeriod&quot;: &quot;5&quot; } ]\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60273959/add-new-key-to-json-array-using-jq",
        "title": "Add new key to json array using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1582028141,
                "post_id": 60280053,
                "comment_id": 106628043,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1582028781,
                "post_id": 60280053,
                "comment_id": 106628425,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9255979,
                    "reputation": 46,
                    "user_id": 6874876,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/50cfcdb4d977a630b2c24b6b611aad17?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "arun kushwaha",
                    "link": "https://stackoverflow.com/users/6874876/arun-kushwaha"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582032300,
                "post_id": 60280053,
                "comment_id": 106630369,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582039672,
                "post_id": 60280053,
                "comment_id": 106634691,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1582026259,
                "creation_date": 1582026259,
                "answer_id": 60280163,
                "question_id": 60280053,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `sort_by` like following:\r\n\r\n```\r\njq &#39;sort_by(.groupId)&#39;\r\n```",
                "title": "sort json array by value jq bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1582039103,
        "creation_date": 1582025895,
        "last_edit_date": 1582039103,
        "question_id": 60280053,
        "body_markdown": "I want to sort below array based on `groupId` such that keys with smaller `groupId` come first in array.\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;groupId&quot;: 11,\r\n    &quot;lowerThreshold&quot;: 33,\r\n    &quot;target&quot;: {\r\n      &quot;alarm_id&quot;: 22\r\n    },\r\n    &quot;thresholdPeriod&quot;: 3,\r\n    &quot;upperThreshold&quot;: 44\r\n  },\r\n  {\r\n    &quot;groupId&quot;: 31,\r\n    &quot;lowerThreshold&quot;: 33,\r\n    &quot;target&quot;: {\r\n      &quot;alarm_id&quot;: 122\r\n    },\r\n    &quot;thresholdPeriod&quot;: 3,\r\n    &quot;upperThreshold&quot;: 44\r\n  },\r\n  {\r\n    &quot;groupId&quot;: &quot;0&quot;,\r\n    &quot;target&quot;: {\r\n      &quot;alarm_id&quot;: &quot;69&quot;\r\n    },\r\n    &quot;upperThreshold&quot;: &quot;20&quot;,\r\n    &quot;lowerThreshold&quot;: &quot;10&quot;,\r\n    &quot;thresholdPeriod&quot;: &quot;5&quot;\r\n  }\r\n]\r\n```\r\n\r\n\r\nExpectation is\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;groupId&quot;: &quot;0&quot;,\r\n    &quot;target&quot;: {\r\n      &quot;alarm_id&quot;: &quot;69&quot;\r\n    },\r\n    &quot;upperThreshold&quot;: &quot;20&quot;,\r\n    &quot;lowerThreshold&quot;: &quot;10&quot;,\r\n    &quot;thresholdPeriod&quot;: &quot;5&quot;\r\n  },\r\n  {\r\n    &quot;groupId&quot;: 11,\r\n    &quot;lowerThreshold&quot;: 33,\r\n    &quot;target&quot;: {\r\n      &quot;alarm_id&quot;: 22\r\n    },\r\n    &quot;thresholdPeriod&quot;: 3,\r\n    &quot;upperThreshold&quot;: 44\r\n  },\r\n  {\r\n    &quot;groupId&quot;: 31,\r\n    &quot;lowerThreshold&quot;: 33,\r\n    &quot;target&quot;: {\r\n      &quot;alarm_id&quot;: 122\r\n    },\r\n    &quot;thresholdPeriod&quot;: 3,\r\n    &quot;upperThreshold&quot;: 44\r\n  }\r\n]\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/60280053/sort-json-array-by-value-jq-bash",
        "title": "sort json array by value jq bash"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582032617,
                "post_id": 60281957,
                "comment_id": 106630523,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3595907,
                    "reputation": 5832,
                    "user_id": 3000629,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fd7f5c9cce7faba20cc43901b5d03ffd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Poshi",
                    "link": "https://stackoverflow.com/users/3000629/poshi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582032692,
                "post_id": 60281957,
                "comment_id": 106630557,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14201915,
                    "reputation": 15,
                    "user_id": 10259601,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-OSUGKADr_oU/AAAAAAAAAAI/AAAAAAAAAAA/APUIFaOU2ivyNqioDzgD4IPcC7jwl2vxPQ/mo/s256-rj/photo.jpg",
                    "display_name": "perrfect",
                    "link": "https://stackoverflow.com/users/10259601/perrfect"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582032783,
                "post_id": 60281957,
                "comment_id": 106630604,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14201915,
                    "reputation": 15,
                    "user_id": 10259601,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-OSUGKADr_oU/AAAAAAAAAAI/AAAAAAAAAAA/APUIFaOU2ivyNqioDzgD4IPcC7jwl2vxPQ/mo/s256-rj/photo.jpg",
                    "display_name": "perrfect",
                    "link": "https://stackoverflow.com/users/10259601/perrfect"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582033117,
                "post_id": 60281957,
                "comment_id": 106630752,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1582033212,
                "creation_date": 1582033212,
                "answer_id": 60282223,
                "question_id": 60281957,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Why don&#39;t you use jq&#39;s split ?\r\n\r\n    jq -Rs --arg a &#39;/&#39; --arg c &#39;node1&#39; &#39;[ .[:-1] |\r\n          split(&quot;\\n&quot;)[] |\r\n          { &quot;{#VHOSTNAME}&quot; : $a , \r\n            &quot;{#QUEUENAME}&quot;: . , \r\n            &quot;{#NODENAME}&quot;: $c } ] |\r\n           { &quot;data&quot; : . }&#39; sample.txt\r\n\r\nOut:\r\n\r\n    {\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;{#VHOSTNAME}&quot;: &quot;/&quot;,\r\n          &quot;{#QUEUENAME}&quot;: &quot;rabbit1-test1&quot;,\r\n          &quot;{#NODENAME}&quot;: &quot;node1&quot;\r\n        },\r\n        {\r\n          &quot;{#VHOSTNAME}&quot;: &quot;/&quot;,\r\n          &quot;{#QUEUENAME}&quot;: &quot;rabbit1-test2&quot;,\r\n          &quot;{#NODENAME}&quot;: &quot;node1&quot;\r\n        },\r\n        {\r\n          &quot;{#VHOSTNAME}&quot;: &quot;/&quot;,\r\n          &quot;{#QUEUENAME}&quot;: &quot;rabbit1-test3&quot;,\r\n          &quot;{#NODENAME}&quot;: &quot;node1&quot;\r\n        }\r\n      ]\r\n    }",
                "title": "How can jq read lines from a file and create valid a JSON?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1709204963,
                "last_edit_date": 1709204963,
                "creation_date": 1709202918,
                "answer_id": 78080657,
                "question_id": 60281957,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "you can postprocess your output like so:\r\n\r\n    jq --slurp &#39;{data: [.[].data[]]}&#39;\r\n\r\nhttps://jqplay.org/s/Y2N499onGFw\r\n\r\nor use double jq: first one with `-R/--raw-input`, then another one with `-s/--slurp`, like this:\r\n\r\n    $ echo  -e &quot;rabbit1-test1\\nrabbit1-test2\\nrabbit1-test3&quot; | jq -R . | jq -s --arg a1 foo --arg a2 bar &#39;[.[] | {x: $a1, y: ., z: $a2} ] | {data: .}&#39;\r\n    {\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;x&quot;: &quot;foo&quot;,\r\n          &quot;y&quot;: &quot;rabbit1-test1&quot;,\r\n          &quot;z&quot;: &quot;bar&quot;\r\n        },\r\n        {\r\n          &quot;x&quot;: &quot;foo&quot;,\r\n          &quot;y&quot;: &quot;rabbit1-test2&quot;,\r\n          &quot;z&quot;: &quot;bar&quot;\r\n        },\r\n        {\r\n          &quot;x&quot;: &quot;foo&quot;,\r\n          &quot;y&quot;: &quot;rabbit1-test3&quot;,\r\n          &quot;z&quot;: &quot;bar&quot;\r\n        }\r\n      ]\r\n    }\r\n",
                "title": "How can jq read lines from a file and create valid a JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1709204963,
        "creation_date": 1582032370,
        "last_edit_date": 1582032805,
        "question_id": 60281957,
        "body_markdown": "I need help with creating a valid JSON file via jq which read lines from the file.\r\n\r\nI have some text.txt file:\r\n\r\n    rabbit1-test1\r\n    rabbit1-test2\r\n    rabbit1-test3\r\n\r\nAnd the bash-script: \r\n\r\n    VHOSTNAME=/\r\n    NODENAME=node1\r\n    \r\n    input=&quot;test.txt&quot;\r\n    while IFS= read -r line; do jq -n \\\r\n                      --arg a &quot;$VHOSTNAME&quot; \\\r\n                      --arg b &quot;$line&quot;  \\\r\n                      --arg c &quot;$NODENAME&quot; \\\r\n                      &#39;{&quot;data&quot;: [{&quot;{#VHOSTNAME}&quot;: $a, &quot;{#QUEUENAME}&quot;: $b, &quot;{#NODENAME}&quot;: $c}]}&#39; ;done &lt; &quot;$input&quot;\r\n\r\nBut, when I run the script, the JSON isn&#39;t valid:\r\n\r\n    {\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;{#VHOSTNAME}&quot;: &quot;/&quot;,\r\n          &quot;{#QUEUENAME}&quot;: &quot;rabbit1-test1&quot;,\r\n          &quot;{#NODENAME}&quot;: &quot;node1&quot;\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;{#VHOSTNAME}&quot;: &quot;/&quot;,\r\n          &quot;{#QUEUENAME}&quot;: &quot;rabbit1-test2&quot;,\r\n          &quot;{#NODENAME}&quot;: &quot;node1&quot;\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;{#VHOSTNAME}&quot;: &quot;/&quot;,\r\n          &quot;{#QUEUENAME}&quot;: &quot;rabbit1-test3&quot;,\r\n          &quot;{#NODENAME}&quot;: &quot;node1&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI can&#39;t understand why jq reads file incorrectly.\r\nPlease help me.",
        "link": "https://stackoverflow.com/questions/60281957/how-can-jq-read-lines-from-a-file-and-create-valid-a-json",
        "title": "How can jq read lines from a file and create valid a JSON?"
    },
    {
        "tags": [
            "json",
            "python-3.x",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 682692,
                    "reputation": 49935,
                    "user_id": 535275,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://i.sstatic.net/Ft2Mw.jpg?s=256",
                    "display_name": "Scott Hunter",
                    "link": "https://stackoverflow.com/users/535275/scott-hunter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582045990,
                "post_id": 60286122,
                "comment_id": 106638361,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9479347,
                    "reputation": 346,
                    "user_id": 7047800,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://www.gravatar.com/avatar/e7e53297765bae6e2710a953abda9ea5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "himabindu",
                    "link": "https://stackoverflow.com/users/7047800/himabindu"
                },
                "reply_to_user": {
                    "account_id": 682692,
                    "reputation": 49935,
                    "user_id": 535275,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://i.sstatic.net/Ft2Mw.jpg?s=256",
                    "display_name": "Scott Hunter",
                    "link": "https://stackoverflow.com/users/535275/scott-hunter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582048125,
                "post_id": 60286122,
                "comment_id": 106639436,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9279256,
                    "reputation": 108860,
                    "user_id": 6890912,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/19GnX.jpg?s=256",
                    "display_name": "blhsing",
                    "link": "https://stackoverflow.com/users/6890912/blhsing"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582048277,
                "post_id": 60286122,
                "comment_id": 106639522,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 682692,
                    "reputation": 49935,
                    "user_id": 535275,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://i.sstatic.net/Ft2Mw.jpg?s=256",
                    "display_name": "Scott Hunter",
                    "link": "https://stackoverflow.com/users/535275/scott-hunter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582048304,
                "post_id": 60286122,
                "comment_id": 106639537,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1582053352,
                "post_id": 60286122,
                "comment_id": 106641834,
                "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": 1582061075,
                "post_id": 60286122,
                "comment_id": 106645279,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1582195573,
                "creation_date": 1582195573,
                "answer_id": 60318140,
                "question_id": 60286122,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will rename and merge your objects by first name.\r\n\r\n```\r\njq &#39;map(.name |= split(&quot; &quot;)[0]) | group_by(.name) | map(add)&#39;\r\n```",
                "title": "Find a record in json Object if the record has specific key in python"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1582195573,
        "creation_date": 1582045828,
        "last_edit_date": 1582064710,
        "question_id": 60286122,
        "body_markdown": "I have a JSON object which has 100000 records. I want a select a record which has specific value to the one of the key\r\n\r\nEg: \r\n```\r\n[{\r\n    &quot;name&quot;: &quot;bindu&quot;,\r\n    &quot;age&quot;: &quot;24&quot;,\r\n    &quot;qualification&quot;: &quot;b.tech&quot; \r\n},\r\n{\r\n    &quot;name&quot;: &quot;naveen&quot;,\r\n    &quot;age&quot;: &quot;23&quot;,\r\n    &quot;qualification&quot;: &quot;b.tech&quot;\r\n},\r\n{\r\n    &quot;name&quot;: &quot;parvathi&quot;,\r\n    &quot;age&quot;: &quot;23&quot;,\r\n    &quot;qualification&quot;: &quot;m.tech&quot;\r\n},\r\n{\r\n    &quot;name&quot;: &quot;bindu s&quot;,\r\n    &quot;status&quot;: &quot;married&quot;\r\n},\r\n{\r\n    &quot;name&quot;: &quot;naveen k&quot;,\r\n    &quot;status&quot;: &quot;unmarried&quot;\r\n\r\n}]\r\n```\r\nnow I want to combine the records which are having the name with &#39;bindu&#39; and &#39;bindu s. We can achieve this by iterating on the JSON object but since the size is more it is taking more time. Is there any way to make this easy.\r\n\r\nI want the output like\r\n```\r\n[{\r\n    &quot;name&quot;: &quot;bindu&quot;,\r\n    &quot;age&quot;: &quot;24&quot;,\r\n    &quot;qualification&quot;: &quot;b.tech&quot;,\r\n    &quot;status&quot;: &quot;married&quot;\r\n},\r\n{\r\n    &quot;name&quot;: &quot;naveen&quot;,\r\n    &quot;age&quot;: &quot;23&quot;,\r\n    &quot;qualification&quot;: &quot;b.tech&quot;,\r\n    &quot;status&quot;: &quot;unmarried&quot;\r\n\r\n},\r\n{\r\n    &quot;name&quot;: &quot;parvathi&quot;,\r\n    &quot;age&quot;: &quot;23&quot;,\r\n    &quot;qualification&quot;: &quot;m.tech&quot;\r\n    &quot;status&quot;: &quot;&quot;\r\n},\r\n```",
        "link": "https://stackoverflow.com/questions/60286122/find-a-record-in-json-object-if-the-record-has-specific-key-in-python",
        "title": "Find a record in json Object if the record has specific key in python"
    },
    {
        "tags": [
            "json",
            "random",
            "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": 1582056479,
                "post_id": 60288601,
                "comment_id": 106643149,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582058329,
                "post_id": 60288601,
                "comment_id": 106643979,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10477927,
                    "reputation": 5076,
                    "user_id": 7723882,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/6aUwy.png?s=256",
                    "display_name": "Matias Barrios",
                    "link": "https://stackoverflow.com/users/7723882/matias-barrios"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582058648,
                "post_id": 60288601,
                "comment_id": 106644127,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10477927,
                    "reputation": 5076,
                    "user_id": 7723882,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/6aUwy.png?s=256",
                    "display_name": "Matias Barrios",
                    "link": "https://stackoverflow.com/users/7723882/matias-barrios"
                },
                "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": 1582058708,
                "post_id": 60288601,
                "comment_id": 106644158,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1582058829,
                "post_id": 60288601,
                "comment_id": 106644212,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1582153514,
                "last_edit_date": 1582153514,
                "creation_date": 1582063496,
                "answer_id": 60290108,
                "question_id": 60288601,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Currently jq does not have a built-in randomization function, but it&#39;s easy enough to generate random numbers that jq can use.  The following solution uses `awk` but in a way that some other PRNG can easily be used.\r\n\r\n```\r\n#!/bin/bash\r\n\r\nfunction template {\r\n    cat&lt;&lt;EOF\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Matias&quot;,\r\n    &quot;age&quot;: &quot;33&quot;\r\n  }\r\n]\r\n\r\nEOF\r\n}\r\n\r\nfunction randoms {\r\n    awk -v n=$1 &#39;BEGIN { for(i=0;i&lt;n;i++) {print int(100*rand())} }&#39;\r\n}\r\n\r\nrandoms 100 | jq -n --argfile template &lt;(template) &#39;\r\n  first($template[] | select(.name | test(&quot;M.*&quot;))) as $t\r\n  | [ $t | .age = inputs]\r\n&#39;\r\n```\r\n\r\n### Note on performance\r\nEven though the above uses awk and jq together, this combination is about 10 times faster than the posted `jtc` solution using `-eu`:  \r\n\r\n&lt;sub&gt;`jq+awk:          u+s = 0.012s`&lt;/sub&gt;\r\n\r\n&lt;sub&gt;`jtc with -eu:    u+s = 0.192s`&lt;/sub&gt;\r\n\r\nUsing jtc in conjunction with awk as above, however, gives u+s == 0.008s on the same machine.",
                "title": "Append multiple dummy objects to json array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1582153514,
        "creation_date": 1582056153,
        "last_edit_date": 1582064743,
        "question_id": 60288601,
        "body_markdown": "Lets say this is my array :\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Matias&quot;,\r\n        &quot;age&quot;: &quot;33&quot;\r\n      }\r\n    ]\r\n\r\nI can do this :\r\n\r\n    echo &quot;$response&quot; | jq &#39;[ .[] | select(.name | test(&quot;M.*&quot;))] | . += [.[]]&#39;\r\n\r\nAnd it will output : \r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Matias&quot;,\r\n        &quot;age&quot;: &quot;33&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Matias&quot;,\r\n        &quot;age&quot;: &quot;33&quot;\r\n      }\r\n    ]\r\n\r\nBut I *cant* do this :\r\n\r\n    echo &quot;$response&quot; | jq &#39;[ .[] | select(.name | test(&quot;M.*&quot;))] | . += [.[] * 3]&#39;\r\n    jq: error (at &lt;stdin&gt;:7): object ({&quot;name&quot;:&quot;Ma...) and number (3) cannot be multiplied\r\n\r\nI need to extend an array to create a dummy array with 100 values. And I cant do it. Also, I would like to have a random *age* on the objects. ( So later on I can filter the file to measure performance of an app .\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60288601/append-multiple-dummy-objects-to-json-array-with-jq",
        "title": "Append multiple dummy objects to json array with jq"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17793636,
                    "reputation": 13,
                    "user_id": 12922012,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c6c37b4589c251be6684cfe031c38b86?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "kex",
                    "link": "https://stackoverflow.com/users/12922012/kex"
                },
                "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": 1582095309,
                "post_id": 60290540,
                "comment_id": 106654047,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582099221,
                "post_id": 60290540,
                "comment_id": 106655567,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1582100640,
                "last_edit_date": 1582100640,
                "creation_date": 1582084580,
                "answer_id": 60292780,
                "question_id": 60290540,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input (after correcting the minor error), the following jq filter produces the output shown below:\r\n\r\n```\r\n[ to_entries[] | {pair: .key} + .value[] ]\r\n```\r\n\r\n### Output\r\n```\r\n[\r\n  {\r\n    &quot;pair&quot;: &quot;binance_BTCUSDT&quot;,\r\n    &quot;price&quot;: &quot;12/02 00:00&quot;,\r\n    &quot;time&quot;: &quot;10232.79&quot;,\r\n    &quot;achg&quot;: -0.006151\r\n  },\r\n  {\r\n    &quot;pair&quot;: &quot;binance_BTCUSDT&quot;,\r\n    &quot;time&quot;: &quot;12/02 17:01&quot;,\r\n    &quot;price&quot;: &quot;10342.92&quot;,\r\n    &quot;achg&quot;: -0.007977\r\n  },\r\n  {\r\n    &quot;pair&quot;: &quot;binance_ZECBNB&quot;,\r\n    &quot;time&quot;: &quot;09/02 03:53&quot;,\r\n    &quot;price&quot;: &quot;3.052&quot;,\r\n    &quot;achg&quot;: 0.1\r\n  }\r\n]\r\n```\r\n\r\n## Variation\r\nIf you want to retain an entry corresponding to `{ &quot;binance_ZENBTC&quot;: []}`, then the following filter would be appropriate:\r\n\r\n```\r\n[to_entries[] | {pair: .key} + (.value[] // {}) ]\r\n```\r\n\r\n\r\n\r\n\r\n",
                "title": "Add parent array name into JSON as key:value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1582100640,
        "creation_date": 1582065972,
        "last_edit_date": 1582097388,
        "question_id": 60290540,
        "body_markdown": "I have JSON like that: \r\n```\r\n{\r\n  &quot;binance_BTCUSDT&quot;: [\r\n    {\r\n      &quot;price&quot;: &quot;12/02 00:00&quot;,\r\n      &quot;time&quot;: &quot;10232.79&quot;,\r\n      &quot;achg&quot;: -0.006151\r\n    },\r\n    {\r\n      &quot;time&quot;: &quot;12/02 17:01&quot;,\r\n      &quot;price&quot;: &quot;10342.92&quot;,\r\n      &quot;achg&quot;: -0.007977\r\n    },\r\n  ],\r\n  &quot;binance_ZECBNB&quot;: [\r\n    {\r\n      &quot;time&quot;: &quot;09/02 03:53&quot;,\r\n      &quot;price&quot;: &quot;3.052&quot;,\r\n      &quot;achg&quot;: 0.1\r\n    }\r\n  ],\r\n  &quot;binance_ZENBTC&quot;: []\r\n}\r\n```\r\nHow to add to any leaf key:value with name of parent array and remove such dividing into arrays at all?\r\n\r\nI tried use jq with   `.[][]|= . + {&quot;pair&quot;: path(.) }` , but I don&#39;t get how to write correctly path().  \r\n\r\n### Expected output\r\n```\r\n[\r\n  {\r\n    &quot;pair&quot;: &quot;binance_BTCUSDT&quot;,\r\n    &quot;price&quot;: &quot;12/02 00:00&quot;,\r\n    &quot;time&quot;: &quot;10232.79&quot;,\r\n    &quot;achg&quot;: -0.006151\r\n  },\r\n  {\r\n    &quot;pair&quot;: &quot;binance_BTCUSDT&quot;,\r\n    &quot;time&quot;: &quot;12/02 17:01&quot;,\r\n    &quot;price&quot;: &quot;10342.92&quot;,\r\n    &quot;achg&quot;: -0.007977\r\n  },\r\n  {\r\n    &quot;pair&quot;: &quot;binance_ZECBNB&quot;,\r\n    &quot;time&quot;: &quot;09/02 03:53&quot;,\r\n    &quot;price&quot;: &quot;3.052&quot;,\r\n    &quot;achg&quot;: 0.1\r\n  }\r\n]\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/60290540/add-parent-array-name-into-json-as-keyvalue",
        "title": "Add parent array name into JSON as key:value"
    },
    {
        "tags": [
            "json",
            "sorting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 86477,
                    "reputation": 199201,
                    "user_id": 240443,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/495d675e3bc42ed1dee469e2ce701f1b?s=256&d=identicon&r=PG",
                    "display_name": "Amadan",
                    "link": "https://stackoverflow.com/users/240443/amadan"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1582082177,
                "post_id": 60292458,
                "comment_id": 106650499,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1582408810,
                "last_edit_date": 1582408810,
                "creation_date": 1582088881,
                "answer_id": 60293412,
                "question_id": 60292458,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[The following was written before the question was updated to explain that the input consists of multiple JSON entities.]\r\n\r\nTo simplify things a bit, the following assumes that you have a huge file consisting of a single JSON array.  Since, by assumption, this file is too big to read into memory, the first step will be to get each of the top-level array elements on a line by itself.  That can be done using jq&#39;s `--stream` command-line option, as described in the [jq FAQ][1], e.g. perhaps along the lines of:\r\n\r\n    jq -cn --stream &#39;fromstream( inputs|(.[0] |= .[1:]) | select(. != [[]]) )&#39;\r\n\r\nThe next step is to prefix each of these lines with the &quot;sort by&quot; value, as described in the link included in the Q.  (That is, jq can easily be used.)\r\n\r\nNext, run the operating system `sort`.\r\n\r\nFinally, if you really need the result as a single large array, you could use a text-processing tool (e.g. awk).\r\n \r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "What is the best way to `sort_by` a huge file that doesn&#39;t fit in memory with `jq`"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1584101462,
        "creation_date": 1582082003,
        "last_edit_date": 1582442895,
        "question_id": 60292458,
        "body_markdown": "I&#39;m working with a text file that has one JSON object per line and I want to use jq to select, group_by (key1), and sort_by (key1) the file. The file looks like this:\r\n\r\n```\r\n# /tmp/sample.json\r\n{&quot;key1&quot;: &quot;value11&quot;, &quot;key2&quot;: &quot;value21&quot;, &quot;key3&quot;: &quot;value31&quot;}\r\n{&quot;key1&quot;: &quot;value11&quot;, &quot;key2&quot;: &quot;value22&quot;, &quot;key3&quot;: &quot;value32&quot;}\r\n{&quot;key1&quot;: &quot;value11&quot;, &quot;key2&quot;: &quot;value22&quot;, &quot;key3&quot;: &quot;value32&quot;}\r\n{&quot;key1&quot;: &quot;value13&quot;, &quot;key2&quot;: &quot;value23&quot;, &quot;key3&quot;: &quot;value33&quot;}\r\n{&quot;key1&quot;: &quot;value13&quot;, &quot;key2&quot;: &quot;value24&quot;, &quot;key3&quot;: &quot;value34&quot;}\r\n{&quot;key1&quot;: &quot;value16&quot;, &quot;key2&quot;: &quot;value26&quot;, &quot;key3&quot;: &quot;value36&quot;}\r\n{&quot;key1&quot;: &quot;value17&quot;, &quot;key2&quot;: &quot;value27&quot;, &quot;key3&quot;: &quot;value37&quot;}\r\n...\r\n```\r\n\r\nI&#39;m running the file through Hadoop MapReduce in [a similar manner to this question][5]:\r\n\r\n```\r\nhadoop jar $HADOOP_HOME/hadoop-streaming.jar \\\r\n    -files $HOME/bin/jq,$HOME/proj-map.jq,$HOME/proj-reduce.jq \\\r\n    -mapper &quot;./jq -c --from-file=proj-map.jq&quot; \\\r\n    -reducer &quot;./jq -ncr --from-file=proj-reduce.jq&quot; \\\r\n\t-input  /tmp/sample.json \\\r\n\t-output /tmp/sample.json.output\r\n```\r\n\r\nwith \r\n\r\n```\r\n#proj-map.jq\r\n# some transformation\r\n{key1, key2}\r\n```\r\n\r\nand\r\n\r\n```\r\n#proj-reduce.jq\r\n# by @peak -- https://stackoverflow.com/a/45715729/948914\r\n# sort-free stream-oriented variant of group_by/1\r\n# f should always evaluate to a string.\r\n# Output: a stream of arrays, one array per group\r\ndef GROUPS_BY(stream; f): reduce stream as $x ({}; .[$x|f] += [$x] ) | .[] ;\r\n\r\nGROUPS_BY(inputs|.key1; .) | {key1: .[0], size: length} | (.size|tostring) + &quot;\\t&quot; + tostring\r\n```\r\n\r\nThe above yields something that I can feed into Unix sort for sorting:\r\n\r\n```\r\n3 {&quot;key1&quot;: &quot;value11&quot;, &quot;size&quot;: 3}\r\n2 {&quot;key1&quot;: &quot;value13&quot;, &quot;size&quot;: 2}\r\n1 {&quot;key1&quot;: &quot;value16&quot;, &quot;size&quot;: 1}\r\n1 {&quot;key1&quot;: &quot;value17&quot;, &quot;size&quot;: 1}\r\n```\r\n\r\nThis works. Now, I don&#39;t want to rely on Unix sort and I&#39;m looking for a way to use jq&#39;s `sort_by()`. I figured out that this can be challenging because from what I understand, `sort_by()` requires an array as input, which implies that the array is loaded in memory. Since the file may not fit in memory, I&#39;m looking for a way using jq&#39;s `sort_by()` without reading the entire file in memory. In particular, I&#39;m interested in an efficient, streaming-type way of sorting, [similar to Unix sort][1], or to the [streaming][2] [`group_by()`][3]. \r\n\r\nIf there is no such way, then to the best of my knowledge is [this answer][4], which combines `jq` and Unix `sort`, as I showed above. Obviously it would be great is `sort_by` worked like Unix `sort` but I don&#39;t have the means to find out.\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/930051/948914\r\n  [2]: https://stackoverflow.com/a/45706920/948914\r\n  [3]: https://stackoverflow.com/a/45715729/948914\r\n  [4]: https://stackoverflow.com/a/55713679/948914\r\n  [5]: https://stackoverflow.com/q/35484244/948914",
        "link": "https://stackoverflow.com/questions/60292458/what-is-the-best-way-to-sort-by-a-huge-file-that-doesnt-fit-in-memory-with-j",
        "title": "What is the best way to `sort_by` a huge file that doesn&#39;t fit in memory with `jq`"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582163515,
                "post_id": 60311790,
                "comment_id": 106686452,
                "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": 1582163595,
                "post_id": 60311790,
                "comment_id": 106686469,
                "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": 1582163668,
                "post_id": 60311790,
                "comment_id": 106686484,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1582163539,
                "creation_date": 1582163539,
                "answer_id": 60311831,
                "question_id": 60311790,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq -r &#39;.[] | [.urlString, .imageUrl] | @csv&#39;\r\n```\r\n\r\nSee this on jqplay at https://jqplay.org/s/zL6HpSSFw0",
                "title": "Convert JSON format to CSV Bash using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1582163603,
        "creation_date": 1582163173,
        "last_edit_date": 1582163603,
        "question_id": 60311790,
        "body_markdown": "Here is my sample code:\r\n\r\n    [\r\n        {\r\n            &quot;urlString&quot; : &quot;https://www.test.com/products/gift-card&quot;,\r\n            &quot;imageUrl&quot; : &quot;https://cdn.shopify.com/s/files/1/0454/6253/products/dope_mone_850x.jpg?v=1539288792&quot;\r\n        },\r\n        {\r\n            &quot;urlString&quot; : &quot;https://www.test.com/products/gift-card&quot;,\r\n            &quot;imageUrl&quot; : &quot;https://cdn.shopify.com/s/files/1/0454/6253/products/dope_mone_850x.jpg?v=1539288792&quot;\r\n        },\r\n    ]\r\n\r\n\r\nI want to create a CSV file with the output:\r\n\r\n    https://www.test.com/products/gift-card,https://cdn.shopify.com/s/files/1/0454/6253/products/dope_mone_850x.jpg?v=1539288792\r\n    https://www.test.com/products/gift-card,https://cdn.shopify.com/s/files/1/0454/6253/products/dope_mone_850x.jpg?v=1539288792\r\n\r\nHeader tags are not essential but if they are in the solution thats fine.\r\n\r\nthanks for the help!",
        "link": "https://stackoverflow.com/questions/60311790/convert-json-format-to-csv-bash-using-jq",
        "title": "Convert JSON format to CSV Bash using jq"
    },
    {
        "tags": [
            "json",
            "variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1582230473,
                "last_edit_date": 1582230473,
                "creation_date": 1582230127,
                "answer_id": 60327949,
                "question_id": 60327817,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s the `select` that is &quot;hiding&quot; some of the input.\r\n\r\nTo produce the output you expect, the simplest is not to use variables at all.  You could, for example, simply write:\r\n\r\n    .resources[].type\r\n",
                "title": "jq variable seems to hid original input"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1582289659,
        "creation_date": 1582229530,
        "last_edit_date": 1582289659,
        "question_id": 60327817,
        "body_markdown": "I&#39;m trying to parse through some json and put certain sections into variables. I think I&#39;m not understanding something about how variables work though.\r\n\r\nJson:\r\n```\r\n{\r\n  &quot;resources&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;Microsoft.ApiManagement/service/apis&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Microsoft.ApiManagement/service/apis/schemas&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nThen using this jq:\r\n```\r\n.resources[] | select(.type == &quot;Microsoft.ApiManagement/service/apis&quot;) as $apis | { types: [.type], apis: $apis}\r\n```\r\nI get this:\r\n```\r\n{\r\n  &quot;types&quot;: [\r\n    &quot;Microsoft.ApiManagement/service/apis&quot;\r\n  ],\r\n  &quot;apis&quot;: {\r\n    &quot;type&quot;: &quot;Microsoft.ApiManagement/service/apis&quot;\r\n  }\r\n}\r\n```\r\nWhen I expected this:\r\n```\r\n{\r\n  &quot;types&quot;: [\r\n    &quot;Microsoft.ApiManagement/service/apis&quot;,\r\n    &quot;Microsoft.ApiManagement/service/apis/schemas&quot;\r\n  ],\r\n  &quot;apis&quot;: {\r\n    &quot;type&quot;: &quot;Microsoft.ApiManagement/service/apis&quot;\r\n  }\r\n}\r\n```\r\n\r\nhttps://jqplay.org/s/4aeBOY9x6q\r\n\r\nAccording to the variables section of the [jq manual][1] \r\n\r\n&gt; The expression exp as $x | ... means: for each value of expression\r\n&gt; exp, run the rest of the pipeline with the entire original input, and\r\n&gt; with $x set to that value. Thus as functions as something of a foreach\r\n&gt; loop.\r\n\r\nWhich makes me think that .type should return from the original set not the filtered result I stored in $apis. Where is the disconnect?\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/v1.4/#Advancedfeatures",
        "link": "https://stackoverflow.com/questions/60327817/jq-variable-seems-to-hid-original-input",
        "title": "jq variable seems to hid original input"
    },
    {
        "tags": [
            "bash",
            "amazon-web-services",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582255443,
                "post_id": 60331676,
                "comment_id": 106722747,
                "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": 1582256175,
                "post_id": 60331676,
                "comment_id": 106722875,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1582260442,
                "creation_date": 1582260442,
                "answer_id": 60332367,
                "question_id": 60331676,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the input file is `input.json`, then:\r\n\r\nTo output in the 2 columns format:\r\n```\r\njq -r  &#39;.Datapoints[] | [.ExtendedStatistics.p80, .Timestamp] | @tsv&#39; input.json | sort -nr\r\n```\r\n\r\nWith Heading as CPUUtilization (2 columns):\r\n```\r\necho CPUUtilization; jq -r  &#39;.Datapoints[] | [.ExtendedStatistics.p80, .Timestamp] | @tsv&#39; input.json | sort -nr \r\n```\r\n\r\nAnd in single column:\r\n```\r\njq -r  &#39;.Datapoints[] | [.ExtendedStatistics.p80] | @tsv&#39; input.json | sort -nr\r\n```",
                "title": "Shell script - Sorting &#39;AWS cloudwatch metrics&#39; json array based on the “Timestamp” property with raw output including statistics"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1582260442,
        "creation_date": 1582254795,
        "last_edit_date": 1582255699,
        "question_id": 60331676,
        "body_markdown": "I am running aws cli\r\n `aws cloudwatch get-metric-statistics --metric-name CPUUtilization --start-time 2010-02-20T12:00:00 --end-time 2010-02-20T15:00:00 --period 60 --namespace AWS/EC2  --extended-statistics p80 --dimensions Name=InstanceId,Value=i-0b123423423`\r\n\r\nthe output comes as \r\n```\r\n{\r\n  &quot;Label&quot;: &quot;CPUUtilization&quot;,\r\n  &quot;Datapoints&quot;: [\r\n    {\r\n      &quot;Timestamp&quot;: &quot;2020-02-20T12:15:00Z&quot;,\r\n      &quot;Unit&quot;: &quot;Percent&quot;,\r\n      &quot;ExtendedStatistics&quot;: {\r\n        &quot;p80&quot;: 0.16587132264856133\r\n      }\r\n    },\r\n   ``` \r\n\r\nHow do i get the output in the below format&#39;s (2 Columns)\r\n\r\n    19.514049550078127\t2020-02-13T20:15:00Z\r\n    12.721997782508938\t2020-02-13T19:15:00Z\r\n    13.318820949213313\t2020-02-13T18:15:00Z\r\n    15.994192991030545\t2020-02-13T17:15:00Z\r\n    18.13096421299414\t2020-02-13T16:15:00Z\r\n\r\nwith Heading as CPUUtilization (2 columns)\r\n\r\n\r\n    CPUUtilization\r\n    19.514049550078127\t2020-02-13T20:15:00Z\r\n    12.721997782508938\t2020-02-13T19:15:00Z\r\n    13.318820949213313\t2020-02-13T18:15:00Z\r\n    15.994192991030545\t2020-02-13T17:15:00Z\r\n    18.13096421299414\t2020-02-13T16:15:00Z\r\n\r\nAnd in single column\r\n\r\n        \r\n    19.514049550078127\t\r\n    12.721997782508938\t\r\n    13.318820949213313\t\r\n    15.994192991030545\t\r\n    18.13096421299414\t\r\n    \r\nHow can achieve this ?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/60331676/shell-script-sorting-aws-cloudwatch-metrics-json-array-based-on-the-timesta",
        "title": "Shell script - Sorting &#39;AWS cloudwatch metrics&#39; json array based on the “Timestamp” property with raw output including statistics"
    },
    {
        "tags": [
            "json",
            "linux",
            "terminal",
            "jq",
            "conditional-operator"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1582258405,
                "creation_date": 1582258405,
                "answer_id": 60332121,
                "question_id": 60331877,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try the following, assuming the file containing that json document is at `/tmp/json`:\r\n\r\n```\r\njq &#39;.results[] | select(.status==301) | .url&#39; /tmp/json\r\n```\r\n\r\nAlso, I notice the document you supplied in the question is not actually a valid JSON document. I assume you meant the following:\r\n\r\n```\r\n{\r\n  &quot;results&quot;: [\r\n    {\r\n      &quot;input&quot;: {\r\n        &quot;FUZZ&quot;: &quot;actuator&quot;,\r\n        &quot;HOST&quot;: &quot;https://zzlckzc4kz-3.algolia.net&quot;\r\n      },\r\n      &quot;position&quot;: 13,\r\n      &quot;status&quot;: 301,\r\n      &quot;length&quot;: 162,\r\n      &quot;words&quot;: 5,\r\n      &quot;lines&quot;: 8,\r\n      &quot;redirectlocation&quot;: &quot;https://algolia.net/1/404&quot;,\r\n      &quot;resultfile&quot;: &quot;&quot;,\r\n      &quot;url&quot;: &quot;https://zzlckzc4kz-3.algolia.net/actuator&quot;\r\n    },\r\n    {\r\n      &quot;input&quot;: {\r\n        &quot;FUZZ&quot;: &quot;actuator/heapdump&quot;,\r\n        &quot;HOST&quot;: &quot;https://zzlckzc4kz-3.algolia.net&quot;\r\n      },\r\n      &quot;position&quot;: 24,\r\n      &quot;status&quot;: 301,\r\n      &quot;length&quot;: 162,\r\n      &quot;words&quot;: 5,\r\n      &quot;lines&quot;: 8,\r\n      &quot;redirectlocation&quot;: &quot;https://algolia.net/1/404&quot;,\r\n      &quot;resultfile&quot;: &quot;&quot;,\r\n      &quot;url&quot;: &quot;https://zzlckzc4kz-3.algolia.net/actuator/heapdump&quot;\r\n    }\r\n  ]\r\n}\r\n\r\n```",
                "title": "How to extract data using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1582258405,
        "creation_date": 1582256384,
        "question_id": 60331877,
        "body_markdown": "I am trying to use jq to extract data from JSON fields that contain a specific value.\r\n\r\nThis is the JSON that I&#39;m working with:\r\n\r\n    &quot;results&quot;: [\r\n    {\r\n      &quot;input&quot;: {\r\n        &quot;FUZZ&quot;: &quot;actuator&quot;,\r\n        &quot;HOST&quot;: &quot;https://zzlckzc4kz-3.algolia.net&quot;\r\n      },\r\n      &quot;position&quot;: 13,\r\n      &quot;status&quot;: 301,\r\n      &quot;length&quot;: 162,\r\n      &quot;words&quot;: 5,\r\n      &quot;lines&quot;: 8,\r\n      &quot;redirectlocation&quot;: &quot;https://algolia.net/1/404&quot;,\r\n      &quot;resultfile&quot;: &quot;&quot;,\r\n      &quot;url&quot;: &quot;https://zzlckzc4kz-3.algolia.net/actuator&quot;\r\n    },\r\n    {\r\n      &quot;input&quot;: {\r\n        &quot;FUZZ&quot;: &quot;actuator/heapdump&quot;,\r\n        &quot;HOST&quot;: &quot;https://zzlckzc4kz-3.algolia.net&quot;\r\n      },\r\n      &quot;position&quot;: 24,\r\n      &quot;status&quot;: 301,\r\n      &quot;length&quot;: 162,\r\n      &quot;words&quot;: 5,\r\n      &quot;lines&quot;: 8,\r\n      &quot;redirectlocation&quot;: &quot;https://algolia.net/1/404&quot;,\r\n      &quot;resultfile&quot;: &quot;&quot;,\r\n      &quot;url&quot;: &quot;https://zzlckzc4kz-3.algolia.net/actuator/heapdump&quot;\r\n    },\r\n    ]\r\n\r\ni want the output to be if &quot;status&quot;: 301 then display &quot;url:&quot;\r\n",
        "link": "https://stackoverflow.com/questions/60331877/how-to-extract-data-using-jq",
        "title": "How to extract data using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1582278880,
                "post_id": 60335775,
                "comment_id": 106730262,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1582297955,
                "creation_date": 1582297955,
                "answer_id": 60341496,
                "question_id": 60335775,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In case there’s more than one occurrence, it might be wise to use the following query:\r\n\r\n    .[]\r\n    | select(.clientId == &quot;account&quot;)\r\n    | .id\r\n\r\n",
                "title": "jq and bash : get a specific value in json when other key value pair matches"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1582297955,
        "creation_date": 1582277788,
        "last_edit_date": 1582278795,
        "question_id": 60335775,
        "body_markdown": "I want to parse a JSON file to get a specific value where the condition is another key/value pair, but I don&#39;t know how to handle this (I am not a developer). For example, I get this JSON\r\n\r\n```\r\n[\r\n&#160;&#160;&#160; {\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;id&quot;: &quot;c490ffaf-92ea-4a29-9614-ab36a088f366&quot;,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;clientId&quot;: &quot;account&quot;,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;name&quot;: &quot;${client_account}&quot;,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;rootUrl&quot;: &quot;${authBaseUrl}&quot;,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;baseUrl&quot;: &quot;/realms/test1/account/&quot;,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;surrogateAuthRequired&quot;: false,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;enabled&quot;: true,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;clientAuthenticatorType&quot;: &quot;client-secret&quot;,\r\n&#160;&#160;&#160; },\r\n&#160;&#160;&#160;&#160;{\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;id&quot;: &quot;2daa32334-24322-4a29-43242-423223&quot;,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;clientId&quot;: &quot;swap&quot;,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;name&quot;: &quot;${client_swap}&quot;,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;rootUrl&quot;: &quot;${authBaseUrl}&quot;,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;baseUrl&quot;: &quot;/realms/test/swap/&quot;,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;surrogateAuthRequired&quot;: false,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;enabled&quot;: true,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;clientAuthenticatorType&quot;: &quot;client-secret&quot;,\r\n&#160;&#160;&#160; },\r\n&#160;&#160;  {\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;id&quot;: &quot;e22112-11111-4a329-22211-333312&quot;,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;clientId&quot;: &quot;broker&quot;,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;name&quot;: &quot;${client_broker}&quot;,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;rootUrl&quot;: &quot;${authBaseUrl}&quot;,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;baseUrl&quot;: &quot;/realms/test/broker/&quot;,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;surrogateAuthRequired&quot;: false,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;enabled&quot;: true,\r\n&#160;&#160;&#160;&#160;&#160;&#160;&#160; &quot;clientAuthenticatorType&quot;: &quot;client-secret&quot;,\r\n&#160;&#160;&#160; },\r\n]\r\n```\r\nI want the value of &quot;id&quot; (c490ffaf-92ea-4a29-9614-ab36a088f366 in this example) from the block where the value from &quot;clientId&quot; is &quot;account&quot;\r\n\r\nHow to do that kind of thing with jq and bash?",
        "link": "https://stackoverflow.com/questions/60335775/jq-and-bash-get-a-specific-value-in-json-when-other-key-value-pair-matches",
        "title": "jq and bash : get a specific value in json when other key value pair matches"
    },
    {
        "tags": [
            "string",
            "csv",
            "jq",
            "quotes",
            "ffprobe"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1582441290,
                "last_edit_date": 1582441290,
                "creation_date": 1582360825,
                "answer_id": 60350449,
                "question_id": 60350315,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `@csv` filter produces CSV in general accordance with the prevalent standards, which require strings to be quoted under certain circumstances (e.g. if they contain commas), and which allow fields to be quoted.\r\n\r\njq&#39;s -r option is much misunderstood. It only affects &quot;top-level&quot; JSON string outputs.  It should be used with the `@csv` option to produce CSV output, but it does not strip quotation marks from string-valued fields.\r\n\r\nIf you want to have fine-grained control over where quotation marks appear, you have numerous options (one of the simplest being `@tsv | gsub(&quot;\\\\t&quot;;&quot;,&quot;)`), but you then run the risk of producing invalid CSV.\r\n",
                "title": "Why does the jq --raw-output argument fail to remove quotes from @csv output?"
            },
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1594757373,
                "creation_date": 1594757373,
                "answer_id": 62903250,
                "question_id": 60350315,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `--raw-output` option, has no control on strings passed to `@csv`, as, by that time, they are not final results of the filter. They are quoted because `@csv` quoted them.\r\n\r\n`jq` considers the result of `@csv` as a single string output value. The `--raw-output` option works as it says in documentation, it does not encode string results in output to JSON.\r\n\r\nIf you try without that option, you will see output as `&quot;\\&quot;01 Jubilee.flac\\&quot;,\\&quot;flac\\&quot;,\\&quot;Bill Charlap Trio\\&quot;&quot;`, which, is a properly encoded JSON string. It has quoting, as well as disallowed characters escaped. \r\nYou can see this difference by simply checking and unchecking the `Raw Output` option at https://jqplay.org/s/OerK1MlARS.\r\n\r\nIf you want unquoted strings in CSV, you can use `join(&quot;,&quot;)` in place of `@csv`, but it will not work well when some string itself has comma in it. \r\n\r\n",
                "title": "Why does the jq --raw-output argument fail to remove quotes from @csv output?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 9,
        "last_activity_date": 1594757373,
        "creation_date": 1582359790,
        "last_edit_date": 1594748637,
        "question_id": 60350315,
        "body_markdown": "I am trying to use `jq` to reformat some elements of the JSON output generated by `ffprobe` as `csv`. I&#39;m close (it seems to me), but struggling with a detail:\r\n\r\nMy [`ffprobe` output is shown in the jq 1.6 playground](https://jqplay.org/s/OerK1MlARS) \r\n\r\nI&#39;m running a recently d/l binary of jq (`jq --version` =&gt; `jq-1.6`) on MacOS Mojave (10.14.6)\r\n\r\nFrom the terminal on my Mac, my results are: \r\n\r\n```bash\r\n$ fn_ffprobeall | jq -r &#39;[.format.filename,.format.format_name,.format.tags.album_artist] | @csv&#39;\r\n&quot;01 Jubilee.flac&quot;,&quot;flac&quot;,&quot;Bill Charlap Trio&quot;\r\n\r\n# where fn_ffprobeall is a function defined as: \r\nfn_ffprobeall () { ffprobe -i &quot;01 Jubilee.flac&quot; -hide_banner -v quiet -print_format json -show_format -show_streams; }\r\n``` \r\n\r\nBut this `jq` output (shown above) is not what I need... I need values *without* the surrounding quotes `&quot;&quot;`. According to [the documentation](https://stedolan.github.io/jq/manual/) for `--raw-output / -r`: \r\n\r\n&gt; With this option, if the filter’s result is a string then it will be written directly to standard output rather than being formatted as a JSON string with quotes. This can be useful for making jq filters talk to non-JSON-based systems.  \r\n\r\nAlso, it seems odd that using `@tsv` instead of `@csv` &quot;*does the right thing*&quot; as the quotes will be stripped. I suppose one could do some additional work to replace `tab` chars with `,`, but I&#39;d like to know if I&#39;m missing something before falling back to that approach.",
        "link": "https://stackoverflow.com/questions/60350315/why-does-the-jq-raw-output-argument-fail-to-remove-quotes-from-csv-output",
        "title": "Why does the jq --raw-output argument fail to remove quotes from @csv output?"
    },
    {
        "tags": [
            "json",
            "filter",
            "aggregate-functions",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1582472060,
                "post_id": 60361634,
                "comment_id": 106781132,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5055888,
                    "reputation": 320,
                    "user_id": 6138682,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/5bJnj.png?s=256",
                    "display_name": "Nils Magnus",
                    "link": "https://stackoverflow.com/users/6138682/nils-magnus"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582625304,
                "post_id": 60361634,
                "comment_id": 106833202,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1628309853,
                "creation_date": 1628309853,
                "answer_id": 68689375,
                "question_id": 60361634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So `jq &#39;max_by(.lat)&#39; input.json `\r\n\r\n`max_by` is a function that  will scan a array and return the element that is the greater .\r\n\r\nThe type can be a string or a number .\r\n\r\nYou have more examples in the documentation https://stedolan.github.io/jq/manual/v1.5/#Builtinoperatorsandfunctions \r\n\r\nsome examples :\r\n\r\nwe have array of objects , we use a the property `p` \r\n\r\n    echo &#39;[{&quot;n&quot;:&quot;a&quot;,&quot;p&quot;:1},{&quot;n&quot;:&quot;c&quot;,&quot;p&quot;:2},{&quot;n&quot;:&quot;b&quot;,&quot;p&quot;:8}]&#39;| jq &#39;max_by(.p)&#39;\r\n    {\r\n      &quot;n&quot;: &quot;b&quot;,\r\n      &quot;p&quot;: 8\r\n    }\r\n\r\nwe have array of objects , we use a the property `n` \r\n\r\n    echo &#39;[{&quot;n&quot;:&quot;a&quot;,&quot;p&quot;:1},{&quot;n&quot;:&quot;c&quot;,&quot;p&quot;:2},{&quot;n&quot;:&quot;b&quot;,&quot;p&quot;:8}]&#39;| jq &#39;max_by(.n)&#39;\r\n    {\r\n      &quot;n&quot;: &quot;c&quot;,\r\n      &quot;p&quot;: 2\r\n     }\r\n",
                "title": "How do I select an attribute which is a sibling to the maximum in a JSON array with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1628309853,
        "creation_date": 1582456680,
        "question_id": 60361634,
        "body_markdown": "An API returns a JSON array like this:\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Rangsdorf, Bahnhof&quot;,\r\n    &quot;lat&quot;: 52.294125,\r\n    &quot;lon&quot;: 13.431112\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Leipzig, Hauptbahnhof&quot;,\r\n    &quot;lat&quot;: 51.344817,\r\n    &quot;lon&quot;: 12.381321\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Senftenberg, Bahnhof&quot;,\r\n    &quot;lat&quot;: 51.52679,\r\n    &quot;lon&quot;: 14.003977\r\n  },\r\n [...]\r\n]\r\n```\r\nI&#39;d like to retrieve that (or one) dict out of the array with the most northern position (i. e. where `lat` has a maximum) using ```jq```. In the example, I&#39;d expect either\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;Rangsdorf, Bahnhof&quot;\r\n}\r\n```\r\nor, even better\r\n```json\r\n  {\r\n    &quot;name&quot;: &quot;Rangsdorf, Bahnhof&quot;,\r\n    &quot;lat&quot;: 52.294125,\r\n    &quot;lon&quot;: 13.431112\r\n  }\r\n```\r\nas a result using ```jq```.",
        "link": "https://stackoverflow.com/questions/60361634/how-do-i-select-an-attribute-which-is-a-sibling-to-the-maximum-in-a-json-array-w",
        "title": "How do I select an attribute which is a sibling to the maximum in a JSON array with jq?"
    },
    {
        "tags": [
            "json",
            "windows",
            "batch-file",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1582513610,
                "last_edit_date": 1582513610,
                "creation_date": 1582512822,
                "answer_id": 60368980,
                "question_id": 60368686,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A small tweak of your jq filter would do the trick:\r\n\r\n    .movie_results[] | [.id, .genre_ids[]] | join(&quot;,&quot;)\r\n\r\n(The above line does not take into account your shell&#39;s rules for escaping special characters. Have you considered circumventing such issues by using the -f command-line option?)\r\n\r\n### An alternative\r\n\r\nHere&#39;s an alternative that avoids using double quotes (`&quot;`) in the filter:\r\n\r\n    .movie_results[] | [.id] + .genre_ids | @csv",
                "title": "How to concatenate an array in json using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1582518054,
        "creation_date": 1582509823,
        "last_edit_date": 1582518054,
        "question_id": 60368686,
        "body_markdown": "trying to combine the rows. Here is the source\r\n```\r\n{\r\n  &quot;movie_results&quot;: [\r\n    {\r\n      &quot;genre_ids&quot;: [\r\n        28,\r\n        35,\r\n        80\r\n      ],\r\n      &quot;id&quot;: 96,\r\n    }\r\n  ]\r\n```\r\nHere is my command line\r\n```\r\nC:\\WINDOWS\\system32&gt;curl &quot;https://api.themoviedb.org/3/find/tt0092644?&amp;external_source=imdb_id&quot; | jq -r &quot;.movie_results[] | .id, (.genre_ids | join(\\&quot;,\\&quot;))\r\n```\r\nIm getting the following result\r\n```\r\n96\r\n28,35,80\r\n```\r\nhow do I make it ```96,28,35,80```? By the way im doing this on windows command line\r\n",
        "link": "https://stackoverflow.com/questions/60368686/how-to-concatenate-an-array-in-json-using-jq",
        "title": "How to concatenate an array in json using JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1582524611,
                "last_edit_date": 1582524611,
                "creation_date": 1582519929,
                "answer_id": 60369752,
                "question_id": 60369670,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As you see, by default, jq reads the entire input stream.  The -n command-line option turns this behavior off, so one (efficient) solution would be:\r\n\r\n    jq -n &#39;input.number&#39; test.txt\r\n\r\nIf your jq does not have `input`, then now would be an excellent time to upgrade; if that is not possible:\r\n\r\n    jq -s &#39;.[0].number&#39; test.txt",
                "title": "How I can get the first data using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1582647187,
        "creation_date": 1582519327,
        "last_edit_date": 1582647187,
        "question_id": 60369670,
        "body_markdown": "I have some test data file test.txt:\r\n\r\n```\r\n{\r\n  &quot;type&quot;: &quot;home&quot;,\r\n  &quot;number&quot;: &quot;212 555-1234&quot;\r\n}\r\n{\r\n  &quot;type&quot;: &quot;fax&quot;,\r\n  &quot;number&quot;: &quot;646 555-4567&quot;\r\n}\r\n```\r\nI try get the first number:\r\n\r\n    jq .number test.txt\r\n\r\nBut it get all number.\r\n\r\nCan anyone help me?",
        "link": "https://stackoverflow.com/questions/60369670/how-i-can-get-the-first-data-using-jq",
        "title": "How I can get the first data using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16333181,
                    "reputation": 2017,
                    "user_id": 11796003,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/yysPJ.jpg?s=256",
                    "display_name": "Adam Strauss",
                    "link": "https://stackoverflow.com/users/11796003/adam-strauss"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582534555,
                "post_id": 60371968,
                "comment_id": 106796735,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3803360,
                    "reputation": 1133,
                    "user_id": 3156383,
                    "user_type": "registered",
                    "accept_rate": 12,
                    "profile_image": "https://www.gravatar.com/avatar/1aa4fe089ace5cb79043f124702463d8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dks551",
                    "link": "https://stackoverflow.com/users/3156383/dks551"
                },
                "reply_to_user": {
                    "account_id": 16333181,
                    "reputation": 2017,
                    "user_id": 11796003,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/yysPJ.jpg?s=256",
                    "display_name": "Adam Strauss",
                    "link": "https://stackoverflow.com/users/11796003/adam-strauss"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582534966,
                "post_id": 60371968,
                "comment_id": 106796904,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1582559113,
                "last_edit_date": 1582559113,
                "creation_date": 1582557505,
                "answer_id": 60378900,
                "question_id": 60371968,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use a `reduce` expression instead of slurping the whole file into memory (`-s`); by iterative manipulation of the input file contents and then appending the required fields one at a time. \r\n\r\n    jq -n &#39;reduce inputs.Parameters[] as $d (.; . + [ { id: $d.Name, value: $d.Value } ])&#39; one.json two.json three.json\r\n\r\nThe `-n` flag is to ensure that we construct the output JSON data from scratch over the input file contents made available over the `inputs` function. Since `reduce` works in an iterative manner, for each of the object in the input, we create a final array, creating the KV pair as desired.",
                "title": "Create merged JSON array from multiple files using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1582559113,
        "creation_date": 1582532931,
        "last_edit_date": 1582557620,
        "question_id": 60371968,
        "body_markdown": "I have multiple JSON files `one.json`, `two.json`, `three.json` with the below format and I want to create a consolidated array from them using `jq`. So, from all the files I want to extract `Name` and `Value` field inside the `Parameters` and use them to create an array where the `id` value will be constructed from the `Name` value and `value` field will be constructed using `Value` field value.\r\n\r\n*input:*  \r\n**one.json**:\r\n\r\n    {\r\n      &quot;Parameters&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;id1&quot;,\r\n          &quot;Value&quot;: &quot;one&quot;,\r\n          &quot;Version&quot;: 2,\r\n          &quot;LastModifiedDate&quot;: 1581663187.36\r\n          \r\n        }\r\n      ]\r\n    }\r\n\r\n**two.json** \r\n\r\n    {\r\n      &quot;Parameters&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;id2&quot;,\r\n          &quot;Value&quot;: &quot;xyz&quot;,\r\n          &quot;Version&quot;: 2,\r\n          &quot;LastModifiedDate&quot;: 1581663187.36\r\n          \r\n        }\r\n      ]\r\n    }\r\n\r\n**three.json**\r\n\r\n    {\r\n      &quot;Parameters&quot;: [\r\n        {\r\n          &quot;Name&quot;: &quot;id3&quot;,\r\n          &quot;Value&quot;: &quot;xyz&quot;,\r\n          &quot;Version&quot;: 2,\r\n          &quot;LastModifiedDate&quot;: 1581663187.36\r\n          \r\n        }\r\n      ]\r\n    }\r\n\r\n*output:*\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;id1&quot;,\r\n        &quot;value&quot;: &quot;one&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;id2&quot;,\r\n        &quot;value&quot;: &quot;xyz&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;id3&quot;,\r\n        &quot;value&quot;: &quot;xyz&quot;\r\n      }\r\n    ]\r\n\r\n\r\nHow to achieve this using `jq`",
        "link": "https://stackoverflow.com/questions/60371968/create-merged-json-array-from-multiple-files-using-jq",
        "title": "Create merged JSON array from multiple files using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1582551398,
                "last_edit_date": 1582551398,
                "creation_date": 1582542984,
                "answer_id": 60374768,
                "question_id": 60372707,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The JSON example contained a superfluous `,` that `jq` won&#39;t accept.\r\n\r\nYour example filter chain appears to operate on `.tasks[]` even though the example appears to be only a single task. So it is not possible to rewrite what you have got into a functioning state. So rather than provide an exact answer to an inexact question, here is the first of the three parts of your filter chain revised:\r\n\r\n```\r\n.inputData.transfers | map(select(.target.filename | match(&quot;xml$&quot;; &quot;i&quot;)))\r\n```\r\n\r\nSee [this jqplay snippet](https://jqplay.org/s/C3UvyrF5hQ).\r\n\r\nRather than write `[ .xs[] | select(p) ]`, just write `.xs | map(select(p))`.",
                "title": "json / jq : multi-level grouping of sub-elements in an array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1582563011,
                "creation_date": 1582563011,
                "answer_id": 60380509,
                "question_id": 60372707,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "i finally found the answer. the trick was to pipe the `.tasks[]` into an expression where the parens were placed around the field elements as a group, which apparently will apply whatever is inside the parens to each element of the array individually, in sequence. then using @dmitry example as a guide, i also placed the elements inside right and left brackets to recreate array elements that i could then select, which could then be output onto 1 line each with `| @csv`. so the final chain that worked for me is :\r\n```\r\n.task[] | ([.inputData.transfers[].target.filename, .outputData.transferLength, .updateDate]) | [(.[0],.[2],.[3])] | @csv&#39;\r\n```\r\n\r\nunfortunately i couldn&#39;t get `match()` to work in this invocation, nor `sub()` ; each of these caused jq to offer a useless error message just before it dumped core.\r\n\r\nmany thanks to the people who replied.",
                "title": "json / jq : multi-level grouping of sub-elements in an array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1582563011,
        "creation_date": 1582535861,
        "last_edit_date": 1582552176,
        "question_id": 60372707,
        "body_markdown": "i&#39;m writing a script that needs to parse incoming json into line-by-line data, taking information from the json at multiple different levels. i&#39;m using [jq][1] to parse the data.\r\n\r\nthe incoming json is an array of &#39;tasks&#39;. each task [i.e. each element of the array] is an object that looks like this :\r\n```\r\n{\r\n  &quot;inputData&quot;: {\r\n    &quot;transfers&quot;: [\r\n      {\r\n        &quot;source&quot;: {\r\n          &quot;directory&quot;: &quot;/path/to/source&quot;,\r\n          &quot;filename&quot;: &quot;somefile.mp3&quot;\r\n        },\r\n        &quot;target&quot;: {\r\n          &quot;directory&quot;: &quot;/path/to/target&quot;,\r\n          &quot;filename&quot;: &quot;somefile.mp3&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;source&quot;: {\r\n          &quot;content&quot;: &quot;&lt;?xml version=\\&quot;1.0\\&quot; encoding=\\&quot;UTF-8\\&quot;?&gt;&lt;delivery&gt;content description&lt;/delivery&gt;&quot;,\r\n          &quot;encoding&quot;: &quot;UTF-8&quot;\r\n        },\r\n        &quot;target&quot;: {\r\n          &quot;directory&quot;: &quot;/path/to/target&quot;,\r\n          &quot;filename&quot;: &quot;somefile.xml&quot;\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  &quot;outputData&quot;: {\r\n    &quot;transferDuration&quot;: &quot;00:00:37:10&quot;,\r\n    &quot;transferLength&quot;: 187813298,\r\n  },\r\n  &quot;updateDate&quot;: &quot;2020-02-21T14:37:18.329Z&quot;,\r\n  &quot;updateUser&quot;: &quot;bob&quot;\r\n}\r\n```\r\ni want to read all of the tasks and, for each one, output a single line composed of the following fields :\r\n\r\n\ttask[n].inputData.transfers[].target.filename, task[n].outputData.transferLength, task[n].updateDate\r\n\r\ni&#39;ve got my filter chain to where it will choose the appropriate fields correctly, even to where it will pick the &#39;correct&#39; single entry from amongst the multiple entries in the `task[].inputData.transfers[]` array, but when i try to get the output of more than a single element, the chain iterates over the array three times, and i get\r\n\r\n\ttask[0].inputData.transfers[].target.filename\r\n\ttask[1].inputData.transfers[].target.filename\r\n\ttask[2].inputData.transfers[].target.filename\r\n\t...\t\r\n\ttask[n].inputData.transfers[].target.filename\r\n\r\nthen the results of the `outputData.transferLength` field for all elements,&lt;br&gt;\r\nthen the results of the `updateDate` field for all elements.\r\n\r\nhere is my filter chain :\r\n\r\n\t&#39;(.tasks[].inputData.transfers[] | select(.target.filename | match(&quot;[Xx][Mm][Ll]$&quot;)).target.filename), .tasks[].outputData.transferLength, .tasks[].updateDate&#39;\r\n\r\ni&#39;m thinking there must be some efficient way to group all of these multi-level elements together for each element of the array ; something like a &#39;**with ...**&#39; clause, like `with tasks[] : blablabla`, but can&#39;t figure out how to do it. can anyone help ?\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq",
        "link": "https://stackoverflow.com/questions/60372707/json-jq-multi-level-grouping-of-sub-elements-in-an-array",
        "title": "json / jq : multi-level grouping of sub-elements in an array"
    },
    {
        "tags": [
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582571893,
                "post_id": 60382388,
                "comment_id": 106816068,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8344031,
                    "reputation": 2835,
                    "user_id": 6268432,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/pnLBv.png?s=256",
                    "display_name": "Alex",
                    "link": "https://stackoverflow.com/users/6268432/alex"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582571958,
                "post_id": 60382388,
                "comment_id": 106816086,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582572022,
                "post_id": 60382388,
                "comment_id": 106816122,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8344031,
                    "reputation": 2835,
                    "user_id": 6268432,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/pnLBv.png?s=256",
                    "display_name": "Alex",
                    "link": "https://stackoverflow.com/users/6268432/alex"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1582572154,
                "post_id": 60382388,
                "comment_id": 106816190,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1582577226,
                "last_edit_date": 1582577226,
                "creation_date": 1582572701,
                "answer_id": 60382728,
                "question_id": 60382388,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If convenience is at a premium, then using `walk` has much to recommend it:\r\n\r\n    walk(if type == &quot;object&quot; and .label.S == &quot;helm_chart_version&quot;\r\n         then .value.S = &quot;0.1.2&quot; else . end)\r\n\r\nThis of course assumes that &quot;S&quot; is known ahead of time. If that&#39;s not the case, then one possibility to consider would be:\r\n\r\n    walk(if type == &quot;object&quot; and has(&quot;label&quot;) and any(.label[]; . == &quot;helm_chart_version&quot;) \r\n         then .value |= map_values(&quot;0.1.2&quot;) else . end)\r\n\r\n## Variations\r\n\r\nIf you don&#39;t want to `walk` the entire object, you could simply walk over `.settings`:\r\n\r\n    .Item.settings\r\n    |= walk(if type == &quot;object&quot; \r\n            and has(&quot;label&quot;)\r\n            and any(.label[]; . == &quot;helm_chart_version&quot;)\r\n            then .value |= map_values(&quot;0.1.2&quot;)\r\n            else . \r\n            end)\r\n\r\nOr if &quot;label&quot; is also an unknown:\r\n\r\n```\r\n.Item.settings\r\n|= (. as $in\r\n    | [paths\r\n       | . as $p\r\n       | select(($in|getpath($p)) == &quot;helm_chart_version&quot;)]\r\n    | reduce .[] as $p ($in; setpath($p | (.[-2] = &quot;value&quot;); &quot;0.1.2&quot;)))\r\n```\r\n\r\n",
                "title": "aws dynamoDB cli - using jq on nested json"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1582576300,
                "last_edit_date": 1582576300,
                "creation_date": 1582572897,
                "answer_id": 60382766,
                "question_id": 60382388,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to traverse individual objects and find the object to update and set its value, you can do\r\n\r\n    jq &#39;(.Item.settings.L[] | select(.M.label.S == &quot;helm_chart_version&quot;)) |= (.M.value.S = &quot;0.1.2&quot;)&#39;\r\n\r\nthe part before the `|=` does the identification of the right object matching your string. Once the object is identified, the update operator `|=` just modifies the field with the desired value. See it working on [jq-play](https://jqplay.org/s/EemeeJFIys)\r\n",
                "title": "aws dynamoDB cli - using jq on nested json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1582577226,
        "creation_date": 1582570991,
        "last_edit_date": 1582575138,
        "question_id": 60382388,
        "body_markdown": "I need to swap a value on a dynamoDB entry. The difficulty is the coworker who put the table together used nested json on the field I need to edit. I&#39;m having trouble figuring out to how to edit a value when the layout is asymmetrical. \r\n\r\nLet&#39;s say a row in dynamoDB shows up like this with get-item:\r\n\r\n    {    \r\n     &quot;Item&quot;: {\r\n          &quot;aws:rep:deleting&quot;: {\r\n            &quot;BOOL&quot;: false\r\n          },\r\n          &quot;service&quot;: {\r\n            &quot;S&quot;: &quot;g&quot;\r\n          },\r\n          &quot;settings&quot;: {\r\n            &quot;L&quot;: [\r\n              {\r\n                &quot;M&quot;: {\r\n                  &quot;fe_enabled&quot;: {\r\n                    &quot;BOOL&quot;: false\r\n                  },\r\n                  &quot;stack_type&quot;: {\r\n                    &quot;S&quot;: &quot;all&quot;\r\n                  },\r\n                  &quot;label&quot;: {\r\n                    &quot;S&quot;: &quot;helm_chart_name&quot;\r\n                  },\r\n                  &quot;value&quot;: {\r\n                    &quot;S&quot;: &quot;gate&quot;\r\n                  }\r\n                }\r\n              },\r\n              {\r\n                &quot;M&quot;: {\r\n                  &quot;fe_enabled&quot;: {\r\n                    &quot;BOOL&quot;: true\r\n                  },\r\n                  &quot;stack_type&quot;: {\r\n                    &quot;S&quot;: &quot;all&quot;\r\n                  },\r\n                  &quot;label&quot;: {\r\n                    &quot;S&quot;: &quot;helm_chart_version&quot;\r\n                  },\r\n                  &quot;value&quot;: {\r\n                    &quot;S&quot;: &quot;0.1.1&quot;\r\n                  }\r\n                }\r\n              }\r\n            ]\r\n          },\r\n          &quot;label&quot;: {\r\n            &quot;S&quot;: &quot;gate&quot;\r\n          },\r\n          &quot;service_children&quot;: {\r\n            &quot;L&quot;: []\r\n          },\r\n          &quot;independent&quot;: {\r\n            &quot;BOOL&quot;: true\r\n          }\r\n        }\r\n    }\r\n\r\nI need to change `helm_chart_version`&#39;s value to - say - `0.1.2`. \r\n\r\nI&#39;ve started by trying to isolate the value. I&#39;ve tried variations of the following with no luck:\r\n\r\n    jq -r &#39;.Item[].L.M | select(.label == &quot;helm_4G_chart_version&quot;) | .value.S&#39;\r\n    #  errors because there are multiple L&#39;s so it&#39;s iterating over null\r\n\r\n    jq &#39;..|.label? | select(type != &quot;null&quot;)&#39;\r\n    #  discovered this neat syntax, but I can&#39;t figure out how to get value from that\r\n\r\n    jq --arg argName &quot;argValue&quot; &#39;()&#39; file.json | sponge file.json\r\n    #  this is likely the &quot;replace&quot; solution, but I don&#39;t know what to put in the () to get the right value\r\n\r\nAlso open to hearing that I&#39;m tackling this incorrectly - I&#39;m a little out of my depth here. I&#39;m planning to save the edited json to a file and then doing a put-item on it. Is this the right way to edit a dynamoDB entry?",
        "link": "https://stackoverflow.com/questions/60382388/aws-dynamodb-cli-using-jq-on-nested-json",
        "title": "aws dynamoDB cli - using jq on nested json"
    }
]