[
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "expand",
            "sub-array"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1632904001,
                "creation_date": 1632904001,
                "answer_id": 69372904,
                "question_id": 69372441,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For each element of the `result` array, create an object with just the `id` field, and for each element of the `snippets` sub-array, add it:\r\n\r\n    .result[] | {id} + .snippets[]\r\n\r\nIf you don&#39;t need all fields of the `snippets` array, simply declare them as before\r\n\r\n    .result[] | {id} + (.snippets[] | {transcipt, matched_entry, start})\r\n\r\nTry it on [jqplay.org][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/BDjEQpbJk-",
                "title": "extract value from subarray and combine with upper value using jq to csv"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1632904001,
        "creation_date": 1632901888,
        "question_id": 69372441,
        "body_markdown": "I have a json file with a sub-array and I want to get each sub-array with the same id in separate lines.\r\njson:\r\n\r\n```\r\n{\r\n    &quot;success&quot;: true,\r\n    &quot;status&quot;: {\r\n        &quot;http&quot;: {\r\n            &quot;code&quot;: 200,\r\n            &quot;message&quot;: &quot;OK&quot;\r\n        }\r\n    },\r\n    &quot;result&quot;: [{\r\n        &quot;id&quot;: &quot;123456789&quot;,\r\n        &quot;start_date&quot;: &quot;2021-01-01 08:17:39.989&quot;,\r\n        &quot;snippets&quot;: [{\r\n            &quot;transcript&quot;: &quot;yes&quot;,\r\n            &quot;matched_entry&quot;: null,\r\n            &quot;start&quot;: &quot;2021-01-16 11:32:25.922&quot;\r\n        }, {\r\n            &quot;transcript&quot;: null,\r\n            &quot;matched_entry&quot;: null,\r\n            &quot;start&quot;: &quot;2021-01-16 11:32:38.179&quot;\r\n        }]\r\n    }, {\r\n        &quot;id&quot;: &quot;987654321&quot;,\r\n        &quot;start_date&quot;: &quot;2021-01-01 08:17:39.989&quot;,\r\n        &quot;duration_total&quot;: 301,\r\n        &quot;snippets&quot;: [{\r\n            &quot;transcript&quot;: &quot;yes&quot;,\r\n            &quot;matched_entry&quot;: null,\r\n            &quot;start&quot;: &quot;2021-01-01 08:17:54.055&quot;\r\n        }, {\r\n            &quot;transcript&quot;: &quot;something&quot;,\r\n            &quot;matched_entry&quot;: &quot; meta entry&quot;,\r\n            &quot;start&quot;: &quot;2021-01-01 08:18:11.028&quot;\r\n        }, {\r\n            &quot;transcript&quot;: &quot;no&quot;,\r\n            &quot;matched_entry&quot;: null,\r\n            &quot;start&quot;: &quot;2021-01-01 08:18:24.057&quot;\r\n        }]\r\n    }]\r\n}\r\n```\r\n\r\nI try to get:\r\n``` \r\n123456789, yes , null, &quot;2021-01-16 11:32:25.922&quot;\r\n123456789, null, null, &quot;2021-01-16 11:32:38.179&quot;\r\n987654321, yes, null, &quot;2021-01-01 08:17:54.055&quot;\r\n987654321, something, &quot;meta entry&quot;, &quot;2021-01-01 08:18:11.028&quot;\r\n987654321, no, null, &quot;2021-01-01 08:18:24.057&quot;\r\n```\r\nfirst attempt was:\r\n\r\n`jq -rc &quot;.result[] | {id: .id, snippetsTranscript: .snippets[].transcript, snippetsMatchedEntry: .snippets[].matched_entry, snippetsStart: .snippets[].start}&quot; 210101_210121_copy.json`\r\n\r\nbut the result is that every combination was returned:\r\n```\r\n{&quot;id&quot;:&quot;123456789&quot;,&quot;snippetsTranscript&quot;:&quot;yes&quot;,&quot;snippetsMatchedEntry&quot;:null,&quot;snippetsStart&quot;:&quot;2021-01-16 11:32:25.922&quot;}\r\n{&quot;id&quot;:&quot;123456789&quot;,&quot;snippetsTranscript&quot;:&quot;yes&quot;,&quot;snippetsMatchedEntry&quot;:null,&quot;snippetsStart&quot;:&quot;2021-01-16 11:32:38.179&quot;}\r\n{&quot;id&quot;:&quot;123456789&quot;,&quot;snippetsTranscript&quot;:&quot;yes&quot;,&quot;snippetsMatchedEntry&quot;:null,&quot;snippetsStart&quot;:&quot;2021-01-16 11:32:25.922&quot;}\r\n{&quot;id&quot;:&quot;123456789&quot;,&quot;snippetsTranscript&quot;:&quot;yes&quot;,&quot;snippetsMatchedEntry&quot;:null,&quot;snippetsStart&quot;:&quot;2021-01-16 11:32:38.179&quot;}\r\n{&quot;id&quot;:&quot;123456789&quot;,&quot;snippetsTranscript&quot;:null,&quot;snippetsMatchedEntry&quot;:null,&quot;snippetsStart&quot;:&quot;2021-01-16 11:32:25.922&quot;}\r\n{&quot;id&quot;:&quot;123456789&quot;,&quot;snippetsTranscript&quot;:null,&quot;snippetsMatchedEntry&quot;:null,&quot;snippetsStart&quot;:&quot;2021-01-16 11:32:38.179&quot;}\r\n{&quot;id&quot;:&quot;123456789&quot;,&quot;snippetsTranscript&quot;:null,&quot;snippetsMatchedEntry&quot;:null,&quot;snippetsStart&quot;:&quot;2021-01-16 11:32:25.922&quot;}\r\n{&quot;id&quot;:&quot;123456789&quot;,&quot;snippetsTranscript&quot;:null,&quot;snippetsMatchedEntry&quot;:null,&quot;snippetsStart&quot;:&quot;2021-01-16 11:32:38.179&quot;} ...\r\n```\r\nthe second attempt was:\r\n\r\n`jq -rc &quot;.result[] | {id: .id, snippetsMatchedEntry: [.snippets[].matched_entry], snippetsStart: [.snippets[].start], snippetsTranscript: [.snippets[].transcript]}&quot; 210901_210921_copy.json`\r\n\r\nbut the result is:\r\n```\r\n{&quot;id&quot;:&quot;123456789&quot;,&quot;snippetsMatchedEntry&quot;:[null,null],&quot;snippetsStart&quot;:[&quot;2021-01-16 11:32:25.922&quot;,&quot;2021-01-16 11:32:38.179&quot;],&quot;snippetsTranscript&quot;:[&quot;yes&quot;,null]}\r\n{&quot;id&quot;:&quot;987654321&quot;,&quot;snippetsMatchedEntry&quot;:[null,&quot; meta entry&quot;,null],&quot;snippetsStart&quot;:[&quot;2021-01-01 08:17:54.055&quot;,&quot;2021-01-01 08:18:11.028&quot;,&quot;2021-01-01 08:18:24.057&quot;],&quot;snippetsTranscript&quot;:[&quot;yes&quot;,&quot;something&quot;,&quot;no&quot;]}\r\n```\r\n\r\nIs this possible with jq?",
        "link": "https://stackoverflow.com/questions/69372441/extract-value-from-subarray-and-combine-with-upper-value-using-jq-to-csv",
        "title": "extract value from subarray and combine with upper value using jq to csv"
    },
    {
        "tags": [
            "bash",
            "numbers",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632916755,
                "post_id": 69375872,
                "comment_id": 122621370,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632917200,
                "post_id": 69375872,
                "comment_id": 122621529,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user15676007"
                },
                "reply_to_user": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632918559,
                "post_id": 69375872,
                "comment_id": 122622055,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user15676007"
                },
                "reply_to_user": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632918974,
                "post_id": 69375872,
                "comment_id": 122622252,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1632919118,
                "creation_date": 1632919118,
                "answer_id": 69376546,
                "question_id": 69375872,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can tell `jq` to do the maths for you:\r\n\r\n    jq &#39;[ .[].docs.count | tonumber ] | add&#39;",
                "title": "Bash script convert none integer variable to integer"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1666483174,
        "creation_date": 1632916450,
        "last_edit_date": 1666483174,
        "question_id": 69375872,
        "body_markdown": "I have a bash script where I make a request like  \r\n\r\n\r\n    GET &quot;/_cat/indices?h=docs.count&amp;format=json&quot; | jq `.[].&quot;docs.count&quot;` \r\n    \r\n    SAVEIFS=$IFS\r\n    IFS=$&#39;\\n&#39;\r\n    response=($response)\r\n    IFS=$SAVEIFS\r\n    \r\n    for (( i=0; i&lt;${#response[@]}; i++ ))\r\n    do\r\n    \r\n    echo &quot;${response[$i]}&quot;\r\n    \r\n    done\r\n\r\n\r\nThe result I get is like the following:\r\n\r\n```\r\n&quot;188&quot;\r\n&quot;363&quot;\r\n&quot;346224&quot;\r\n```\r\n\r\nI would like to summarize these ones into one big number but I only get some kind of fault since they are not numbers. I have tried several different solutions I have found when I google but I do not succed to convert to integers (numbers).\r\nMy skills in bash are not that good. Does anyone have a solution for how I should do?\r\n\r\nThe IFS was something I found when I googled. Perhaps there is a better way to do it?",
        "link": "https://stackoverflow.com/questions/69375872/bash-script-convert-none-integer-variable-to-integer",
        "title": "Bash script convert none integer variable to integer"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632925943,
                "post_id": 69378337,
                "comment_id": 122625742,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6938819,
                    "reputation": 209,
                    "user_id": 5325898,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/YbWpn.jpg?s=256",
                    "display_name": "Katja Eichelberger",
                    "link": "https://stackoverflow.com/users/5325898/katja-eichelberger"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632926295,
                "post_id": 69378337,
                "comment_id": 122625930,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1632927488,
                "last_edit_date": 1632927488,
                "creation_date": 1632926946,
                "answer_id": 69378681,
                "question_id": 69378337,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From the `jq` manual:\r\n&gt; The walk(f) function applies f recursively to every component of the\r\n&gt; input entity.\r\n\r\nUse this to recursively go through all items, check your conditions and use `del` if necessary:\r\n\r\n    walk(\r\n      if type == &quot;object&quot; and .type == &quot;Link&quot; then del(.type) else . end\r\n    )\r\n\r\nEdit: If &quot;matching is less important&quot;, as you state, then just use `del` on any object:\r\n\r\n    walk(if type == &quot;object&quot; then del(.type, .linkType) else . end)",
                "title": "JQ: Delete key:value pairs anywhere in JSON tree"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1632927488,
        "creation_date": 1632925616,
        "question_id": 69378337,
        "body_markdown": "I am looking for a way to delete key:value pairs (where key is a known string) anywhere in the JSON tree with `jq`.\r\n\r\nSpecifically: I would like to delete `&quot;type&quot;: &quot;Link&quot;` and `&quot;linkType&quot;: &quot;Entry&quot;` everywhere (in all parts of the hierarchy, where ever they appear). My JSON file is +800000 rows long and is nested deeply. \r\n\r\nSnippet:\r\n\r\n    {\r\n      &quot;entries&quot;: [\r\n        {\r\n          &quot;sys&quot;: {\r\n            &quot;id&quot;: &quot;vcLKKhJ3mZNfGMvVZZi07&quot;,\r\n            &quot;contentType&quot;: {\r\n              &quot;sys&quot;: {\r\n                &quot;id&quot;: &quot;page&quot;\r\n              }\r\n            }\r\n          },\r\n          &quot;fields&quot;: {\r\n            &quot;title&quot;: {\r\n              &quot;de-DE&quot;: &quot;Startseite&quot;,\r\n              &quot;en-US&quot;: &quot;Home&quot;\r\n            },\r\n            &quot;description&quot;: {\r\n              &quot;en-US&quot;: &quot;foo&quot;\r\n            },\r\n            &quot;keywords&quot;: {\r\n              &quot;en-US&quot;: &quot;bar&quot;\r\n            },\r\n            &quot;stageModules&quot;: {\r\n              &quot;en-US&quot;: [\r\n                {\r\n                  &quot;sys&quot;: {\r\n                    &quot;type&quot;: &quot;Link&quot;,\r\n                    &quot;linkType&quot;: &quot;Entry&quot;,\r\n                    &quot;id&quot;: &quot;11AfBBuNK8bx3EygAS3WTY&quot;\r\n                  }\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nI&#39;ve tried so many different things to iterate through the file to remove these two from the output, I constantly end up with &quot;Cannot index array with string&quot;. E.g.\r\n\r\n    [ .[] | select(.linkType != &quot;Entry&quot;, .type != &quot;Link&quot; ) ]\r\n\r\nIdeal result:\r\n\r\n    {\r\n      &quot;entries&quot;: [\r\n        {\r\n          &quot;sys&quot;: {\r\n            &quot;id&quot;: &quot;vcLKKhJ3mZNfGMvVZZi07&quot;,\r\n            &quot;contentType&quot;: {\r\n              &quot;sys&quot;: {\r\n                &quot;id&quot;: &quot;page&quot;\r\n              }\r\n            }\r\n          },\r\n          &quot;fields&quot;: {\r\n            &quot;title&quot;: {\r\n              &quot;de-DE&quot;: &quot;Startseite&quot;,\r\n              &quot;en-US&quot;: &quot;Home&quot;\r\n            },\r\n            &quot;description&quot;: {\r\n              &quot;en-US&quot;: &quot;foo&quot;\r\n            },\r\n            &quot;keywords&quot;: {\r\n              &quot;en-US&quot;: &quot;bar&quot;\r\n            },\r\n            &quot;stageModules&quot;: {\r\n              &quot;en-US&quot;: [\r\n                {\r\n                  &quot;sys&quot;: {\r\n                    &quot;id&quot;: &quot;11AfBBuNK8bx3EygAS3WTY&quot;\r\n                  }\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nCan someone help me out?\r\nThank you for your help.",
        "link": "https://stackoverflow.com/questions/69378337/jq-delete-keyvalue-pairs-anywhere-in-json-tree",
        "title": "JQ: Delete key:value pairs anywhere in JSON tree"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632932670,
                "post_id": 69379954,
                "comment_id": 122629084,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1632932851,
                "creation_date": 1632932851,
                "answer_id": 69380224,
                "question_id": 69379954,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Is this what you are looking for?\r\n    \r\n    jq &#39;.Subnets[] | &quot;\\(.Id) \\(.SubnetId) \\(.Tags | from_entries | .Status)&quot;&#39; subnets.json",
                "title": "jq - extract multiple fields from a list, with a nested list of key/value pairs"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1632938051,
        "creation_date": 1632931716,
        "last_edit_date": 1632938051,
        "question_id": 69379954,
        "body_markdown": "I have the following structure:\r\n```json\r\n{\r\n  &quot;Subnets&quot;: [\r\n    {\r\n      &quot;SubnetId&quot;: &quot;foo1&quot;,\r\n      &quot;Id&quot;: &quot;bar1&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;foo&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;Status&quot;,\r\n          &quot;Value&quot;: &quot;dev&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;SubnetId&quot;: &quot;foo2&quot;,\r\n      &quot;Id&quot;: &quot;bar2&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;foo&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;Status&quot;,\r\n          &quot;Value&quot;: &quot;dev&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI can extract multiple keys at the &quot;top level&quot; like so:\r\n```\r\ncat subnets.json| jq &#39;.Subnets[] | &quot;\\(.Id) \\(.SubnetId)&quot;&#39;\r\n```\r\n\r\nAnyone know how I can also display one of the tags by key name, let&#39;s say I also want the Status tag displayed on the same line as the Id and SubnetId.\r\n\r\nThx for any help,\r\n",
        "link": "https://stackoverflow.com/questions/69379954/jq-extract-multiple-fields-from-a-list-with-a-nested-list-of-key-value-pairs",
        "title": "jq - extract multiple fields from a list, with a nested list of key/value pairs"
    },
    {
        "tags": [
            "jq",
            "zendesk-api"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1632933021,
                "post_id": 69380073,
                "comment_id": 122629255,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22896479,
                    "reputation": 5,
                    "user_id": 17035927,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GidsSy2SWMtY9M7FyTKBuKCKvMIJ9io26QQnI50TA=k-s256",
                    "display_name": "Brendan Stephens",
                    "link": "https://stackoverflow.com/users/17035927/brendan-stephens"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632935612,
                "post_id": 69380073,
                "comment_id": 122630365,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22896479,
                    "reputation": 5,
                    "user_id": 17035927,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GidsSy2SWMtY9M7FyTKBuKCKvMIJ9io26QQnI50TA=k-s256",
                    "display_name": "Brendan Stephens",
                    "link": "https://stackoverflow.com/users/17035927/brendan-stephens"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632935711,
                "post_id": 69380073,
                "comment_id": 122630414,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22896479,
                    "reputation": 5,
                    "user_id": 17035927,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GidsSy2SWMtY9M7FyTKBuKCKvMIJ9io26QQnI50TA=k-s256",
                    "display_name": "Brendan Stephens",
                    "link": "https://stackoverflow.com/users/17035927/brendan-stephens"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632936889,
                "post_id": 69380073,
                "comment_id": 122630846,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1632950943,
                "creation_date": 1632950943,
                "answer_id": 69383548,
                "question_id": 69380073,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The way in which you&#39;ve asked the question is very confusing to most of us, but if I understand things correctly, this will help:\r\n\r\n```\r\n.comments[]\r\n| .created_at as $date\r\n| .attachments[]\r\n| {id, $date, name: .file_name, url: .content_url, size}\r\n```\r\n\r\nNotice the use of some small jq clevernesses, e.g. `{id}` for `{&quot;id&quot;: .id}`\r\nand `{$date}` for `{&quot;date&quot;: $date}`.\r\n",
                "title": "jq : parents with non-empty child arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1632950943,
        "creation_date": 1632932218,
        "last_edit_date": 1632932935,
        "question_id": 69380073,
        "body_markdown": "I&#39;m working with the zendesk API and the attachments are an array under comments -- effectively:\r\n\r\n```\r\n[\r\n  &quot;comments[].attachments[].content_type&quot;,\r\n  &quot;comments[].attachments[].content_url&quot;,\r\n  &quot;comments[].attachments[].file_name&quot;,\r\n  &quot;comments[].attachments[].height&quot;,\r\n  &quot;comments[].attachments[].id&quot;,\r\n  &quot;comments[].attachments[].mapped_content_url&quot;,\r\n  &quot;comments[].attachments[].size&quot;,\r\n  &quot;comments[].attachments[].thumbnails[].content_type&quot;,\r\n  &quot;comments[].attachments[].thumbnails[].content_url&quot;,\r\n  &quot;comments[].attachments[].thumbnails[].file_name&quot;,\r\n  &quot;comments[].attachments[].thumbnails[].height&quot;,\r\n  &quot;comments[].attachments[].thumbnails[].id&quot;,\r\n  &quot;comments[].attachments[].thumbnails[].mapped_content_url&quot;,\r\n  &quot;comments[].attachments[].thumbnails[].size&quot;,\r\n  &quot;comments[].attachments[].thumbnails[].url&quot;,\r\n  &quot;comments[].attachments[].thumbnails[].width&quot;,\r\n  &quot;comments[].attachments[].url&quot;,\r\n  &quot;comments[].attachments[].width&quot;,\r\n  &quot;comments[].audit_id&quot;,\r\n  &quot;comments[].author_id&quot;,\r\n  &quot;comments[].body&quot;,\r\n  &quot;comments[].created_at&quot;,\r\n  &quot;comments[].html_body&quot;,\r\n  &quot;comments[].id&quot;,\r\n  &quot;comments[].metadata.system.client&quot;,\r\n  &quot;comments[].metadata.system.ip_address&quot;,\r\n  &quot;comments[].metadata.system.latitude&quot;,\r\n  &quot;comments[].metadata.system.location&quot;,\r\n  &quot;comments[].metadata.system.longitude&quot;,\r\n  &quot;comments[].plain_body&quot;,\r\n  &quot;comments[].public&quot;,\r\n  &quot;comments[].type&quot;,\r\n  &quot;comments[].via.channel&quot;,\r\n  &quot;comments[].via.source.to.address&quot;,\r\n  &quot;comments[].via.source.to.name&quot;,\r\n  &quot;count&quot;\r\n]\r\n```\r\n\r\nI&#39;m trying to select comments where the attachments are not empty.\r\n \r\nI can select `jq &#39;.comments[].attachments[]&#39;`, which effectively returns the correct number of attachments, but since it&#39;s possible to upload with the same name, I need the parent created_at for disambiguation.\r\n\r\nIf I use :\r\n\r\n```\r\njq &#39;.comments[] | select(.attachments[] &gt; 0) | {id: .attachments[].id, date: .created_at, name: .attachments[].file_name, url: .attachments[].content_url, size: .attachments[].size}&#39;\r\n```\r\n\r\nThis appears to append attachments to every comment. \r\n\r\nHow do you effectively select the parent only when the child array is empty?",
        "link": "https://stackoverflow.com/questions/69380073/jq-parents-with-non-empty-child-arrays",
        "title": "jq : parents with non-empty child arrays"
    },
    {
        "tags": [
            "bash",
            "jq",
            "xq"
        ],
        "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": 1632935287,
                "post_id": 69380683,
                "comment_id": 122630242,
                "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": 1632935347,
                "post_id": 69380683,
                "comment_id": 122630258,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4640554,
                    "reputation": 197,
                    "user_id": 3760559,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/210c4fe8d0ec1633460a0bb88192d797?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Nagendra Kumar Singh",
                    "link": "https://stackoverflow.com/users/3760559/nagendra-kumar-singh"
                },
                "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": 1632935714,
                "post_id": 69380683,
                "comment_id": 122630417,
                "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": 1632936447,
                "post_id": 69380683,
                "comment_id": 122630683,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1632937820,
                "last_edit_date": 1632937820,
                "creation_date": 1632936645,
                "answer_id": 69381026,
                "question_id": 69380683,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What you&#39;re asking for isn&#39;t really an array, so I&#39;m ignoring that part of the question.\r\n\r\n```jq\r\n# Original, unmodified code here\r\n.Package.types |\r\nif type==&quot;array&quot; then .[] else . end |\r\nselect(.name==&quot;ApexClass&quot;) |\r\nselect(.members!=&quot;Test&quot;) |\r\n.members |\r\n# New code here\r\nif type == &quot;string&quot; then [.] else . end | join(&quot;,&quot;)\r\n```\r\n\r\nThat last line is the critical part -- wrapping the result in a list, should it be a string, before doing the `join()`.",
                "title": "How to make Jq return always in array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1687464568,
                "last_edit_date": 1687464568,
                "creation_date": 1687464153,
                "answer_id": 76535279,
                "question_id": 69380683,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have installed the https://kislyuk.github.io/yq/ bundled version of xq using `pip install yq` then you have some additional options available:\r\n\r\n```\r\n$ xq --help\r\n\r\n  -h, --help            show this help message and exit\r\n  --xml-output, -x      Transcode jq JSON output back into XML and emit it\r\n  --xml-item-depth XML_ITEM_DEPTH\r\n                        Specify depth of items to emit (default 0; use a positive integer to stream large docs)\r\n  --xml-dtd             Preserve XML Document Type Definition (disables streaming of multiple docs)\r\n  --xml-root XML_ROOT   When transcoding back to XML, envelope the output in an element with this name\r\n  --xml-force-list XML_FORCE_LIST\r\n                        Emit a list for elements with this name even if they occur only once (option can repeat)\r\n  --in-place, -i        Edit files in place (no backup - use caution)\r\n  --version             show program&#39;s version number and exit\r\n```\r\n\r\n`--xml-force-list` Emit a list for elements with this name even if they occur only once (option can repeat)\r\n\r\nTherefore should be able to do:\r\n```\r\ncat manifest/package.xml | xq . --xml-force-list &quot;members&quot;\r\n```\r\n\r\nWhich will ensure `members` is always an array whether there is one instance or more than one.\r\n\r\nThis uses the https://github.com/martinblech/xmltodict library `force_list` function.\r\n\r\n  [1]: https://github.com/sibprogrammer/xq",
                "title": "How to make Jq return always in array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1687464568,
        "creation_date": 1632935030,
        "last_edit_date": 1632935990,
        "question_id": 69380683,
        "body_markdown": "My input may be:\r\n\r\n    &lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;\r\n    &lt;Package xmlns=&quot;http://soap.sforce.com/2006/04/metadata&quot;&gt;\r\n        &lt;types&gt;\r\n            &lt;members&gt;UserTriggerHandler_Test&lt;/members&gt;\r\n            &lt;members&gt;UserTriggerHandasdler_Test&lt;/members&gt;\r\n            &lt;name&gt;ApexClass&lt;/name&gt;\r\n        &lt;/types&gt;\r\n        &lt;version&gt;52.0&lt;/version&gt;\r\n    &lt;/Package&gt;\r\n\r\nOr \r\n\r\n    &lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;\r\n    &lt;Package xmlns=&quot;http://soap.sforce.com/2006/04/metadata&quot;&gt;\r\n        &lt;types&gt;\r\n            &lt;members&gt;UserTriggerHandasdler_Test&lt;/members&gt;\r\n            &lt;name&gt;ApexClass&lt;/name&gt;\r\n        &lt;/types&gt;\r\n        &lt;version&gt;52.0&lt;/version&gt;\r\n    &lt;/Package&gt;\r\n\r\nXp value for these are :\r\n\r\n\t{\r\n\t\t&quot;Package&quot;: {\r\n\t\t\t&quot;@xmlns&quot;: &quot;http://soap.sforce.com/2006/04/metadata&quot;,\r\n\t\t\t&quot;types&quot;: {\r\n\t\t\t\t&quot;members&quot;: &quot;UserTriggerHandasdler_Test&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;ApexClass&quot;\r\n\t\t\t},\r\n\t\t\t&quot;version&quot;: &quot;52.0&quot;\r\n\t\t}\r\n\t}\r\n\r\nand \r\n\r\n\t{\r\n\t\t&quot;Package&quot;: {\r\n\t\t\t&quot;@xmlns&quot;: &quot;http://soap.sforce.com/2006/04/metadata&quot;,\r\n\t\t\t&quot;types&quot;: {\r\n\t\t\t\t&quot;members&quot;: [&quot;UserTriggerHandler_Test&quot;, &quot;UserTriggerHandasdler_Test&quot;],\r\n\t\t\t\t&quot;name&quot;: &quot;ApexClass&quot;\r\n\t\t\t},\r\n\t\t\t&quot;version&quot;: &quot;52.0&quot;\r\n\t\t}\r\n\t}\r\n\r\nRespectively.\r\n\r\nAnd I am trying to pass the input to this function.\r\n\r\n    classsvalue=`cat manifest/package.xml | xq . | jq &#39;.Package.types | if type==&quot;array&quot; then .[] else . end | select(.name==&quot;ApexClass&quot;) |select(.members!=&quot;Test&quot;)|.members | join(&quot;,&quot;)&#39;`\r\n    echo $classsvalue\r\n\r\nBut it fails because of `join(&quot;,&quot;)`. I want to force `jq` to always return members in an array. Is this possible?\r\n\r\nI am expecting out put as `&quot;UserTriggerHandasdler_Test&quot;` and `&quot;UserTriggerHandasdler_Test,UserTriggerHandasdler_Test&quot;` respectively.",
        "link": "https://stackoverflow.com/questions/69380683/how-to-make-jq-return-always-in-array",
        "title": "How to make Jq return always in array"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1632958545,
                "creation_date": 1632958545,
                "answer_id": 69384413,
                "question_id": 69384375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Take a look at the [error suppression operator ?][1] that works a bit like the new ?. nullable chaining operator in Javascript.\r\n\r\n```\r\nThe ? operator, used as EXP?, is shorthand for try EXP.\r\n\r\nExample:\r\njq &#39;[.[]|(.a)?]&#39;\r\nInput\t[{}, true, {&quot;a&quot;:1}]\r\nOutput\t[null, 1]\r\n```\r\n\r\nThey have a slightly simpler demonstrable example of this at https://jqplay.org/jq?q=%5B.%5B%5D%7C(.a)%3F%5D&amp;j=%5B%7B%7D%2C%20true%2C%20%7B%22a%22%3A1%7D%5D and the [try-catch][2] operator is similar if all you need is custom error handling (or just error ignoring...).\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#ErrorSuppression/OptionalOperator:?\r\n  [2]: https://stedolan.github.io/jq/manual/#try-catch",
                "title": "Extracting values with jq only when they exist"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1632958545,
        "creation_date": 1632958144,
        "question_id": 69384375,
        "body_markdown": "I have a large file of records that contain fields that look something like this:\r\n\r\n       {\r\n      &quot;id&quot;: &quot;1000001&quot;,\r\n      &quot;updatedDate&quot;: &quot;2018-12-21T01:52:00Z&quot;,\r\n      &quot;createdDate&quot;: &quot;1993-11-30T02:59:25Z&quot;,\r\n      &quot;varFields&quot;: [\r\n        {\r\n          &quot;fieldTag&quot;: &quot;b&quot;,\r\n          &quot;content&quot;: &quot;1000679727&quot;\r\n        },\r\n        {\r\n          &quot;fieldTag&quot;: &quot;v&quot;,\r\n          &quot;content&quot;: &quot;v.1&quot;\r\n        }\r\n   }\r\n\r\nI need to extract the .content element along with other things, but only when the fieldTag associated with it is &quot;v&quot;. Only some records contain a fieldTag &quot;v&quot;.\r\n\r\nWhen I try to parse using \r\n\r\n     (.varFields[] |select(.fieldTag==&quot;v&quot;) | &quot;\\(.content)&quot;) // &quot;&quot;\r\n\r\nit works fine so long as v is present. However, when it is not present, I get \r\n\r\n    jq: error (at &lt;stdin&gt;:353953): Cannot iterate over null (null)\r\n\r\nI tried to get rid of the error with multiple variations, including things to the effect of \r\n\r\n    (select((.varFields[] |select(.fieldTag==&quot;v&quot;) | .content) != null) | .varFields[] |select(.fieldTag==&quot;v&quot;) | &quot;\\(.content)&quot;) // &quot;&quot;\r\n\r\nbut I&#39;m still getting the same error. What am I missing?",
        "link": "https://stackoverflow.com/questions/69384375/extracting-values-with-jq-only-when-they-exist",
        "title": "Extracting values with jq only when they exist"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8760742,
                    "reputation": 2207,
                    "user_id": 13527856,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IZXmn.jpg?s=256",
                    "display_name": "MarcoLucidi",
                    "link": "https://stackoverflow.com/users/13527856/marcolucidi"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1633097360,
                "post_id": 69407077,
                "comment_id": 122677107,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1633098524,
                "last_edit_date": 1633098524,
                "creation_date": 1633098029,
                "answer_id": 69407448,
                "question_id": 69407077,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It would be cleaner and less error prone to format the string using `printf`\r\n\r\n    PET=&#39;dog&#39;\r\n    NAME=&#39;sam&#39;\r\n    toy1=&quot;t1&quot;\r\n    toy2=&quot;t2&quot;\r\n    toy3=&quot;t3&quot;\r\n\r\n    jq_args=$(printf &#39;.pets.&quot;%s&quot; += {PetInfo: {name: &quot;%s&quot;}, toys: [&quot;%s-postfix&quot;, &quot;%s-postfix&quot;, &quot;%s-postfix&quot;]}}&#39; &quot;${PET}&quot; &quot;${NAME}&quot; &quot;${toy1}&quot; &quot;${toy2}&quot; &quot;${toy3}&quot;)\r\n    echo &quot;$jq_args&quot;\r\n\r\nResult:\r\n\r\n    .pets.&quot;dog&quot; += {PetInfo: {name: &quot;sam&quot;}, toys: [&quot;t1-postfix&quot;, &quot;t2-postfix&quot;, &quot;t3-postfix&quot;]}\r\n\r\nAdditionally, redundant quoting could be avoided by quoting the arg on this command\r\n\r\n    cat myfile.json | jq &quot;$jq_args&quot;",
                "title": "jq format when running from a bash script with variable expansion"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1633099517,
                "last_edit_date": 1633099517,
                "creation_date": 1633099208,
                "answer_id": 69407762,
                "question_id": 69407077,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. Fix your jq code by removing extra `}` at end\r\n2. Fix bash jq call:\r\n\r\n     Add cotes `&quot;...&quot;` around your `$jq_args`\r\n\r\n     so don&#39;t use singles `&#39;...&#39;` in your `jq_args` definition\r\n3. Use `printf` with `-v` option to define `jq_args`:\r\n\r\n     `printf -v jq_args &quot;...format...&quot; value1 value2 ...`\r\n\r\nSo your code became:\r\n```bash\r\nPET=&quot;some-new-pet&quot;\r\nNAME=&quot;my-brand-new-pet&quot;\r\ntoy1=&quot;toy1&quot;\r\ntoy2=&quot;toy2&quot;\r\ntoy3=&quot;toy3&quot;\r\nformat=&#39;.pets.&quot;%s&quot; += {PetInfo: {name: &quot;%s&quot;}, toys: [&quot;%s&quot;, &quot;%s&quot;, &quot;%s&quot;]}&#39;\r\nprintf -v jq_args &quot;${format}&quot; &quot;${PET}&quot; &quot;${NAME}&quot; &quot;${toy1}&quot; &quot;${toy2}&quot; &quot;${toy3}&quot;\r\ncat myfile.json | jq &quot;$jq_args&quot;\r\n```\r\n\r\nOutput:\r\n```\r\n{\r\n  &quot;pets&quot;: {\r\n    &quot;some-new-pet&quot;: {\r\n      &quot;PetInfo&quot;: {\r\n        &quot;name&quot;: &quot;my-brand-new-pet&quot;\r\n      },\r\n      &quot;toys&quot;: [\r\n        &quot;toy1&quot;,\r\n        &quot;toy2&quot;,\r\n        &quot;toy3&quot;\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nNotes:\r\n * When you define your format, you put it into simple cotes `&#39;...&#39;`. It&#39;s really better to format JSON (or XML) without back-slashes (`\\\\`) before each double cotes (`&quot;`)\r\n * Use `printf -v variable_name`. It&#39;s more readable than `var_name=$(printf ...)`",
                "title": "jq format when running from a bash script with variable expansion"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1633110174,
                "creation_date": 1633110174,
                "answer_id": 69410029,
                "question_id": 69407077,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I do not recommend constructing a `jq` filter using variable expansion or `printf`. It will work for simple cases but will fail if the string contains double quotes, backslashes or control-codes, as they have special meanings inside a JSON string. As an alternative to using `printf`, `jq` has a way to pass in variables directly via the command-line, avoiding all these issues.\r\n\r\n```\r\npet=&#39;some-second-pet&#39;\r\nname=&#39;my-even-newer&#39;\r\ntoy1=toy1\r\ntoy2=toy2\r\ntoy3=toy3\r\njq \\\r\n    --arg pet &quot;$pet&quot; \\\r\n    --arg name &quot;$name&quot; \\\r\n    --arg toy1 &quot;$toy1&quot; \\\r\n    --arg toy2 &quot;$toy2&quot; \\\r\n    --arg toy3 &quot;$toy3&quot; \\\r\n    &#39;.pets[$pet] += {\r\n        PetInfo: {name: $name},\r\n        toys: [&quot;\\($toy1)-postfix&quot;, &quot;\\($toy2)-postfix&quot;, &quot;\\($toy3)-postfix&quot;]\r\n    }&#39; \\\r\n    myfile.json\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n{\r\n  &quot;pets&quot;: {\r\n    &quot;some-new-pet&quot;: {\r\n      &quot;PetInfo&quot;: {\r\n        &quot;name&quot;: &quot;my-brand-new-pet&quot;,\r\n        &quot;toys&quot;: [\r\n          &quot;toy1-postfix&quot;,\r\n          &quot;toy2-postfix&quot;,\r\n          &quot;toy3-postfix&quot;\r\n        ]\r\n      }\r\n    },\r\n    &quot;some-second-pet&quot;: {\r\n      &quot;PetInfo&quot;: {\r\n        &quot;name&quot;: &quot;my-even-newer-pet&quot;\r\n      },\r\n      &quot;toys&quot;: [\r\n        &quot;toy1-postfix&quot;,\r\n        &quot;toy2-postfix&quot;,\r\n        &quot;toy3-postfix&quot;\r\n      ]\r\n    }\r\n  }\r\n}\r\n```",
                "title": "jq format when running from a bash script with variable expansion"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1633110879,
                "creation_date": 1633110879,
                "answer_id": 69410164,
                "question_id": 69407077,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nBy constructing the jq filter (&quot;code&quot;) using outer bash variables (&quot;data&quot;) you may run into escaping issues, which could eventually break or even divert your filter. (see https://en.wikipedia.org/wiki/Code_injection)\r\n\r\nInstead, use mechanisms by jq to introduce external data through variables (parameter `--arg`):\r\n\r\n    jq --arg pet &quot;${PET}&quot; \\\r\n      --arg name &quot;${NAME}&quot; \\\r\n      --arg toy1 &quot;${toy1}-postfix&quot; \\\r\n      --arg toy2 &quot;${toy2}-postfix&quot; \\\r\n      --arg toy3 &quot;${toy3}-postfix&quot; \\\r\n      &#39;\r\n        \r\n        .pets[$pet] += {PetInfo: {$name, toys: [$toy1,$toy2,$toy3]}}\r\n        \r\n      &#39; myfile.json\r\n  \r\nIf you have an unknown number of variables to include, check out jq&#39;s `--args` parameter (note the additional `s`)\r\n  ",
                "title": "jq format when running from a bash script with variable expansion"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1633110879,
        "creation_date": 1633096467,
        "question_id": 69407077,
        "body_markdown": "I&#39;ve got a jq command that works when running directly from the shell or from within a shell script, but when I try to add variable expansion, I get jq errors for unexpected format or invalid characters. My goal is to have a quick and easy way to update some json configuration. \r\n\r\nHere&#39;s a simplified example. \r\n\r\nThe format of the json I&#39;m modifying:\r\n```\r\n{\r\n  &quot;pets&quot;: {\r\n      &quot;some-new-pet&quot;: {\r\n          &quot;PetInfo&quot;: {\r\n             &quot;name&quot;: &quot;my-brand-new-pet&quot;,\r\n             &quot;toys&quot;: [\r\n                 &quot;toy1-postfix&quot;,\r\n                 &quot;toy2-postfix&quot;,\r\n                 &quot;toy3-postfix&quot;\r\n              ]\r\n          }\r\n      }  \r\n   }\r\n}\r\n```\r\n\r\nThe jq without variable expansion: \r\n```\r\ncat myfile.json | jq &#39;.pets.&quot;some-new-pet&quot; += {PetInfo: {name: &quot;my-brand-new-pet&quot;}, toys: [&quot;toy1&quot;, &quot;toy2&quot;, &quot;toy3&quot;]}}&#39; \r\n```\r\n\r\nThe above runs fine, and adds the new `pets.some-new-pet` entry to my json. \r\n\r\nBelow is what I&#39;m trying to do with variable expansion that fails.\r\n\r\n```\r\njq_args = &quot;&#39;.pets.\\&quot;${PET}\\&quot; += {PetInfo: {name: \\&quot;${NAME}\\&quot;}, toys: [\\&quot;${toy1}-postfix\\&quot;, \\&quot;${toy2}-postfix\\&quot;, \\&quot;${toy3}-postfix\\&quot;]}}&#39;&quot;\r\ncat myfile.json | jq $jq_args\r\n``` \r\n\r\nThe error message I get with the above:\r\n```\r\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1: &#39;.pets.&quot;some-new-pet&quot;\r\n```\r\n\r\nMy file is formatted as utf-8 and uses LF line endings. ",
        "link": "https://stackoverflow.com/questions/69407077/jq-format-when-running-from-a-bash-script-with-variable-expansion",
        "title": "jq format when running from a bash script with variable expansion"
    },
    {
        "tags": [
            "json",
            "jq",
            "github-actions"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633112306,
                "post_id": 69410346,
                "comment_id": 122682653,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1959443,
                    "reputation": 3145,
                    "user_id": 1761521,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/3bf9cdee52067928d3f9aa20b18a27b6?s=256&d=identicon&r=PG",
                    "display_name": "spitfiredd",
                    "link": "https://stackoverflow.com/users/1761521/spitfiredd"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633112748,
                "post_id": 69410346,
                "comment_id": 122682779,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633113169,
                "post_id": 69410346,
                "comment_id": 122682909,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633113476,
                "post_id": 69410346,
                "comment_id": 122682986,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1959443,
                    "reputation": 3145,
                    "user_id": 1761521,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/3bf9cdee52067928d3f9aa20b18a27b6?s=256&d=identicon&r=PG",
                    "display_name": "spitfiredd",
                    "link": "https://stackoverflow.com/users/1761521/spitfiredd"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633114639,
                "post_id": 69410346,
                "comment_id": 122683354,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1648711503,
                "last_edit_date": 1648711503,
                "creation_date": 1648709639,
                "answer_id": 71688114,
                "question_id": 69410346,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your step appends `JSON_STRING=value` to `$GITHUB_ENV`. This causes the `JSON_STRING` environment variable to be set in subsequent steps.\r\n\r\nNormally `GITHUB_ENV` contains one `VAR=value` per line. Though, multiline values can also be added [if they&#39;re surrounded by delimiters][1].\r\n\r\nSo the problem is that `jq` formats its output on multiple lines by default. A simple fix would be to pass `--compact-output / -c` to `jq` so that your JSON string fits on a single line.\r\n\r\n\r\n  [1]: https://docs.github.com/en/actions/using-workflows/workflow-commands-for-github-actions#multiline-strings",
                "title": "Error creating JSON string in github action"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1648711503,
        "creation_date": 1633111982,
        "question_id": 69410346,
        "body_markdown": "In one of my steps in a github action, I am trying to create a JSON string that I can use in a later step.  \r\n\r\nI get an error on the following step,\r\n\r\n    - name: Generate JSON string\r\n            run: echo &quot;JSON_STRING=$( jq -n \\\r\n                    --arg image &quot;foo&quot; \\\r\n                    --arg region &quot;us-west-2&quot; \\\r\n                    --arg secret &quot;mysecret&quot; \\\r\n                    --arg env &quot;prod&quot; \\\r\n                    &#39;{&quot;flask&quot;:{&quot;image&quot;: $image,&quot;ports&quot;:{&quot;5000&quot;:&quot;HTTP&quot;},&quot;environment&quot;:{&quot;FLASK_ENV&quot;:$env,&quot;AWS_SECRET_NAME&quot;: $secret,&quot;AWS_REGION_NAME&quot;: $region}}}&#39; )&quot; &gt;&gt; $GITHUB_ENV\r\n\r\nIn a terminal shell (ubuntu), I am able to run this command and generate a JSON string.",
        "link": "https://stackoverflow.com/questions/69410346/error-creating-json-string-in-github-action",
        "title": "Error creating JSON string in github action"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633114371,
                "post_id": 69410606,
                "comment_id": 122683279,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1022874,
                    "reputation": 35264,
                    "user_id": 1032785,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/30816b3d787c2bd9d6f036318304f225?s=256&d=identicon&r=PG",
                    "display_name": "jordanm",
                    "link": "https://stackoverflow.com/users/1032785/jordanm"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633114407,
                "post_id": 69410606,
                "comment_id": 122683288,
                "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": 1,
                "creation_date": 1633116611,
                "post_id": 69410606,
                "comment_id": 122683923,
                "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": 1633116736,
                "post_id": 69410606,
                "comment_id": 122683958,
                "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": 1633117214,
                "post_id": 69410606,
                "comment_id": 122684091,
                "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": 2,
                "creation_date": 1633117528,
                "post_id": 69410606,
                "comment_id": 122684189,
                "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": 1633118424,
                "post_id": 69410606,
                "comment_id": 122684461,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28339,
                    "reputation": 37328,
                    "user_id": 75652,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/303ee8d24a8776dcf67b30c1d4e8b064?s=256&d=identicon&r=PG",
                    "display_name": "janneb",
                    "link": "https://stackoverflow.com/users/75652/janneb"
                },
                "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": 1633119913,
                "post_id": 69410606,
                "comment_id": 122684857,
                "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": 1,
                "creation_date": 1633121780,
                "post_id": 69410606,
                "comment_id": 122685380,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1633118632,
                "last_edit_date": 1633118632,
                "creation_date": 1633115276,
                "answer_id": 69410923,
                "question_id": 69410606,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When reaching some complexity (or when I need to externally process some of the data between transformations) I typically end up using something along the lines of\r\n\r\n```bash\r\njq --slurpfile foo &lt;(\r\n  \r\n  # first inner shell script\r\n  read foo &lt;&lt;&lt;$(&lt;/path/to/some/oneliner/file)\r\n  jq -n --arg f $foo &#39;{foo: $f}&#39;\r\n\r\n) --slurpfile bar &lt;(\r\n\r\n  # second inner shell script\r\n  bar=$(some_command)\r\n  jq -n --arg b $bar &#39;{bar: $b}&#39;\r\n\r\n) -n &#39;$foo[0] + $bar[0]&#39;\r\n```\r\n\r\nThat way, the outermost jq call may still have a &#39;real&#39; input on its own, and the inner calls are fairly maintainable with all bash variables in scope.",
                "title": "How can I incrementally generate JSON calling jq from bash repeatedly?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1633116838,
                "creation_date": 1633116838,
                "answer_id": 69411163,
                "question_id": 69410606,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can save and process intermediary JSON for the next jq command:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\nread -r foo &lt;a.txt\r\n\r\njson=&quot;$(jq -n --arg f &quot;$foo&quot; &#39;{foo: $f}&#39;)&quot;\r\n\r\n\r\nbar=&quot;$(pwd)&quot;\r\njq -n --arg b &quot;$bar&quot; &quot;$json&quot;&#39;+{bar: $b}&#39;\r\n\r\n# or alternatively\r\njq --arg b &quot;$bar&quot; &#39;.bar=$b&#39; &lt;&lt;&lt;&quot;$json&quot;\r\n```",
                "title": "How can I incrementally generate JSON calling jq from bash repeatedly?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1633140966,
                "last_edit_date": 1633140966,
                "creation_date": 1633139956,
                "answer_id": 69413438,
                "question_id": 69410606,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The Q makes it seem that `$foo` and `$bar` can be pre-computed,\r\nin which case you can use as a model:\r\n\r\n    jq -n --arg f &quot;$foo&quot; --arg b &quot;$bar&quot; &#39;.foo = $f | .bar = $b&#39; \r\n\r\nOf course if the value of $foo is very large, it would be better to\r\nmake those values available to jq using a file-oriented command-line\r\noption, such as `--slurpfile`.\r\n\r\nIf the computation of some of the values depends on very\r\nlarge files, then invoking jq several times might make sense.  In that\r\ncase, making N calls to jq to marshal the values, then making one\r\nextra call to assemble them into a single JSON object (perhaps using\r\n&#39;jq -s add&#39;) seems very reasonable.\r\n\r\nAn alternative along the lines suggested in the title of the Q would\r\nbe to create a pipeline of calls to jq, e.g.:\r\n```\r\n  jq -n --argfile f &lt;(some nasty stuff) &#39;.foo = $f&#39; |\r\n    jq  --argfile b &lt;(some more nasty stuff) &#39;.bar = $b&#39; | ...\r\n```\r\nFinally, if $bar depends on $foo in some way, then if that dependence\r\ncan be expressed in a jq program, you could read in the underlying\r\nvalues in one invocation of jq, using a more complex jq program.\r\n",
                "title": "How can I incrementally generate JSON calling jq from bash repeatedly?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1633140966,
        "creation_date": 1633113462,
        "last_edit_date": 1633117590,
        "question_id": 69410606,
        "body_markdown": "Is there some accepted &#39;best practice&#39; of generating JSON documents using bash and jq? I have a script to gather various data, and to make it easier to further process using other tools I&#39;d like to output the data in JSON format. So I&#39;m using jq to make sure all the quoting etc. gets done correctly, as recommended in this answer: https://stackoverflow.com/a/48470227/75652. However, I&#39;m struggling with how to generate it piecemeal instead of one giant jq call at the end. E.g. something like\r\n\r\n&lt;pre&gt;&lt;code&gt;\r\nread foo &amp;lt;&amp;lt;&amp;lt;$(&amp;lt;/path/to/some/oneliner/file)\r\njq -n --arg f $foo &#39;{foo: $f}&#39;\r\n\r\nbar=$(some_command)\r\njq -n --arg b $bar &#39;{bar: $b}&#39;\r\n&lt;/code&gt;&lt;/pre&gt;\r\n\r\nWill generate two separate objects (which can be processed with tools that support various more or less informal &quot;JSON streaming&quot; formats, including jq) whereas I&#39;d want a single object, something like\r\n\r\n&lt;pre&gt;&lt;code&gt;\r\n{ &quot;foo&quot;: SOMETHING, &quot;bar&quot;: SOMETHING_ELSE }\r\n&lt;/code&gt;&lt;/pre&gt;\r\n\r\nbut I can&#39;t do that with multiple jq calls as jq will complain that the incomplete JSON is malformed.\r\n\r\nAnd to further add some complexity, in some cases I need to generate nested JSON structures. In another language like python I&#39;d just put all the data in a set of nested dictionaries and then dump it to JSON in the end, but nested dictionaries in bash seem very tedious..",
        "link": "https://stackoverflow.com/questions/69410606/how-can-i-incrementally-generate-json-calling-jq-from-bash-repeatedly",
        "title": "How can I incrementally generate JSON calling jq from bash repeatedly?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1633159340,
                "last_edit_date": 1633159340,
                "creation_date": 1633156426,
                "answer_id": 69414581,
                "question_id": 69414451,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "here it is the correct syntax:\r\n\r\n       echo &#39;[{&quot;name&quot;: &quot;bhanu&quot;,&quot;dept&quot;:&quot;test&quot;}]&#39; | jq  -r &#39;.[0].name&#39;\r\n       bhanu\r\n\r\nin your case(json not stringified) you can use a little help from sed:\r\n\r\n      echo &#39;[{name: bhanu,dept:test}]&#39; | sed  &#39;s/[a-zA-Z]\\+/&quot;&amp;&quot;/g&#39; | jq -r &#39;.[0].name&#39;\r\n     bhanu\r\n",
                "title": "How to get exact value from raw json string using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1633161148,
                "creation_date": 1633161148,
                "answer_id": 69415048,
                "question_id": 69414451,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As pointed out by @R2D2, if you wish to use jq, one option would be to modify the value of testValue so that it is valid JSON, e.g. manually or using some text-wrangling tools.  \r\n\r\nThere are potentially two other options you might wish to consider:\r\n\r\n* change whatever it is that is producing the JSON-like text so that it produces JSON or some JSON variant for which a converter to JSON exists\r\n* modify the value of testValue so that it is valid as a jq program, e.g.\r\n```\r\ntestValue=&#39;[{name: &quot;bhanu&quot;, dept: &quot;test&quot;}]&#39;\r\njq -rn &quot;$testValue | .[0].name&quot;\r\n```",
                "title": "How to get exact value from raw json string using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1633161148,
        "creation_date": 1633155002,
        "last_edit_date": 1633155894,
        "question_id": 69414451,
        "body_markdown": "I am getting Json output(Missing quotes in jsonString) from my 3rd party API I wan to parse the output and get one of the property value.\r\n\r\nBelow are the sample code:\r\n\r\n    echo &quot;Hello World!&quot;\r\n    testValue=&#39;[{name: bhanu,dept:test}]&#39;\r\n    echo &quot; test value &quot; $testValue\r\n    echo &quot;$testValue&quot; |  jq -r &#39;.[0].name\r\n\r\nGetting below error:\r\n\r\n  parse error: Invalid literal at line 1, column 8 \r\n\r\nCan you please help me on it.\r\n   ",
        "link": "https://stackoverflow.com/questions/69414451/how-to-get-exact-value-from-raw-json-string-using-jq",
        "title": "How to get exact value from raw json string using JQ"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1633173973,
                "last_edit_date": 1633173973,
                "creation_date": 1633172586,
                "answer_id": 69416302,
                "question_id": 69416175,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can extract the paths using just `jq`, with its regular expression based `match` filter:\r\n\r\n```sh\r\n$ cargo metadata | jq -r &#39;.workspace_members[] | match(&quot;(?&lt;=path\\\\+file:)[^)]+&quot;) | .string&#39;\r\n///workspace/module1\r\n///workspace/nested/module2\r\n///workspace/nested/module3\r\n```\r\n\r\nTo iterate over them in a `bash` loop:\r\n\r\n```sh\r\nwhile read -r path; do\r\n    # Something with $path\r\ndone &lt; &lt;(cargo metadata | jq -r &#39;.workspace_members[] | match(&quot;(?&lt;=path\\\\+file:)[^)]+&quot;) | .string&#39;)\r\n```\r\n\r\nor save the lines in an array\r\n\r\n```sh\r\nreadarray -t paths &lt; &lt;(cargo metadata | jq -r &#39;.workspace_members[] | match(&quot;(?&lt;=path\\\\+file:)[^)]+&quot;) | .string&#39;)\r\n```",
                "title": "Split, find and iterate over output of command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1633173973,
        "creation_date": 1633171647,
        "last_edit_date": 1633173856,
        "question_id": 69416175,
        "body_markdown": "I currently have the following bash command:\r\n\r\n```bash\r\ncargo metadata | jq .workspace_members[]\r\n```\r\n\r\nAnd it returns something like the following:\r\n\r\n```\r\n&quot;module1 0.1.0 (path+file:///workspace/module1)&quot;\r\n&quot;module2 0.1.0 (path+file:///workspace/nested/module2)&quot;\r\n&quot;module3 0.1.0 (path+file:///workspace/nested/module3)&quot;\r\n```\r\n\r\nI would like to split the string/stream/input by new lines and find (using the regexp `path\\+file\\:(.*)\\)`) the file path on each line. And then be able to iterate over them:\r\n\r\n```bash\r\nfor path in strings; do\r\n   echo &quot;$path&quot;\r\ndone\r\n```\r\n\r\nWhich would then print out the paths:\r\n\r\n```\r\n///workspace/module1\r\n///workspace/nested/module2\r\n///workspace/nested/module3\r\n```",
        "link": "https://stackoverflow.com/questions/69416175/split-find-and-iterate-over-output-of-command",
        "title": "Split, find and iterate over output of command"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1633200415,
                "creation_date": 1633200415,
                "answer_id": 69419282,
                "question_id": 69418875,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could join both calls into one by producing two outputs with the requests separated by comma\r\n\r\n    (\r\n      .data[]\r\n      | select(.type == &quot;poc_receipts_v1&quot;)\r\n      | select(.challengee != null)\r\n      | select(.challengee == $a)\r\n    ),\r\n    (\r\n      .data[]\r\n      | select(.type == &quot;poc_receipts_v1&quot;)\r\n      | select(.path[].challengee != null)\r\n      | select(.path[].challengee == $a)\r\n    )\r\n\r\nHowever, as your requests basically accomplish the same task just in different locations, you could factor them out, simplifying it to\r\n\r\n    .data[]\r\n    | select(.type == &quot;poc_receipts_v1&quot;)\r\n    | select((.,.path[]).challengee != null)\r\n    | select((.,.path[]).challengee == $a)\r\n\r\nAlso, if you provide `$a` via the `--arg` parameter, you could also skip testing against `null` as the string may only be empty but never `null`.",
                "title": "Extract multiple nested in a single JQ run"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1633200415,
        "creation_date": 1633196987,
        "question_id": 69418875,
        "body_markdown": "I need to extract multiple nested fields from a json payload. Here is an example of a payload.\r\n\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;version&quot;: 10030002,\r\n      &quot;type&quot;: &quot;poc_request_v1&quot;,\r\n      &quot;time&quot;: 1632442480,\r\n      &quot;secret_hash&quot;: &quot;5AGdvx6te0KwMfHaTjsLHlTBcW5N14d1mBooiBKvW-Y&quot;,\r\n      &quot;onion_key_hash&quot;: &quot;ONR5Z8TmpnJo73Xr2H_4P18IAH5dUwvRKDFhcO_iAJ8&quot;,\r\n      &quot;height&quot;: 1023815,\r\n      &quot;hash&quot;: &quot;kezroutI0xpWe8glndloExmbww2U-EMI0Xb3sZa_ma4&quot;,\r\n      &quot;fee&quot;: 0,\r\n      &quot;challenger_owner&quot;: &quot;1359NhpbxJg1jRpDenJvrmD2P3ZN3hWGSGzUF6Uyn828zYdyYVt&quot;,\r\n      &quot;challenger_location&quot;: &quot;8c2aaa8268753ff&quot;,\r\n      &quot;challenger&quot;: &quot;112VEhPPMYF95neEEwwgnckHej4bgZ1roo13SMx18RSJxLq6JuiK&quot;,\r\n      &quot;block_hash&quot;: &quot;M-N28KOlVvIpYaKteJ4pFvPk0XDCmXgSp9V8mUi50lw&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;rewards_v2&quot;,\r\n      &quot;time&quot;: 1632441462,\r\n      &quot;start_epoch&quot;: 1023764,\r\n      &quot;rewards&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;poc_challengees&quot;,\r\n          &quot;gateway&quot;: &quot;112VEhPPMYF95neEEwwgnckHej4bgZ1roo13SMx18RSJxLq6JuiK&quot;,\r\n          &quot;amount&quot;: 8000901,\r\n          &quot;account&quot;: &quot;1359NhpbxJg1jRpDenJvrmD2P3ZN3hWGSGzUF6Uyn828zYdyYVt&quot;\r\n        }\r\n      ],\r\n      &quot;height&quot;: 1023796,\r\n      &quot;hash&quot;: &quot;O2j3mHBdIVLXz0yMWMNAzf3xRJ6J8dxw8AB3DqSNSH0&quot;,\r\n      &quot;end_epoch&quot;: 1023795\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;poc_receipts_v1&quot;,\r\n      &quot;time&quot;: 1632440612,\r\n      &quot;secret&quot;: &quot;AAtGKfGBp21LZqq2MzcZqCYn1UFVD5ERSytLv4OGY9xWBMUDJHA04jABt-SgcyRUYHkCtO323Bgt5RMxsBbL7HESEY3gldxQGBedYm9wAS5BzvFiW21HjYUp-2-grpH4OwY&quot;,\r\n      &quot;request_block_hash&quot;: &quot;fhqUiJg-coBBpFa7VqTypWB3-sfHIwnMApdfZ3oD_Aw&quot;,\r\n      &quot;path&quot;: [\r\n        {\r\n          &quot;witnesses&quot;: [\r\n            {\r\n              &quot;timestamp&quot;: 1632439246365596700,\r\n              &quot;snr&quot;: -5.800000190734863,\r\n              &quot;signal&quot;: -113,\r\n              &quot;packet_hash&quot;: &quot;gvzk31QfjcDkJw7CU79X55ZXk04Un2Z4PuZOtIhwPnY&quot;,\r\n              &quot;owner&quot;: &quot;14iwCHcr1KPfNRXPky4RaMhBVoLfHojDMt2Dje2p2XrU3YhAG6j&quot;,\r\n              &quot;location_hex&quot;: &quot;882aaa80d7fffff&quot;,\r\n              &quot;location&quot;: &quot;8c2aaa80d6ce7ff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;117Hdm1RkxkH9tS632ki8uBzU8w9LyonYKYCXRgiePN5HA59wSq&quot;,\r\n              &quot;frequency&quot;: 904.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF9BW125&quot;,\r\n              &quot;channel&quot;: 1\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632439246401554200,\r\n              &quot;snr&quot;: -10.199999809265137,\r\n              &quot;signal&quot;: -113,\r\n              &quot;packet_hash&quot;: &quot;gvzk31QfjcDkJw7CU79X55ZXk04Un2Z4PuZOtIhwPnY&quot;,\r\n              &quot;owner&quot;: &quot;14DJ5htcGMHgDB18Dpd5uSsSggLBqir52gvXawBw4mifEiNuaxq&quot;,\r\n              &quot;location_hex&quot;: &quot;882aaa968bfffff&quot;,\r\n              &quot;location&quot;: &quot;8c2aaa968b987ff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;11BMbZgVNhZwbn3pq4Xggp48eG2W5rVEn9eV9QCZP8hae98Kjb7&quot;,\r\n              &quot;frequency&quot;: 904.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF9BW125&quot;,\r\n              &quot;channel&quot;: 1\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632439244526317300,\r\n              &quot;snr&quot;: -2.799999952316284,\r\n              &quot;signal&quot;: -117,\r\n              &quot;packet_hash&quot;: &quot;gvzk31QfjcDkJw7CU79X55ZXk04Un2Z4PuZOtIhwPnY&quot;,\r\n              &quot;owner&quot;: &quot;13vv6uqoDQTGkUqo5Wy7APqBuNP1WY2gVBAJx5v15VVwjgyALvW&quot;,\r\n              &quot;location_hex&quot;: &quot;882aaa8705fffff&quot;,\r\n              &quot;location&quot;: &quot;8c2aaa87056a1ff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;11g73hc6NmPv3dssGN5zgkJGfuhBmCRqxqDjcM16RwEPjWZozg4&quot;,\r\n              &quot;frequency&quot;: 904.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF9BW125&quot;,\r\n              &quot;channel&quot;: 1\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632439244583344600,\r\n              &quot;snr&quot;: -14,\r\n              &quot;signal&quot;: -115,\r\n              &quot;packet_hash&quot;: &quot;gvzk31QfjcDkJw7CU79X55ZXk04Un2Z4PuZOtIhwPnY&quot;,\r\n              &quot;owner&quot;: &quot;14d2dqrkxVNAYeyxg71HzsQ2ExdbYQJWfq7GoRbv7Y2PregRg4R&quot;,\r\n              &quot;location_hex&quot;: &quot;882aaa80bdfffff&quot;,\r\n              &quot;location&quot;: &quot;8c2aaa80bc869ff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;11r4BXSjp7nKrxqjiHzS4k4yQkoPBZ2boL4gYA4nhUJbKLvYb1U&quot;,\r\n              &quot;frequency&quot;: 904.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF9BW125&quot;,\r\n              &quot;channel&quot;: 1\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632439246349839000,\r\n              &quot;snr&quot;: -15.199999809265137,\r\n              &quot;signal&quot;: -112,\r\n              &quot;packet_hash&quot;: &quot;gvzk31QfjcDkJw7CU79X55ZXk04Un2Z4PuZOtIhwPnY&quot;,\r\n              &quot;owner&quot;: &quot;142ooh6JRW8spP7PfRVagqEndSuN3pGcGdZWo5dkPoRRn6EAXTx&quot;,\r\n              &quot;location_hex&quot;: &quot;882aaa84dbfffff&quot;,\r\n              &quot;location&quot;: &quot;8c2aaa84da545ff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;112iqY2yF2EbKQgxN9nWu2BczqU8qoAYpfrSkUaaea7XEFUWLXgz&quot;,\r\n              &quot;frequency&quot;: 904.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF9BW125&quot;,\r\n              &quot;channel&quot;: 1\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632439246361085700,\r\n              &quot;snr&quot;: -12.800000190734863,\r\n              &quot;signal&quot;: -119,\r\n              &quot;packet_hash&quot;: &quot;gvzk31QfjcDkJw7CU79X55ZXk04Un2Z4PuZOtIhwPnY&quot;,\r\n              &quot;owner&quot;: &quot;13iC2Fz8Xtw9bD53WYERxTPSUfrQ7d2qdUGdvyH5ocT6jF4bcZ2&quot;,\r\n              &quot;location_hex&quot;: &quot;882aae28cbfffff&quot;,\r\n              &quot;location&quot;: &quot;8c2aae28ca583ff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;11221nH7EB9U9yBvKQRjXwhC6QUHkKQqLFrosxuTwHkXLjJEP46W&quot;,\r\n              &quot;frequency&quot;: 904.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF9BW125&quot;,\r\n              &quot;channel&quot;: 1\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632439246360691000,\r\n              &quot;snr&quot;: -6,\r\n              &quot;signal&quot;: -103,\r\n              &quot;packet_hash&quot;: &quot;gvzk31QfjcDkJw7CU79X55ZXk04Un2Z4PuZOtIhwPnY&quot;,\r\n              &quot;owner&quot;: &quot;13DHKGg9VxMLhgcUvnWmLHcfLUpX46ZYMUFU7Hvy8aQDr8eeJMx&quot;,\r\n              &quot;location_hex&quot;: &quot;882aaa168dfffff&quot;,\r\n              &quot;location&quot;: &quot;8c2aaa168da27ff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;11RaAJUXLEziygkwxBgNcEPPYs2dmYGeZiAr8Ho629UByr5u6nr&quot;,\r\n              &quot;frequency&quot;: 904.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF9BW125&quot;,\r\n              &quot;channel&quot;: 1\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632439246561084700,\r\n              &quot;snr&quot;: -4.199999809265137,\r\n              &quot;signal&quot;: -112,\r\n              &quot;packet_hash&quot;: &quot;gvzk31QfjcDkJw7CU79X55ZXk04Un2Z4PuZOtIhwPnY&quot;,\r\n              &quot;owner&quot;: &quot;13FmorVZh5uB3QXqUTtfSLDZsoGyNtH766DuZCtcSTS1d9myW2s&quot;,\r\n              &quot;location_hex&quot;: &quot;882aae75ebfffff&quot;,\r\n              &quot;location&quot;: &quot;8c2aae75eb2bbff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;1128xQoqhYwZbgmXYQCgXQfcihHMWvsuE77dnRvkmUthH7EJXW25&quot;,\r\n              &quot;frequency&quot;: 904.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF9BW125&quot;,\r\n              &quot;channel&quot;: 1\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632439246364830500,\r\n              &quot;snr&quot;: -2.200000047683716,\r\n              &quot;signal&quot;: -114,\r\n              &quot;packet_hash&quot;: &quot;gvzk31QfjcDkJw7CU79X55ZXk04Un2Z4PuZOtIhwPnY&quot;,\r\n              &quot;owner&quot;: &quot;13VVqYrm4YeBFFu8rwBa3kwgGYkcsuvcLm6fGVhfSVvW2o8udqU&quot;,\r\n              &quot;location_hex&quot;: &quot;882aaa8421fffff&quot;,\r\n              &quot;location&quot;: &quot;8c2aaa8421667ff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;112L9qP6GRXEhmiH7qkKj6sphUMeXNMxaKuEoMycXco5vbmidme9&quot;,\r\n              &quot;frequency&quot;: 904.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF9BW125&quot;,\r\n              &quot;channel&quot;: 1\r\n            }\r\n          ],\r\n          &quot;receipt&quot;: {\r\n            &quot;tx_power&quot;: 0,\r\n            &quot;timestamp&quot;: 1632439244895009000,\r\n            &quot;snr&quot;: 0,\r\n            &quot;signal&quot;: 0,\r\n            &quot;origin&quot;: &quot;p2p&quot;,\r\n            &quot;gateway&quot;: &quot;112VEhPPMYF95neEEwwgnckHej4bgZ1roo13SMx18RSJxLq6JuiK&quot;,\r\n            &quot;frequency&quot;: 0,\r\n            &quot;datarate&quot;: null,\r\n            &quot;data&quot;: &quot;aQw&quot;,\r\n            &quot;channel&quot;: 0\r\n          },\r\n          &quot;geocode&quot;: {\r\n            &quot;short_street&quot;: &quot;Stumptown Rd&quot;,\r\n            &quot;short_state&quot;: &quot;VA&quot;,\r\n            &quot;short_country&quot;: &quot;US&quot;,\r\n            &quot;short_city&quot;: &quot;Leesburg&quot;,\r\n            &quot;long_street&quot;: &quot;Stumptown Road&quot;,\r\n            &quot;long_state&quot;: &quot;Virginia&quot;,\r\n            &quot;long_country&quot;: &quot;United States&quot;,\r\n            &quot;long_city&quot;: &quot;Leesburg&quot;,\r\n            &quot;city_id&quot;: &quot;bGVlc2J1cmd2aXJnaW5pYXVuaXRlZCBzdGF0ZXM&quot;\r\n          },\r\n          &quot;challengee_owner&quot;: &quot;1359NhpbxJg1jRpDenJvrmD2P3ZN3hWGSGzUF6Uyn828zYdyYVt&quot;,\r\n          &quot;challengee_lon&quot;: -77.53639565293369,\r\n          &quot;challengee_location_hex&quot;: &quot;882aaa8269fffff&quot;,\r\n          &quot;challengee_location&quot;: &quot;8c2aaa8268753ff&quot;,\r\n          &quot;challengee_lat&quot;: 39.21665905449698,\r\n          &quot;challengee&quot;: &quot;112VEhPPMYF95neEEwwgnckHej4bgZ1roo13SMx18RSJxLq6JuiK&quot;\r\n        }\r\n      ],\r\n      &quot;onion_key_hash&quot;: &quot;wIZSJP7orTBJrv_LzVAetD2yz7CoM-rF5tVseYFqMsc&quot;,\r\n      &quot;height&quot;: 1023779,\r\n      &quot;hash&quot;: &quot;jkK8IIhZI8FQszUrGhQj6CS5Mo_ubTi7FgF1wHeVydU&quot;,\r\n      &quot;fee&quot;: 0,\r\n      &quot;challenger_owner&quot;: &quot;14aL3TLnykg9spujEygbp7L1ZNCS69SqHhpF8EtYyxTny7XUF3h&quot;,\r\n      &quot;challenger_lon&quot;: -157.99353068344223,\r\n      &quot;challenger_location&quot;: &quot;8c46482f0229dff&quot;,\r\n      &quot;challenger_lat&quot;: 21.48119606796577,\r\n      &quot;challenger&quot;: &quot;112ZXALFHvujHsGByny1yxHKfXSJ2CQL5jTEQpfCaVfZ9y2JmKJq&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;rewards_v2&quot;,\r\n      &quot;time&quot;: 1632427105,\r\n      &quot;start_epoch&quot;: 1023533,\r\n      &quot;rewards&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;poc_challengees&quot;,\r\n          &quot;gateway&quot;: &quot;112VEhPPMYF95neEEwwgnckHej4bgZ1roo13SMx18RSJxLq6JuiK&quot;,\r\n          &quot;amount&quot;: 6703336,\r\n          &quot;account&quot;: &quot;1359NhpbxJg1jRpDenJvrmD2P3ZN3hWGSGzUF6Uyn828zYdyYVt&quot;\r\n        }\r\n      ],\r\n      &quot;height&quot;: 1023565,\r\n      &quot;hash&quot;: &quot;ozllRv-RI6j5eC6ICeTH4FfQGJA9eWms5x4U_c7xnE8&quot;,\r\n      &quot;end_epoch&quot;: 1023564\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;poc_receipts_v1&quot;,\r\n      &quot;time&quot;: 1632426945,\r\n      &quot;secret&quot;: &quot;AO8bck7WawEwM9azahZjkn2PjJyIAc6gEyxNo52Cm7zLBPx_guCGy0vtqS1tQJAd9qhGHmMn11nfpk0AlvyvvtUXGg7aOVTvJxCBS-dhgod5DtQ0t8ZK_Ghvmi0KrEi8jyw&quot;,\r\n      &quot;request_block_hash&quot;: &quot;XEQR7zaljcwj4SHBZqZo7zRli05g6Q07izZjgm8n5m4&quot;,\r\n      &quot;path&quot;: [\r\n        {\r\n          &quot;witnesses&quot;: [\r\n            {\r\n              &quot;timestamp&quot;: 1632426010146206200,\r\n              &quot;snr&quot;: -6,\r\n              &quot;signal&quot;: -119,\r\n              &quot;packet_hash&quot;: &quot;qOK8ETrxcSWBdyLKNBjkYopBeX8b7piwxMFhFRTCfM8&quot;,\r\n              &quot;owner&quot;: &quot;13vv6uqoDQTGkUqo5Wy7APqBuNP1WY2gVBAJx5v15VVwjgyALvW&quot;,\r\n              &quot;location_hex&quot;: &quot;882aaa8705fffff&quot;,\r\n              &quot;location&quot;: &quot;8c2aaa87056a1ff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;11g73hc6NmPv3dssGN5zgkJGfuhBmCRqxqDjcM16RwEPjWZozg4&quot;,\r\n              &quot;frequency&quot;: 904.2999877929688,\r\n              &quot;datarate&quot;: &quot;SF9BW125&quot;,\r\n              &quot;channel&quot;: 2\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632426011662074000,\r\n              &quot;snr&quot;: -9.5,\r\n              &quot;signal&quot;: -113,\r\n              &quot;packet_hash&quot;: &quot;qOK8ETrxcSWBdyLKNBjkYopBeX8b7piwxMFhFRTCfM8&quot;,\r\n              &quot;owner&quot;: &quot;14DJ5htcGMHgDB18Dpd5uSsSggLBqir52gvXawBw4mifEiNuaxq&quot;,\r\n              &quot;location_hex&quot;: &quot;882aaa968bfffff&quot;,\r\n              &quot;location&quot;: &quot;8c2aaa968b987ff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;11BMbZgVNhZwbn3pq4Xggp48eG2W5rVEn9eV9QCZP8hae98Kjb7&quot;,\r\n              &quot;frequency&quot;: 904.2999877929688,\r\n              &quot;datarate&quot;: &quot;SF9BW125&quot;,\r\n              &quot;channel&quot;: 2\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632426011668748300,\r\n              &quot;snr&quot;: -7,\r\n              &quot;signal&quot;: -103,\r\n              &quot;packet_hash&quot;: &quot;qOK8ETrxcSWBdyLKNBjkYopBeX8b7piwxMFhFRTCfM8&quot;,\r\n              &quot;owner&quot;: &quot;13DHKGg9VxMLhgcUvnWmLHcfLUpX46ZYMUFU7Hvy8aQDr8eeJMx&quot;,\r\n              &quot;location_hex&quot;: &quot;882aaa168dfffff&quot;,\r\n              &quot;location&quot;: &quot;8c2aaa168da27ff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;11RaAJUXLEziygkwxBgNcEPPYs2dmYGeZiAr8Ho629UByr5u6nr&quot;,\r\n              &quot;frequency&quot;: 904.2999877929688,\r\n              &quot;datarate&quot;: &quot;SF9BW125&quot;,\r\n              &quot;channel&quot;: 2\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632426011674181000,\r\n              &quot;snr&quot;: -4.800000190734863,\r\n              &quot;signal&quot;: -112,\r\n              &quot;packet_hash&quot;: &quot;qOK8ETrxcSWBdyLKNBjkYopBeX8b7piwxMFhFRTCfM8&quot;,\r\n              &quot;owner&quot;: &quot;13VVqYrm4YeBFFu8rwBa3kwgGYkcsuvcLm6fGVhfSVvW2o8udqU&quot;,\r\n              &quot;location_hex&quot;: &quot;882aaa8421fffff&quot;,\r\n              &quot;location&quot;: &quot;8c2aaa8421667ff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;112L9qP6GRXEhmiH7qkKj6sphUMeXNMxaKuEoMycXco5vbmidme9&quot;,\r\n              &quot;frequency&quot;: 904.2999877929688,\r\n              &quot;datarate&quot;: &quot;SF9BW125&quot;,\r\n              &quot;channel&quot;: 2\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632426011665020400,\r\n              &quot;snr&quot;: -13.199999809265137,\r\n              &quot;signal&quot;: -111,\r\n              &quot;packet_hash&quot;: &quot;qOK8ETrxcSWBdyLKNBjkYopBeX8b7piwxMFhFRTCfM8&quot;,\r\n              &quot;owner&quot;: &quot;142ooh6JRW8spP7PfRVagqEndSuN3pGcGdZWo5dkPoRRn6EAXTx&quot;,\r\n              &quot;location_hex&quot;: &quot;882aaa84dbfffff&quot;,\r\n              &quot;location&quot;: &quot;8c2aaa84da545ff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;112iqY2yF2EbKQgxN9nWu2BczqU8qoAYpfrSkUaaea7XEFUWLXgz&quot;,\r\n              &quot;frequency&quot;: 904.2999877929688,\r\n              &quot;datarate&quot;: &quot;SF9BW125&quot;,\r\n              &quot;channel&quot;: 2\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632426009927039200,\r\n              &quot;snr&quot;: -13.800000190734863,\r\n              &quot;signal&quot;: -116,\r\n              &quot;packet_hash&quot;: &quot;qOK8ETrxcSWBdyLKNBjkYopBeX8b7piwxMFhFRTCfM8&quot;,\r\n              &quot;owner&quot;: &quot;13UfRstRWx9sGxrbrCB5rU2yJ7yxk83TwZ38CBAUjbvN1zGBc8T&quot;,\r\n              &quot;location_hex&quot;: &quot;882aaa8095fffff&quot;,\r\n              &quot;location&quot;: &quot;8c2aaa809554bff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;11dksEizEv5Q32mY8Qtsy9VVaWLsttoLWgdU6BKrnRba25Xtgpb&quot;,\r\n              &quot;frequency&quot;: 904.2999877929688,\r\n              &quot;datarate&quot;: &quot;SF9BW125&quot;,\r\n              &quot;channel&quot;: 2\r\n            }\r\n          ],\r\n          &quot;receipt&quot;: {\r\n            &quot;tx_power&quot;: 0,\r\n            &quot;timestamp&quot;: 1632426010451664400,\r\n            &quot;snr&quot;: 0,\r\n            &quot;signal&quot;: 0,\r\n            &quot;origin&quot;: &quot;p2p&quot;,\r\n            &quot;gateway&quot;: &quot;112VEhPPMYF95neEEwwgnckHej4bgZ1roo13SMx18RSJxLq6JuiK&quot;,\r\n            &quot;frequency&quot;: 0,\r\n            &quot;datarate&quot;: null,\r\n            &quot;data&quot;: &quot;GrU&quot;,\r\n            &quot;channel&quot;: 0\r\n          },\r\n          &quot;geocode&quot;: {\r\n            &quot;short_street&quot;: &quot;Stumptown Rd&quot;,\r\n            &quot;short_state&quot;: &quot;VA&quot;,\r\n            &quot;short_country&quot;: &quot;US&quot;,\r\n            &quot;short_city&quot;: &quot;Leesburg&quot;,\r\n            &quot;long_street&quot;: &quot;Stumptown Road&quot;,\r\n            &quot;long_state&quot;: &quot;Virginia&quot;,\r\n            &quot;long_country&quot;: &quot;United States&quot;,\r\n            &quot;long_city&quot;: &quot;Leesburg&quot;,\r\n            &quot;city_id&quot;: &quot;bGVlc2J1cmd2aXJnaW5pYXVuaXRlZCBzdGF0ZXM&quot;\r\n          },\r\n          &quot;challengee_owner&quot;: &quot;1359NhpbxJg1jRpDenJvrmD2P3ZN3hWGSGzUF6Uyn828zYdyYVt&quot;,\r\n          &quot;challengee_lon&quot;: -77.53639565293369,\r\n          &quot;challengee_location_hex&quot;: &quot;882aaa8269fffff&quot;,\r\n          &quot;challengee_location&quot;: &quot;8c2aaa8268753ff&quot;,\r\n          &quot;challengee_lat&quot;: 39.21665905449698,\r\n          &quot;challengee&quot;: &quot;112VEhPPMYF95neEEwwgnckHej4bgZ1roo13SMx18RSJxLq6JuiK&quot;\r\n        }\r\n      ],\r\n      &quot;onion_key_hash&quot;: &quot;RvG4TcKf-KZWCRbzDrAYXkww6lIo0UQENllAhCSOMQ4&quot;,\r\n      &quot;height&quot;: 1023562,\r\n      &quot;hash&quot;: &quot;qt2hw63Sy1irpL1A9f6MoQxQPkHeektyjMPZX2kT69c&quot;,\r\n      &quot;fee&quot;: 0,\r\n      &quot;challenger_owner&quot;: &quot;13zY4XYe3fyBiZmR4zex4oF86DY47p2q3LKu2giDRRsWhVysnSo&quot;,\r\n      &quot;challenger_lon&quot;: 9.787413897456222,\r\n      &quot;challenger_location&quot;: &quot;8c1f15aa599c9ff&quot;,\r\n      &quot;challenger_lat&quot;: 53.65579988144066,\r\n      &quot;challenger&quot;: &quot;11TEymZeRAcX4a7uLSkEheE3FqsPgLjrRbV6L3EcqLbdtsdTgK7&quot;\r\n    },\r\n    {\r\n      &quot;version&quot;: 10030002,\r\n      &quot;type&quot;: &quot;poc_request_v1&quot;,\r\n      &quot;time&quot;: 1632426833,\r\n      &quot;secret_hash&quot;: &quot;lPK1RGwBDDIYYiPdrIjz24jdXO1NRzQXtqD-AXInuOs&quot;,\r\n      &quot;onion_key_hash&quot;: &quot;qdYuM-rRy-4r6bHxE0HsTQe1bLGgw6lkIWwA4X5BeTU&quot;,\r\n      &quot;height&quot;: 1023560,\r\n      &quot;hash&quot;: &quot;IJ_3Awa33JMlwzhUcgu-4t_GJK6_5ovZSgrzxrLc9EY&quot;,\r\n      &quot;fee&quot;: 0,\r\n      &quot;challenger_owner&quot;: &quot;1359NhpbxJg1jRpDenJvrmD2P3ZN3hWGSGzUF6Uyn828zYdyYVt&quot;,\r\n      &quot;challenger_location&quot;: &quot;8c2aaa8268753ff&quot;,\r\n      &quot;challenger&quot;: &quot;112VEhPPMYF95neEEwwgnckHej4bgZ1roo13SMx18RSJxLq6JuiK&quot;,\r\n      &quot;block_hash&quot;: &quot;72MFW1c1HvyC2MsB4JOovPUnE1ZKU2D1YfwvbCxPr_g&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;rewards_v2&quot;,\r\n      &quot;time&quot;: 1632415788,\r\n      &quot;start_epoch&quot;: 1023337,\r\n      &quot;rewards&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;poc_challengers&quot;,\r\n          &quot;gateway&quot;: &quot;112VEhPPMYF95neEEwwgnckHej4bgZ1roo13SMx18RSJxLq6JuiK&quot;,\r\n          &quot;amount&quot;: 678175,\r\n          &quot;account&quot;: &quot;1359NhpbxJg1jRpDenJvrmD2P3ZN3hWGSGzUF6Uyn828zYdyYVt&quot;\r\n        }\r\n      ],\r\n      &quot;height&quot;: 1023369,\r\n      &quot;hash&quot;: &quot;YJbpiwCPj-y29vXeqsw1B4Y-4OsnWmLtjZxVsA7D5iw&quot;,\r\n      &quot;end_epoch&quot;: 1023368\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;poc_receipts_v1&quot;,\r\n      &quot;time&quot;: 1632414233,\r\n      &quot;secret&quot;: &quot;ACLDpK6nmg1eKEiLkQqaIMVpIVrTTm7laYcM7bTomHIyBB2P_vsrV0pLRDxN0Rx6eQhkTo6DUp-IYnzarIY4iZ09e0hmSOyP3qcrjOzVpNxXTOpYkCr7NO1TZ1WT6QRRjQ4&quot;,\r\n      &quot;request_block_hash&quot;: &quot;XftRbucsA5BMw3QmDDjVQLk6XZe24aeqXm3iv3qw0h0&quot;,\r\n      &quot;path&quot;: [\r\n        {\r\n          &quot;witnesses&quot;: [\r\n            {\r\n              &quot;timestamp&quot;: 1632413226330888400,\r\n              &quot;snr&quot;: 8.5,\r\n              &quot;signal&quot;: -99,\r\n              &quot;packet_hash&quot;: &quot;Z5oskyjoIXm4YKehTFpFKHVJleC5tYqvJU9uuGv5HH4&quot;,\r\n              &quot;owner&quot;: &quot;13wtfBxAamhLXhrxpyXwqrC9LXBEsrVEyncpPV89RqGBHW64idF&quot;,\r\n              &quot;location_hex&quot;: &quot;8819683215fffff&quot;,\r\n              &quot;location&quot;: &quot;8c196832151a1ff&quot;,\r\n              &quot;is_valid&quot;: false,\r\n              &quot;invalid_reason&quot;: &quot;witness_rssi_below_lower_bound&quot;,\r\n              &quot;gateway&quot;: &quot;112rm5hSz1Q6VN6AvhmGac8wMtB2crTCCL6Z7qyMMWnYWmkkgSHt&quot;,\r\n              &quot;frequency&quot;: 867.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF12BW125&quot;,\r\n              &quot;channel&quot;: 0\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632413226904438800,\r\n              &quot;snr&quot;: 4,\r\n              &quot;signal&quot;: -106,\r\n              &quot;packet_hash&quot;: &quot;Z5oskyjoIXm4YKehTFpFKHVJleC5tYqvJU9uuGv5HH4&quot;,\r\n              &quot;owner&quot;: &quot;147AZkVEZcSLzcGzrdX9oXWDao2pKkghh4drLQ2s7k6tzAHcLJp&quot;,\r\n              &quot;location_hex&quot;: &quot;8819683215fffff&quot;,\r\n              &quot;location&quot;: &quot;8c19683214ec7ff&quot;,\r\n              &quot;is_valid&quot;: false,\r\n              &quot;invalid_reason&quot;: &quot;witness_too_close&quot;,\r\n              &quot;gateway&quot;: &quot;11ePZFG7YWJ39tMB5FCMgAhCGzBXs6LkJeEHxFKLHHDahkF5UyT&quot;,\r\n              &quot;frequency&quot;: 867.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF12BW125&quot;,\r\n              &quot;channel&quot;: 0\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632413226334567700,\r\n              &quot;snr&quot;: -18.5,\r\n              &quot;signal&quot;: -117,\r\n              &quot;packet_hash&quot;: &quot;Z5oskyjoIXm4YKehTFpFKHVJleC5tYqvJU9uuGv5HH4&quot;,\r\n              &quot;owner&quot;: &quot;13549kA7LtJ33z1yU2ZzwUQcHS1SPkhTFm2bFMARPX9fnTFbBdu&quot;,\r\n              &quot;location_hex&quot;: &quot;881968321dfffff&quot;,\r\n              &quot;location&quot;: &quot;8c1968321d883ff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;112mbK6ApE2p27P9NhsiZGeQQEbScMwtYrLWAxV1qsfWnsEeSmkP&quot;,\r\n              &quot;frequency&quot;: 867.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF12BW125&quot;,\r\n              &quot;channel&quot;: 0\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632413226329127400,\r\n              &quot;snr&quot;: -0.800000011920929,\r\n              &quot;signal&quot;: -114,\r\n              &quot;packet_hash&quot;: &quot;Z5oskyjoIXm4YKehTFpFKHVJleC5tYqvJU9uuGv5HH4&quot;,\r\n              &quot;owner&quot;: &quot;14DYNAMxsvWcnvqt8dZX126j8dEBZzLYAJ9j7DtxLm6fMcCkdqh&quot;,\r\n              &quot;location_hex&quot;: &quot;8819683213fffff&quot;,\r\n              &quot;location&quot;: &quot;8c196832122dbff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;112vzPXBzqyoSrWLr9x6NRzEFV7cjg2kADPhN9GGpdQoCqtvtMNG&quot;,\r\n              &quot;frequency&quot;: 867.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF12BW125&quot;,\r\n              &quot;channel&quot;: 0\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632413224376567300,\r\n              &quot;snr&quot;: -16.200000762939453,\r\n              &quot;signal&quot;: -121,\r\n              &quot;packet_hash&quot;: &quot;Z5oskyjoIXm4YKehTFpFKHVJleC5tYqvJU9uuGv5HH4&quot;,\r\n              &quot;owner&quot;: &quot;14DYNAMxsvWcnvqt8dZX126j8dEBZzLYAJ9j7DtxLm6fMcCkdqh&quot;,\r\n              &quot;location_hex&quot;: &quot;88196832c9fffff&quot;,\r\n              &quot;location&quot;: &quot;8c196832c918dff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;112Xz9MHLtivY6xgVxBfbzQaV2Dzh7gdhVE2E3e9yhX4suczRvJq&quot;,\r\n              &quot;frequency&quot;: 867.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF12BW125&quot;,\r\n              &quot;channel&quot;: 0\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632413226330442500,\r\n              &quot;snr&quot;: 8,\r\n              &quot;signal&quot;: -95,\r\n              &quot;packet_hash&quot;: &quot;Z5oskyjoIXm4YKehTFpFKHVJleC5tYqvJU9uuGv5HH4&quot;,\r\n              &quot;owner&quot;: &quot;13uExhAK2zjmmFH71EtEZVpt7sDaYZKTLpKAyRAKHEAhUHrV5kz&quot;,\r\n              &quot;location_hex&quot;: &quot;8819683217fffff&quot;,\r\n              &quot;location&quot;: &quot;8c19683217b3dff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;112HmY3PwFBaESNzdgSX6ouh5UdsWFTgU9RvFUWyCDjGBSTS2htW&quot;,\r\n              &quot;frequency&quot;: 867.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF12BW125&quot;,\r\n              &quot;channel&quot;: 0\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632413226329093600,\r\n              &quot;snr&quot;: -6.800000190734863,\r\n              &quot;signal&quot;: -115,\r\n              &quot;packet_hash&quot;: &quot;Z5oskyjoIXm4YKehTFpFKHVJleC5tYqvJU9uuGv5HH4&quot;,\r\n              &quot;owner&quot;: &quot;14DYNAMxsvWcnvqt8dZX126j8dEBZzLYAJ9j7DtxLm6fMcCkdqh&quot;,\r\n              &quot;location_hex&quot;: &quot;881968ad23fffff&quot;,\r\n              &quot;location&quot;: &quot;8c1968ad22b61ff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;11qFGscLoZ33n7tBYR7fT5fshPpYnA7bRAiNZqJMDvnAg2qQVux&quot;,\r\n              &quot;frequency&quot;: 867.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF12BW125&quot;,\r\n              &quot;channel&quot;: 0\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632413224877203500,\r\n              &quot;snr&quot;: 4.800000190734863,\r\n              &quot;signal&quot;: -107,\r\n              &quot;packet_hash&quot;: &quot;Z5oskyjoIXm4YKehTFpFKHVJleC5tYqvJU9uuGv5HH4&quot;,\r\n              &quot;owner&quot;: &quot;13CijJkXY32mFE2rrEvN3UbuW7BfknmX1Q9qyoRqa7GknQE1wPQ&quot;,\r\n              &quot;location_hex&quot;: &quot;8819683215fffff&quot;,\r\n              &quot;location&quot;: &quot;8c19683214415ff&quot;,\r\n              &quot;is_valid&quot;: false,\r\n              &quot;invalid_reason&quot;: &quot;witness_too_close&quot;,\r\n              &quot;gateway&quot;: &quot;112YwncrEjZg3iXg3avmFqFwvEKfybwVZzymou81FCA4TbZwKRxt&quot;,\r\n              &quot;frequency&quot;: 867.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF12BW125&quot;,\r\n              &quot;channel&quot;: 0\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632413226330943500,\r\n              &quot;snr&quot;: -10.5,\r\n              &quot;signal&quot;: -109,\r\n              &quot;packet_hash&quot;: &quot;Z5oskyjoIXm4YKehTFpFKHVJleC5tYqvJU9uuGv5HH4&quot;,\r\n              &quot;owner&quot;: &quot;14Egw3AwM3BFyHnDdLCSiMbbw9zxiJ6BVZyNgRXzQT7DkeFQtSq&quot;,\r\n              &quot;location_hex&quot;: &quot;88196832c5fffff&quot;,\r\n              &quot;location&quot;: &quot;8c196832c4cb9ff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;11vPAh63j5r4kdTJ9g1Vss58meWCBkGJHgYgLK6x6FaZWiDTwDt&quot;,\r\n              &quot;frequency&quot;: 867.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF12BW125&quot;,\r\n              &quot;channel&quot;: 0\r\n            },\r\n            {\r\n              &quot;timestamp&quot;: 1632413226332651500,\r\n              &quot;snr&quot;: -12.5,\r\n              &quot;signal&quot;: -117,\r\n              &quot;packet_hash&quot;: &quot;Z5oskyjoIXm4YKehTFpFKHVJleC5tYqvJU9uuGv5HH4&quot;,\r\n              &quot;owner&quot;: &quot;147Ao9QkGjLHUeDoZR1Y2aRXofL3Dk3QD6GzubcPAyyneE2ZpvZ&quot;,\r\n              &quot;location_hex&quot;: &quot;881968ad35fffff&quot;,\r\n              &quot;location&quot;: &quot;8c1968ad34605ff&quot;,\r\n              &quot;is_valid&quot;: true,\r\n              &quot;gateway&quot;: &quot;11iWaFHzYvDCKgGXD9TLoUHG69A38nse97v1uujWycrB5vVrrxe&quot;,\r\n              &quot;frequency&quot;: 867.0999755859375,\r\n              &quot;datarate&quot;: &quot;SF12BW125&quot;,\r\n              &quot;channel&quot;: 0\r\n            }\r\n          ],\r\n          &quot;receipt&quot;: {\r\n            &quot;tx_power&quot;: 0,\r\n            &quot;timestamp&quot;: 1632413222754133000,\r\n            &quot;snr&quot;: 0,\r\n            &quot;signal&quot;: 0,\r\n            &quot;origin&quot;: &quot;p2p&quot;,\r\n            &quot;gateway&quot;: &quot;112KhPSzzLi5Dpx4Boc8JjyPjuV8pRdK8HLM1hyJP454Mce6kMM&quot;,\r\n            &quot;frequency&quot;: 0,\r\n            &quot;datarate&quot;: null,\r\n            &quot;data&quot;: &quot;MFI&quot;,\r\n            &quot;channel&quot;: 0\r\n          },\r\n          &quot;geocode&quot;: {\r\n            &quot;short_street&quot;: &quot;Westfalenstraat&quot;,\r\n            &quot;short_state&quot;: &quot;NH&quot;,\r\n            &quot;short_country&quot;: &quot;NL&quot;,\r\n            &quot;short_city&quot;: &quot;Alkmaar&quot;,\r\n            &quot;long_street&quot;: &quot;Westfalenstraat&quot;,\r\n            &quot;long_state&quot;: &quot;Noord-Holland&quot;,\r\n            &quot;long_country&quot;: &quot;Netherlands&quot;,\r\n            &quot;long_city&quot;: &quot;Alkmaar&quot;,\r\n            &quot;city_id&quot;: &quot;YWxrbWFhcm5vb3JkLWhvbGxhbmRuZXRoZXJsYW5kcw&quot;\r\n          },\r\n          &quot;challengee_owner&quot;: &quot;13VcQ3EEFtN39UGZkjnP9ww9AHwgb4pwVniKpHBjgwRtaGUMevA&quot;,\r\n          &quot;challengee_lon&quot;: 4.757355055721787,\r\n          &quot;challengee_location_hex&quot;: &quot;8819683215fffff&quot;,\r\n          &quot;challengee_location&quot;: &quot;8c196832146ebff&quot;,\r\n          &quot;challengee_lat&quot;: 52.66685608872497,\r\n          &quot;challengee&quot;: &quot;112KhPSzzLi5Dpx4Boc8JjyPjuV8pRdK8HLM1hyJP454Mce6kMM&quot;\r\n        }\r\n      ],\r\n      &quot;onion_key_hash&quot;: &quot;c47EirQ1o4smB0pKTKb-ZqwoEcpliY0Ohty-660kprY&quot;,\r\n      &quot;height&quot;: 1023339,\r\n      &quot;hash&quot;: &quot;6CcxHLQ5jd3Y07cp6YC-s3xVtpHOrqtGQD8utBy7U7A&quot;,\r\n      &quot;fee&quot;: 0,\r\n      &quot;challenger_owner&quot;: &quot;1359NhpbxJg1jRpDenJvrmD2P3ZN3hWGSGzUF6Uyn828zYdyYVt&quot;,\r\n      &quot;challenger_lon&quot;: -77.53639565293369,\r\n      &quot;challenger_location&quot;: &quot;8c2aaa8268753ff&quot;,\r\n      &quot;challenger_lat&quot;: 39.21665905449698,\r\n      &quot;challenger&quot;: &quot;112VEhPPMYF95neEEwwgnckHej4bgZ1roo13SMx18RSJxLq6JuiK&quot;\r\n    },\r\n    {\r\n      &quot;version&quot;: 10030002,\r\n      &quot;type&quot;: &quot;poc_request_v1&quot;,\r\n      &quot;time&quot;: 1632412882,\r\n      &quot;secret_hash&quot;: &quot;Qw6A5ZdNxo0P7-oYSF7dsRZ9BCRdO8LOoTrA-1wGSYI&quot;,\r\n      &quot;onion_key_hash&quot;: &quot;c47EirQ1o4smB0pKTKb-ZqwoEcpliY0Ohty-660kprY&quot;,\r\n      &quot;height&quot;: 1023313,\r\n      &quot;hash&quot;: &quot;fgBFe6AgRaEhhBn46LEtkHqqwFTGXMJnXuDcAPsxKi0&quot;,\r\n      &quot;fee&quot;: 0,\r\n      &quot;challenger_owner&quot;: &quot;1359NhpbxJg1jRpDenJvrmD2P3ZN3hWGSGzUF6Uyn828zYdyYVt&quot;,\r\n      &quot;challenger_location&quot;: &quot;8c2aaa8268753ff&quot;,\r\n      &quot;challenger&quot;: &quot;112VEhPPMYF95neEEwwgnckHej4bgZ1roo13SMx18RSJxLq6JuiK&quot;,\r\n      &quot;block_hash&quot;: &quot;tN00Y9cUoqSEtqyXAZF1-y8wbo-iylaBY7vg15ELOUk&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;poc_receipts_v1&quot;,\r\n      &quot;time&quot;: 1632406600,\r\n      &quot;secret&quot;: &quot;AA_7SYOib95FCvY949gW--TDmLygYQLBtUqvcbXpfunhBB47NkLa4KLjJURcv1qUSQc9czIGmT7PGaVfGPyK3W7GHgP1uBgWWVXSf8Oe89BQ6HjNewK-aLC-v6TnuV-3XB8&quot;,\r\n      &quot;request_block_hash&quot;: &quot;Lvao9qVshVF0rvyVMg5IMbrobsEGS9g74aKnljVXR4g&quot;,\r\n      &quot;path&quot;: [\r\n        {\r\n          &quot;witnesses&quot;: [],\r\n          &quot;receipt&quot;: {\r\n            &quot;tx_power&quot;: 0,\r\n            &quot;timestamp&quot;: 1632405723838919700,\r\n            &quot;snr&quot;: 0,\r\n            &quot;signal&quot;: 0,\r\n            &quot;origin&quot;: &quot;p2p&quot;,\r\n            &quot;gateway&quot;: &quot;112VEhPPMYF95neEEwwgnckHej4bgZ1roo13SMx18RSJxLq6JuiK&quot;,\r\n            &quot;frequency&quot;: 0,\r\n            &quot;datarate&quot;: null,\r\n            &quot;data&quot;: &quot;h38&quot;,\r\n            &quot;channel&quot;: 0\r\n          },\r\n          &quot;geocode&quot;: {\r\n            &quot;short_street&quot;: &quot;Stumptown Rd&quot;,\r\n            &quot;short_state&quot;: &quot;VA&quot;,\r\n            &quot;short_country&quot;: &quot;US&quot;,\r\n            &quot;short_city&quot;: &quot;Leesburg&quot;,\r\n            &quot;long_street&quot;: &quot;Stumptown Road&quot;,\r\n            &quot;long_state&quot;: &quot;Virginia&quot;,\r\n            &quot;long_country&quot;: &quot;United States&quot;,\r\n            &quot;long_city&quot;: &quot;Leesburg&quot;,\r\n            &quot;city_id&quot;: &quot;bGVlc2J1cmd2aXJnaW5pYXVuaXRlZCBzdGF0ZXM&quot;\r\n          },\r\n          &quot;challengee_owner&quot;: &quot;1359NhpbxJg1jRpDenJvrmD2P3ZN3hWGSGzUF6Uyn828zYdyYVt&quot;,\r\n          &quot;challengee_lon&quot;: -77.53639565293369,\r\n          &quot;challengee_location_hex&quot;: &quot;882aaa8269fffff&quot;,\r\n          &quot;challengee_location&quot;: &quot;8c2aaa8268753ff&quot;,\r\n          &quot;challengee_lat&quot;: 39.21665905449698,\r\n          &quot;challengee&quot;: &quot;112VEhPPMYF95neEEwwgnckHej4bgZ1roo13SMx18RSJxLq6JuiK&quot;\r\n        }\r\n      ],\r\n      &quot;onion_key_hash&quot;: &quot;aPnoauwxe_Yi0FsM0h80FqObVP1-lu9paUlNfBYyfhw&quot;,\r\n      &quot;height&quot;: 1023200,\r\n      &quot;hash&quot;: &quot;G9yIBcWHAJp3TIiiqabQqLLiW1cWCNxpd-FYgAQ0CXA&quot;,\r\n      &quot;fee&quot;: 0,\r\n      &quot;challenger_owner&quot;: &quot;13FCmP8BeLCojKjUwSY2RHaKfK6wjzZDkz22P9DMuoKuuTidCEh&quot;,\r\n      &quot;challenger_lon&quot;: -84.28750188212047,\r\n      &quot;challenger_location&quot;: &quot;8c44c1318d16dff&quot;,\r\n      &quot;challenger_lat&quot;: 33.91727612784748,\r\n      &quot;challenger&quot;: &quot;11UMasSfidH27f96CJE2dtzjddRb4DTKG1CSWKHqxDwGd78Ht84&quot;\r\n    },\r\n    {\r\n      &quot;version&quot;: 10030002,\r\n      &quot;type&quot;: &quot;poc_request_v1&quot;,\r\n      &quot;time&quot;: 1632396554,\r\n      &quot;secret_hash&quot;: &quot;E1TkvicQEPE-EjaWYkaBLqvRAcyJRFd5ryAmYKIBOtU&quot;,\r\n      &quot;onion_key_hash&quot;: &quot;Ln2fBa3CJdYT28GC7I48WlS7GlzOGIIYUWhp2uCrEEQ&quot;,\r\n      &quot;height&quot;: 1023014,\r\n      &quot;hash&quot;: &quot;6sVmHs1xzExfaY-0AeUqk0lqNnrP1brJy6Rz3LU0ESE&quot;,\r\n      &quot;fee&quot;: 0,\r\n      &quot;challenger_owner&quot;: &quot;1359NhpbxJg1jRpDenJvrmD2P3ZN3hWGSGzUF6Uyn828zYdyYVt&quot;,\r\n      &quot;challenger_location&quot;: &quot;8c2aaa8268753ff&quot;,\r\n      &quot;challenger&quot;: &quot;112VEhPPMYF95neEEwwgnckHej4bgZ1roo13SMx18RSJxLq6JuiK&quot;,\r\n      &quot;block_hash&quot;: &quot;Xb_lC0tNuniPEs3JEfD1ZFLuJoREq8m4x-jWbTwL6X8&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;rewards_v2&quot;,\r\n      &quot;time&quot;: 1632383551,\r\n      &quot;start_epoch&quot;: 1022741,\r\n      &quot;rewards&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;poc_challengees&quot;,\r\n          &quot;gateway&quot;: &quot;112VEhPPMYF95neEEwwgnckHej4bgZ1roo13SMx18RSJxLq6JuiK&quot;,\r\n          &quot;amount&quot;: 4333595,\r\n          &quot;account&quot;: &quot;1359NhpbxJg1jRpDenJvrmD2P3ZN3hWGSGzUF6Uyn828zYdyYVt&quot;\r\n        }\r\n      ],\r\n      &quot;height&quot;: 1022773,\r\n      &quot;hash&quot;: &quot;G-Bf54kqmprh6TSDiLD0Y6H8Cie-sY8idkdMgwAJK6c&quot;,\r\n      &quot;end_epoch&quot;: 1022772\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nCurrently, what I&#39;m doing to get the data I need is something like this:\r\n\r\n```\r\na=&quot;112VEhPPMYF95neEEwwgnckHej4bgZ1roo13SMx18RSJxLq6JuiK&quot;\r\n\r\nthis_data=&quot;$(jq -r --arg a &quot;${a}&quot; &#39;.data[] | select(.type == &quot;poc_receipts_v1&quot;) | select(.challengee != null) | select(.challengee == $a)&#39; file.json)\r\n$(jq -r --arg a &quot;${a}&quot; &#39;.data[] | select(.type == &quot;poc_receipts_v1&quot;) | select(.path[].challengee != null) | select(.path[].challengee == $a)&#39; file.json)&quot;\r\n```\r\n\r\nSo I&#39;m running 2 JQ queries to get the values that I&#39;m looking for, which is taxing on CPU since the json file is pretty large. It would be nice to do this in a single JQ query so I dont need to re-read the file on the second query.\r\n\r\nThanks,",
        "link": "https://stackoverflow.com/questions/69418875/extract-multiple-nested-in-a-single-jq-run",
        "title": "Extract multiple nested in a single JQ run"
    },
    {
        "tags": [
            "json",
            "group-by",
            "count",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1633258179,
                "creation_date": 1633258179,
                "answer_id": 69424122,
                "question_id": 69423726,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using group_by :\r\n\r\n```\r\njq  &#39;map(\r\n         (.member_id) as $m\r\n        | .loans[].media[]\r\n        | select(.title==&quot;foo&quot;)\r\n        | {id: $m, title: .title}\r\n        )\r\n    |group_by(.id)[]\r\n    |.[0] + { count: length }\r\n&#39; input-file\r\n```",
                "title": "How to count occurrences of a key-value pair per individual object in JQ?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1633338105,
                "last_edit_date": 1633338105,
                "creation_date": 1633325858,
                "answer_id": 69431315,
                "question_id": 69423726,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. When the main goal is to count, it is usually more efficient to avoid constructing an array if determining its length is the only reason for doing so.  In the present case you could, for example, write:\r\n\r\n\r\n```\r\ndef count(s): reduce s as $x (null; .+1);\r\n\r\n&quot;foo&quot; as $title | .[] | {\r\n  id: .member_id,\r\n  $title,\r\n  count: count(.loans[].media[] | select(.title == $title))\r\n}\r\n```\r\n\r\n2. `group_by` has its uses, but it is well to be aware that it is  inefficient even for grouping, because its implementation involves a sort, which is not strictly necessary if the goal is to &quot;group by&quot; some criterion.  A completely generic sort-free &quot;group by&quot; function is a bit tricky to implement, but often a simple but non-generic version is sufficient, such as:\r\n```\r\n# sort-free variant of group_by/1\r\n# f must always evaluate to an integer or always to a string, which\r\n# could be achieved by using `tostring`.\r\n# Output: an array in the former case, or an object in the latter case\r\ndef GROUP_BY(f): reduce .[] as $x (null; .[$x|f] += [$x] );\r\n```\r\n\r\n",
                "title": "How to count occurrences of a key-value pair per individual object in JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1633338105,
        "creation_date": 1633254738,
        "last_edit_date": 1633328988,
        "question_id": 69423726,
        "body_markdown": "I could not find how to count occurrence of &quot;title&quot; grouped by &quot;member_id&quot;...\r\nThe json file is:\r\n\r\n    [\r\n     {\r\n      &quot;member_id&quot;: 123,\r\n      &quot;loans&quot;:[\r\n       {\r\n        &quot;date&quot;: &quot;123&quot;,\r\n        &quot;media&quot;: [\r\n         { &quot;title&quot;: &quot;foo&quot; },\r\n         { &quot;title&quot;: &quot;bar&quot; }\r\n        ]\r\n       },\r\n       {\r\n        &quot;date&quot;: &quot;456&quot;,\r\n        &quot;media&quot;: [\r\n         { &quot;title&quot;: &quot;foo&quot; }\r\n        ]\r\n       }\r\n      ]\r\n     },\r\n     {\r\n      &quot;member_id&quot;: 456,\r\n      &quot;loans&quot;:[\r\n       {\r\n        &quot;date&quot;: &quot;789&quot;,\r\n        &quot;media&quot;: [\r\n         { &quot;title&quot;: &quot;foo&quot;}\r\n        ]\r\n       }\r\n      ]\r\n     }\r\n    ]\r\n\r\nWith this query I get loan entries for users with &quot;title==foo&quot;\r\n\r\n     jq &#39;.[] | (.member_id) as $m | .loans[].media[] | select(.title==&quot;foo&quot;) | {id: $m, title: .title}&#39; member.json\r\n    {\r\n      &quot;id&quot;: 123,\r\n      &quot;title&quot;: &quot;foo&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: 123,\r\n      &quot;title&quot;: &quot;foo&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: 456,\r\n      &quot;title&quot;: &quot;foo&quot;\r\n    }\r\n\r\nBut I could not find how to get count by user (*group by*) for a title, to get a result like:\r\n\r\n    {\r\n      &quot;id&quot;: 123,\r\n      &quot;title&quot;: &quot;foo&quot;,\r\n      &quot;count&quot;: 2\r\n    }\r\n    {\r\n      &quot;id&quot;: 456,\r\n      &quot;title&quot;: &quot;foo&quot;,\r\n      &quot;count&quot;: 1\r\n    }\r\n\r\nI got errors like `jq: error (at member.json:31): object ({&quot;title&quot;:&quot;f...) and array ([[123]]) cannot be sorted, as they are not both arrays` or similar...",
        "link": "https://stackoverflow.com/questions/69423726/how-to-count-occurrences-of-a-key-value-pair-per-individual-object-in-jq",
        "title": "How to count occurrences of a key-value pair per individual object in JQ?"
    },
    {
        "tags": [
            "json",
            "jq",
            "text-manipulation"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1633343679,
                "post_id": 69434407,
                "comment_id": 122725737,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1633372850,
                "last_edit_date": 1633372850,
                "creation_date": 1633346737,
                "answer_id": 69435180,
                "question_id": 69434407,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could walk through using `..`, select everything that is an empty array `[]` and set it to `empty`\r\n\r\n```\r\n(.. | select(. == [])) |= empty\r\n```\r\n\r\nEdit:\r\n\r\nIn [this comment][1], oguz ismail uses `del()` instead of `|= empty` which is the preferred approach if the empty arrays to be deleted may be located not only in an object `{&quot;a&quot;:[]}` but also in a superordinate array (`[[]]`).\r\n\r\n```\r\ndel(.. | select(. == []))\r\n```\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/69434407/jq-remove-empty-arrays-from-json#comment122728063_69435180",
                "title": "JQ: Remove empty arrays from JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1633372850,
        "creation_date": 1633342983,
        "question_id": 69434407,
        "body_markdown": "I am having trouble deleting all empty arrays from a JSON file with `jq`.\r\n\r\nI&#39;ve tried:\r\n\r\n    walk(if type == &quot;array&quot; then map(select(length &gt; 0)) else . end)\r\n\r\nwhich removes empty strings, but the arrays stay in the document. Is there a way to remove the arrays completely?\r\nThank you for your support.",
        "link": "https://stackoverflow.com/questions/69434407/jq-remove-empty-arrays-from-json",
        "title": "JQ: Remove empty arrays from JSON"
    },
    {
        "tags": [
            "json",
            "regex",
            "awk",
            "grep",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1633378388,
                "last_edit_date": 1633378388,
                "creation_date": 1633372552,
                "answer_id": 69440840,
                "question_id": 69439635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Sounds like you want something like this:\r\n\r\n    $ cat tst.sh\r\n    #!/usr/bin/env bash\r\n    \r\n    idx=0\r\n    while IFS= read -r url; do\r\n        (( idx++ ))\r\n        sfx=&quot;${url##*.}&quot;\r\n        case &quot;$sfx&quot; in\r\n            png ) ;;\r\n            * ) sfx=&#39;jpg&#39; ;;\r\n        esac\r\n        echo curl &quot;$url&quot; -o &quot;${idx}.${sfx}&quot;\r\n    done &lt; &lt;(jq -r &#39;.url&#39; &quot;${1:-images.json}&quot;)\r\n\r\n&lt;p&gt;\r\n\r\n    $ ./tst.sh\r\n    curl https://enkistroy.ru/800/600/https/avatars.mds.yandex.net/get-zen_doc/1852570/pub_5dbb15dfba281e00b14b4174_5dbb2300e3062c00b072ecce/scale_1200 -o 1.jpg\r\n    curl https://forums.cdprojektred.com/index.php?attachments/unbenannt-jpg.6709974/ -o 2.jpg\r\n    curl https://64.media.tumblr.com/1309f93790c53ccacc333b28d12dac66/tumblr_p9fqienz291x5m66ko1_r1_1280.png -o 3.png\r\n    curl https://i.pinimg.com/originals/4c/21/0c/4c210ca963cf4d52636615ac08126b05.jpg -o 4.jpg\r\n\r\nThe above assumes that any URL that doesn&#39;t end in `.png` is JPEG, massage to suit with whatever rules you&#39;re aware of for identifying the image types to use as the file suffixes or restrict the curl to only the JPEG files.\r\n\r\nObviously remove the `echo` when you&#39;re done testing and want to actually execute the `curl`.\r\n\r\nTo use the image data as the index (see the comments below):\r\n\r\n    $ cat tst.sh\r\n    #!/usr/bin/env bash\r\n    \r\n    while read -r idx url; do\r\n        sfx=&quot;${url##*.}&quot;\r\n        case &quot;$sfx&quot; in\r\n            png ) ;;\r\n            * ) sfx=&#39;jpg&#39; ;;\r\n        esac\r\n        echo curl &quot;$url&quot; -o &quot;${idx}.${sfx}&quot;\r\n    done &lt; &lt;( jq -j &#39;.image, &quot; &quot;, .url, &quot;\\n&quot;&#39; &quot;${1:-images.json}&quot; )\r\n\r\n&lt;p&gt;\r\n\r\n    $ ./tst.sh\r\n    curl https://enkistroy.ru/800/600/https/avatars.mds.yandex.net/get-zen_doc/1852570/pub_5dbb15dfba281e00b14b4174_5dbb2300e3062c00b072ecce/scale_1200 -o 136.jpg\r\n    curl https://forums.cdprojektred.com/index.php?attachments/unbenannt-jpg.6709974/ -o 137.jpg\r\n    curl https://64.media.tumblr.com/1309f93790c53ccacc333b28d12dac66/tumblr_p9fqienz291x5m66ko1_r1_1280.png -o 138.png\r\n    curl https://i.pinimg.com/originals/4c/21/0c/4c210ca963cf4d52636615ac08126b05.jpg -o 139.jpg\r\n\r\n",
                "title": "Download URLs in JSON file and save with a specific naming pattern"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1633461558,
                "creation_date": 1633461558,
                "answer_id": 69456139,
                "question_id": 69439635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "*Maybe writing python script would be easier?*\r\n\r\nPython has built-in module [`imghdr`][1] which comes handy if you have image file, but do not know in what format. Let say that you downloaded your `https://64.media.tumblr.com/1309f93790c53ccacc333b28d12dac66/tumblr_p9fqienz291x5m66ko1_r1_1280.png`\r\nand save it under name `138`, to detect what format of image it actually is launch `python` in same catalog and do\r\n\r\n    import imghdr\r\n    imgformat = imghdr.what(&quot;138&quot;)\r\n    print(imgformat)\r\n\r\noutput\r\n\r\n    jpeg\r\nBuilt-in [`os`][2] module allow to easily change name to include this extension, i.e.:\r\n\r\n    import imghdr\r\n    import os\r\n    filename = &quot;138&quot;\r\n    imgformat = imghdr.what(&quot;138&quot;)\r\n    if imgformat:\r\n        os.rename(filename, filename + &quot;.&quot; + imgformat)\r\n\r\nNote `if imgformat:` is used so when image format was not recognized there is no operation\r\n\r\n\r\n  [1]: https://docs.python.org/3/library/imghdr.html\r\n  [2]: https://docs.python.org/3/library/os.html",
                "title": "Download URLs in JSON file and save with a specific naming pattern"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1633461558,
        "creation_date": 1633365990,
        "last_edit_date": 1633369186,
        "question_id": 69439635,
        "body_markdown": "I&#39;d like to download images and rename them by their index \r\n\r\nThe only thing I have is a jsonlines file which looks like this:\r\n ```\r\n{&quot;image&quot;: 136, &quot;url&quot;: &quot;https://enkistroy.ru/800/600/https/avatars.mds.yandex.net/get-zen_doc/1852570/pub_5dbb15dfba281e00b14b4174_5dbb2300e3062c00b072ecce/scale_1200&quot;}\r\n{&quot;image&quot;: 137, &quot;url&quot;: &quot;https://forums.cdprojektred.com/index.php?attachments/unbenannt-jpg.6709974/&quot;}\r\n{&quot;image&quot;: 138, &quot;url&quot;: &quot;https://64.media.tumblr.com/1309f93790c53ccacc333b28d12dac66/tumblr_p9fqienz291x5m66ko1_r1_1280.png&quot;}\r\n{&quot;image&quot;: 139, &quot;url&quot;: &quot;https://i.pinimg.com/originals/4c/21/0c/4c210ca963cf4d52636615ac08126b05.jpg&quot;}\r\n```\r\nI&#39;ve tried using `jq tool, grep, wget and curl`\r\n\r\n    egrep -o &#39;https:[^\\&quot;]*jpg&#39; images.json | xargs -n 1 curl -O\r\n\r\nThis only downloads https links with jpg files without renaming them\r\n\r\nMaybe writing python script would be easier?\r\n\r\nEDIT:\r\n\r\nTried this not sure how to rename with curl? `curl -O &quot;#1.jpg&quot;` \r\n\r\n`jq -r &#39;.url&#39; images.json | parallel curl -O`",
        "link": "https://stackoverflow.com/questions/69439635/download-urls-in-json-file-and-save-with-a-specific-naming-pattern",
        "title": "Download URLs in JSON file and save with a specific naming pattern"
    },
    {
        "tags": [
            "bash",
            "shell",
            "scripting",
            "jq",
            "double-quotes"
        ],
        "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": 1633380933,
                "post_id": 69442309,
                "comment_id": 122740381,
                "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": 1633380958,
                "post_id": 69442309,
                "comment_id": 122740386,
                "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": 1633380987,
                "post_id": 69442309,
                "comment_id": 122740394,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9250771,
                    "reputation": 23,
                    "user_id": 6871363,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cb330f50cba94397645d62ab25478f18?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "K. Don",
                    "link": "https://stackoverflow.com/users/6871363/k-don"
                },
                "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": 1633381015,
                "post_id": 69442309,
                "comment_id": 122740401,
                "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": 2,
                "creation_date": 1633381048,
                "post_id": 69442309,
                "comment_id": 122740410,
                "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": 1633381193,
                "post_id": 69442309,
                "comment_id": 122740456,
                "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": 1633381270,
                "post_id": 69442309,
                "comment_id": 122740482,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9250771,
                    "reputation": 23,
                    "user_id": 6871363,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cb330f50cba94397645d62ab25478f18?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "K. Don",
                    "link": "https://stackoverflow.com/users/6871363/k-don"
                },
                "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": 1,
                "creation_date": 1633381855,
                "post_id": 69442309,
                "comment_id": 122740629,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1633381014,
        "creation_date": 1633380899,
        "question_id": 69442309,
        "body_markdown": "I&#39;m attempting to parse the output of a script that takes a parameter and for each parameter pulls some json. I&#39;m parsing with jq.\r\nOn the command line for one run of the script a command like this one works:\r\n\r\n`./script_that_produces_json --intput=value | jq &#39;.[] | select(.name==&quot;objecName&quot;) | .fieldIWant`\r\n\r\nI need to run this for a variety of parameters, which I am attempting to read from an array. This is what my code looks like now:\r\n\r\n```\r\nfor entry in &quot;${array[@]}&quot;\r\ndo\r\n    output=$(./script_that_produces_json --input=$entry | jq &#39;.[] | select(.name==&quot;$entry&quot;) | .fieldIWant)&#39;\r\n    print($output)\r\ndone\r\n\r\n```\r\n\r\nThis yields the variable substituted, but there are no quotes around it, which fails when passed to jq. I&#39;ve been hacking around this with various combinations of quotes with no success.\r\n\r\n**How do I quote the variable/string correctly such that both the variable is replaced and the quotes are passed?**",
        "link": "https://stackoverflow.com/questions/69442309/how-to-pass-a-quoted-variable-name-through-to-a-sub-command-in-bash",
        "title": "How to pass a quoted variable name through to a sub command in bash"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": -1,
                "last_activity_date": 1633429174,
                "last_edit_date": 1633429174,
                "creation_date": 1633428768,
                "answer_id": 69448620,
                "question_id": 69448191,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this:\r\n```jq\r\n.[0] | select(\r\n  .name == &quot;build_job&quot; and .status == &quot;success&quot; and (\r\n      .artifacts[] | select(.file_type == &quot;archive&quot;) | length &gt; 0\r\n   )\r\n) | .id\r\n```\r\nThis selects successful `build_job`s containing one or more `archive` artifacts. Unfortunately, multiple ids are returned if there&#39;s more than one such artifacts. Here&#39;s how to wrap the expression to fix that:\r\n```jq\r\n[ \r\n  .[] | select(\r\n    .name == &quot;build_job&quot; and .status == &quot;success&quot; and (\r\n      .artifacts[] | select(.file_type == &quot;archive&quot;) | length &gt; 0\r\n    )\r\n  )\r\n] | unique | .[].id\r\n```",
                "title": "Double condition in array with JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1633429873,
                "creation_date": 1633429873,
                "answer_id": 69448878,
                "question_id": 69448191,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the last condition, take the array `.artifacts`, reduce it to those elements matching your criteria `map(select(.file_type == &quot;archive&quot;))` and test the resulting array&#39;s length `length &gt; 0`.\r\n\r\nAll together:\r\n\r\n```\r\n.[0] | select(\r\n  .name == &quot;build_job&quot; and\r\n  .status == &quot;success&quot; and (\r\n    (.artifacts | map(select(.file_type == &quot;archive&quot;))) | length &gt; 0\r\n  )\r\n)\r\n| .id",
                "title": "Double condition in array with JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1633438767,
                "last_edit_date": 1633438767,
                "creation_date": 1633431517,
                "answer_id": 69449219,
                "question_id": 69448191,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the last condition, you presumably mean something like:\r\n\r\n    all(.artifacts[];\r\n        if .file_type == &quot;archive&quot; then .size &gt; 0 else true end)\r\n\r\nwhich can also be written as:\r\n\r\n    all(.artifacts[] | select(.file_type == &quot;archive&quot;);\r\n        .size &gt; 0)\r\n\r\nI’d recommend using either `all` or `any`, depending on your requirements.",
                "title": "Double condition in array with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1633438767,
        "creation_date": 1633427005,
        "question_id": 69448191,
        "body_markdown": "My JSON is an array of one object like this:\r\n\r\n```json\r\n[{\r\n  &quot;id&quot;: 125650,\r\n  &quot;status&quot;: &quot;success&quot;,\r\n  &quot;name&quot;: &quot;build_job&quot;,\r\n  &quot;artifacts&quot;: [\r\n    {\r\n      &quot;file_type&quot;: &quot;archive&quot;,\r\n      &quot;size&quot;: 72720116,\r\n      &quot;filename&quot;: &quot;artifacts.zip&quot;,\r\n      &quot;file_format&quot;: &quot;zip&quot;\r\n    },\r\n    {\r\n      &quot;file_type&quot;: &quot;metadata&quot;,\r\n      &quot;size&quot;: 1406,\r\n      &quot;filename&quot;: &quot;metadata.gz&quot;,\r\n      &quot;file_format&quot;: &quot;gzip&quot;\r\n    }\r\n  ]\r\n}]\r\n```\r\n\r\nI want to select only the object ID if the following conditions matches:\r\n- status == success\r\n- name == build_job\r\n- artifacts.size &gt; 0 where file_type == archive\r\n\r\nI&#39;m stuck on the last condition, I can select artifacts with size &gt; 0, OR artifacts where file_type = archive, but not both at the same time. \r\n\r\nHere&#39;s my current query :\r\n\r\n```bash\r\n| jq &#39;.[0] | select(.name == &quot;build_job&quot; and .status == &quot;success&quot; and .artifacts[].file_type == &quot;archive&quot;) | .id&#39;\r\n```\r\n\r\nCan you help me with that ?",
        "link": "https://stackoverflow.com/questions/69448191/double-condition-in-array-with-jq",
        "title": "Double condition in array with JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1633451808,
                "creation_date": 1633451808,
                "answer_id": 69454246,
                "question_id": 69453999,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes, it is possible. I wrote a function for that once and posted [here](/a/61655940/10248678). You can use it like so:\r\n```\r\ndef pick(paths):\r\n  . as $in\r\n  | reduce path(paths) as $path (null;\r\n    setpath($path; $in | getpath($path))\r\n  );\r\n\r\npick(.object.a, .string)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/zIqtX15_4X)&lt;/sup&gt;",
                "title": "Using jq, is it possible to return the same json object but only with selected fields/keys on multiple levels?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1633451808,
        "creation_date": 1633450589,
        "question_id": 69453999,
        "body_markdown": "Say I have a multilevel json like the following:\r\n\r\n```\r\n{\r\n  &quot;array&quot;: [\r\n    1,\r\n    2,\r\n    3\r\n  ],\r\n  &quot;boolean&quot;: true,\r\n  &quot;color&quot;: &quot;gold&quot;,\r\n  &quot;null&quot;: null,\r\n  &quot;number&quot;: 123,\r\n  &quot;object&quot;: {\r\n    &quot;a&quot;: &quot;b&quot;,\r\n    &quot;c&quot;: &quot;d&quot;\r\n  },\r\n  &quot;string&quot;: &quot;Hello World&quot;\r\n}\r\n```\r\n\r\nCan jq return the same json but with fields that I choose on multiple levels?\r\n\r\ne.g.\r\n\r\n```\r\n{\r\n  &quot;object&quot;: {\r\n    &quot;a&quot;: &quot;b&quot;,\r\n  },\r\n  &quot;string&quot;: &quot;Hello World&quot;\r\n}\r\n```\r\n\r\nHere, I have selected the `string` field at the top level, and the `a` field within the `object` field.\r\n\r\nEdit: In practice, there are multiple fields on each level that I would like to select, and the levels are &gt;4.",
        "link": "https://stackoverflow.com/questions/69453999/using-jq-is-it-possible-to-return-the-same-json-object-but-only-with-selected-f",
        "title": "Using jq, is it possible to return the same json object but only with selected fields/keys on multiple levels?"
    },
    {
        "tags": [
            "json",
            "jq",
            "uuid"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1633495826,
                "last_edit_date": 1633495826,
                "creation_date": 1633484751,
                "answer_id": 69458953,
                "question_id": 69457618,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one possibility that does not require your shell to support &quot;process substitution&quot; but which entails two passes, the first for determining the number of UUIDs that are required:\r\n```\r\n# Syntax: generate N\r\nfunction generate {\r\n    for ((i=0; i&lt;$1; i++)) ; do\r\n\tuuidgen\r\n    done\r\n}    \r\n\r\ngenerate $( &lt;composer.lock jq &#39;.packages|length&#39;) | \r\n  jq -nR --argfile input composer.lock  &#39;\r\n    ($input \r\n    | .packages[]\r\n    | {site: &quot;foo&quot;, name: .name, version: .version, type: .type,\r\n       id: input})&#39;\r\n```",
                "title": "How to populate value with input"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1633530394,
                "last_edit_date": 1633530394,
                "creation_date": 1633487711,
                "answer_id": 69459209,
                "question_id": 69457618,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your shell supports process substitution, you can avoid a two-pass solution as follows:\r\n\r\n    jq -nR  --argfile input composer.lock &#39;\r\n      $input \r\n      | .packages[]  \r\n      | {site: &quot;foo&quot;, name: .name, version: .version, type: .type, id: input}\r\n     &#39; &lt; &lt;(while true; do uuidgen; done)\r\n\r\n---\r\nThe point here is that by using process substitution as above, the termination of the &quot;consumer&quot; (jq) will also terminate the &quot;producer&quot;  of UUIDs.",
                "title": "How to populate value with input"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1633530394,
        "creation_date": 1633470517,
        "last_edit_date": 1633488658,
        "question_id": 69457618,
        "body_markdown": "From a composer.lock I am creating json output of some fields, like this:\r\n\r\n```js\r\n &lt;composer.lock jq  &#39;.packages[] | {site: &quot;foo&quot;, name: .name, version: .version, type: .type}&#39; | jq -s\r\n```\r\nIt works fine:\r\n\r\n```json\r\n  {\r\n    &quot;site&quot;: &quot;foo&quot;,\r\n    &quot;name&quot;: &quot;webmozart/path-util&quot;,\r\n    &quot;version&quot;: &quot;2.3.0&quot;,\r\n    &quot;type&quot;: &quot;library&quot;\r\n  },\r\n  {\r\n    &quot;site&quot;: &quot;foo&quot;,\r\n    &quot;name&quot;: &quot;webonyx/graphql-php&quot;,\r\n    &quot;version&quot;: &quot;v14.9.0&quot;,\r\n    &quot;type&quot;: &quot;library&quot;\r\n  }\r\n```\r\n\r\nbut now I want to add a generated value, using uuidgen, but I can&#39;t figure out how to do that.\r\n\r\nEnd result would be something like:\r\n\r\n```json\r\n  {\r\n    &quot;site&quot;: &quot;foo&quot;,\r\n    &quot;name&quot;: &quot;webmozart/path-util&quot;,\r\n    &quot;version&quot;: &quot;2.3.0&quot;,\r\n    &quot;type&quot;: &quot;library&quot;,\r\n    &quot;uuid&quot;: &quot;c4e97c3c-147d-4360-a601-6b4f6f5e71bb&quot;\r\n  },\r\n  {\r\n    &quot;site&quot;: &quot;foo&quot;,\r\n    &quot;name&quot;: &quot;webonyx/graphql-php&quot;,\r\n    &quot;version&quot;: &quot;v14.9.0&quot;,\r\n    &quot;type&quot;: &quot;library&quot;,\r\n    &quot;uuid&quot;: &quot;6fbe472b-49fe-4064-93f0-09a18a7e1c24&quot;\r\n  }\r\n```\r\nI think I should use input, but all I tried so far have failed.",
        "link": "https://stackoverflow.com/questions/69457618/how-to-populate-value-with-input",
        "title": "How to populate value with input"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1633548579,
                "last_edit_date": 1633548579,
                "creation_date": 1633535368,
                "answer_id": 69468843,
                "question_id": 69468778,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One of many ways would be simply to add `\\n` to the end of the string specification.\r\n\r\nIf the extra newline at the end is unwanted, you could, for example, use `sed &#39;$d&#39;` to remove it.",
                "title": "jq - print newlines while processing rows from an array"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1633535776,
                "creation_date": 1633535776,
                "answer_id": 69468938,
                "question_id": 69468778,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another option is to use [`map()`][1] combined with [`join(&quot;\\n\\n&quot;)`][2] to insert an `\\n` between each iteration. This way there won&#39;t be a trailing newline:\r\n\r\n```\r\njq -rj &#39;.records | map(&quot;id: \\(.id)\\nname: \\(.name)&quot;) | join(&quot;\\n\\n&quot;)&#39; input.json\r\n```\r\n\r\n```none\r\nid: 1\r\nname: hello\r\n\r\nid: 2\r\nname: world\r\n```\r\n\r\n\r\n----------\r\n\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.\r\n\r\n&gt; ##### `--join-output` / `-j`:\r\n&gt;\r\n&gt; Like `-r` but jq won&#39;t print a newline after each output.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#map(x),map_values(x)\r\n  [2]: https://stedolan.github.io/jq/manual/#join(str)",
                "title": "jq - print newlines while processing rows from an array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1714455252,
                "last_edit_date": 1714455252,
                "creation_date": 1714393297,
                "answer_id": 78402691,
                "question_id": 69468778,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I recommend this: I just splitted the output string in parts and added an extra  empty filter &quot;&quot; to get an empty line.\r\n\r\n```\r\njq -r &#39;.records[] |  &quot;id: \\(.id)&quot;, &quot;name: \\(.name)&quot;, &quot;&quot;&#39; afile.json\r\n```",
                "title": "jq - print newlines while processing rows from an array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1714455252,
        "creation_date": 1633535080,
        "question_id": 69468778,
        "body_markdown": "Suppose I have a json like this:\r\n\r\n```\r\n{\r\n  &quot;records&quot;: [\r\n    {\r\n        &quot;id&quot;: 1,\r\n        &quot;name&quot;: &quot;hello&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: 2,\r\n        &quot;name&quot;: &quot;world&quot;    \r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI could do this:\r\n\r\n```\r\n$ jq -r &#39;.records[] | &quot;id: \\(.id) name: \\(.name)&quot;&#39; afile.json\r\nid: 1 name: hello\r\nid: 2 name: world\r\n```\r\n\r\nHow can I insert new lines so that I could get this:\r\n```\r\nid: 1\r\nname: hello\r\n\r\nid: 2\r\nname: world\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/69468778/jq-print-newlines-while-processing-rows-from-an-array",
        "title": "jq - print newlines while processing rows from an array"
    },
    {
        "tags": [
            "json",
            "jq",
            "maxby"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1633556103,
                "creation_date": 1633556103,
                "answer_id": 69472937,
                "question_id": 69472830,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n[.objects[]\r\n | select(.name|test(&quot;rhel/.&quot;))]\r\n| max_by(.name|split(&quot;.&quot;)[-2]|tonumber)\r\n```\r\n\r\nproduces:\r\n```\r\n{\r\n  &quot;name&quot;: &quot;rhel/app-3.11.4.629600.txt&quot;\r\n}\r\n```\r\n\r\nIf you only want the names you could begin by extracting them:\r\n```\r\n[.objects[].name|select(test(&quot;rhel/.&quot;))]\r\n| max_by(split(&quot;.&quot;)[-2]|tonumber)\r\n```\r\n\r\n",
                "title": "Selecting &#39;name&#39; with highest build number from json list"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1633556385,
        "creation_date": 1633555390,
        "last_edit_date": 1633556385,
        "question_id": 69472830,
        "body_markdown": "Here is my sample data, it&#39;s a list of objects in a storage bucket on Oracle cloud:\r\n```\r\n{\r\n\t&quot;objects&quot;: [\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;rhel/&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;rhel/app-3.9.6.629089.txt&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;rhel/app-3.11.4.629600.txt&quot;\r\n\t\t}\r\n\t]\r\n}\r\n```\r\nThe part of the value before the &#39;/&#39; is a folder name, after is a filename. The last number in the filename is a build number. The desired output is the name of the object with the highest build number in the rhel folder:\r\n```\r\n$ jq -r &#39;some_program&#39; file.json \r\nrhel/app-3.11.4.629600.txt\r\n```\r\nI can somewhat process the data to exclude the bare &quot;rhel/&quot; folder as follows:\r\n```\r\n$ jq -r &#39;.objects[] | select(.name|test(&quot;rhel/.&quot;))&#39; file.json\r\n{\r\n  &quot;name&quot;: &quot;rhel/app-3.9.6.629089.txt&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;rhel/app-3.11.4.629600.txt&quot;\r\n}\r\n```\r\nWhen I try to split this on the period jq throws an error:\r\n```\r\n$ jq -r &#39;.objects[] | select(.name|test(&quot;rhel/.&quot;)) | split(&quot;.&quot;)&#39; file.json\r\njq: error (at file.json:1): split input and separator must be strings\r\n```\r\nI was expecting to use &#39;map(tonumber)[-2]&#39; on the result of the split and wrap the entirety in &#39;max_by()&#39;.\r\n\r\nHow can get closer to the desired output with jq?",
        "link": "https://stackoverflow.com/questions/69472830/selecting-name-with-highest-build-number-from-json-list",
        "title": "Selecting &#39;name&#39; with highest build number from json list"
    },
    {
        "tags": [
            "json",
            "key",
            "grouping",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1633583128,
                "creation_date": 1633583128,
                "answer_id": 69475720,
                "question_id": 69475661,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Expand each group only once.\r\n``` none\r\ngroup_by(.g)[] | .[0].g, (.[] | &quot;\\(.k1) \\(.k2)&quot;), &quot;&quot;\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/_YSNymVriw)&lt;/sup&gt;",
                "title": "jq: group input and produce grouped raw output"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1633610699,
                "creation_date": 1633610699,
                "answer_id": 69481427,
                "question_id": 69475661,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A more generic alternative :\r\n\r\n```\r\njq --raw-output &#39;group_by(.g)|\r\n        map(.[0].g as $g | del(.[].g) |\r\n             [$g] + map(\r\n                 [.[]] | join(&quot; &quot;)\r\n             ) | join(&quot;\\n&quot;)\r\n        ) |\r\n        join(&quot;\\n\\n&quot;)&#39;\r\n```",
                "title": "jq: group input and produce grouped raw output"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1633610699,
        "creation_date": 1633582518,
        "question_id": 69475661,
        "body_markdown": "Consider the following JSON input:\r\n```json\r\n[\r\n    {\r\n        &quot;g&quot;: &quot;g1&quot;,\r\n        &quot;k1&quot;: &quot;v11&quot;,\r\n        &quot;k2&quot;: &quot;v12&quot;\r\n    },\r\n    {\r\n        &quot;g&quot;: &quot;g1&quot;,\r\n        &quot;k1&quot;: &quot;v21&quot;,\r\n        &quot;k2&quot;: &quot;v22&quot;\r\n    },\r\n    {\r\n        &quot;g&quot;: &quot;g2&quot;,\r\n        &quot;k1&quot;: &quot;v31&quot;,\r\n        &quot;k2&quot;: &quot;v32&quot;\r\n    }\r\n]\r\n```\r\n\r\nI would like `jq` to produce the following output:\r\n```\r\ng1\r\nv11 v12\r\nv21 v22\r\n\r\ng2\r\nv31 v32\r\n```\r\n\r\nMy attempt with the jq command:\r\n```shell\r\njq --raw-output &#39;group_by(.g) | .[] | {g: .[0].g, v: .} | &quot;\\(.g)\\n\\(.v[].k1) \\(.v[].k2)\\n&quot;&#39;\r\n```\r\n\r\nProduces incorrect results:\r\n```\r\ng1\r\nv11 v12\r\n\r\ng1\r\nv21 v12\r\n\r\ng1\r\nv11 v22\r\n\r\ng1\r\nv21 v22\r\n\r\ng2\r\nv31 v32\r\n```\r\n\r\nLink to jqplay: https://jqplay.org/s/w81t2OW9iO",
        "link": "https://stackoverflow.com/questions/69475661/jq-group-input-and-produce-grouped-raw-output",
        "title": "jq: group input and produce grouped raw output"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4255829,
                    "reputation": 307,
                    "user_id": 3481556,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/7123832915d8b47abb9866f1bbb20969?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "aidandeno",
                    "link": "https://stackoverflow.com/users/3481556/aidandeno"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633595311,
                "post_id": 69477790,
                "comment_id": 122802971,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12910677,
                    "reputation": 464,
                    "user_id": 9336478,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/0X8Ga.png?s=256",
                    "display_name": "Lunartist",
                    "link": "https://stackoverflow.com/users/9336478/lunartist"
                },
                "reply_to_user": {
                    "account_id": 4255829,
                    "reputation": 307,
                    "user_id": 3481556,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/7123832915d8b47abb9866f1bbb20969?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "aidandeno",
                    "link": "https://stackoverflow.com/users/3481556/aidandeno"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633595860,
                "post_id": 69477790,
                "comment_id": 122803210,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1633596886,
                "last_edit_date": 1633596886,
                "creation_date": 1633596394,
                "answer_id": 69478110,
                "question_id": 69477790,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `max_by` to find the maximum according to a specific path.\r\n\r\nIf you want to retain the timestamp, convert the objects using `to_entries` to a `key`/`value` pair and find the maximum:\r\n\r\n    jq &#39;.MonitorHistory | fromjson | to_entries | max_by(.value.CpuUsage | tonumber) | {(.key):.value}&#39;\r\n\r\nOtherwise, if you only need the highest number\r\n\r\n    jq &#39;[.MonitorHistory | fromjson[].CpuUsage | tonumber] | max&#39;\r\n",
                "title": "How do I parse a timebased result using jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1633596873,
                "creation_date": 1633596873,
                "answer_id": 69478220,
                "question_id": 69477790,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;ll need to first parse the `MonitorHistory` json string to get it into a workable form. Then take advantage of the fact that json objects when enumerated in jq are in alphabetical order (since they appear to be ISO timestamps). Just pull the values from each of the entries. Since it&#39;s all just single property objects, just spit out the values.\r\n\r\n```\r\n.MonitorHistory | fromjson[][] | tonumber\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/k_IiAV6KmN)",
                "title": "How do I parse a timebased result using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1633597997,
        "creation_date": 1633595064,
        "last_edit_date": 1633597997,
        "question_id": 69477790,
        "body_markdown": "I want to monitor highest CpuUsage from this result. How do I parse a `json` that changes its category on a time base?\r\n\r\n    {\r\n      &quot;MonitorHistory&quot;: &quot;{\\&quot;2021-10-06T00:00:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.45\\&quot;},\\&quot;2021-10-06T00:01:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.57\\&quot;},\\&quot;2021-10-06T00:02:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.73\\&quot;},\\&quot;2021-10-06T00:03:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.6\\&quot;},\\&quot;2021-10-06T00:04:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.45\\&quot;},\\&quot;2021-10-06T00:05:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.57\\&quot;},\\&quot;2021-10-06T00:06:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.6\\&quot;},\\&quot;2021-10-06T00:07:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.65\\&quot;},\\&quot;2021-10-06T00:08:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.72\\&quot;},\\&quot;2021-10-06T00:09:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.57\\&quot;},\\&quot;2021-10-06T00:10:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.87\\&quot;},\\&quot;2021-10-06T00:11:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.67\\&quot;},\\&quot;2021-10-06T00:12:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.78\\&quot;},\\&quot;2021-10-06T00:13:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.72\\&quot;},\\&quot;2021-10-06T00:14:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.73\\&quot;},\\&quot;2021-10-06T00:15:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.92\\&quot;},\\&quot;2021-10-06T00:16:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;1.0\\&quot;},\\&quot;2021-10-06T00:17:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;1.23\\&quot;},\\&quot;2021-10-06T00:18:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.93\\&quot;},\\&quot;2021-10-06T00:19:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.98\\&quot;},\\&quot;2021-10-06T00:20:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.87\\&quot;},\\&quot;2021-10-06T00:21:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;0.95\\&quot;},\\&quot;2021-10-06T00:22:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;1.18\\&quot;},\\&quot;2021-10-06T00:23:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;1.08\\&quot;},\\&quot;2021-10-06T00:24:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;1.15\\&quot;},\\&quot;2021-10-06T00:25:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;1.37\\&quot;},\\&quot;2021-10-06T00:26:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;1.72\\&quot;},\\&quot;2021-10-06T00:27:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;1.6\\&quot;},\\&quot;2021-10-06T00:28:00Z\\&quot;:{\\&quot;CpuUsage\\&quot;:\\&quot;1.47\\&quot;}}&quot;\r\n    }\r\n\r\nMy desired result is a collection of CpuUsage values like \r\n`0.45 0.73 0.6...`",
        "link": "https://stackoverflow.com/questions/69477790/how-do-i-parse-a-timebased-result-using-jq",
        "title": "How do I parse a timebased result using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1633622102,
                "last_edit_date": 1633622102,
                "creation_date": 1633601504,
                "answer_id": 69479327,
                "question_id": 69479140,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward solution, which would be easy to adapt to handle the renaming of keys:\r\n```\r\n[.[]]\r\n| transpose\r\n| {items: map( {name: .[0], age: .[1], town: .[2] } )}\r\n```",
                "title": "Merge fields from different arrays in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1633602233,
                "creation_date": 1633602233,
                "answer_id": 69479477,
                "question_id": 69479140,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that makes it easy to handle the key names without explicitly mentioning any of them:\r\n\r\n```\r\ndef objectify($keys):\r\n  with_entries( .key |= $keys[.] );\r\n\r\nkeys_unsorted as $keys\r\n| [.[]]\r\n| transpose\r\n| {items: map( objectify($keys) )}\r\n\r\n```\r\n",
                "title": "Merge fields from different arrays in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1633622102,
        "creation_date": 1633600617,
        "question_id": 69479140,
        "body_markdown": "I have the following kind of array:\r\n\r\n```\r\n{\r\n  &quot;name&quot;: [\r\n    &quot;Paul&quot;,\r\n    &quot;Alex&quot;,\r\n    &quot;John&quot;\r\n  ],\r\n  &quot;age&quot;: [\r\n    &quot;22&quot;,\r\n    &quot;31&quot;,\r\n    &quot;56&quot;\r\n  ],\r\n  &quot;town&quot;: [\r\n    &quot;New York&quot;,\r\n    &quot;Los Angeles&quot;,\r\n    &quot;Detroit&quot;\r\n  ]\r\n}\r\n\r\n```\r\n\r\nFrom this I want to create new arrays with the relevant information combined into one large array called &quot;items&quot;.\r\n\r\n```\r\n{&quot;items&quot;: [\r\n    {\r\n        &quot;name&quot;: &quot;Paul&quot;,\r\n        &quot;age&quot;: &quot;22&quot;,\r\n        &quot;town&quot;: &quot;New York&quot;\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;Alex&quot;,\r\n        &quot;age&quot;: &quot;31&quot;,\r\n        &quot;town&quot;: &quot;Los Angeles&quot;\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;John&quot;,\r\n        &quot;age&quot;: &quot;56&quot;,\r\n        &quot;town&quot;: &quot;Detroit&quot;\r\n    },\r\n]}\r\n```\r\n\r\nI found out that I can do something like this to get the first string in an array but I can&#39;t find how to iterate over all strings.\r\n\r\n    jq &#39;{items: [{ name: .name | first,  age: .age | first, town: .town | first}]}&#39;",
        "link": "https://stackoverflow.com/questions/69479140/merge-fields-from-different-arrays-in-jq",
        "title": "Merge fields from different arrays in jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11380463,
                    "reputation": 18628,
                    "user_id": 8343484,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Frs71.jpg?s=256",
                    "display_name": "Marko E",
                    "link": "https://stackoverflow.com/users/8343484/marko-e"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633608647,
                "post_id": 69480708,
                "comment_id": 122808359,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1633609057,
                "post_id": 69480708,
                "comment_id": 122808551,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13342630,
                    "reputation": 423,
                    "user_id": 9630404,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/819bd8d616deec09eb7b2619c849022d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "tomi",
                    "link": "https://stackoverflow.com/users/9630404/tomi"
                },
                "reply_to_user": {
                    "account_id": 11380463,
                    "reputation": 18628,
                    "user_id": 8343484,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Frs71.jpg?s=256",
                    "display_name": "Marko E",
                    "link": "https://stackoverflow.com/users/8343484/marko-e"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633615988,
                "post_id": 69480708,
                "comment_id": 122811843,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13342630,
                    "reputation": 423,
                    "user_id": 9630404,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/819bd8d616deec09eb7b2619c849022d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "tomi",
                    "link": "https://stackoverflow.com/users/9630404/tomi"
                },
                "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": 1633616012,
                "post_id": 69480708,
                "comment_id": 122811853,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1633616521,
                "creation_date": 1633616521,
                "answer_id": 69482855,
                "question_id": 69480708,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use a negative index to enumerate from the back of an array: to get the last element of the last array in the `values` of the last element of `result`:\r\n\r\n```jq\r\n.data.result[-1].values[-1][-1]\r\n```",
                "title": "JQ get data from an array of array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1647398482,
                "creation_date": 1647398482,
                "answer_id": 71491233,
                "question_id": 69480708,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "demo: https://jqplay.org/s/YMpB8-A4-Q\r\n\r\n```\r\nfilter: \r\n.data.result[].values[1][1]?\r\n\r\ninput:\r\n{\r\n  &quot;status&quot;: &quot;success&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;resultType&quot;: &quot;matrix&quot;,\r\n    &quot;result&quot;: [\r\n      {\r\n        &quot;metric&quot;: {\r\n          &quot;myMetric&quot;: &quot;ABC&quot;\r\n        },\r\n        &quot;values&quot;: [\r\n          [\r\n            1633597734,\r\n            &quot;64.54166666666667&quot;\r\n          ],\r\n          [\r\n            1633598034,\r\n            &quot;65.51666666666667&quot;\r\n          ]\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n}\r\n\r\noutput:\r\n&quot;65.51666666666667&quot;\r\n\r\n```",
                "title": "JQ get data from an array of array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1647398482,
        "creation_date": 1633607754,
        "last_edit_date": 1633623823,
        "question_id": 69480708,
        "body_markdown": "How can I get a value from an array of arrays. This is JSON from which I have to get the data:\r\n```json\r\n{\r\n  &quot;status&quot;: &quot;success&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;resultType&quot;: &quot;matrix&quot;,\r\n    &quot;result&quot;: [\r\n      {\r\n        &quot;metric&quot;: {\r\n          &quot;myMetric&quot;: &quot;ABC&quot;\r\n        },\r\n        &quot;values&quot;: [\r\n          [\r\n            1633597734,\r\n            &quot;64.54166666666667&quot;\r\n          ],\r\n          [\r\n            1633598034,\r\n            &quot;65.51666666666667&quot;  &lt;-- wanted value\r\n          ]\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nI have to get value from the last array in ```values```.\r\nI tried the following:\r\n```\r\njq .data.result.values input.json\r\njq .data.result.values[] input.json\r\njq .data.result.values[][] input.json\r\n```\r\nFor every one the result is:\r\n```\r\njq: error (at json:0): Cannot index array with string &quot;values&quot;\r\n```\r\nHow can I get value from the last array in ```values```?",
        "link": "https://stackoverflow.com/questions/69480708/jq-get-data-from-an-array-of-array",
        "title": "JQ get data from an array of array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1633613316,
                "creation_date": 1633613316,
                "answer_id": 69482081,
                "question_id": 69481933,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nselect(.sppci_device_type | . == &quot;sppci_audiodevice&quot; or . == &quot;sppci_nvme&quot;) ._name\r\n```\r\nor\r\n```\r\nselect(.sppci_device_type | IN(&quot;sppci_audiodevice&quot;, &quot;sppci_nvme&quot;)) ._name\r\n```",
                "title": "Select multiple JSON values from same key with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1633613328,
        "creation_date": 1633612769,
        "last_edit_date": 1633613328,
        "question_id": 69481933,
        "body_markdown": "I have the following JSON output:\r\n\r\n```\r\n$ system_profiler -json SPPCIDataType | jq -r &#39;.SPPCIDataType[]&#39;\r\n{\r\n  &quot;_name&quot;: &quot;Radeon RX 580&quot;,\r\n  &quot;sppci_bus&quot;: &quot;sppci_pci_device&quot;,\r\n  &quot;sppci_device_type&quot;: &quot;sppci_displaycontroller&quot;,\r\n  &quot;sppci_device-id&quot;: &quot;0x67df&quot;,\r\n  &quot;sppci_driver_installed&quot;: &quot;affirmative_string&quot;,\r\n  &quot;sppci_link-speed&quot;: &quot;5.0 GT/s&quot;,\r\n  &quot;sppci_link-width&quot;: &quot;x16&quot;,\r\n  &quot;sppci_msi&quot;: &quot;Yes&quot;,\r\n  &quot;sppci_name&quot;: &quot;ATY,AMD,RadeonFramebuffer&quot;,\r\n  &quot;sppci_revision-id&quot;: &quot;0x00e7&quot;,\r\n  &quot;sppci_slot_name&quot;: &quot;Slot-1&quot;,\r\n  &quot;sppci_subsystem-id&quot;: &quot;0xe353&quot;,\r\n  &quot;sppci_subsystem-vendor-id&quot;: &quot;0x1da2&quot;,\r\n  &quot;sppci_vendor-id&quot;: &quot;0x1002&quot;\r\n}\r\n{\r\n  &quot;_name&quot;: &quot;pci1002,aaf0&quot;,\r\n  &quot;sppci_bus&quot;: &quot;sppci_pci_device&quot;,\r\n  &quot;sppci_device_type&quot;: &quot;sppci_audiodevice&quot;,\r\n  &quot;sppci_device-id&quot;: &quot;0xaaf0&quot;,\r\n  &quot;sppci_driver_installed&quot;: &quot;affirmative_string&quot;,\r\n  &quot;sppci_link-speed&quot;: &quot;5.0 GT/s&quot;,\r\n  &quot;sppci_link-width&quot;: &quot;x16&quot;,\r\n  &quot;sppci_msi&quot;: &quot;Yes&quot;,\r\n  &quot;sppci_revision-id&quot;: &quot;0x0000&quot;,\r\n  &quot;sppci_slot_name&quot;: &quot;Slot-1&quot;,\r\n  &quot;sppci_subsystem-id&quot;: &quot;0xaaf0&quot;,\r\n  &quot;sppci_subsystem-vendor-id&quot;: &quot;0x1da2&quot;,\r\n  &quot;sppci_vendor-id&quot;: &quot;0x1002&quot;\r\n}\r\n{\r\n  &quot;_name&quot;: &quot;PXS3&quot;,\r\n  &quot;sppci_bus&quot;: &quot;sppci_pci_device&quot;,\r\n  &quot;sppci_device_type&quot;: &quot;sppci_usbxhci&quot;,\r\n  &quot;sppci_device-id&quot;: &quot;0x1242&quot;,\r\n  &quot;sppci_driver_installed&quot;: &quot;affirmative_string&quot;,\r\n  &quot;sppci_link-speed&quot;: &quot;5.0 GT/s&quot;,\r\n  &quot;sppci_link-width&quot;: &quot;x2&quot;,\r\n  &quot;sppci_msi&quot;: &quot;Yes&quot;,\r\n  &quot;sppci_revision-id&quot;: &quot;0x0000&quot;,\r\n  &quot;sppci_slot_name&quot;: &quot;Slot-3&quot;,\r\n  &quot;sppci_subsystem-id&quot;: &quot;0x7230&quot;,\r\n  &quot;sppci_subsystem-vendor-id&quot;: &quot;0x16b8&quot;,\r\n  &quot;sppci_vendor-id&quot;: &quot;0x1b21&quot;\r\n}\r\n{\r\n  &quot;_name&quot;: &quot;pci144d,a808&quot;,\r\n  &quot;sppci_bus&quot;: &quot;sppci_pci_device&quot;,\r\n  &quot;sppci_device_type&quot;: &quot;sppci_nvme&quot;,\r\n  &quot;sppci_device-id&quot;: &quot;0xa808&quot;,\r\n  &quot;sppci_driver_installed&quot;: &quot;affirmative_string&quot;,\r\n  &quot;sppci_link-speed&quot;: &quot;8.0 GT/s&quot;,\r\n  &quot;sppci_link-width&quot;: &quot;x4&quot;,\r\n  &quot;sppci_msi&quot;: &quot;Yes&quot;,\r\n  &quot;sppci_revision-id&quot;: &quot;0x0000&quot;,\r\n  &quot;sppci_slot_name&quot;: &quot;Slot-2@8,0,0&quot;,\r\n  &quot;sppci_subsystem-id&quot;: &quot;0xa801&quot;,\r\n  &quot;sppci_subsystem-vendor-id&quot;: &quot;0x144d&quot;,\r\n  &quot;sppci_vendor-id&quot;: &quot;0x144d&quot;\r\n}\r\n{\r\n  &quot;_name&quot;: &quot;pci144d,a808&quot;,\r\n  &quot;sppci_bus&quot;: &quot;sppci_pci_device&quot;,\r\n  &quot;sppci_device_type&quot;: &quot;sppci_nvme&quot;,\r\n  &quot;sppci_device-id&quot;: &quot;0xa808&quot;,\r\n  &quot;sppci_driver_installed&quot;: &quot;affirmative_string&quot;,\r\n  &quot;sppci_link-speed&quot;: &quot;8.0 GT/s&quot;,\r\n  &quot;sppci_link-width&quot;: &quot;x4&quot;,\r\n  &quot;sppci_msi&quot;: &quot;Yes&quot;,\r\n  &quot;sppci_revision-id&quot;: &quot;0x0000&quot;,\r\n  &quot;sppci_slot_name&quot;: &quot;Slot-2@9,0,0&quot;,\r\n  &quot;sppci_subsystem-id&quot;: &quot;0xa801&quot;,\r\n  &quot;sppci_subsystem-vendor-id&quot;: &quot;0x144d&quot;,\r\n  &quot;sppci_vendor-id&quot;: &quot;0x144d&quot;\r\n}\r\n```\r\n\r\nI&#39;m currently selecting the `_name` when `sppci_device_type` is equal to `sppci_nvme`:\r\n```\r\n$ system_profiler -json SPPCIDataType | jq -r &#39;.SPPCIDataType[] | select(.sppci_device_type == &quot;sppci_nvme&quot;)._name&#39;\r\npci144d,a808\r\npci144d,a808\r\n```\r\n\r\nWhat is the correct `select` statement for a key matching any one of multiple values? Something like:\r\n```\r\nselect(.sppci_device_type EQUAL TO (&quot;sppci_audiodevice&quot; OR &quot;sppci_nvme&quot;))._name\r\n```",
        "link": "https://stackoverflow.com/questions/69481933/select-multiple-json-values-from-same-key-with-jq",
        "title": "Select multiple JSON values from same key with jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1633628353,
                "last_edit_date": 1633628353,
                "creation_date": 1633626772,
                "answer_id": 69485249,
                "question_id": 69485161,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want the last unique item, simply `reverse` the array first\r\n\r\n    jq &#39;reverse | unique_by( {name} )&#39;\r\n\r\nAnd if you want to retain the original order, `reverse` back again afterwards\r\n\r\n    jq &#39;reverse | unique_by( {name} ) | reverse&#39;",
                "title": "How to get output with unique values but only with last instance of a duplicate key - unique_by"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1633628353,
        "creation_date": 1633626207,
        "last_edit_date": 1633626694,
        "question_id": 69485161,
        "body_markdown": "I am currently working with jq to parse through some json. I would like to retrieve unique values based on a certain key. I came across `unique_by`. It does just that of getting unique values for key `name` but I am still not getting my desired output. From my understanding, `unique_by` looks at key `name` value an uses the first instance and then removes the duplicates that follow in the final output. However, I would like to grab the last duplicate key `name` value and display that in the final output. \r\n\r\nBelow is an example of my desired output. Is it possible to do this with `unique_by` or what would be the best approach? \r\n\r\n`cat file.json`\r\n\r\nOriginal json:\r\n```\r\n[\r\n    {\r\n      &quot;name&quot;: &quot;app-fastly&quot;,\r\n      &quot;tag&quot;: &quot;20210825-95-448f024&quot;,\r\n      &quot;image&quot;: &quot;docker.io/repoxy/app-fastly:20210825-95-448f024&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;app-lovely&quot;,\r\n      &quot;tag&quot;: &quot;20211004-2101-b6a256c&quot;,\r\n      &quot;image&quot;: &quot;ghcr.io/repox/app-lovely:20211004-2101-b6a256c&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;app-lovely&quot;,\r\n      &quot;tag&quot;: &quot;20211007-6622-b3fooba&quot;,\r\n      &quot;image&quot;: &quot;ghcr.io/repoxy/app-lovely:20211007-6622-b3fooba&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;app-dogwood&quot;,\r\n      &quot;tag&quot;: &quot;20210325-36-2a349e9&quot;,\r\n      &quot;image&quot;: &quot;docker.io/repoxy/app-dogwood:20210325-36-2a349e9&quot;\r\n    }\r\n]\r\n```\r\n\r\nJq Command:\r\n```\r\ncat file.json | jq &#39;unique_by( {name} )&#39;\r\n```\r\n\r\nCurrent Output:\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;app-dogwood&quot;,\r\n    &quot;tag&quot;: &quot;20210325-36-2a349e9&quot;,\r\n    &quot;image&quot;: &quot;docker.io/repoxy/app-dogwood:20210325-36-2a349e9&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;app-fastly&quot;,\r\n    &quot;tag&quot;: &quot;20210825-95-448f024&quot;,\r\n    &quot;image&quot;: &quot;docker.io/repoxy/app-fastly:20210825-95-448f024&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;app-lovely&quot;,\r\n    &quot;tag&quot;: &quot;20211004-2101-b6a256c&quot;,\r\n    &quot;image&quot;: &quot;ghcr.io/repox/app-lovely:20211004-2101-b6a256c&quot;\r\n  }\r\n]\r\n```\r\n\r\nDesired Output:\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;app-dogwood&quot;,\r\n    &quot;tag&quot;: &quot;20210325-36-2a349e9&quot;,\r\n    &quot;image&quot;: &quot;docker.io/repoxy/app-dogwood:20210325-36-2a349e9&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;app-fastly&quot;,\r\n    &quot;tag&quot;: &quot;20210825-95-448f024&quot;,\r\n    &quot;image&quot;: &quot;docker.io/repoxy/app-fastly:20210825-95-448f024&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;app-lovely&quot;,\r\n    &quot;tag&quot;: &quot;20211007-6622-b3fooba&quot;,\r\n    &quot;image&quot;: &quot;ghcr.io/repoxy/app-lovely:20211007-6622-b3fooba&quot;\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/69485161/how-to-get-output-with-unique-values-but-only-with-last-instance-of-a-duplicate",
        "title": "How to get output with unique values but only with last instance of a duplicate key - unique_by"
    },
    {
        "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": 1633688963,
                "post_id": 69494382,
                "comment_id": 122832420,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1633689140,
                "post_id": 69494382,
                "comment_id": 122832487,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1633688861,
        "creation_date": 1633688861,
        "question_id": 69494382,
        "body_markdown": "I have json like this\r\n\r\n    {\r\n       &quot;Subject&quot;: {\r\n           &quot;Data&quot;: &quot;Value&quot;,\r\n           &quot;Charset&quot;: &quot;UTF-8&quot;\r\n       },\r\n       &quot;Body&quot;: {\r\n           &quot;Text&quot;: {\r\n               &quot;Data&quot;: &quot;Value&quot;,\r\n               &quot;Charset&quot;: &quot;UTF-8&quot;\r\n           },\r\n           &quot;Html&quot;: {\r\n               &quot;Data&quot;: &quot;Data example&quot;,\r\n               &quot;Charset&quot;: &quot;UTF-8&quot;\r\n           }\r\n       }\r\n    }\r\n\r\nAnd I need pass into this variables from bash script like this:\r\n\r\n    {\r\n       &quot;Subject&quot;: {\r\n           &quot;Data&quot;: &quot;Value $value1&quot;,\r\n           &quot;Charset&quot;: &quot;UTF-8&quot;\r\n       },\r\n       &quot;Body&quot;: {\r\n           &quot;Text&quot;: {\r\n               &quot;Data&quot;: &quot;Value $value2&quot;,\r\n               &quot;Charset&quot;: &quot;UTF-8&quot;\r\n           },\r\n           &quot;Html&quot;: {\r\n               &quot;Data&quot;: &quot;Data example&quot;,\r\n               &quot;Charset&quot;: &quot;UTF-8&quot;\r\n           }\r\n       }\r\n    }\r\n\r\nI tried with this:\r\n\r\n    jq -n --arg value1 test --arg value2 -f message.jq \r\nbut this ignore my $variables from message.jq, when I delete &quot;&quot; (quotes in message.jq close to $variable then working by json is destroyed I need quotes with variables.",
        "link": "https://stackoverflow.com/questions/69494382/how-to-pass-environment-bash-variables-into-json-using-jq",
        "title": "How to pass environment bash variables into json using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633695049,
                "post_id": 69495568,
                "comment_id": 122834674,
                "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": 1633695346,
                "post_id": 69495568,
                "comment_id": 122834794,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1633694960,
                "creation_date": 1633694960,
                "answer_id": 69495625,
                "question_id": 69495568,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You didn&#39;t lose precision, you just created more results.\r\n\r\nUse the update operator `|=` instead. In this case, you could even go with `/=`.\r\n\r\n    jq &#39;.entries[].timestamp /= 1000.0&#39; data.json\r\n\r\nTry it on [jqplay.org][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/81PPFCdDIk",
                "title": "jq: divide a decimal number but keep precision"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1633970076,
                "last_edit_date": 1633970076,
                "creation_date": 1633717079,
                "answer_id": 69500172,
                "question_id": 69495568,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The two `[]` conspired to create n^2 entries.\r\n\r\n```sh\r\njq &#39;.entries[].timestamp = .entries[].timestamp/1000.0&#39;   # BAD\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/lLDw6XAO2P)\r\n\r\n---\r\n\r\nExtract the common bits.\r\n\r\n```sh\r\njq &#39;.entries[] |= ( .timestamp = .timestamp/1000.0 )&#39;   # Good\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/Dcvn3qfuu-)\r\n\r\n---\r\n\r\nSimplified:\r\n\r\n```sh\r\njq &#39;.entries[] |= ( .timestamp /= 1000.0 )&#39;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/GG09nvQL7T)\r\n\r\n---\r\n\r\nSimplified:\r\n\r\n```sh\r\njq &#39;.entries[].timestamp /= 1000.0&#39;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/81PPFCdDIk)\r\n",
                "title": "jq: divide a decimal number but keep precision"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1633970076,
        "creation_date": 1633694674,
        "question_id": 69495568,
        "body_markdown": "I have some JSON data that looks like this:\r\n\r\n```json\r\n{\r\n  &quot;entries&quot;: [\r\n    {\r\n      &quot;frame&quot;: 1,\r\n      &quot;timestamp&quot;: 0,\r\n      &quot;r&quot;: 130,\r\n      &quot;g&quot;: 105,\r\n      &quot;b&quot;: 99\r\n    },\r\n    {\r\n      &quot;frame&quot;: 2,\r\n      &quot;timestamp&quot;: 99.96299999999974,\r\n      &quot;r&quot;: 129,\r\n      &quot;g&quot;: 105,\r\n      &quot;b&quot;: 99\r\n    },\r\n...\r\n}\r\n```\r\n\r\nI&#39;ve tried running `jq &#39;.entries[].timestamp = .entries[].timestamp/1000.0&#39; data.json` but the outcome has lost precision on the values. I&#39;m getting:\r\n\r\n```json\r\n{\r\n  &quot;entries&quot;: [\r\n    {\r\n      &quot;frame&quot;: 1,\r\n      &quot;timestamp&quot;: 0,\r\n      &quot;r&quot;: 130,\r\n      &quot;g&quot;: 105,\r\n      &quot;b&quot;: 99\r\n    },\r\n    {\r\n      &quot;frame&quot;: 2,\r\n      &quot;timestamp&quot;: 0,\r\n      &quot;r&quot;: 129,\r\n      &quot;g&quot;: 105,\r\n      &quot;b&quot;: 99\r\n    },\r\n...\r\n}\r\n```\r\n\r\nHave I missed something obvious here? Is there a different way to do this?",
        "link": "https://stackoverflow.com/questions/69495568/jq-divide-a-decimal-number-but-keep-precision",
        "title": "jq: divide a decimal number but keep precision"
    },
    {
        "tags": [
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1633836370,
                "creation_date": 1633836370,
                "answer_id": 69512054,
                "question_id": 69499499,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In your `text` value, there is no mention of the command `echo ...`, you may use a subshell to evaluate the result. Also, you can use single quote for `--data` instead of double quote to avoid escaping:\r\n\r\n```bash\r\ncurl -vvv -X POST \\\r\n    -H &quot;Content-type: application/json&quot; \\\r\n    --data &#39;{&quot;text&quot;:&quot;&#39;&quot;$(echo $job_message | jq -r &#39;.[0].status&#39;)&quot;&#39;&quot;}&#39; \\\r\n    &quot;https://hooks.slack.com/services/xxxxx&quot;\r\n```\r\n\r\nAlso you can use `jq -n` to build the JSON object:\r\n\r\n```bash\r\ncurl -vvv -H &quot;Content-type: application/json&quot; \\\r\n    -d &quot;$(jq -n --arg text $job_message &#39;{&quot;text&quot;: ($text | fromjson)[0].status}&#39;)&quot; \\\r\n    &quot;https://hooks.slack.com/services/xxxxx&quot;\r\n```\r\nYou can also pipe `jq` command output to the body like [this](https://stackoverflow.com/a/25049637/2614364) and use `jq` only to build the json object:\r\n\r\n```bash\r\njq -n --arg text $job_message &#39;{&quot;text&quot;: ($text | fromjson)[0].status}&#39; | \\\r\n   curl -vvv -H &quot;Content-Type: application/json&quot; -d @- &quot;https://hooks.slack.com/services/xxxxx&quot;\r\n```",
                "title": "jq command gives invalid payload with curl"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1633837048,
        "creation_date": 1633713018,
        "last_edit_date": 1633837048,
        "question_id": 69499499,
        "body_markdown": "I have a JSON list and I am trying to POST a particular key: value from the list to the slack webhook using curl. I am using jq to get the value for a specific key\r\n\r\nThis works fine:\r\n```bash\r\necho {{job.message}} | jq -r &#39;.[0] | .status&#39;\r\n```\r\n\r\nThis does not work:\r\n```bash\r\ncurl -vvv -X POST -H &quot;Content-type: application/json&quot; --data \\&quot;{\\&quot;text\\&quot;:\\&quot;{{job.message}} | jq -r &#39;&#39;.[0] | .status&#39;&#39;\\&quot;}\\&quot; https://hooks.slack.com/services/xxxxx\r\n```\r\n\r\n`job.message` is a variable with json list\r\n\r\nWhen I output the result using echo in shell, it works fine but when I use curl it show invalid payload or .key not found even though the key is present. ",
        "link": "https://stackoverflow.com/questions/69499499/jq-command-gives-invalid-payload-with-curl",
        "title": "jq command gives invalid payload with curl"
    },
    {
        "tags": [
            "json",
            "linux",
            "parsing",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1633714837,
                "creation_date": 1633714837,
                "answer_id": 69499798,
                "question_id": 69499767,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `jq -f json2csv` instead.\r\n\r\nFrom `man jq`:\r\n\r\n&gt; -Ldirectory / -L directory:\r\n&gt;\r\n&gt; Prepend directory to the search list for modules. If this option is used then no builtin search list is used. See the  section  on  modules\r\n           below.\r\n\r\nCompare this to:\r\n\r\n&gt; -f filename / --from-file filename:\r\n&gt;\r\n&gt;Read filter from the file rather than from a command line, like awk&#180;s -f option. You can also use # to make comments.",
                "title": "jq script file not getting the key/value pair"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1633714837,
        "creation_date": 1633714626,
        "question_id": 69499767,
        "body_markdown": "I would like to put all jq filters inside a text file and use the `jq -L` option to execute the filters. However, I can&#39;t get this simple thing working.\r\n\r\nInside my `sample2.json` file, I have:\r\n\r\n    {\r\n            &quot;a&quot;: 86,\r\n            &quot;b&quot;: 99\r\n    }\r\n\r\n[![enter image description here][1]][1]\r\n\r\nInside my `json2csv` file, I have:\r\n\r\n    .[&quot;a&quot;]\r\n\r\n\r\n[![enter image description here][2]][2]\r\n\r\nWhen I do:\r\n\r\n    cat sample.json | jq -L json2csv\r\n\r\nThe output is the whole sample.json file, like this:\r\n\r\n[![enter image description here][3]][3]\r\n\r\nbut I would expect the output is only `86`because:\r\n\r\n[![enter image description here][4]][4]\r\n\r\n\r\nHow do I change the content of the `json2csv` file so I can only get the `86` in the output?\r\nI am using jq 1.6. Thanks!\r\n\r\n  [1]: https://i.sstatic.net/mFubc.png\r\n  [2]: https://i.sstatic.net/SmbvW.png\r\n  [3]: https://i.sstatic.net/gPH62.png\r\n  [4]: https://i.sstatic.net/p38MZ.png",
        "link": "https://stackoverflow.com/questions/69499767/jq-script-file-not-getting-the-key-value-pair",
        "title": "jq script file not getting the key/value pair"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633724310,
                "post_id": 69500591,
                "comment_id": 122845411,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1633720155,
                "creation_date": 1633720155,
                "answer_id": 69500713,
                "question_id": 69500591,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One option is creating an object with only k0-0 pair and adding the input to it like so:\r\n```\r\n{k0: 0} + .\r\n```",
                "title": "How to insert on top in JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1633747445,
        "creation_date": 1633719476,
        "last_edit_date": 1633747445,
        "question_id": 69500591,
        "body_markdown": "This can let me insert a key/value pair to a json, but how do I insert the `&quot;k0&quot;: 0` before the `&quot;k1&quot;: 1`?\r\n\r\n[![enter image description here][1]][1]\r\n\r\nI would like the result to be:\r\n\r\n        {\r\n            &quot;k0&quot;: 0,\r\n            &quot;k1&quot;: 1\r\n        }\r\n\r\nThank you!\r\n\r\n\r\n  [1]: https://i.sstatic.net/DSoY4.png",
        "link": "https://stackoverflow.com/questions/69500591/how-to-insert-on-top-in-jq",
        "title": "How to insert on top in JQ?"
    },
    {
        "tags": [
            "powershell",
            "jq",
            "oracle-cloud-infrastructure"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 19375,
                    "reputation": 447959,
                    "user_id": 45375,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/39f6e2dc52425b1e08027c01bb880be0?s=256&d=identicon&r=PG",
                    "display_name": "mklement0",
                    "link": "https://stackoverflow.com/users/45375/mklement0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1633791281,
                "post_id": 69505903,
                "comment_id": 122857030,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1633802482,
                "last_edit_date": 1633802482,
                "creation_date": 1633778240,
                "answer_id": 69506227,
                "question_id": 69505903,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Double quotes inside single quotes need to be escaped :\r\n\r\n```\r\nPS C:\\myfiles&gt; oci compute instance list-vnics --all --compartment-id xxxxx  --profile myprof |C:\\myfiles\\jq-win64.exe &#39;.data[]|select(.\\&quot;hostname-label\\&quot;==\\&quot;test1\\&quot;)&#39;\r\n```\r\n\r\nIf you have variable, pass it as argument :\r\n\r\n```\r\nPS C:\\myfiles&gt; oci compute instance list-vnics --all --compartment-id xxxxx  --profile myprof |C:\\myfiles\\jq-win64.exe --arg host_name $host_name &#39;.data[]|select(.\\&quot;hostname-label\\&quot;==$host_name)&#39;\r\n```\r\n",
                "title": "Jq - Syntax error when ran on windows powershell however on bash terminal it was successful"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1633809991,
        "creation_date": 1633775432,
        "last_edit_date": 1633809991,
        "question_id": 69505903,
        "body_markdown": "I was trying to parse an OCI JSON output using JQ and getting syntax error in Windows powershell however the same command is working fine in Bash terminal.\r\nPleae let me know if i miss anything.\r\n\r\n    PS C:\\myfiles&gt; oci compute instance list-vnics --all --compartment-id xxxxxx  --profile myprof |C:\\myfiles\\jq-win64.exe &quot;.data[]|select(.&quot;hostname-label&quot;==&quot;test1&quot; )&quot;\r\n\r\n`jq: error: syntax error, unexpected $end, expecting &#39;;&#39; or &#39;)&#39; (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.data[]|select(.\r\njq: 1 compile error\r\nPS C:myfiles&gt;`\r\n\r\n\r\nTried with the JQ statement in single quotes, its giving below syntax error:\r\n\r\n    PS C:\\myfiles&gt; oci compute instance list-vnics --all --compartment-id xxxxx  --profile myprof |C:\\myfiles\\jq-win64.exe &#39;.data[]|select(.&quot;hostname-label&quot;==&quot;test1&quot; )&#39;\r\n`jq: error: syntax error, unexpected ==, expecting &#39;$&#39; (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.data[]|select(.hostname-label==test1 )\r\njq: 1 compile error\r\nPS C:\\MYDATA\\myfiles&gt;`\r\n\r\nI tried the same in jplay.org and it was working fine there as well. Please let me know how to fix this in Windows.\r\n\r\nThanks\r\n\r\n ",
        "link": "https://stackoverflow.com/questions/69505903/jq-syntax-error-when-ran-on-windows-powershell-however-on-bash-terminal-it-was",
        "title": "Jq - Syntax error when ran on windows powershell however on bash terminal it was successful"
    },
    {
        "tags": [
            "json",
            "linux",
            "unix",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1633805429,
                "last_edit_date": 1633805429,
                "creation_date": 1633801603,
                "answer_id": 69509203,
                "question_id": 69509122,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Read in both files as variables using `--argfile`, then `map` both to just their `Car ID`, then subtract the first array from the second resulting in an array of `Car ID`s you want to keep, and finally use the keys to `select` the right elements from the second input file.\r\n\r\n```\r\njq -n \\\r\n  --argfile file1 file1.json \\\r\n  --argfile file2 file2.json \\\r\n  &#39;\r\n    # Take both input files and create an array $ids with all\r\n    # Car IDs from the second file that are not part of the first one\r\n    [ $file1, $file2 ]\r\n    | map(.[&quot;User Data&quot;] | map(.[&quot;Car ID&quot;]))\r\n    | (.[1] - .[0]) as $ids\r\n    \r\n    # Take the second input file and select only those entries\r\n    # whose Car ID is part of the previously stored array of Car IDs\r\n    | $file2\r\n    | .[&quot;User Data&quot;] |= map(select(.[&quot;Car ID&quot;] == $ids[]))\r\n  &#39;\r\n```",
                "title": "jq compare 2 json files and delete duplicate objects by key value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1633805429,
        "creation_date": 1633800817,
        "question_id": 69509122,
        "body_markdown": "I have 2 json files that I wish to compare with each other and end up with a file that has just the unique objects from the second file. A unique object is not determined by the full object but rather by the value of one key within it called `Car ID`. Below are a sample of the json files to explain this better:\r\n\r\nfile1.json:\r\n\r\n    {\r\n    &quot;User Data&quot;: [\r\n    {&quot;First Name&quot;: &quot;Tony&quot;, &quot;Last Name&quot;: &quot;Evans&quot;, &quot;DOB&quot;: &quot;1987-02-01&quot;, &quot;Car ID&quot;: &quot;UJ928JD9&quot;},\r\n    {&quot;First Name&quot;: &quot;John&quot;, &quot;Last Name&quot;: &quot;Smith&quot;, &quot;DOB&quot;: &quot;1972-11-27&quot;, &quot;Car ID&quot;: &quot;UJ235UW8&quot;},\r\n    {&quot;First Name&quot;: &quot;Kirsty&quot;, &quot;Last Name&quot;: &quot;Morgan&quot;, &quot;DOB&quot;: &quot;1991-06-08&quot;, &quot;Car ID&quot;: &quot;UJ424KL2&quot;},\r\n    ...\r\n    ]\r\n    }\r\n\r\nfile2.json\r\n\r\n    {\r\n    &quot;User Data&quot;: [\r\n    {&quot;First Name&quot;: &quot;Harry&quot;, &quot;Last Name&quot;: &quot;Jones&quot;, &quot;DOB&quot;: &quot;1983-03-09&quot;, &quot;Car ID&quot;: &quot;UJ928JD9&quot;},\r\n    {&quot;First Name&quot;: &quot;Jeremy&quot;, &quot;Last Name&quot;: &quot;Blake&quot;, &quot;DOB&quot;: &quot;1965-09-21&quot;, &quot;Car ID&quot;: &quot;UJ345IE2&quot;},\r\n    {&quot;First Name&quot;: &quot;Jason&quot;, &quot;Last Name&quot;: &quot;Roberts&quot;, &quot;DOB&quot;: &quot;1972-10-18&quot;, &quot;Car ID&quot;: &quot;UJ424KL2&quot;},\r\n    ...\r\n    ]\r\n    }\r\n\r\nIn the sample above, the Car ID is the same for 2 lines so only the second object from the second file should remain, as so:\r\n\r\n    {\r\n        &quot;User Data&quot;: [\r\n        {&quot;First Name&quot;: &quot;Jeremy&quot;, &quot;Last Name&quot;: &quot;Blake&quot;, &quot;DOB&quot;: &quot;1965-09-21&quot;, &quot;Car ID&quot;: &quot;UJ345IE2&quot;}\r\n        ]\r\n        }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69509122/jq-compare-2-json-files-and-delete-duplicate-objects-by-key-value",
        "title": "jq compare 2 json files and delete duplicate objects by key value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10795251,
                    "reputation": 5508,
                    "user_id": 7941251,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/4nchL.jpg?s=256",
                    "display_name": "SuperStormer",
                    "link": "https://stackoverflow.com/users/7941251/superstormer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633900537,
                "post_id": 69519035,
                "comment_id": 122877249,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1633958754,
                "last_edit_date": 1633958754,
                "creation_date": 1633904493,
                "answer_id": 69519395,
                "question_id": 69519035,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The article you are referring to has several examples of what you can do once you have the JSON in a local file.  If you want to avoid creating an intermediate file, you could pipe the JSON from the `curl` command directly to jq, e.g. along the lines of:\r\n\r\n    curl ... | jq -fr myprogram.jq\r\n\r\nHowever, in practice, blindly piping the output of curl in this way sometimes results in unexpected failures, notably as happens when the actual output produced by curl (on stdout) includes some kind of header non-JSON header.  If such extra information cannot be avoided, then it can usually be removed by adding a text-processing command such as `sed` to the pipeline, e.g. along the lines of:\r\n\r\n    curl ... | sed 1,2d | jq -fr myprogram.jq\r\n\r\n",
                "title": "In article &quot;How to convert arbitrary simple JSON to CSV using jq?&quot; , what would be the jq command to accomplish this?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1633958754,
        "creation_date": 1633900394,
        "last_edit_date": 1633900595,
        "question_id": 69519035,
        "body_markdown": "My json file is basically the same as this except it&#39;s all on one line. My goal is to obtain a .csv file like the possible output listed below. I obtain the json file with a curl command, would I put the jq command to obtain the .csv output and the end of the curl command? I would appreciate any guidance.  \r\n\r\n    Input:\r\n\r\n    [\r\n        {&quot;code&quot;: &quot;NSW&quot;, &quot;name&quot;: &quot;New South Wales&quot;, &quot;level&quot;:&quot;state&quot;, &quot;country&quot;: &quot;AU&quot;},\r\n        {&quot;code&quot;: &quot;AB&quot;, &quot;name&quot;: &quot;Alberta&quot;, &quot;level&quot;:&quot;province&quot;, &quot;country&quot;: &quot;CA&quot;},\r\n        {&quot;code&quot;: &quot;ABD&quot;, &quot;name&quot;: &quot;Aberdeenshire&quot;, &quot;level&quot;:&quot;council area&quot;, &quot;country&quot;: &quot;GB&quot;},\r\n        {&quot;code&quot;: &quot;AK&quot;, &quot;name&quot;: &quot;Alaska&quot;, &quot;level&quot;:&quot;state&quot;, &quot;country&quot;: &quot;US&quot;}\r\n    ]\r\n\r\n    Possible output:\r\n\r\n    code,name,level,country\r\n    NSW,New South Wales,state,AU\r\n    AB,Alberta,province,CA\r\n    ABD,Aberdeenshire,council area,GB\r\n    AK,Alaska,state,US\r\n",
        "link": "https://stackoverflow.com/questions/69519035/in-article-how-to-convert-arbitrary-simple-json-to-csv-using-jq-what-would",
        "title": "In article &quot;How to convert arbitrary simple JSON to CSV using jq?&quot; , what would be the jq command to accomplish this?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1633916137,
                "last_edit_date": 1633916137,
                "creation_date": 1633911428,
                "answer_id": 69519875,
                "question_id": 69519816,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Before piping your TSV file into `jq` you should extract the JSON column first. For instance, use `cut` from GNU coreutils to get the second field in a tab-separated line:\r\n\r\n```bash\r\ncut -f2 &lt;&lt;&lt; $&#39;A\\t{&quot;a&quot;: 1}&#39;$&#39;\\nB\\t{&quot;a&quot;: 2}&#39; | jq --slurp &#39;.[] | .a&#39;\r\n```\r\n\r\nIn order to print the other columns as well, you may use `paste` to put the columns back together:\r\n\r\n```bash\r\npaste &lt;(\r\n  cut -f1 &lt;&lt;&lt; $&#39;A\\t{&quot;a&quot;: 1}&#39;$&#39;\\nB\\t{&quot;a&quot;: 2}&#39;\r\n) &lt;(\r\n  cut -f2 &lt;&lt;&lt; $&#39;A\\t{&quot;a&quot;: 1}&#39;$&#39;\\nB\\t{&quot;a&quot;: 2}&#39; | jq --slurp &#39;.[] | .a&#39;\r\n)\r\n```\r\n\r\nTo solve this entirely in `jq` you have to read it as non-JSON first and interpret the second column as JSON using jq&#39;s `fromjson`\r\n\r\n    jq -Rr &#39;./&quot;\\t&quot; | .[1] |= (fromjson | .a) | @tsv&#39; &lt;&lt;&lt; $&#39;A\\t{&quot;a&quot;: 1}&#39;$&#39;\\nB\\t{&quot;a&quot;: 2}&#39;",
                "title": "processing TSV embedded with JSON using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1633918411,
                "last_edit_date": 1633918411,
                "creation_date": 1633915765,
                "answer_id": 69520166,
                "question_id": 69519816,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```bash\r\njq --raw-input --raw-output --slurp &#39;split(&quot;\\n&quot;) | map(split(&quot;\\t&quot;)) | map(select(length&gt;0)) | .[] | {&quot;p&quot;:.[0], &quot;j&quot;:.[1] | fromjson} | [.p, .j.a] | @tsv&#39; &lt;&lt;&lt; $&#39;A\\t{&quot;a&quot;: 1}&#39;$&#39;\\nB\\t{&quot;a&quot;: 2}&#39;\r\n\r\nA\t1\r\nB\t2\r\n```\r\nor process line by line for huge data\r\n```bash\r\ncat ./data.txt | while read line;\r\ndo\r\n    echo &quot;$line&quot; | jq --raw-input --raw-output --slurp &#39;split(&quot;\\t&quot;) | {&quot;p&quot;:.[0], &quot;j&quot;:.[1] | fromjson} | [.p, .j.a] | @tsv&#39;\r\ndone\r\n```",
                "title": "processing TSV embedded with JSON using jq?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1633918411,
        "creation_date": 1633910551,
        "question_id": 69519816,
        "body_markdown": "```\r\n$ jq --slurp &#39;.[] | .a&#39; &lt;&lt;&lt; &#39;{&quot;a&quot;: 1}&#39;$&#39;\\n&#39;&#39;{&quot;a&quot;: 2}&#39;\r\n1\r\n2\r\n```\r\n\r\nI can process a one-column TSV file like above. When there are multiple columns and one column is JSON, how to print the processing result of the JSON column alone with other columns literally? In the following example, how to print the first column and the JSON processing result of the 2nd column?\r\n\r\n```\r\n$ jq --slurp &#39;.[] | .a&#39; &lt;&lt;&lt; $&#39;A\\t{&quot;a&quot;: 1}&#39;$&#39;\\nB\\t{&quot;a&quot;: 2}&#39;\r\nparse error: Invalid numeric literal at line 1, column 2\r\n```",
        "link": "https://stackoverflow.com/questions/69519816/processing-tsv-embedded-with-json-using-jq",
        "title": "processing TSV embedded with JSON using jq?"
    },
    {
        "tags": [
            "json",
            "jq",
            "export-to-csv"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1633919973,
                "creation_date": 1633919973,
                "answer_id": 69520454,
                "question_id": 69520350,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try\r\n\r\n    jq -r &#39;\r\n      \r\n      # Headers\r\n      [&quot;STK_NUM&quot;, &quot;DLR_COST&quot;, &quot;RTL_AMT&quot;],\r\n      \r\n      # Rows\r\n      (.[] | [.STK_NUM, .DLR_COST, .RTL_AMT])\r\n      \r\n      # Output Format\r\n      | @csv\r\n      \r\n    &#39; HSEitm.json",
                "title": "How to extract json data and output to csv using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1633923345,
                "creation_date": 1633923345,
                "answer_id": 69520759,
                "question_id": 69520350,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the spirit of DRY:\r\n```\r\njq -r &#39;\r\n  [&quot;STK_NUM&quot;, &quot;DLR_COST&quot;, &quot;RTL_AMT&quot;] as $headers\r\n  | $headers, \r\n    # Rows:\r\n    map(.[$headers[]]) \r\n  | @csv\r\n&#39;\r\n```",
                "title": "How to extract json data and output to csv using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1633923345,
        "creation_date": 1633918401,
        "last_edit_date": 1633922815,
        "question_id": 69520350,
        "body_markdown": "My json array file is one long file and has many objects [{},{},{},{}], within each object I need the value for three keys: &quot;STK_NUM&quot;:&quot;1004251 &quot;, &quot;DLR_COST&quot;:40.32 , &quot;RTL_AMT&quot;:9.99. How would I write the jq program to get the key names as headers in my csv file: STK_NUM, DLR_COST,RTL_AMT and the values of these keys from all objects: 1004251,40.32,9.99 ? These three keys are in every object.\r\n\r\nDesired csv:\r\n```\r\nSTK_NUM,DLR_COST,RTL_AMT\r\n1004251,40.32,9.99\r\n1012658,29.99,4.69\r\n1232556,18.89,2.49\r\n```\r\nI&#39;ve tried:\r\n```\r\njq -r .[].STK_NUM HSEitm.json\r\n```\r\nresult:\r\n```\r\n&quot;1004251&quot;\r\n&quot;1012658&quot;\r\n&quot;1232556&quot;\r\n```\r\nAll my other jq script attempts result in errors because I don&#39;t know what I&#39;m doing.\r\n\r\nIf anyone could show me I would be very grateful.\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69520350/how-to-extract-json-data-and-output-to-csv-using-jq",
        "title": "How to extract json data and output to csv using jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1633983199,
                "last_edit_date": 1633983199,
                "creation_date": 1633982482,
                "answer_id": 69531857,
                "question_id": 69531760,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One solution is to store the parent object while selecting on the child array:\r\n\r\n```bash\r\njq &#39;.connections[] | . as $parent | .emailAddresses // empty | .[] | select(.value == &quot;mail@mail1.com&quot;) | $parent.resourceName&#39; file.json\r\n```",
                "title": "need to extract specific string with JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1633983582,
                "creation_date": 1633983582,
                "answer_id": 69532054,
                "question_id": 69531760,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`emailAddresses` is an array. Use `any` if finding one element that matches will suffice.\r\n\r\n    .connections[] | select(any(.emailAddresses[];.value == &quot;mail@mail1.com&quot;)).resourceName",
                "title": "need to extract specific string with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1633983582,
        "creation_date": 1633981939,
        "question_id": 69531760,
        "body_markdown": "I have a JSON file (see below) and with JQ I need to extract the **resourceName** value for value = **mail@mail1.com**\r\n\r\nSo in my case, the result should be **name_1**\r\n\r\nAny idea to do that ?\r\nBecause this does not work : \r\n\r\n**jq &#39;.connections[] | select(.emailAddresses.value | test(&quot;mail@mail1.com&quot;; &quot;i&quot;)) | .resourceName&#39; file.json**\r\n\r\n    {\r\n      &quot;connections&quot;: [\r\n        {\r\n          &quot;resourceName&quot;: &quot;name_1&quot;,\r\n          &quot;etag&quot;: &quot;123456789&quot;,\r\n          &quot;emailAddresses&quot;: [\r\n            {\r\n              &quot;metadata&quot;: {\r\n                &quot;primary&quot;: true,\r\n                &quot;source&quot;: {\r\n                  &quot;type&quot;: &quot;CONTACT&quot;,\r\n                  &quot;id&quot;: &quot;123456&quot;\r\n                }\r\n              },\r\n              &quot;value&quot;: &quot;mail@mail1.com&quot;,\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;resourceName&quot;: &quot;name_2&quot;,\r\n          &quot;etag&quot;: &quot;987654321&quot;,\r\n          &quot;emailAddresses&quot;: [\r\n            {\r\n              &quot;metadata&quot;: {\r\n                &quot;primary&quot;: true,\r\n                &quot;source&quot;: {\r\n                  &quot;type&quot;: &quot;CONTACT&quot;,\r\n                  &quot;id&quot;: &quot;654321&quot;\r\n                },\r\n                &quot;sourcePrimary&quot;: true\r\n              },\r\n              &quot;value&quot;: &quot;mail@mail2.com&quot;\r\n            }\r\n          ]\r\n        }\r\n      ],\r\n      &quot;totalPeople&quot;: 187,\r\n      &quot;totalItems&quot;: 187\r\n    }",
        "link": "https://stackoverflow.com/questions/69531760/need-to-extract-specific-string-with-jq",
        "title": "need to extract specific string with JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1633985029,
                "creation_date": 1633985029,
                "answer_id": 69532306,
                "question_id": 69532143,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After some trial and error, I came up with:\r\n```\r\n$ cat j.json | jq &#39;to_entries | map({(.key): (.value | tostring[:20] + &quot; ...&quot;)})&#39; | jq -s &#39;.[] | add&#39;\r\n{\r\n  &quot;a&quot;: &quot;shortval&quot;,\r\n  &quot;b&quot;: &quot;4213&quot;,\r\n  &quot;c&quot;: &quot;23154646789132456&quot;,\r\n  &quot;d&quot;: &quot;a very long string t&quot;,\r\n  &quot;e&quot;: &quot;{\\&quot;x\\&quot;:\\&quot;some value\\&quot;,\\&quot;y&quot;\r\n}\r\n```\r\n\r\nWhich is what I want. This seems a bit inelegant, especially having to do the `-s` call, but it&#39;s good enough for what I&#39;m doing. I&#39;ll leave the question unanswered in case someone has a better solution.",
                "title": "How to abbreviate/truncate the value of every key?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1633988057,
                "last_edit_date": 1633988057,
                "creation_date": 1633985485,
                "answer_id": 69532365,
                "question_id": 69532143,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the simplest case, we convert each item using `tostring` and check the string&#39;s `length`\r\n\r\n```\r\n$ jq --argjson n 10 &#39;.[] |= (\r\n  tostring | if length &gt; $n then .[:$n] + &quot;...&quot; else . end\r\n)&#39; j.json\r\n{\r\n  &quot;a&quot;: &quot;hi&quot;,\r\n  &quot;b&quot;: &quot;4213&quot;,\r\n  &quot;c&quot;: &quot;2315464678...&quot;,\r\n  &quot;d&quot;: &quot;a very lon...&quot;,\r\n  &quot;e&quot;: &quot;{\\&quot;x\\&quot;:\\&quot;some...&quot;\r\n}\r\n```\r\n\r\nTo prevent the numbers from being converted to strings, we can wrap the simple case with another `if` condition checking the item&#39;s `type`\r\n\r\n```\r\n$ jq --argjson n 10 &#39;.[] |= (\r\n  if type == &quot;number&quot; then . else\r\n    tostring | if length &gt; $n then .[:$n] + &quot;...&quot; else . end\r\n  end\r\n)&#39; j.json\r\n{\r\n  &quot;a&quot;: &quot;hi&quot;,\r\n  &quot;b&quot;: 4213,\r\n  &quot;c&quot;: 23154646789132456,\r\n  &quot;d&quot;: &quot;a very lon...&quot;,\r\n  &quot;e&quot;: &quot;{\\&quot;x\\&quot;:\\&quot;some...&quot;\r\n}\r\n```\r\n\r\nFinally, if we want to keep the numbers as numbers if and only if their string representation matches the length criteria, we serialize both conditions with both applying `tostring` once for conversion and once for testing:\r\n\r\n```\r\n$ jq --argjson n 10 &#39;.[] |= (\r\n  if type == &quot;number&quot; then . else tostring end\r\n  | if tostring | length &gt; $n then tostring | .[:$n] + &quot;...&quot; else . end\r\n)&#39; j.json\r\n{\r\n  &quot;a&quot;: &quot;hi&quot;,\r\n  &quot;b&quot;: 4213,\r\n  &quot;c&quot;: &quot;2315464678...&quot;,\r\n  &quot;d&quot;: &quot;a very lon...&quot;,\r\n  &quot;e&quot;: &quot;{\\&quot;x\\&quot;:\\&quot;some...&quot;\r\n}\r\n```\r\n\r\n\r\n\r\n",
                "title": "How to abbreviate/truncate the value of every key?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1634062678,
        "creation_date": 1633984107,
        "last_edit_date": 1634062678,
        "question_id": 69532143,
        "body_markdown": "I have a JSON like:\r\n```json\r\n{\r\n  &quot;a&quot;: &quot;hi&quot;,\r\n  &quot;b&quot;: 4213,\r\n  &quot;c&quot;: 23154646789132456,\r\n  &quot;d&quot;: &quot;a very long string that should be shortened&quot;,\r\n  &quot;e&quot;: {\r\n    &quot;x&quot;: &quot;some value&quot;,\r\n    &quot;y&quot;: {\r\n      &quot;alpha&quot;: &quot;foo&quot;\r\n    }\r\n  }\r\n}\r\n```\r\nI would like to use jq to &quot;abbreviate&quot; values longer than `n` characters. Each value should be converted to a string `s`, and if the result is longer than `n`, it should be replaced with `s[:n] + &quot; ...&quot;`. If the string is not too long, it should ideally be left as the original value. I expect a result like:\r\n```json\r\n# n=5\r\n{\r\n  &quot;a&quot;: &quot;hi&quot;,\r\n  &quot;b&quot;: 4213,  # &quot;4213&quot; would be acceptable too, but not preferable\r\n  &quot;c&quot;: &quot;23154 ...&quot;,\r\n  &quot;d&quot; : &quot;a ver ...,\r\n  &quot;e&quot; : &quot;{\\n\\&quot;x\\&quot; ...&quot;  # I don&#39;t care how whitespace is handled\r\n}\r\n# yes, I know there&#39;s no comments in JSON :)\r\n```\r\n\r\nThe idea is to have something like &quot;folding&quot; when looking at complex objects, so that I can get an overview of what top level keys are there, and then decide which key I want to &quot;zoom in&quot; to (eg `jq &#39;.e&#39;`).\r\n\r\nIn Python I could do something like:\r\n```\r\nj = load_my_json()\r\nfor k in j:\r\n    s = str(j[k])\r\n    if len(s) &gt; n:\r\n       j[k] = f&quot;{s[:10]}...&quot;\r\n```\r\n\r\nBut how can I do it in jq?",
        "link": "https://stackoverflow.com/questions/69532143/how-to-abbreviate-truncate-the-value-of-every-key",
        "title": "How to abbreviate/truncate the value of every key?"
    },
    {
        "tags": [
            "json",
            "linux",
            "shell",
            "unix",
            "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": 1633992031,
                "post_id": 69533089,
                "comment_id": 122902554,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20376551,
                    "reputation": 21,
                    "user_id": 14947583,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1e6b2455b5fa803371998811189f1696?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sammy",
                    "link": "https://stackoverflow.com/users/14947583/sammy"
                },
                "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": 1634025024,
                "post_id": 69533089,
                "comment_id": 122908884,
                "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": 1634129410,
                "post_id": 69533089,
                "comment_id": 122942755,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20376551,
                    "reputation": 21,
                    "user_id": 14947583,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1e6b2455b5fa803371998811189f1696?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sammy",
                    "link": "https://stackoverflow.com/users/14947583/sammy"
                },
                "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": 1634136955,
                "post_id": 69533089,
                "comment_id": 122946276,
                "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": 1634137274,
                "post_id": 69533089,
                "comment_id": 122946425,
                "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": 1634137336,
                "post_id": 69533089,
                "comment_id": 122946455,
                "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": 1634137449,
                "post_id": 69533089,
                "comment_id": 122946515,
                "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": 1634139271,
                "post_id": 69533089,
                "comment_id": 122947263,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1635239219,
                "creation_date": 1635239219,
                "answer_id": 69720315,
                "question_id": 69533089,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a two step solution.\r\n\r\n1. transform the input into an easy-to-use &quot;dictionary&quot;\r\n2. look up user ids in the new object using the last 4 chars of .id in .data\r\n\r\nTransform the user list input.\r\n\r\n```\r\n$ jq -Rs -f users.jq &lt; users.txt | tee  users.json \r\n{\r\n  &quot;eeee&quot;: &quot;5&quot;,\r\n  &quot;sdfg&quot;: &quot;44&quot;,\r\n  &quot;dfg2&quot;: &quot;66&quot;,\r\n  &quot;3dfg&quot;: &quot;12&quot;,\r\n  &quot;t4tl&quot;: &quot;69&quot;,\r\n  &quot;aaaa&quot;: &quot;1&quot;,\r\n  &quot;bbbb&quot;: &quot;2&quot;,\r\n  &quot;cccc&quot;: &quot;3&quot;,\r\n  &quot;dddd&quot;: &quot;4&quot;\r\n}\r\n```\r\n\r\ndatabase.json (input)\r\n\r\n```\r\n{ &quot;data&quot;: [\r\n        { &quot;id&quot;: &quot;dkfjgh48sdfg&quot;, &quot;abc&quot;: &quot;sdfdsf&quot;, &quot;pqr&quot;: &quot;sdkfj&quot; },\r\n        { &quot;id&quot;: &quot;sdfg742sdfg2&quot;, &quot;abc&quot;: &quot;aksjdfj&quot;, &quot;pqr&quot;: &quot;alkejf&quot; },\r\n        { &quot;id&quot;: &quot;sdfjk7df3dfg&quot;, &quot;abc&quot;: &quot;smdfb&quot;, &quot;pqr&quot;: &quot;sdjkfhakj&quot; },\r\n        { &quot;id&quot;: &quot;xxxxxxxxxxxx&quot;, &quot;abc&quot;: &quot;smdfb&quot;, &quot;pqr&quot;: &quot;sdjkfhakj&quot; },\r\n        { &quot;id&quot;: &quot;nope........&quot;, &quot;abc&quot;: &quot;smdfb&quot;, &quot;pqr&quot;: &quot;sdjkfhakj&quot; },\r\n        { &quot;id&quot;: &quot;____________&quot;, &quot;abc&quot;: &quot;smdfb&quot;, &quot;pqr&quot;: &quot;sdjkfhakj&quot; },\r\n        { &quot;id&quot;: &quot;pltrsg2rt4tl&quot;, &quot;abc&quot;: &quot;artgrre&quot;, &quot;pqr&quot;: &quot;sfeewrwg&quot; } ] }\r\n\r\n```\r\n\r\n\r\nSelect objects from data that match the input\r\n\r\n```\r\n$ jq -r --argjson users  &quot;$(&lt; users.json )&quot; -f match.jq &lt; database.json \r\n44 dkfjgh48sdfg\r\n66 sdfg742sdfg2\r\n12 sdfjk7df3dfg\r\n69 pltrsg2rt4tl\r\n```\r\n\r\n#### Scripts\r\n\r\n**users.jq**\r\n\r\n```jq\r\n  [\r\n    split(&quot;\\n&quot;)[]|\r\n    split(&quot; &quot;)|\r\n    select((.[]|length &gt; 0))\r\n  ]\r\n  | map({  (.[1]|tostring)  :  (.[0]|tostring)  })\r\n  | add\r\n```\r\n\r\n**match.jq**\r\n\r\n```jq\r\n\r\n.data[]\r\n| (.id|split(&quot;&quot;)|reverse|.[0:4]|reverse|join(&quot;&quot;)) as $l4\r\n| { orig: ., uid: $users[$l4] }\r\n| select(.uid != null)\r\n| &quot;\\( .uid ) \\( .orig.id )&quot;\r\n\r\n\r\n```\r\n\r\n#### Input\r\n\r\nusers.txt\r\n\r\n```\r\n  5 eeee\r\n  44 sdfg\r\n  66 dfg2\r\n  12 3dfg\r\n  69 t4tl\r\n  1 aaaa\r\n  2 bbbb\r\n  3 cccc\r\n  4 dddd\r\n```\r\n\r\n",
                "title": "Extract matching strings ids in JSON dataset from input file using Unix"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1635239943,
        "creation_date": 1633991141,
        "last_edit_date": 1635239943,
        "question_id": 69533089,
        "body_markdown": "I have JSON data from which I extract ids for the various customers using .jq. With the help of UNIX commands, I have fetched this JSON data through API calls. Now, I am trying to get all the IDs for that customer.\r\n\r\nWith the help of the below script if the customer has more than one id my data looks something like this\r\n\r\n**Script**\r\n\r\n```bash\r\nappKey=12345678999999999988999\r\ntokenInXml=$(curl -X POST \\\r\n\t  &quot;APIURL/authentication&quot; \\\r\n\t  -H &#39;Accept: application/xml&#39; \\\r\n\t  -H &#39;Content-Type: application/xml&#39; \\\r\n\t  -H &quot;Finicity-App-Key: $appKey&quot; \\\r\n\t  -H &#39;cache-control: no-cache&#39; \\\r\n\t  -d &quot;&lt;credentials&gt;\r\n\t\t\t&lt;partnerId&gt;11111111111111111&lt;/partnerId&gt;\r\n\t\t\t&lt;partnerSecret&gt;asdfdsfggfgfgfdss&lt;/partnerSecret&gt;\r\n\t\t&lt;/credentials&gt;&quot;)\r\n\r\nSUBSTRING=$(echo $tokenInXml| cut -d&#39;&gt;&#39; -f 4)\r\ntoken=$(echo $SUBSTRING| cut -d&#39;&lt;&#39; -f 1)\r\n\r\nCOUNTER=0\r\n\r\nwhile IFS= read -r line\r\ndo\r\n    customerId=$(echo $line | awk &#39;{print $1}&#39;)\r\n\t    \r\n    (( COUNTER++ ))\r\n\r\n    response=$(curl --fail --silent \\\r\n     -H &quot;App-Key:$appKey&quot; -H &quot;App-Token:$token&quot; \\\r\n     -H &quot;Content-Length:0&quot; -H &quot;Content-Type: application/xml&quot; \\\r\n     -H &quot;Accept:application/json&quot; -H &quot;Exclude-Metrics:true&quot; \\\r\n     -X GET &quot;APIURL/${customerId}/reports&quot; -d &#39;&#39; )\r\n\t\r\n\trep=$(echo &quot;${response}&quot; |\r\n       jq -r &#39;.reports[] | select(.id | contains(&quot;-&quot;)|not)| .id&#39;)\r\n\t\t\r\ndone &lt; &quot;inputfile.txt&quot;\r\n\r\n```\r\n\r\nExample JSON file for customer id 123456788 will look like this\r\n\r\n```json\r\n{ &quot;data&quot;: [\r\n  { &quot;id&quot;: &quot;dkfjgh48sdfg&quot;, &quot;abc&quot;: &quot;sdfdsf&quot;, &quot;pqr&quot;: &quot;sdkfj&quot; },\r\n  { &quot;id&quot;: &quot;sdfg742sdfg2&quot;, &quot;abc&quot;: &quot;aksjdfj&quot;, &quot;pqr&quot;: &quot;alkejf&quot; },\r\n  { &quot;id&quot;: &quot;sdfjk7df3dfg&quot;, &quot;abc&quot;: &quot;smdfb&quot;, &quot;pqr&quot;: &quot;sdjkfhakj&quot; },\r\n  { &quot;id&quot;: &quot;pltrsg2rt4tl&quot;, &quot;abc&quot;: &quot;artgrre&quot;, &quot;pqr&quot;: &quot;sfeewrwg&quot; } ] }\r\n\r\n``` \r\n\r\nOutput:\r\n```\r\n123456789 hksdf21sdfi\r\naflire65sfdh\r\nsdfghklj256v\r\nsdkfjh2dr7gd\r\n\r\n123456788 dkfjgh48sdfg\r\nsdfg742sdfg2\r\nsdfjk7df3dfg\r\npltrsg2rt4tl\r\n```\r\nHere the 123456789 123456788 are the customer ids and the alphanumeric string is id. I want to filter only those id&#39;s whose last four-digit matches with the input list which looks like this\r\n\r\n```\r\nInput List\r\n\r\n123456789 256v\r\n123456788 dfg2\r\n123456788 t4tl\r\n\r\n``` \r\n\r\nExpected output:\r\n```\r\n123456789 sdfghklj256v\r\n123456788 sdfg742sdfg2\r\n123456788 pltrsg2rt4tl\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69533089/extract-matching-strings-ids-in-json-dataset-from-input-file-using-unix",
        "title": "Extract matching strings ids in JSON dataset from input file using Unix"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1634013512,
                "creation_date": 1634013512,
                "answer_id": 69535140,
                "question_id": 69534972,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`@csv` requires an array as input but `.reservationSummary.pickLoc.locationCode` only produces a string. Instead, make it an array by wrapping it into `[]` and then add the two arrays together using `+`:\r\n\r\n    [.reservationSummary.pickLoc.locationCode] + (\r\n      .vehicleSummaryList[]\r\n      | [.carClass, .carGroup, .carAvailability, .payLaterRate.totalRateAmount]\r\n    )\r\n    | @csv",
                "title": "Add string to each row when converting json to csv with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1634013512,
        "creation_date": 1634011670,
        "question_id": 69534972,
        "body_markdown": "I&#39;m trying to convert this JSON:\r\n```\r\n{\r\n  &quot;reservationSummary&quot;: {\r\n    &quot;pickLoc&quot;: {\r\n      &quot;locationCode&quot;: &quot;EWR&quot;\r\n    }\r\n  },\r\n  &quot;vehicleSummaryList&quot;: [\r\n    {\r\n      &quot;carGroup&quot;: &quot;Economy&quot;,\r\n      &quot;carClass&quot;: &quot;A&quot;,\r\n      &quot;payNowRate&quot;: {\r\n        &quot;amount&quot;: &quot;2327.49&quot;,\r\n        &quot;totalRateAmount&quot;: &quot;3387.19&quot;\r\n      },\r\n      &quot;payLaterRate&quot;: {\r\n        &quot;amount&quot;: &quot;2449.99&quot;,\r\n        &quot;totalRateAmount&quot;: &quot;3540.79&quot;\r\n      }    },\r\n    {\r\n      &quot;carGroup&quot;: &quot;Compact&quot;,\r\n      &quot;carClass&quot;: &quot;B&quot;,\r\n      &quot;payNowRate&quot;: {\r\n        &quot;amount&quot;: &quot;2327.49&quot;,\r\n        &quot;totalRateAmount&quot;: &quot;3387.19&quot;\r\n      },\r\n      &quot;payLaterRate&quot;: {\r\n        &quot;amount&quot;: &quot;2449.99&quot;,\r\n        &quot;totalRateAmount&quot;: &quot;3540.79&quot;\r\n      }    }\r\n  ]\r\n}\r\n```\r\ninto a csv that looks like this:\r\n```\r\nEWR,A,Economy,A,3540.79\r\nEWR,B,Compact,A,3540.79\r\n```\r\nNOTE: I added `EWR` (from `.reservationSummary.pickLoc.locationCode`to the 1st column of each row.\r\n\r\nI&#39;ve successfully gotten the csv without it like this:\r\n```\r\njq -r &#39;(.vehicleSummaryList[] | [.carClass, .carGroup, .carAvailability, .payLaterRate.totalRateAmount])|@csv&#39; examle.json\r\n```\r\nBut any attempt to add `.reservationSummary.pickLoc.locationCode` like this:\r\n```\r\njq -r &#39;.reservationSummary.pickLoc.locationCode, (.vehicleSummaryList[] | [.carClass, .carGroup, .carAvailability, .payLaterRate.totalRateAmount])|@csv&#39; examle.json\r\n```\r\ngets an error like this:\r\n```\r\njq: error (at examle.json:51): string (&quot;EWR&quot;) cannot be csv-formatted, only array\r\n```",
        "link": "https://stackoverflow.com/questions/69534972/add-string-to-each-row-when-converting-json-to-csv-with-jq",
        "title": "Add string to each row when converting json to csv with JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1634060004,
                "last_edit_date": 1634060004,
                "creation_date": 1634024121,
                "answer_id": 69536696,
                "question_id": 69536572,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Can&#39;t say it&#39;s less hideous, but yeah, it is possible to do this entirely in JQ.\r\n``` sh\r\njq -nr &#39;[inputs | [.[&quot;@graph&quot;][][&quot;rdfs:label&quot;]]] | .[0]-.[1] | .[]&#39; {9.0,13.0}/schemaorg-all-http.jsonld\r\n```\r\n\r\nExplanation:\r\n\r\nGiven two files, say x:\r\n\r\n``` sh\r\n[\r\n{&quot;x&quot;: 1},\r\n{&quot;x&quot;: 2}\r\n]\r\n```\r\n\r\nand y\r\n\r\n```\r\n[\r\n{&quot;x&quot;: 3},\r\n{&quot;x&quot;: 4}\r\n]\r\n```\r\n\r\n`jq -n &#39;inputs&#39; x y` produces\r\n\r\n``` sh\r\n[\r\n  {\r\n    &quot;x&quot;: 1\r\n  },\r\n  {\r\n    &quot;x&quot;: 2\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;x&quot;: 3\r\n  },\r\n  {\r\n    &quot;x&quot;: 4\r\n  }\r\n]\r\n```\r\n\r\nObserve how this is just two things, one after the other. We will eventually want to address them, so we wrap it in an array.\r\n\r\n`jq -n &#39;[inputs]&#39; x y`\r\n\r\n``` sh\r\n[\r\n  [\r\n    {\r\n      &quot;x&quot;: 1\r\n    },\r\n    {\r\n      &quot;x&quot;: 2\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;x&quot;: 3\r\n    },\r\n    {\r\n      &quot;x&quot;: 4\r\n    }\r\n  ]\r\n]\r\n```\r\n\r\nthe reason for `jq -n` is in https://stackoverflow.com/q/55995980/308851.\r\n\r\nOnce this is done and understood the rest is relatively easy. \r\n\r\n1. `.[&quot;@graph&quot;]` extracts `@graph` which is an array of objects,\r\n1. `[]` iterates said array \r\n1. `[&quot;rdfs:label&quot;]` extracts the `[&quot;rdfs:label&quot;]` key from each object. Note [there&#39;s no dot before](https://stackoverflow.com/q/69537349/308851) `[&quot;rdfs:label&quot;]` and that&#39;s strange. \r\n1. As we know `inputs` just outputs the input files, on after the other, recall how it is not an array. The pipe operator &quot;if the one on the left produces multiple results, the one on the right will be run for each of those results&quot; so `inputs | .[&quot;@graph&quot;][][&quot;rdfs:label&quot;]` applies this extraction to each input. \r\n1. However, the end result is again just multiple results for each file and we want to work on it so we need to collect it into an array. The manual says about about the array construction `[]` operator &quot;You can use it to construct an array  to &quot;collect&quot; all the results of a filter into an array (as in `[.items[].name]`)&quot; which is exactly what we are doing. Except we do not have something as nice as `.name` we have `[&quot;rdfs:label&quot;]` instead because of the colon we need to use this more verbose and much more confusing syntax. We now have `inputs | [.[&quot;@graph&quot;][][&quot;rdfs:label&quot;]]` which will output an array for each input file. These arrays contain the value of `rdfs:label` and have the same number of strings as `@graph` had objects.\r\n1. What should be familiar now is that we take this output and wrap it into an array so that it can be addressed later and so we arrive to `[inputs | [.[&quot;@graph&quot;][][&quot;rdfs:label&quot;]]]`. Running each step and observing the output is helpful. You will get a two dimensional array -- the outer dimension is the number of files, the inside, as in the previous point, is the same number of strings as `@graph` had objects.\r\n1. The dot for jq means &quot;the whole input&quot; so the first operator will take this array of arrays and take the first and second elements of it and calculate the difference.\r\n1. Finally, instead of outputting this array, we want to output one thing after the other which will allow `-r` to strip the quotes. The `.[]` means to iterate over the difference array and output each element. It&#39;s the opposite operation to the `[]` array constructor.\r\n",
                "title": "Run the same jq pipeline on two files and compare the results?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1664702698,
        "creation_date": 1634023470,
        "last_edit_date": 1664702698,
        "question_id": 69536572,
        "body_markdown": "If I run `comm -23 &lt;(jq -r &#39;.[&quot;@graph&quot;][] |.[&quot;rdfs:label&quot;] &#39; 9.0/schemaorg-all-http.jsonld|sort) &lt;(jq -r &#39;.[&quot;@graph&quot;][] | .[&quot;rdfs:label&quot;] &#39; 13.0/schemaorg-all-http.jsonld|sort)` in the schema.org repo data/release directory then it works. It&#39;s hideous, on the other hand. Would it be possible to collapse it into a single `jq` command?",
        "link": "https://stackoverflow.com/questions/69536572/run-the-same-jq-pipeline-on-two-files-and-compare-the-results",
        "title": "Run the same jq pipeline on two files and compare the results?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8760742,
                    "reputation": 2207,
                    "user_id": 13527856,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IZXmn.jpg?s=256",
                    "display_name": "MarcoLucidi",
                    "link": "https://stackoverflow.com/users/13527856/marcolucidi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634030001,
                "post_id": 69537349,
                "comment_id": 122910731,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 118083,
                    "reputation": 11830,
                    "user_id": 308851,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://i.sstatic.net/lWWID.jpg?s=256",
                    "display_name": "chx",
                    "link": "https://stackoverflow.com/users/308851/chx"
                },
                "reply_to_user": {
                    "account_id": 8760742,
                    "reputation": 2207,
                    "user_id": 13527856,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IZXmn.jpg?s=256",
                    "display_name": "MarcoLucidi",
                    "link": "https://stackoverflow.com/users/13527856/marcolucidi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634031166,
                "post_id": 69537349,
                "comment_id": 122911179,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1634044014,
                "last_edit_date": 1634044014,
                "creation_date": 1634036939,
                "answer_id": 69539498,
                "question_id": 69537349,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The dot serves two different purposes in jq:\r\n\r\n* A dot on its own means &quot;the current object&quot;. Let&#39;s call this the _identity dot._ It can only appear at the start of an expression or subexpression, for example at the very start, or after a binary operator like the `|` or `+` or `and`, or inside an opening parenthesis `(`.\r\n* A dot followed by a string or an identifier means &quot;retrieve the named field of the current object&quot;. Let&#39;s call this an _indexing dot._ Whatever is to the left of it needs to be a complete subexpression, for example a literal value, a parenthesised expression, a function call, etc. It can&#39;t appear in any of the places the identity dot can appear.\r\n\r\nThe thing to understand is that in the square bracket operators, the dot shown in the documentation is an identity dot - it&#39;s not actually part of the operator itself. The operator is just the square brackets and their contents, and it needs to be attached to another complete expression.\r\n\r\nIn general, both square bracket operators (e.g. `[&quot;foo&quot;]` or `[]` or `[0]` or `[2:5]`) and object identifier indexing operators (e.g. `.foo` or `.&quot;foo&quot;`) can be appended to another expression. Only the object identifier indexing operators can appear &quot;bare&quot; with no expression on the left. Since the square bracket operators can&#39;t appear bare, you will typically see them in the documentation composed after an identity dot.\r\n\r\nThese are all equivalent:\r\n\r\n```\r\n.foo            # indexing dot\r\n.&quot;foo&quot;          # indexing dot\r\n. .foo          # identity dot and indexing dot\r\n. | .foo        # identity dot and indexing dot\r\n.[&quot;foo&quot;]        # identity dot\r\n. | .[&quot;foo&quot;]    # two identity dots\r\n```\r\n\r\nSo the answer to your question is that the last dot in `.&quot;@graph&quot;[].[&quot;rdfs:label&quot;]` isn&#39;t allowed because:\r\n\r\n* It can&#39;t be an identity dot because it has an expression on the left.\r\n* It can&#39;t be an indexing dot because it doesn&#39;t have an identifier or a string on the right, it has a square bracket.\r\n\r\nAll that said, it looks like newer versions of jq are going to extend the syntax to allow square bracket operators immediately after an indexing dot, and having the intuitive meaning of just applying that indexing operation the same as if there had been no dot, so hopefully you won&#39;t need to worry about the difference in the future.",
                "title": "Why this jq pipeline doesn&#39;t need a dot?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1634076224,
                "creation_date": 1634076224,
                "answer_id": 69547525,
                "question_id": 69537349,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the terminology of the jq manual, jq expressions are\r\nfundamentally composed of pipes and what it calls &quot;basic filters&quot;. The\r\nfirst filter under the heading &quot;Basic Filters&quot; is the identify filter,\r\n`.`; and `.[]` is the &quot;Array/Object Value Iterator&quot;.\r\n\r\nFrom this perspective, that is, from the perspective of\r\npipes-and-basic-filters, the expression under consideration\r\n`.&quot;@graph&quot;[][&quot;rdfs:label&quot;]` can be viewed as an abbreviated form of\r\nthe pipeline:\r\n\r\n    .[&quot;@graph&quot;] | .[] | .[&quot;rdfs:label&quot;]\r\n\r\nSo from this perspective, the question is what abbreviations are allowed.\r\nOne of the most important abbreviation rules is:\r\n\r\n    E | .[] #=&gt; E[]\r\n\r\nAnother is:\r\n\r\n    .[&quot;&lt;string&gt;&quot;] #=&gt; .&quot;&lt;string&gt;&quot;\r\n\r\nApplication of these rules yields the simplified expression.\r\n\r\nSo perhaps the basic answer to the &quot;why&quot; in this question is: for convenience. :-)",
                "title": "Why this jq pipeline doesn&#39;t need a dot?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1634076224,
        "creation_date": 1634027452,
        "question_id": 69537349,
        "body_markdown": "`jq -r &#39;.&quot;@graph&quot;[][&quot;rdfs:label&quot;]&#39; 9.0/schemaorg-all-http.jsonld` works but `jq -r &#39;.&quot;@graph&quot;[].[&quot;rdfs:label&quot;]&#39; 9.0/schemaorg-all-http.jsonld` does not and I don&#39;t understand why `.[&quot;rdfs:label&quot;]` does _not_ need the dot. https://stackoverflow.com/a/39798796/308851 suggests it needs `.name` after `[]` and https://stedolan.github.io/jq/manual/#Basicfilters says\r\n\r\n&gt; For example .[&quot;foo::bar&quot;] and .[&quot;foo.bar&quot;] work while .foo::bar does not,\r\n\r\nWhere did the dot go?\r\n",
        "link": "https://stackoverflow.com/questions/69537349/why-this-jq-pipeline-doesnt-need-a-dot",
        "title": "Why this jq pipeline doesn&#39;t need a dot?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1634067460,
                "last_edit_date": 1634067460,
                "creation_date": 1634060047,
                "answer_id": 69544752,
                "question_id": 69544555,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\npaths( objects | .ENTITY == &quot;TEXT&quot; )\r\n```\r\n\r\nFormat the output as desired. For example,\r\n\r\n```sh\r\njq -r &#39;paths( objects | .ENTITY == &quot;TEXT&quot; ) | join(&quot;.&quot;)&#39;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/ROvYL27zwT)\r\n\r\n---\r\n\r\n[*The following consists of my original answer*]\r\n\r\n```jq\r\npath( .. | select( type == &quot;object&quot; and .ENTITY == &quot;TEXT&quot; ) )\r\n```\r\n\r\nFormat the output as desired. For example,\r\n\r\n```sh\r\njq -r &#39;path( .. | select( type ==&quot;object&quot; and .ENTITY == &quot;TEXT&quot; ) ) | join(&quot;.&quot;)&#39;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/9J3HoJHamA)\r\n",
                "title": "Finding the path to all occurrences of a specific key is a specify value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1634060820,
                "creation_date": 1634060820,
                "answer_id": 69544903,
                "question_id": 69544555,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I understood your question correctly, you are searching for leafs with a given key/field whose value matches a given value. This approach uses `leaf_paths` to get all leafs along with `getpath` to get their values, `transpose` to tuple them up, and finally `select` to reduce the list to those matching the criteria. The output is only the path arrays.\r\n\r\n    jq --arg key &quot;ENTITY&quot; --arg value &quot;TEXT&quot; &#39;\r\n      [[leaf_paths],[getpath(leaf_paths)]]\r\n      | transpose\r\n      | map(select(.[0][-1] == $key and .[1] == $value))[][0]\r\n    &#39;\r\n",
                "title": "Finding the path to all occurrences of a specific key is a specify value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1634067460,
        "creation_date": 1634059021,
        "question_id": 69544555,
        "body_markdown": "I have a bunch of hundred thousand line json files, and I&#39;m trying to work how out they are structured. \r\n\r\nI&#39;d like to print the path to all keys named &quot;ENTITY&quot; with a value &quot;TEXT&quot;. \r\n\r\nthese can be nested at any level. There are lots of examples for finding one at a particular level, e.g. https://stackoverflow.com/questions/18592173/select-objects-based-on-value-of-variable-in-object-using-jq\r\n\r\nBut I&#39;m actually trying to figure out where these items are nested, since the file is so large, I can&#39;t do it by inspection.\r\n",
        "link": "https://stackoverflow.com/questions/69544555/finding-the-path-to-all-occurrences-of-a-specific-key-is-a-specify-value",
        "title": "Finding the path to all occurrences of a specific key is a specify value"
    },
    {
        "tags": [
            "json",
            "shell",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1634063534,
                "creation_date": 1634063534,
                "answer_id": 69545413,
                "question_id": 69545347,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Is this what you are looking for?\r\n\r\n    select(.type | IN(&quot;mammal&quot;,&quot;reptile&quot;))",
                "title": "`in` operator in jq. But, it doesn&#39;t work as I want"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1634063534,
        "creation_date": 1634063188,
        "question_id": 69545347,
        "body_markdown": "with input like this:\r\n```\r\n{&quot;type&quot;: &quot;mammal&quot;, &quot;value&quot;: &quot;lion&quot;}\r\n{&quot;type&quot;: &quot;reptile&quot;, &quot;value&quot;: &quot;snake&quot;}\r\n{&quot;type&quot;: &quot;insect&quot;, &quot;value&quot;: &quot;fly&quot;}\r\n{&quot;type&quot;: &quot;mammal&quot;, &quot;value&quot;: &quot;chicken&quot;}\r\n```\r\n\r\nI could get what I want with `select(.type==&quot;mammal&quot; or .type==&quot;reptile&quot;)`. But this is simplified version, as you can expect, this could be too verbose easily.\r\n\r\nSo I want to do the same with more succinct way like `select(.type in [&quot;mammal&quot;, &quot;reptile&quot;])`. I know that it&#39;s not valid though, it&#39;s a pseudo code and you could  understand my intention.\r\n\r\nI tried several things with in/1 and index/1, but I couldn&#39;t be happy... What should I do?",
        "link": "https://stackoverflow.com/questions/69545347/in-operator-in-jq-but-it-doesnt-work-as-i-want",
        "title": "`in` operator in jq. But, it doesn&#39;t work as I want"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1634067149,
                "creation_date": 1634067149,
                "answer_id": 69546074,
                "question_id": 69545895,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have the filters in the wrong order. Try:\r\n\r\n```\r\njq &#39;.prefixes[] | select(.region|startswith(&quot;us-west&quot;)) | .ip_prefix&#39; &lt;your json file&gt; \r\n```\r\nWhat this is doing is getting the `prefixes` array, filtering for elements where the region starts with &quot;us-west&quot; and then selecting the `ip_prefix`.",
                "title": "jq select field based on contains from another field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1634157142,
        "creation_date": 1634066180,
        "last_edit_date": 1634157142,
        "question_id": 69545895,
        "body_markdown": "I am trying to pull out of this list the `ip_prefix` based on where region contains `us-west-` and list them in csv.  When I try `jq &#39;.prefixes[] | .ip_prefix,.region | select(contains(&quot;us&quot;)?)&#39; file.json` I only get  a list of regions.\r\n\r\n```json\r\n{\r\n  &quot;syncToken&quot;: &quot;15985471&quot;,\r\n  &quot;createDate&quot;: &quot;2021-10-08-20-13-16&quot;,\r\n  &quot;prefixes&quot;: [\r\n    {\r\n      &quot;ip_prefix&quot;: &quot;3.5.140.0/22&quot;,\r\n      &quot;region&quot;: &quot;ap-northeast-2&quot;,\r\n      &quot;service&quot;: &quot;AMAZON&quot;,\r\n      &quot;network_border_group&quot;: &quot;ap-northeast-2&quot;\r\n    },\r\n    {\r\n      &quot;ip_prefix&quot;: &quot;13.34.37.64/27&quot;,\r\n      &quot;region&quot;: &quot;ap-southeast-4&quot;,\r\n      &quot;service&quot;: &quot;AMAZON&quot;,\r\n      &quot;network_border_group&quot;: &quot;ap-southeast-4&quot;\r\n    },\r\n    {\r\n      &quot;ip_prefix&quot;: &quot;35.180.0.0/16&quot;,\r\n      &quot;region&quot;: &quot;eu-west-3&quot;,\r\n      &quot;service&quot;: &quot;AMAZON&quot;,\r\n      &quot;network_border_group&quot;: &quot;eu-west-3&quot;\r\n    },\r\n    {\r\n      &quot;ip_prefix&quot;: &quot;52.93.153.170/32&quot;,\r\n      &quot;region&quot;: &quot;eu-west-2&quot;,\r\n      &quot;service&quot;: &quot;AMAZON&quot;,\r\n      &quot;network_border_group&quot;: &quot;eu-west-2&quot;\r\n    },\r\n    {\r\n      &quot;ip_prefix&quot;: &quot;52.93.178.234/32&quot;,\r\n      &quot;region&quot;: &quot;us-west-1&quot;,\r\n      &quot;service&quot;: &quot;AMAZON&quot;,\r\n      &quot;network_border_group&quot;: &quot;us-west-1&quot;\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/69545895/jq-select-field-based-on-contains-from-another-field",
        "title": "jq select field based on contains from another field"
    },
    {
        "tags": [
            "json",
            "shell",
            "command-line",
            "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": 1634132814,
                "post_id": 69555673,
                "comment_id": 122944431,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1634132970,
                "post_id": 69555673,
                "comment_id": 122944505,
                "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": 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": 1634133082,
                "post_id": 69555673,
                "comment_id": 122944570,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634133413,
                "post_id": 69555673,
                "comment_id": 122944711,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22553865,
                    "reputation": 79,
                    "user_id": 16742581,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e417ad09ffa39504955a1aeca59bfc2f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dogman",
                    "link": "https://stackoverflow.com/users/16742581/dogman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634133509,
                "post_id": 69555673,
                "comment_id": 122944763,
                "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": 1634133614,
                "post_id": 69555673,
                "comment_id": 122944809,
                "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": 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": 1634134114,
                "post_id": 69555673,
                "comment_id": 122945012,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22553865,
                    "reputation": 79,
                    "user_id": 16742581,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e417ad09ffa39504955a1aeca59bfc2f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dogman",
                    "link": "https://stackoverflow.com/users/16742581/dogman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634134210,
                "post_id": 69555673,
                "comment_id": 122945050,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22553865,
                    "reputation": 79,
                    "user_id": 16742581,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e417ad09ffa39504955a1aeca59bfc2f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dogman",
                    "link": "https://stackoverflow.com/users/16742581/dogman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1634135603,
                "post_id": 69555673,
                "comment_id": 122945646,
                "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": 1634136317,
                "post_id": 69555673,
                "comment_id": 122945965,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1634129079,
                "creation_date": 1634129079,
                "answer_id": 69555839,
                "question_id": 69555673,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just read in `food.json` using parameter `--slurpfile food food.json` and modify `program.jq` to include it: `input as $owners | {$owners, food: $food[0].food, animals: [inputs]}`.",
                "title": "Joining multiple objects under a single object and adding sibling objects using jq -f .jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1634129079,
        "creation_date": 1634128433,
        "question_id": 69555673,
        "body_markdown": "So from what I gather `jq` [does support](https://github.com/stedolan/jq/issues/461) using `-f` multiple times. However I&#39;m not sure if this is what I want.\r\n\r\nSo I have:\r\n\r\n## cats.json\r\n\r\n```json\r\n{\r\n  &quot;cats&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;fluffles&quot;,\r\n      &quot;age&quot;: 10,\r\n      &quot;color&quot;: &quot;white&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n## dogs.json\r\n\r\n```json\r\n{\r\n  &quot;dogs&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;sam&quot;,\r\n      &quot;age&quot;: 5,\r\n      &quot;color&quot;: &quot;black and white&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;rover&quot;,\r\n      &quot;age&quot;: 2,\r\n      &quot;color&quot;: &quot;brown and white&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n## snakes.json\r\n```json\r\n{\r\n  &quot;snakes&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;noodles&quot;,\r\n      &quot;age&quot;: 10,\r\n      &quot;color&quot;: &quot;green&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI was able to merge this object:\r\n\r\n## owners.json\r\n\r\n```json\r\n{\r\n  &quot;owners&quot;: [\r\n    &quot;peter&quot;,\r\n    &quot;william&quot;,\r\n    &quot;sally&quot;\r\n  ]\r\n}\r\n```\r\n\r\nusing\r\n\r\n```\r\njq -n -f program.jq owners.json $(ls *.json | grep -v &#39;owners.json&#39;)\r\n```\r\n\r\nwhich contains the `jq` program\r\n\r\n```\r\ninput as $owners | {$owners, animals: [inputs]}\r\n```\r\n\r\nas suggested [in the reply](https://stackoverflow.com/a/69183207/16742581).\r\n\r\nHowever I&#39;m not sure what to do if I want to merge two additional objects, say I had:\r\n\r\n## food.json\r\n\r\n```json\r\n{\r\n  &quot;food&quot;: [\r\n    &quot;meat&quot;,\r\n    &quot;fish&quot;,\r\n    &quot;vegetables&quot;\r\n  ]\r\n}\r\n```\r\n\r\nas well that I want at the top, resulting in:\r\n\r\n```json\r\n{\r\n  &quot;owners&quot;: [\r\n    &quot;peter&quot;,\r\n    &quot;william&quot;,\r\n    &quot;sally&quot;\r\n  ],\r\n  &quot;food&quot;: [\r\n    &quot;meat&quot;,\r\n    &quot;fish&quot;,\r\n    &quot;vegetables&quot;\r\n  ],\r\n  &quot;animals&quot;: [\r\n    {\r\n      &quot;cats&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;fluffles&quot;,\r\n          &quot;age&quot;: 10,\r\n          &quot;color&quot;: &quot;white&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;dogs&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;sam&quot;,\r\n          &quot;age&quot;: 5,\r\n          &quot;color&quot;: &quot;black and white&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;rover&quot;,\r\n          &quot;age&quot;: 2,\r\n          &quot;color&quot;: &quot;brown and white&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;snakes&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;noodles&quot;,\r\n          &quot;age&quot;: 10,\r\n          &quot;color&quot;: &quot;green&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/69555673/joining-multiple-objects-under-a-single-object-and-adding-sibling-objects-using",
        "title": "Joining multiple objects under a single object and adding sibling objects using jq -f .jq"
    },
    {
        "tags": [
            "syntax",
            "jq",
            "jsonpath"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1634155320,
                "last_edit_date": 1634155320,
                "creation_date": 1634154985,
                "answer_id": 69561604,
                "question_id": 69561522,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What you have appears to be a JSONPath syntax (https://github.com/json-path/JsonPath) , which is not applicable in `jq` which has its own DSL syntax\r\n\r\nFor this specific case to filter on a condition, you need a `select` statement\r\n\r\n```none\r\n[ &quot;color&quot;, &quot;category&quot;, &quot;type&quot; ], \r\n( .colors[] | select( .type == &quot;secondary&quot; ) | [ .color, .category, .type] ) | @csv\r\n```\r\n\r\n&lt;sup&gt;[jqplay demo][1]&lt;/sup&gt;\r\n\r\n\r\n  [1]: https://jqplay.org/s/yEzcotWrMS",
                "title": "Issue using JSONpath syntax in jq while converting JSON to CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1634174818,
        "creation_date": 1634154480,
        "last_edit_date": 1634174818,
        "question_id": 69561522,
        "body_markdown": " I&#39;m trying to convert this JSON to CSV with some condition. And my condition is &quot;type&quot; should be &quot;secondary&quot;. It should display the field having type secondary. Getting error with below cmd.\r\n\r\n```\r\njq -r &#39;[&quot;color&quot;,&quot;category&quot;,&quot;type&quot;], ([?type==&quot;secondary&quot;].colors | [.color, .category, .type]) | @csv&#39; test.json &gt; test.csv\r\n```\r\n\r\n```json\r\n    {\r\n      &quot;colors&quot;: [\r\n        {\r\n          &quot;color&quot;: &quot;black&quot;,\r\n          &quot;category&quot;: &quot;hue&quot;,\r\n          &quot;type&quot;: &quot;primary&quot;,\r\n          &quot;code&quot;: {\r\n            &quot;rgba&quot;: [255,255,255,1],\r\n            &quot;hex&quot;: &quot;#000&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;color&quot;: &quot;white&quot;,\r\n          &quot;category&quot;: &quot;value&quot;,\r\n          &quot;code&quot;: {\r\n            &quot;rgba&quot;: [0,0,0,1],\r\n            &quot;hex&quot;: &quot;#FFF&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;color&quot;: &quot;red&quot;,\r\n          &quot;category&quot;: &quot;hue&quot;,\r\n          &quot;type&quot;: &quot;primary&quot;,\r\n          &quot;code&quot;: {\r\n            &quot;rgba&quot;: [255,0,0,1],\r\n            &quot;hex&quot;: &quot;#FF0&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;color&quot;: &quot;blue&quot;,\r\n          &quot;category&quot;: &quot;hue&quot;,\r\n          &quot;type&quot;: &quot;primary&quot;,\r\n          &quot;code&quot;: {\r\n            &quot;rgba&quot;: [0,0,255,1],\r\n            &quot;hex&quot;: &quot;#00F&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;color&quot;: &quot;yellow&quot;,\r\n          &quot;category&quot;: &quot;hue&quot;,\r\n          &quot;type&quot;: &quot;primary&quot;,\r\n          &quot;code&quot;: {\r\n            &quot;rgba&quot;: [255,255,0,1],\r\n            &quot;hex&quot;: &quot;#FF0&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;color&quot;: &quot;green&quot;,\r\n          &quot;category&quot;: &quot;hue&quot;,\r\n          &quot;type&quot;: &quot;secondary&quot;,\r\n          &quot;code&quot;: {\r\n            &quot;rgba&quot;: [0,255,0,1],\r\n            &quot;hex&quot;: &quot;#0F0&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n```",
        "link": "https://stackoverflow.com/questions/69561522/issue-using-jsonpath-syntax-in-jq-while-converting-json-to-csv",
        "title": "Issue using JSONpath syntax in jq while converting JSON to CSV"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1634216953,
                "last_edit_date": 1634216953,
                "creation_date": 1634215331,
                "answer_id": 69570916,
                "question_id": 69570802,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming that your input file is actually an array of objects, then the following might work for you:\r\n\r\n```\r\n$ jq &#39;map(. + { &quot;FullAddress&quot;: &quot;redis://\\(.Address):\\(.Port)&quot; })&#39; input.json\r\n[\r\n  {\r\n    &quot;Address&quot;: &quot;myaddress1.com&quot;,\r\n    &quot;Port&quot;: 6379,\r\n    &quot;FullAddress&quot;: &quot;redis://myaddress1.com:6379&quot;\r\n  },\r\n  {\r\n    &quot;Address&quot;: &quot;myaddress2.com&quot;,\r\n    &quot;Port&quot;: 6379,\r\n    &quot;FullAddress&quot;: &quot;redis://myaddress2.com:6379&quot;\r\n  }\r\n]\r\n```",
                "title": "How to add new field to JSON with jq based on other values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1634216953,
        "creation_date": 1634214831,
        "question_id": 69570802,
        "body_markdown": "Assume I have the following JSON:\r\n\r\n```\r\n{\r\n  &quot;Address&quot;: &quot;myaddress1.com&quot;,\r\n  &quot;Port&quot;: 6379\r\n},\r\n{\r\n  &quot;Address&quot;: &quot;myaddress2.com&quot;,\r\n  &quot;Port&quot;: 6379\r\n}\r\n```\r\n\r\nI want to concatenate both the port and address and also prepend and append some text achieving solely with jq. For example I want the new output to be:\r\n\r\n```\r\n{\r\n  &quot;Address&quot;: &quot;myaddress1.com&quot;,\r\n  &quot;Port&quot;: 6379,\r\n  &quot;FullAddress&quot;: &quot;redis://myaddress1.com:6379\r\n},\r\n{\r\n  &quot;Address&quot;: &quot;myaddress2.com&quot;,\r\n  &quot;Port&quot;: 6379,\r\n  &quot;FullAddress&quot;: &quot;redis://myaddress2.com:6379\r\n}\r\n```\r\n\r\nIs this possible with just JQ or do I need to use a scripting language?\r\n",
        "link": "https://stackoverflow.com/questions/69570802/how-to-add-new-field-to-json-with-jq-based-on-other-values",
        "title": "How to add new field to JSON with jq based on other values"
    },
    {
        "tags": [
            "jq",
            "oracle-cloud-infrastructure"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1684984,
                    "reputation": 32085,
                    "user_id": 1548468,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0745dce203d52699e63a575b3103ad70?s=256&d=identicon&r=PG",
                    "display_name": "Botje",
                    "link": "https://stackoverflow.com/users/1548468/botje"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634217178,
                "post_id": 69571099,
                "comment_id": 122969652,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19427215,
                    "reputation": 31,
                    "user_id": 14208491,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-z0tIcGC6zzI/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucneKAjZgdNB6PnbRfXf4Fb8V6HAYQ/s256-rj/photo.jpg",
                    "display_name": "Safney",
                    "link": "https://stackoverflow.com/users/14208491/safney"
                },
                "reply_to_user": {
                    "account_id": 1684984,
                    "reputation": 32085,
                    "user_id": 1548468,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0745dce203d52699e63a575b3103ad70?s=256&d=identicon&r=PG",
                    "display_name": "Botje",
                    "link": "https://stackoverflow.com/users/1548468/botje"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634217382,
                "post_id": 69571099,
                "comment_id": 122969757,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1634217518,
                "creation_date": 1634217518,
                "answer_id": 69571452,
                "question_id": 69571099,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As updated by Botje - JQ can not process as its not JSON. I used --query and it worked.\r\n\r\n    oci bastion session list  --bastion-id  $BSTN_OCID --output table --profile $PROF --all --query &#39;data[].id&#39;\r\n    ",
                "title": "OCI CLI command failing with Parse error when using --output table"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1634217518,
        "creation_date": 1634216080,
        "question_id": 69571099,
        "body_markdown": "I was trying a simple OCI CLI command when ran without the option --output table is working absolutely fine, but when i add that option -- output table it is giving parse error.\r\nPlease let me know if i miss anything here..\r\n\r\nWorking command\r\n-------------\r\n\r\n     oci --profile $PROF bastion session list --all --bastion-id $BSTN_OCID  |jq -r &#39;.data[].id&#39;\r\n\r\nFailing command\r\n---------------\r\n\r\n     oci --profile $PROF bastion session list --all --bastion-id $BSTN_OCID --output table |jq -r &#39;.data[].id&#39;\r\n\r\nError\r\n-----\r\n\r\n    parse error: Invalid numeric literal at line 2, column 0\r\n",
        "link": "https://stackoverflow.com/questions/69571099/oci-cli-command-failing-with-parse-error-when-using-output-table",
        "title": "OCI CLI command failing with Parse error when using --output table"
    },
    {
        "tags": [
            "bash",
            "variables",
            "while-loop",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1634221776,
                "post_id": 69572458,
                "comment_id": 122971829,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1634222019,
                "post_id": 69572458,
                "comment_id": 122971942,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2805962,
                    "reputation": 19485,
                    "user_id": 2413201,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/rxfuw.jpg?s=256",
                    "display_name": "Armali",
                    "link": "https://stackoverflow.com/users/2413201/armali"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634314268,
                "post_id": 69572458,
                "comment_id": 122999097,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1634315923,
                "creation_date": 1634315923,
                "answer_id": 69587990,
                "question_id": 69572458,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nselect(.pathPattern==$URL|tostring)\r\n```\r\n\r\nThis is unlikely to be what you intend. The pipe `|` operator has lower precedence than the equality `==` operator. This filter is equivalent to:\r\n\r\n```\r\nselect((.pathPattern==$URL)|tostring)\r\n```\r\n\r\n...which will work out as either of these:\r\n\r\n```\r\nselect(true|tostring)\r\nselect(false|tostring)\r\n```\r\n\r\n...which will in turn be:\r\n\r\n```\r\nselect(&quot;true&quot;)\r\nselect(&quot;false&quot;)\r\n```\r\n\r\n...and perhaps you can see where this is going. All strings are considered truth-like values. So these filters will actually select all the settings every time!",
                "title": "BASH: My variable&#39;s value is not displaying correctly inside a loop"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1634536718,
                "creation_date": 1634536718,
                "answer_id": 69611407,
                "question_id": 69572458,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I managed to make it work by replacing the single quote to double quotes in my JQ filter.\r\n\r\n    # Get the request method\r\n    method=$(cat settings.json | ./jq &quot;.settings[] | select(.pathPattern==$URL|tostring).httpOperations[] | select(.method == \\&quot;PUT\\&quot; or .method == \\&quot;POST\\&quot;).method&quot;)\r\n\r\nI did not need to use the **--arg** option to define a JQ variable, what happened instead is I&#39;m directly calling my bash variable and luckily it worked fine.",
                "title": "BASH: My variable&#39;s value is not displaying correctly inside a loop"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1634536718,
        "creation_date": 1634221618,
        "last_edit_date": 1634221998,
        "question_id": 69572458,
        "body_markdown": "In the function below, I&#39;m using JQ to parse the JSON data and get the **httpOperations** key/value pair.\r\n\r\n  \r\n\r\n    #!/usr/bin/env bash\r\n    function batch_post() {\r\n      SETTINGS_INPUT=$1 #! Variable that holds the argument value\r\n      n=0\r\n      :&gt; &quot;${SETTINGS_INPUT}&quot;_req.tmp #! This will just create an empty file\r\n      \r\n      while read setting\r\n      do\r\n        # Get parameters that need to go in the batch put/post request\r\n        url=$(echo $setting | ./jq -r &#39;.url&#39;)\r\n        body=$(echo $setting | ./jq -r &#39;.response.body&#39;)\r\n    \r\n        # Get the request method\r\n        method=$(cat settings.json | ./jq --arg URL ${url} &#39;.settings[] | select(.pathPattern==$URL|tostring).httpOperations[] | select(.method == &quot;PUT&quot; or .method == &quot;POST&quot;).method&#39;)\r\n           \r\n        # Save individual requests to be added to the batch request\r\n        let n=n+1\r\n      done &lt;&lt;&lt; $(cat ${SETTINGS_INPUT} | ./jq -c &#39;.&#39;)\r\n    \r\n      # Format individual requests in the expected batch json format\r\n      cat &quot;${SETTINGS_INPUT}&quot;_req.tmp | ./jq -n &#39;.requests |= [inputs]&#39; &gt; &quot;${SETTINGS_LIST}&quot;_batch_post_put_req\r\n      # TODO: Validate this has the correct format and PUT/POST according to the settings\r\n      cat &quot;${SETTINGS_LIST}&quot;_batch_post_put_req\r\n      \r\n      #! DO NOT execute API call with put/post request\r\n    }\r\n\r\nand I&#39;m passing a JSON file as my argument to this function, below is the content of the JSON file. Please note that this is not the full JSON data that I&#39;m actually using.\r\n\r\n       {\r\n      &quot;settings&quot; : [ {\r\n        &quot;key&quot; : &quot;AccountingRules&quot;,\r\n        &quot;description&quot; : &quot;Accounting Rules settings&quot;,\r\n        &quot;context&quot; : &quot;Entity&quot;,\r\n        &quot;pathPattern&quot; : &quot;/accounting-rules&quot;,\r\n        &quot;httpOperations&quot; : [ {\r\n          &quot;method&quot; : &quot;GET&quot;,\r\n          &quot;url&quot; : &quot;/settings/accounting-rules&quot;,\r\n          &quot;parameters&quot; : [ ],\r\n          &quot;responseType&quot; : {\r\n            &quot;$ref&quot; : &quot;#/definitions/AccountingRules&quot;,\r\n            &quot;definitions&quot; : {\r\n              &quot;AccountingRules&quot; : {\r\n                &quot;additionalProperties&quot; : false,\r\n                &quot;type&quot; : &quot;object&quot;,\r\n                &quot;properties&quot; : {\r\n                  &quot;allowRevenueScheduleNegativeAmounts&quot; : {\r\n                    &quot;type&quot; : &quot;boolean&quot;\r\n                  },\r\n                  &quot;allowBlankAccountingCodes&quot; : {\r\n                    &quot;type&quot; : &quot;boolean&quot;\r\n                  },\r\n                  &quot;allowCreationInClosedPeriod&quot; : {\r\n                    &quot;type&quot; : &quot;boolean&quot;\r\n                  },\r\n                  &quot;allowUsageInClosedPeriod&quot; : {\r\n                    &quot;type&quot; : &quot;boolean&quot;\r\n                  },\r\n                  &quot;differentCurrencies&quot; : {\r\n                    &quot;type&quot; : &quot;boolean&quot;\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }, {\r\n          &quot;method&quot; : &quot;PUT&quot;,\r\n          &quot;url&quot; : &quot;/settings/accounting-rules&quot;,\r\n          &quot;parameters&quot; : [ ],\r\n          &quot;requestType&quot; : {\r\n            &quot;$ref&quot; : &quot;#/definitions/AccountingRules&quot;,\r\n            &quot;definitions&quot; : {\r\n              &quot;AccountingRules&quot; : {\r\n                &quot;additionalProperties&quot; : false,\r\n                &quot;type&quot; : &quot;object&quot;,\r\n                &quot;properties&quot; : {\r\n                  &quot;allowRevenueScheduleNegativeAmounts&quot; : {\r\n                    &quot;type&quot; : &quot;boolean&quot;\r\n                  },\r\n                  &quot;allowBlankAccountingCodes&quot; : {\r\n                    &quot;type&quot; : &quot;boolean&quot;\r\n                  },\r\n                  &quot;allowCreationInClosedPeriod&quot; : {\r\n                    &quot;type&quot; : &quot;boolean&quot;\r\n                  },\r\n                  &quot;allowUsageInClosedPeriod&quot; : {\r\n                    &quot;type&quot; : &quot;boolean&quot;\r\n                  },\r\n                  &quot;differentCurrencies&quot; : {\r\n                    &quot;type&quot; : &quot;boolean&quot;\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;responseType&quot; : {\r\n            &quot;$ref&quot; : &quot;#/definitions/AccountingRules&quot;,\r\n            &quot;definitions&quot; : {\r\n              &quot;AccountingRules&quot; : {\r\n                &quot;additionalProperties&quot; : false,\r\n                &quot;type&quot; : &quot;object&quot;,\r\n                &quot;properties&quot; : {\r\n                  &quot;allowRevenueScheduleNegativeAmounts&quot; : {\r\n                    &quot;type&quot; : &quot;boolean&quot;\r\n                  },\r\n                  &quot;allowBlankAccountingCodes&quot; : {\r\n                    &quot;type&quot; : &quot;boolean&quot;\r\n                  },\r\n                  &quot;allowCreationInClosedPeriod&quot; : {\r\n                    &quot;type&quot; : &quot;boolean&quot;\r\n                  },\r\n                  &quot;allowUsageInClosedPeriod&quot; : {\r\n                    &quot;type&quot; : &quot;boolean&quot;\r\n                  },\r\n                  &quot;differentCurrencies&quot; : {\r\n                    &quot;type&quot; : &quot;boolean&quot;\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          }\r\n        } ]\r\n      }, {\r\n        &quot;key&quot; : &quot;AgingBuckets&quot;,\r\n        &quot;description&quot; : &quot;Aging Buckets&quot;,\r\n        &quot;context&quot; : &quot;Entity&quot;,\r\n        &quot;pathPattern&quot; : &quot;/aging-buckets&quot;,\r\n        &quot;httpOperations&quot; : [ {\r\n          &quot;method&quot; : &quot;GET&quot;,\r\n          &quot;url&quot; : &quot;/settings/aging-buckets&quot;,\r\n          &quot;parameters&quot; : [ ],\r\n          &quot;responseType&quot; : {\r\n            &quot;$ref&quot; : &quot;#/definitions/AgingBucket&quot;,\r\n            &quot;definitions&quot; : {\r\n              &quot;Bucket&quot; : {\r\n                &quot;additionalProperties&quot; : false,\r\n                &quot;type&quot; : &quot;object&quot;,\r\n                &quot;properties&quot; : {\r\n                  &quot;name&quot; : {\r\n                    &quot;type&quot; : &quot;string&quot;,\r\n                    &quot;maxLength&quot; : 100\r\n                  },\r\n                  &quot;fromDaysPastDue&quot; : {\r\n                    &quot;type&quot; : &quot;integer&quot;\r\n                  },\r\n                  &quot;toDaysPastDue&quot; : {\r\n                    &quot;type&quot; : &quot;integer&quot;\r\n                  }\r\n                },\r\n                &quot;required&quot; : [ &quot;name&quot; ]\r\n              },\r\n              &quot;AgingBucket&quot; : {\r\n                &quot;additionalProperties&quot; : false,\r\n                &quot;type&quot; : &quot;object&quot;,\r\n                &quot;properties&quot; : {\r\n                  &quot;includeNegativeInvoice&quot; : {\r\n                    &quot;type&quot; : &quot;boolean&quot;\r\n                  },\r\n                  &quot;buckets&quot; : {\r\n                    &quot;type&quot; : &quot;array&quot;,\r\n                    &quot;items&quot; : {\r\n                      &quot;$ref&quot; : &quot;#/definitions/Bucket&quot;\r\n                    }\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          }\r\n        } ]\r\n    }\r\n    ]}\r\n\r\nAnd whenever I&#39;m displaying the output for my variable named &quot;method&quot;, the output that&#39;s being returned is stacked on top of one another. To give you an example, the issue looks like this when displaying the $method value.\r\n\r\n    Display method below\r\n    &quot;PUT&quot;\r\n    &quot;POST&quot;\r\n    &quot;PUT&quot;\r\n    &quot;POST&quot;\r\n    &quot;PUT&quot;\r\n    &quot;POST&quot;\r\n    &quot;PUT&quot;\r\n    &quot;POST&quot;\r\n    &quot;PUT&quot;\r\n    &quot;POST&quot;\r\n    &quot;PUT&quot;\r\n    &quot;POST&quot;\r\n    &quot;PUT&quot;\r\n    &quot;PUT&quot;\r\n    &quot;POST&quot;\r\n    &quot;PUT&quot;\r\n    &quot;POST&quot;\r\n    &quot;POST&quot;\r\n    &quot;PUT&quot;\r\n    &quot;POST&quot;\r\n    Done displaying method\r\n\r\nWherein I&#39;m expecting the output to be just a single &quot;PUT&quot; or &quot;POST&quot; only. Also, the thing I observed that&#39;s kind of weird for me is that this issue will show up when I try to display my variable executing &quot;$ echo ${method}&quot; command but when I remove the curly braces it sometimes works fine.",
        "link": "https://stackoverflow.com/questions/69572458/bash-my-variables-value-is-not-displaying-correctly-inside-a-loop",
        "title": "BASH: My variable&#39;s value is not displaying correctly inside a loop"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634269339,
                "post_id": 69579355,
                "comment_id": 122984948,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1634326443,
                "last_edit_date": 1634326443,
                "creation_date": 1634268767,
                "answer_id": 69579685,
                "question_id": 69579355,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Actually it&#39;s fairly simple references:\r\n\r\n```\r\njq --argfile cat_lookup categories.json --argfile cat_word en_CA.json &#39;\r\n  .category_key = $cat_lookup[.category_id | tostring].key \r\n  | .category_desc = $cat_word.global.transactionsCategories[.category_key]\r\n&#39; ${START_YEAR}-transaction.json\r\n```\r\nproducing\r\n\r\n```\r\n{\r\n  &quot;transaction_date&quot;: &quot;2020-01-01&quot;,\r\n  &quot;id&quot;: 365707178,\r\n  &quot;category_id&quot;: 113,\r\n  &quot;description&quot;: &quot;PAYPAL *JOES DC&quot;,\r\n  &quot;category_key&quot;: &quot;electronicsComputers&quot;,\r\n  &quot;category_desc&quot;: &quot;Electronics &amp; Computers&quot;\r\n}\r\n{\r\n  &quot;transaction_date&quot;: &quot;2020-01-02&quot;,\r\n  &quot;id&quot;: 366592530,\r\n  &quot;category_id&quot;: 84,\r\n  &quot;description&quot;: &quot;SANSOTEI RAMEN&quot;,\r\n  &quot;category_key&quot;: &quot;restaurants&quot;,\r\n  &quot;category_desc&quot;: &quot;Restaurants &quot;\r\n}\r\n...\r\n```\r\n\r\nOr in one step (without storing the category key):\r\n\r\n```\r\njq --argfile cat_lookup categories.json --argfile cat_word en_CA.json &#39;\r\n  .category_desc = $cat_word.global.transactionsCategories[\r\n    $cat_lookup[.category_id | tostring].key\r\n  ]\r\n&#39; ${START_YEAR}-transaction.json\r\n```\r\n\r\nNote: The [jq manual][1] discourages you from using `--argfile` and suggests to use `--slurpfile` instead. This would slightly change the way you have to access your variables, as they would become an array containing the actual object as single element. Thus, with `--slurpfile` use `$cat_lookup[0]` and `$cat_word[0]` instead of `$cat_lookup` and `$cat_word`, respectively.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "How to do a two-step lookup using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1634326443,
        "creation_date": 1634265115,
        "question_id": 69579355,
        "body_markdown": "My bank provides a very poor excuse for transaction export which makes doing reconciling receipts for taxes way more difficult than it needs be, fortunately their web site is an SPA that is chock-full of rich json formatted data.\r\n\r\nHaving extracted all of the transaction data for a year, I&#39;d now like to transform that data into filenames (`date - cat - desc - amt.pdf`) to use for receipt scans to help speed up the reconciling process.  \r\n\r\nI&#39;m close to being able to do this but a doing a double lookup has stumped me and I could use the help of someone more well versed in `jq`. \r\n\r\n## Sample transaction data\r\n\r\nHere&#39;s a sample set of the data (many fields omitted for privacy).\r\n\r\n```sh\r\nexport START_YEAR=2020\r\ncat ${START_YEAR}-transaction.json | jq -c -r \\\r\n&#39;{ transaction_date: .transaction_date | capture(&quot;(?&lt;x&gt;[0-9,-]{10})&quot;) | join(&quot;-&quot;), id: .id, category_id: .category_id, description: .description }&#39; \\\r\n| tail -4\r\n```\r\n\r\n```json\r\n{&quot;transaction_date&quot;:&quot;2020-01-01&quot;,&quot;id&quot;:365707178,&quot;category_id&quot;:113,&quot;description&quot;:&quot;PAYPAL *JOES DC&quot;}\r\n{&quot;transaction_date&quot;:&quot;2020-01-02&quot;,&quot;id&quot;:366592530,&quot;category_id&quot;:84,&quot;description&quot;:&quot;SANSOTEI RAMEN&quot;}\r\n{&quot;transaction_date&quot;:&quot;2020-01-02&quot;,&quot;id&quot;:365963458,&quot;category_id&quot;:84,&quot;description&quot;:&quot;RURU RESTAURANT&quot;}\r\n{&quot;transaction_date&quot;:&quot;2020-01-09&quot;,&quot;id&quot;:367661534,&quot;category_id&quot;:211,&quot;description&quot;:&quot;PAYMENT - THANK YOU&quot;}\r\n{&quot;transaction_date&quot;:&quot;2020-01-12&quot;,&quot;id&quot;:368954730,&quot;category_id&quot;:35,&quot;description&quot;:&quot;PEARSON PARKING T3&quot;}\r\n{&quot;transaction_date&quot;:&quot;2020-03-03&quot;,&quot;id&quot;:383492950,&quot;category_id&quot;:84,&quot;description&quot;:&quot;WVRST&quot;}\r\n{&quot;transaction_date&quot;:&quot;2020-03-18&quot;,&quot;id&quot;:387334378,&quot;category_id&quot;:113,&quot;description&quot;:&quot;WWW.ALIEXPRESS.COM LONDON GBR&quot;}\r\n{&quot;transaction_date&quot;:&quot;2020-03-27&quot;,&quot;id&quot;:389293681,&quot;category_id&quot;:91,&quot;description&quot;:&quot;PAYPAL *CORGI TECH GBR&quot;}\r\n{&quot;transaction_date&quot;:&quot;2020-10-09&quot;,&quot;id&quot;:445515569,&quot;category_id&quot;:52,&quot;description&quot;:&quot;GOODLIFE FITNESS&quot;}\r\n{&quot;transaction_date&quot;:&quot;2020-10-27&quot;,&quot;id&quot;:448912859,&quot;category_id&quot;:211,&quot;description&quot;:&quot;Credit Card Payment&quot;}\r\n{&quot;transaction_date&quot;:&quot;2020-12-18&quot;,&quot;id&quot;:466667441,&quot;category_id&quot;:64,&quot;description&quot;:&quot;KICKSTARTER: A TECHNOL SHAM SHUI PO KOW&quot;}\r\n{&quot;transaction_date&quot;:&quot;2020-12-31&quot;,&quot;id&quot;:469463176,&quot;category_id&quot;:4,&quot;description&quot;:&quot;Interest Paid&quot;}\r\n```\r\n\r\n## Lookup #1: category id to translation tag\r\n\r\nFirst the `category_id` is looked up in following categories data set to extract out a category.key which is a translation tag (i.e. category_id 113 is `electronicsComputers`)\r\n\r\ncategories.json (extracted from angular app file - `app.dc68cc71460569631f28.js`)\r\n```json\r\n{&quot;1&quot;:{&quot;id&quot;:1,&quot;icon&quot;:&quot;icon-income&quot;,&quot;key&quot;:&quot;income&quot;,&quot;parentCategoryId&quot;:null,&quot;color&quot;:&quot;#609b02&quot;},&quot;2&quot;:{&quot;id&quot;:2,&quot;icon&quot;:&quot;icon-cheque&quot;,&quot;key&quot;:&quot;payrollorEmploymentIncome&quot;,&quot;parentCategoryId&quot;:1},&quot;4&quot;:{&quot;id&quot;:4,&quot;icon&quot;:&quot;icon-interest&quot;,&quot;key&quot;:&quot;interestCapitalIncome&quot;,&quot;parentCategoryId&quot;:1},&quot;5&quot;:{&quot;id&quot;:5,&quot;icon&quot;:&quot;icon-income-tax-94&quot;,&quot;key&quot;:&quot;taxRefund&quot;,&quot;parentCategoryId&quot;:1},&quot;13&quot;:{&quot;id&quot;:13,&quot;icon&quot;:&quot;icon-home&quot;,&quot;key&quot;:&quot;home&quot;,&quot;parentCategoryId&quot;:null,&quot;color&quot;:&quot;#335400&quot;},&quot;14&quot;:{&quot;id&quot;:14,&quot;icon&quot;:&quot;r&quot;,&quot;key&quot;:&quot;groceries&quot;,&quot;parentCategoryId&quot;:116},&quot;16&quot;:{&quot;id&quot;:16,&quot;icon&quot;:&quot;icon-lightbulb&quot;,&quot;key&quot;:&quot;electricityHeatingUtilities&quot;,&quot;parentCategoryId&quot;:13},&quot;17&quot;:{&quot;id&quot;:17,&quot;icon&quot;:&quot;icon-home-insurance&quot;,&quot;key&quot;:&quot;homeInsurancePremiums&quot;,&quot;parentCategoryId&quot;:307},&quot;18&quot;:{&quot;id&quot;:18,&quot;icon&quot;:&quot;icon-tv&quot;,&quot;key&quot;:&quot;tVPhoneInternet&quot;,&quot;parentCategoryId&quot;:13},&quot;20&quot;:{&quot;id&quot;:20,&quot;icon&quot;:&quot;icon-cleaning&quot;,&quot;key&quot;:&quot;homeCleaning&quot;,&quot;parentCategoryId&quot;:13},&quot;21&quot;:{&quot;id&quot;:21,&quot;icon&quot;:&quot;icon-rent-paid&quot;,&quot;key&quot;:&quot;rentPaid&quot;,&quot;parentCategoryId&quot;:13},&quot;23&quot;:{&quot;id&quot;:23,&quot;icon&quot;:&quot;s&quot;,&quot;key&quot;:&quot;furnishingsAppliancesD&#233;cor&quot;,&quot;parentCategoryId&quot;:13},&quot;24&quot;:{&quot;id&quot;:24,&quot;icon&quot;:&quot;icon-art&quot;,&quot;key&quot;:&quot;flowersCandlesArtSmallItems&quot;,&quot;parentCategoryId&quot;:64},&quot;27&quot;:{&quot;id&quot;:27,&quot;icon&quot;:&quot;icon-mortgage&quot;,&quot;key&quot;:&quot;mortgage&quot;,&quot;parentCategoryId&quot;:13},&quot;28&quot;:{&quot;id&quot;:28,&quot;icon&quot;:&quot;icon-property-taxes&quot;,&quot;key&quot;:&quot;propertyTaxes&quot;,&quot;parentCategoryId&quot;:13},&quot;29&quot;:{&quot;id&quot;:29,&quot;icon&quot;:&quot;c&quot;,&quot;key&quot;:&quot;homeImprovementsRepairs&quot;,&quot;parentCategoryId&quot;:13},&quot;32&quot;:{&quot;id&quot;:32,&quot;icon&quot;:&quot;icon-car&quot;,&quot;key&quot;:&quot;carsTransportation&quot;,&quot;parentCategoryId&quot;:null,&quot;color&quot;:&quot;#0064d8&quot;},&quot;33&quot;:{&quot;id&quot;:33,&quot;icon&quot;:&quot;icon-auto-insurance&quot;,&quot;key&quot;:&quot;autoInsurancePremiums&quot;,&quot;parentCategoryId&quot;:307},&quot;35&quot;:{&quot;id&quot;:35,&quot;icon&quot;:&quot;icon-car&quot;,&quot;key&quot;:&quot;parking&quot;,&quot;parentCategoryId&quot;:32},&quot;36&quot;:{&quot;id&quot;:36,&quot;icon&quot;:&quot;icon-gas&quot;,&quot;key&quot;:&quot;gasFuel&quot;,&quot;parentCategoryId&quot;:32},&quot;37&quot;:{&quot;id&quot;:37,&quot;icon&quot;:&quot;icon-wrench&quot;,&quot;key&quot;:&quot;autoMaintenanceExpenses&quot;,&quot;parentCategoryId&quot;:32},&quot;38&quot;:{&quot;id&quot;:38,&quot;icon&quot;:&quot;icon-auto-loan&quot;,&quot;key&quot;:&quot;autoLoanLeasePayment&quot;,&quot;parentCategoryId&quot;:32},&quot;39&quot;:{&quot;id&quot;:39,&quot;icon&quot;:&quot;icon-bus&quot;,&quot;key&quot;:&quot;taxisPublicTransportation&quot;,&quot;parentCategoryId&quot;:32},&quot;40&quot;:{&quot;id&quot;:40,&quot;icon&quot;:&quot;icon-family&quot;,&quot;key&quot;:&quot;family&quot;,&quot;parentCategoryId&quot;:null,&quot;color&quot;:&quot;#335400&quot;},&quot;41&quot;:{&quot;id&quot;:41,&quot;icon&quot;:&quot;icon-baby&quot;,&quot;key&quot;:&quot;childcare&quot;,&quot;parentCategoryId&quot;:40},&quot;42&quot;:{&quot;id&quot;:42,&quot;icon&quot;:&quot;icon-childrens-clothes&quot;,&quot;key&quot;:&quot;children&#39;sClothing&quot;,&quot;parentCategoryId&quot;:40},&quot;43&quot;:{&quot;id&quot;:43,&quot;icon&quot;:&quot;icon-childrens-toys&quot;,&quot;key&quot;:&quot;children&#39;sToys&quot;,&quot;parentCategoryId&quot;:40},&quot;46&quot;:{&quot;id&quot;:46,&quot;icon&quot;:&quot;icon-paddleball&quot;,&quot;key&quot;:&quot;children&#39;sRecreationalActivities&quot;,&quot;parentCategoryId&quot;:40},&quot;48&quot;:{&quot;id&quot;:48,&quot;icon&quot;:&quot;icon-health-and-beauty&quot;,&quot;key&quot;:&quot;healthBeauty&quot;,&quot;parentCategoryId&quot;:null,&quot;color&quot;:&quot;#048476&quot;},&quot;49&quot;:{&quot;id&quot;:49,&quot;icon&quot;:&quot;l&quot;,&quot;key&quot;:&quot;drugStoresandPharmacies&quot;,&quot;parentCategoryId&quot;:48},&quot;50&quot;:{&quot;id&quot;:50,&quot;icon&quot;:&quot;icon-health-insurance&quot;,&quot;key&quot;:&quot;lifeHealthInsurancePremiums&quot;,&quot;parentCategoryId&quot;:307},&quot;51&quot;:{&quot;id&quot;:51,&quot;icon&quot;:&quot;icon-bandaid&quot;,&quot;key&quot;:&quot;doctorsHealthcare&quot;,&quot;parentCategoryId&quot;:48},&quot;52&quot;:{&quot;id&quot;:52,&quot;icon&quot;:&quot;icon-sports&quot;,&quot;key&quot;:&quot;sports&quot;,&quot;parentCategoryId&quot;:70},&quot;54&quot;:{&quot;id&quot;:54,&quot;icon&quot;:&quot;icon-loans-taxes-fines&quot;,&quot;key&quot;:&quot;loansTaxesandFines&quot;,&quot;parentCategoryId&quot;:null,&quot;color&quot;:&quot;#4c7b02&quot;},&quot;55&quot;:{&quot;id&quot;:55,&quot;icon&quot;:&quot;icon-fines&quot;,&quot;key&quot;:&quot;fines&quot;,&quot;parentCategoryId&quot;:54},&quot;59&quot;:{&quot;id&quot;:59,&quot;icon&quot;:&quot;icon-bank-fees&quot;,&quot;key&quot;:&quot;bankFeesServiceFees&quot;,&quot;parentCategoryId&quot;:54},&quot;61&quot;:{&quot;id&quot;:61,&quot;icon&quot;:&quot;icon-media&quot;,&quot;key&quot;:&quot;subscriptionsMedia&quot;,&quot;parentCategoryId&quot;:64},&quot;64&quot;:{&quot;id&quot;:64,&quot;icon&quot;:&quot;icon-shopping&quot;,&quot;key&quot;:&quot;shoppingServices&quot;,&quot;parentCategoryId&quot;:null,&quot;color&quot;:&quot;#7a18c2&quot;},&quot;65&quot;:{&quot;id&quot;:65,&quot;icon&quot;:&quot;icon-clothing&quot;,&quot;key&quot;:&quot;clothingShoes&quot;,&quot;parentCategoryId&quot;:64},&quot;66&quot;:{&quot;id&quot;:66,&quot;icon&quot;:&quot;icon-heart&quot;,&quot;key&quot;:&quot;beautyProducts&quot;,&quot;parentCategoryId&quot;:48},&quot;67&quot;:{&quot;id&quot;:67,&quot;icon&quot;:&quot;icon-scissors&quot;,&quot;key&quot;:&quot;barberHairdressingSalon&quot;,&quot;parentCategoryId&quot;:48},&quot;69&quot;:{&quot;id&quot;:69,&quot;icon&quot;:&quot;icon-iron&quot;,&quot;key&quot;:&quot;dryCleaningClothingRepairs&quot;,&quot;parentCategoryId&quot;:64},&quot;70&quot;:{&quot;id&quot;:70,&quot;icon&quot;:&quot;icon-leisure&quot;,&quot;key&quot;:&quot;leisure&quot;,&quot;parentCategoryId&quot;:null,&quot;color&quot;:&quot;#7a18c2&quot;},&quot;71&quot;:{&quot;id&quot;:71,&quot;icon&quot;:&quot;icon-fast-food&quot;,&quot;key&quot;:&quot;fastFoodQuickService&quot;,&quot;parentCategoryId&quot;:116},&quot;72&quot;:{&quot;id&quot;:72,&quot;icon&quot;:&quot;icon-spa&quot;,&quot;key&quot;:&quot;spaMassagePersonalCare&quot;,&quot;parentCategoryId&quot;:48},&quot;76&quot;:{&quot;id&quot;:76,&quot;icon&quot;:&quot;icon-membership&quot;,&quot;key&quot;:&quot;memberships&quot;,&quot;parentCategoryId&quot;:70},&quot;79&quot;:{&quot;id&quot;:79,&quot;icon&quot;:&quot;icon-beer&quot;,&quot;key&quot;:&quot;barsPubsNightclubs&quot;,&quot;parentCategoryId&quot;:70},&quot;81&quot;:{&quot;id&quot;:81,&quot;icon&quot;:&quot;icon-martini&quot;,&quot;key&quot;:&quot;alcoholBars&quot;,&quot;parentCategoryId&quot;:116},&quot;82&quot;:{&quot;id&quot;:82,&quot;icon&quot;:&quot;icon-champagne&quot;,&quot;key&quot;:&quot;tobaccoAlcohol&quot;,&quot;parentCategoryId&quot;:64},&quot;84&quot;:{&quot;id&quot;:84,&quot;icon&quot;:&quot;icon-restaurant&quot;,&quot;key&quot;:&quot;restaurants&quot;,&quot;parentCategoryId&quot;:116},&quot;86&quot;:{&quot;id&quot;:86,&quot;icon&quot;:&quot;icon-education&quot;,&quot;key&quot;:&quot;education&quot;,&quot;parentCategoryId&quot;:null,&quot;color&quot;:&quot;#02685d&quot;},&quot;87&quot;:{&quot;id&quot;:87,&quot;icon&quot;:&quot;icon-student-loans&quot;,&quot;key&quot;:&quot;studentLoanPayment&quot;,&quot;parentCategoryId&quot;:86},&quot;88&quot;:{&quot;id&quot;:88,&quot;icon&quot;:&quot;icon-graduation&quot;,&quot;key&quot;:&quot;tuitionCourses&quot;,&quot;parentCategoryId&quot;:86},&quot;89&quot;:{&quot;id&quot;:89,&quot;icon&quot;:&quot;icon-papers&quot;,&quot;key&quot;:&quot;schoolBooksMaterialsStationery&quot;,&quot;parentCategoryId&quot;:86},&quot;91&quot;:{&quot;id&quot;:91,&quot;icon&quot;:&quot;icon-gift&quot;,&quot;key&quot;:&quot;gifts&quot;,&quot;parentCategoryId&quot;:64},&quot;95&quot;:{&quot;id&quot;:95,&quot;icon&quot;:&quot;icon-party&quot;,&quot;key&quot;:&quot;partiesCelebrations&quot;,&quot;parentCategoryId&quot;:64},&quot;96&quot;:{&quot;id&quot;:96,&quot;icon&quot;:&quot;icon-plane&quot;,&quot;key&quot;:&quot;vacationTravel&quot;,&quot;parentCategoryId&quot;:null,&quot;color&quot;:&quot;#0064d8&quot;},&quot;97&quot;:{&quot;id&quot;:97,&quot;icon&quot;:&quot;icon-train&quot;,&quot;key&quot;:&quot;transportationCarRental&quot;,&quot;parentCategoryId&quot;:96},&quot;98&quot;:{&quot;id&quot;:98,&quot;icon&quot;:&quot;d&quot;,&quot;key&quot;:&quot;hotelsAccommodation&quot;,&quot;parentCategoryId&quot;:96},&quot;99&quot;:{&quot;id&quot;:99,&quot;icon&quot;:&quot;icon-surfboard&quot;,&quot;key&quot;:&quot;recreationEntertainmentonVacation&quot;,&quot;parentCategoryId&quot;:96},&quot;100&quot;:{&quot;id&quot;:100,&quot;icon&quot;:&quot;icon-alcoholic-drink&quot;,&quot;key&quot;:&quot;foodLivingExpensesonVacation&quot;,&quot;parentCategoryId&quot;:96},&quot;101&quot;:{&quot;id&quot;:101,&quot;icon&quot;:&quot;icon-savings&quot;,&quot;key&quot;:&quot;investmentsSavings&quot;,&quot;parentCategoryId&quot;:null,&quot;color&quot;:&quot;#38629c&quot;},&quot;102&quot;:{&quot;id&quot;:102,&quot;icon&quot;:&quot;u&quot;,&quot;key&quot;:&quot;regularSavings&quot;,&quot;parentCategoryId&quot;:101},&quot;104&quot;:{&quot;id&quot;:104,&quot;icon&quot;:&quot;icon-donations-and-charities&quot;,&quot;key&quot;:&quot;charityDonations&quot;,&quot;parentCategoryId&quot;:null,&quot;color&quot;:&quot;#bc2e8d&quot;},&quot;105&quot;:{&quot;id&quot;:105,&quot;icon&quot;:&quot;icon-pets&quot;,&quot;key&quot;:&quot;pets&quot;,&quot;parentCategoryId&quot;:40},&quot;106&quot;:{&quot;id&quot;:106,&quot;icon&quot;:&quot;icon-trailer&quot;,&quot;key&quot;:&quot;summerHome/Cottage/Trailer&quot;,&quot;parentCategoryId&quot;:13},&quot;828&quot;:{&quot;id&quot;:828,&quot;icon&quot;:&quot;icon-condo-fees&quot;,&quot;key&quot;:&quot;condoFees&quot;,&quot;parentCategoryId&quot;:13},&quot;830&quot;:{&quot;id&quot;:830,&quot;icon&quot;:&quot;icon-tangerine-rewards&quot;,&quot;key&quot;:&quot;tangerineMoneyBackRewards&quot;,&quot;parentCategoryId&quot;:1},&quot;831&quot;:{&quot;id&quot;:831,&quot;icon&quot;:&quot;icon-uncategorized-expenses&quot;,&quot;key&quot;:&quot;uncategorizedExpenses&quot;,&quot;parentCategoryId&quot;:null,&quot;color&quot;:&quot;#757575&quot;},&quot;832&quot;:{&quot;id&quot;:832,&quot;icon&quot;:&quot;u&quot;,&quot;key&quot;:&quot;goalSavings&quot;,&quot;parentCategoryId&quot;:101},&quot;833&quot;:{&quot;id&quot;:833,&quot;icon&quot;:&quot;u&quot;,&quot;key&quot;:&quot;recipes&quot;,&quot;parentCategoryId&quot;:101},&quot;113&quot;:{&quot;id&quot;:113,&quot;icon&quot;:&quot;icon-computer&quot;,&quot;key&quot;:&quot;electronicsComputers&quot;,&quot;parentCategoryId&quot;:64},&quot;114&quot;:{&quot;id&quot;:114,&quot;icon&quot;:&quot;icon-jewelry&quot;,&quot;key&quot;:&quot;jewelleryAccessories&quot;,&quot;parentCategoryId&quot;:64},&quot;115&quot;:{&quot;id&quot;:115,&quot;icon&quot;:&quot;icon-toll&quot;,&quot;key&quot;:&quot;tolls&quot;,&quot;parentCategoryId&quot;:32},&quot;116&quot;:{&quot;id&quot;:116,&quot;icon&quot;:&quot;p&quot;,&quot;key&quot;:&quot;foodDining&quot;,&quot;parentCategoryId&quot;:null,&quot;color&quot;:&quot;#9339d4&quot;},&quot;117&quot;:{&quot;id&quot;:117,&quot;icon&quot;:&quot;icon-carwash&quot;,&quot;key&quot;:&quot;carCleaning&quot;,&quot;parentCategoryId&quot;:32},&quot;118&quot;:{&quot;id&quot;:118,&quot;icon&quot;:&quot;icon-rattle&quot;,&quot;key&quot;:&quot;supportPayment&quot;,&quot;parentCategoryId&quot;:40},&quot;121&quot;:{&quot;id&quot;:121,&quot;icon&quot;:&quot;icon-sin&quot;,&quot;key&quot;:&quot;socialInsurance&quot;,&quot;parentCategoryId&quot;:1},&quot;124&quot;:{&quot;id&quot;:124,&quot;icon&quot;:&quot;icon-loan&quot;,&quot;key&quot;:&quot;loanPayments&quot;,&quot;parentCategoryId&quot;:54},&quot;129&quot;:{&quot;id&quot;:129,&quot;icon&quot;:&quot;icon-pacifier&quot;,&quot;key&quot;:&quot;childcareProducts&quot;,&quot;parentCategoryId&quot;:40},&quot;131&quot;:{&quot;id&quot;:131,&quot;icon&quot;:&quot;icon-emergency-savings&quot;,&quot;key&quot;:&quot;emergencyFund&quot;,&quot;parentCategoryId&quot;:101},&quot;143&quot;:{&quot;id&quot;:143,&quot;icon&quot;:&quot;icon-other-pension&quot;,&quot;key&quot;:&quot;otherPension&quot;,&quot;parentCategoryId&quot;:1},&quot;145&quot;:{&quot;id&quot;:145,&quot;icon&quot;:&quot;icon-rental-income&quot;,&quot;key&quot;:&quot;rentalIncome&quot;,&quot;parentCategoryId&quot;:1},&quot;199&quot;:{&quot;id&quot;:199,&quot;icon&quot;:&quot;icon-compass&quot;,&quot;key&quot;:&quot;outdoorActivities&quot;,&quot;parentCategoryId&quot;:70},&quot;202&quot;:{&quot;id&quot;:202,&quot;icon&quot;:&quot;icon-paintbrush&quot;,&quot;key&quot;:&quot;artsCraftsMusic&quot;,&quot;parentCategoryId&quot;:70},&quot;210&quot;:{&quot;id&quot;:210,&quot;icon&quot;:&quot;icon-exclude-from-budget&quot;,&quot;key&quot;:&quot;excludefromBudget&quot;,&quot;parentCategoryId&quot;:null,&quot;color&quot;:&quot;#d50179&quot;},&quot;211&quot;:{&quot;id&quot;:211,&quot;icon&quot;:&quot;icon-credit-card-payment&quot;,&quot;key&quot;:&quot;creditCardPayments&quot;,&quot;parentCategoryId&quot;:210},&quot;212&quot;:{&quot;id&quot;:212,&quot;icon&quot;:&quot;icon-transfers&quot;,&quot;key&quot;:&quot;transfersBetweenownAccounts&quot;,&quot;parentCategoryId&quot;:210},&quot;216&quot;:{&quot;id&quot;:216,&quot;icon&quot;:&quot;icon-cash-withdrawal&quot;,&quot;key&quot;:&quot;aBMOtherCashWithdrawals&quot;,&quot;parentCategoryId&quot;:831},&quot;258&quot;:{&quot;id&quot;:258,&quot;icon&quot;:&quot;icon-dice&quot;,&quot;key&quot;:&quot;lotteriesGambling&quot;,&quot;parentCategoryId&quot;:70},&quot;259&quot;:{&quot;id&quot;:259,&quot;icon&quot;:&quot;icon-glasses&quot;,&quot;key&quot;:&quot;eyeCare&quot;,&quot;parentCategoryId&quot;:48},&quot;268&quot;:{&quot;id&quot;:268,&quot;icon&quot;:&quot;icon-uncategorized-income&quot;,&quot;key&quot;:&quot;uncategorizedIncome&quot;,&quot;parentCategoryId&quot;:1},&quot;283&quot;:{&quot;id&quot;:283,&quot;icon&quot;:&quot;icon-income-tax-89&quot;,&quot;key&quot;:&quot;incomeTaxPaid&quot;,&quot;parentCategoryId&quot;:54},&quot;289&quot;:{&quot;id&quot;:289,&quot;icon&quot;:&quot;icon-headphones&quot;,&quot;key&quot;:&quot;musicandApps&quot;,&quot;parentCategoryId&quot;:64},&quot;292&quot;:{&quot;id&quot;:292,&quot;icon&quot;:&quot;icon-savings-transfers&quot;,&quot;key&quot;:&quot;savingsAccountTransactions&quot;,&quot;parentCategoryId&quot;:210},&quot;298&quot;:{&quot;id&quot;:298,&quot;icon&quot;:&quot;icon-pocket-money&quot;,&quot;key&quot;:&quot;allowancePocketMoneyEtc&quot;,&quot;parentCategoryId&quot;:40},&quot;307&quot;:{&quot;id&quot;:307,&quot;icon&quot;:&quot;icon-insurance&quot;,&quot;key&quot;:&quot;insurance&quot;,&quot;parentCategoryId&quot;:null,&quot;color&quot;:&quot;#9b53cb&quot;},&quot;315&quot;:{&quot;id&quot;:315,&quot;icon&quot;:&quot;icon-retirement-savings&quot;,&quot;key&quot;:&quot;retirementSavings&quot;,&quot;parentCategoryId&quot;:101},&quot;801&quot;:{&quot;id&quot;:801,&quot;icon&quot;:&quot;icon-support-income&quot;,&quot;key&quot;:&quot;supportIncome&quot;,&quot;parentCategoryId&quot;:1},&quot;802&quot;:{&quot;id&quot;:802,&quot;icon&quot;:&quot;icon-coffee&quot;,&quot;key&quot;:&quot;coffeeShops&quot;,&quot;parentCategoryId&quot;:116},&quot;803&quot;:{&quot;id&quot;:803,&quot;icon&quot;:&quot;icon-desk-1&quot;,&quot;key&quot;:&quot;homeOffice&quot;,&quot;parentCategoryId&quot;:13},&quot;804&quot;:{&quot;id&quot;:804,&quot;icon&quot;:&quot;icon-dependants&quot;,&quot;key&quot;:&quot;dependants&quot;,&quot;parentCategoryId&quot;:40},&quot;805&quot;:{&quot;id&quot;:805,&quot;icon&quot;:&quot;icon-tooth&quot;,&quot;key&quot;:&quot;dental&quot;,&quot;parentCategoryId&quot;:48},&quot;806&quot;:{&quot;id&quot;:806,&quot;icon&quot;:&quot;icon-bottle&quot;,&quot;key&quot;:&quot;nursingCareFacilities&quot;,&quot;parentCategoryId&quot;:48},&quot;807&quot;:{&quot;id&quot;:807,&quot;icon&quot;:&quot;icon-sports-apparel&quot;,&quot;key&quot;:&quot;sportsApparel&quot;,&quot;parentCategoryId&quot;:64},&quot;808&quot;:{&quot;id&quot;:808,&quot;icon&quot;:&quot;icon-pens&quot;,&quot;key&quot;:&quot;schoolSupplies&quot;,&quot;parentCategoryId&quot;:64},&quot;809&quot;:{&quot;id&quot;:809,&quot;icon&quot;:&quot;m&quot;,&quot;key&quot;:&quot;entertainment&quot;,&quot;parentCategoryId&quot;:70},&quot;810&quot;:{&quot;id&quot;:810,&quot;icon&quot;:&quot;icon-school-bus&quot;,&quot;key&quot;:&quot;fieldtripsMiscellaneousExpenses&quot;,&quot;parentCategoryId&quot;:86},&quot;811&quot;:{&quot;id&quot;:811,&quot;icon&quot;:&quot;icon-alcoholic-drink&quot;,&quot;key&quot;:&quot;travelAgenciesTourOperators&quot;,&quot;parentCategoryId&quot;:96},&quot;812&quot;:{&quot;id&quot;:812,&quot;icon&quot;:&quot;icon-signpost&quot;,&quot;key&quot;:&quot;souvenirsGifts&quot;,&quot;parentCategoryId&quot;:96},&quot;813&quot;:{&quot;id&quot;:813,&quot;icon&quot;:&quot;icon-securities&quot;,&quot;key&quot;:&quot;securities&quot;,&quot;parentCategoryId&quot;:101},&quot;814&quot;:{&quot;id&quot;:814,&quot;icon&quot;:&quot;icon-retirement-savings&quot;,&quot;key&quot;:&quot;rRSPs/RSPs&quot;,&quot;parentCategoryId&quot;:101},&quot;815&quot;:{&quot;id&quot;:815,&quot;icon&quot;:&quot;icon-savings&quot;,&quot;key&quot;:&quot;tFSAs&quot;,&quot;parentCategoryId&quot;:101},&quot;816&quot;:{&quot;id&quot;:816,&quot;icon&quot;:&quot;icon-trust-fund&quot;,&quot;key&quot;:&quot;trustFund&quot;,&quot;parentCategoryId&quot;:101},&quot;817&quot;:{&quot;id&quot;:817,&quot;icon&quot;:&quot;icon-education&quot;,&quot;key&quot;:&quot;rESPs&quot;,&quot;parentCategoryId&quot;:101},&quot;818&quot;:{&quot;id&quot;:818,&quot;icon&quot;:&quot;icon-travel-insurance&quot;,&quot;key&quot;:&quot;travelInsurancePremiums&quot;,&quot;parentCategoryId&quot;:307},&quot;819&quot;:{&quot;id&quot;:819,&quot;icon&quot;:&quot;icon-marine-insurance&quot;,&quot;key&quot;:&quot;marineInsurancePremiums&quot;,&quot;parentCategoryId&quot;:307},&quot;820&quot;:{&quot;id&quot;:820,&quot;icon&quot;:&quot;icon-pet-insurance&quot;,&quot;key&quot;:&quot;petInsurancePremiums&quot;,&quot;parentCategoryId&quot;:307},&quot;821&quot;:{&quot;id&quot;:821,&quot;icon&quot;:&quot;icon-charities&quot;,&quot;key&quot;:&quot;charities&quot;,&quot;parentCategoryId&quot;:104},&quot;822&quot;:{&quot;id&quot;:822,&quot;icon&quot;:&quot;icon-donations&quot;,&quot;key&quot;:&quot;donations&quot;,&quot;parentCategoryId&quot;:104},&quot;823&quot;:{&quot;id&quot;:823,&quot;icon&quot;:&quot;icon-credit-card-other&quot;,&quot;key&quot;:&quot;nonTangerineCreditCardPayments&quot;,&quot;parentCategoryId&quot;:831},&quot;824&quot;:{&quot;id&quot;:824,&quot;icon&quot;:&quot;icon-weights&quot;,&quot;key&quot;:&quot;gymSports&quot;,&quot;parentCategoryId&quot;:48},&quot;826&quot;:{&quot;id&quot;:826,&quot;icon&quot;:&quot;icon-tangerine-loan-payment&quot;,&quot;key&quot;:&quot;tangerineLoanPayments&quot;,&quot;parentCategoryId&quot;:210},&quot;827&quot;:{&quot;id&quot;:827,&quot;icon&quot;:&quot;icon-tangerine-mortgage-payment&quot;,&quot;key&quot;:&quot;tangerineMortgagePayments&quot;,&quot;parentCategoryId&quot;:210},&quot;829&quot;:{&quot;id&quot;:829,&quot;icon&quot;:&quot;icon-interest-charge&quot;,&quot;key&quot;:&quot;interestCharge&quot;,&quot;parentCategoryId&quot;:54},&quot;112&quot;:{&quot;id&quot;:112,&quot;icon&quot;:&quot;icon-question2&quot;,&quot;key&quot;:&quot;uncategorized&quot;,&quot;parentCategoryId&quot;:null,&quot;color&quot;:&quot;#757575&quot;}}\r\n```\r\n\r\n## Lookup #2: translation tag to natural language description\r\n\r\nNext the translation tag obtained from step #1 (i.e. `electronicsComputers`) is looked up in a file called `en_CA.json` (or `fr_CA.json` if using the site in French), this gives the desired natural language description: `Electronics &amp; Computers`\r\n\r\n```json\r\n{&quot;OMITTED_OTHER_STUFF&quot;:{},&quot;global&quot;:{&quot;OMITTED_OTHER_STUFF&quot;:{},&quot;transactionsCategories&quot;:{&quot;income&quot;:&quot;Income&quot;,&quot;payrollorEmploymentIncome&quot;:&quot; Payroll or Employment Income&quot;,&quot;interestCapitalIncome&quot;:&quot;Interest &amp; Capital Income&quot;,&quot;taxRefund&quot;:&quot;Tax Refund&quot;,&quot;home&quot;:&quot;Home&quot;,&quot;groceries&quot;:&quot; Groceries&quot;,&quot;electricityHeatingUtilities&quot;:&quot; Electricity &amp; Heating (Utilities)&quot;,&quot;homeInsurancePremiums&quot;:&quot; Home Insurance Premiums&quot;,&quot;tVPhoneInternet&quot;:&quot;TV, Phone &amp; Internet&quot;,&quot;homeCleaning&quot;:&quot;Home Cleaning&quot;,&quot;rentPaid&quot;:&quot;Rent Paid&quot;,&quot;furnishingsAppliancesD&#233;cor&quot;:&quot;Furnishings, Appliances &amp; D&#233;cor&quot;,&quot;flowersCandlesArtSmallItems&quot;:&quot;Flowers, Candles, Art &amp; Small Items&quot;,&quot;mortgage&quot;:&quot;Mortgage&quot;,&quot;propertyTaxes&quot;:&quot;Property Taxes&quot;,&quot;homeImprovementsRepairs&quot;:&quot;Home Improvements &amp; Repairs&quot;,&quot;carsTransportation&quot;:&quot;Cars &amp; Transportation&quot;,&quot;autoInsurancePremiums&quot;:&quot;Auto Insurance Premiums&quot;,&quot;parking&quot;:&quot; Parking&quot;,&quot;gasFuel&quot;:&quot;Gas &amp; Fuel&quot;,&quot;autoMaintenanceExpenses&quot;:&quot;Auto Maintenance &amp; Expenses &quot;,&quot;autoLoanLeasePayment&quot;:&quot;Auto Loan &amp; Lease Payment&quot;,&quot;taxisPublicTransportation&quot;:&quot;Taxis &amp; Public Transportation&quot;,&quot;family&quot;:&quot;Family&quot;,&quot;childcare&quot;:&quot; Childcare&quot;,&quot;children&#39;sClothing&quot;:&quot;Children&#39;s Clothing&quot;,&quot;children&#39;sToys&quot;:&quot;Children&#39;s Toys&quot;,&quot;children&#39;sRecreationalActivities&quot;:&quot;Children&#39;s Recreational Activities&quot;,&quot;healthBeauty&quot;:&quot;Health &amp; Beauty&quot;,&quot;drugStoresandPharmacies&quot;:&quot; Drug Stores and Pharmacies&quot;,&quot;lifeHealthInsurancePremiums&quot;:&quot;Life &amp; Health Insurance Premiums&quot;,&quot;doctorsHealthcare&quot;:&quot;Doctors &amp; Healthcare&quot;,&quot;sports&quot;:&quot;Sports&quot;,&quot;loansTaxesandFines&quot;:&quot;Loans, Taxes, and Fines&quot;,&quot;fines&quot;:&quot; Fines&quot;,&quot;bankFeesServiceFees&quot;:&quot;Bank Fees &amp; Service Fees&quot;,&quot;subscriptionsMedia&quot;:&quot;Subscriptions &amp; Media&quot;,&quot;shoppingServices&quot;:&quot;Shopping &amp; Services&quot;,&quot;clothingShoes&quot;:&quot;Clothing &amp; Shoes&quot;,&quot;beautyProducts&quot;:&quot;Beauty Products&quot;,&quot;barberHairdressingSalon&quot;:&quot;Barber &amp; Hairdressing Salon&quot;,&quot;dryCleaningClothingRepairs&quot;:&quot;Dry Cleaning &amp; Clothing Repairs&quot;,&quot;leisure&quot;:&quot;Leisure &quot;,&quot;fastFoodQuickService&quot;:&quot;Fast Food (Quick Service)&quot;,&quot;spaMassagePersonalCare&quot;:&quot;Spa, Massage &amp; Personal Care&quot;,&quot;memberships&quot;:&quot; Memberships&quot;,&quot;barsPubsNightclubs&quot;:&quot;Bars, Pubs &amp; Nightclubs &quot;,&quot;alcoholBars&quot;:&quot;Alcohol &amp; Bars &quot;,&quot;tobaccoAlcohol&quot;:&quot;Tobacco &amp; Alcohol&quot;,&quot;restaurants&quot;:&quot;Restaurants &quot;,&quot;education&quot;:&quot;Education&quot;,&quot;studentLoanPayment&quot;:&quot; Student Loan Payment&quot;,&quot;tuitionCourses&quot;:&quot;Tuition &amp; Courses&quot;,&quot;schoolBooksMaterialsStationery&quot;:&quot;School Books, Materials &amp; Stationery&quot;,&quot;gifts&quot;:&quot;Gifts&quot;,&quot;partiesCelebrations&quot;:&quot;Parties &amp; Celebrations&quot;,&quot;vacationTravel&quot;:&quot;Vacation &amp; Travel&quot;,&quot;transportationCarRental&quot;:&quot; Transportation &amp; Car Rental&quot;,&quot;hotelsAccommodation&quot;:&quot;Hotels &amp; Accommodation&quot;,&quot;recreationEntertainmentonVacation&quot;:&quot;Recreation &amp; Entertainment on Vacation&quot;,&quot;foodLivingExpensesonVacation&quot;:&quot;Food &amp; Living Expenses on Vacation&quot;,&quot;investmentsSavings&quot;:&quot;Investments &amp; Savings&quot;,&quot;regularSavings&quot;:&quot; Regular Savings&quot;,&quot;goalSavings&quot;:&quot;Goals&quot;,&quot;charityDonations&quot;:&quot;Charity &amp; Donations&quot;,&quot;pets&quot;:&quot;Pets&quot;,&quot;summerHome/Cottage/Trailer&quot;:&quot;Summer Home/ Cottage/Trailer  &quot;,&quot;uncategorizedExpenses&quot;:&quot;Miscellaneous Expenses&quot;,&quot;electronicsComputers&quot;:&quot;Electronics &amp; Computers&quot;,&quot;jewelleryAccessories&quot;:&quot;Jewellery &amp; Accessories&quot;,&quot;tolls&quot;:&quot;Tolls&quot;,&quot;foodDining&quot;:&quot;Food &amp; Dining&quot;,&quot;carCleaning&quot;:&quot;Car Cleaning&quot;,&quot;supportPayment&quot;:&quot;Support Payment&quot;,&quot;socialInsurance&quot;:&quot;Payments from Government&quot;,&quot;loanPayments&quot;:&quot;Loan Payments&quot;,&quot;childcareProducts&quot;:&quot;Childcare Products&quot;,&quot;emergencyFund&quot;:&quot;Emergency Fund&quot;,&quot;otherPension&quot;:&quot;Other Pension&quot;,&quot;rentalIncome&quot;:&quot;Rental Income&quot;,&quot;outdoorActivities&quot;:&quot;Outdoor Activities &quot;,&quot;artsCraftsMusic&quot;:&quot;Arts, Crafts &amp; Music&quot;,&quot;excludefromBudget&quot;:&quot;Exclude from Budget&quot;,&quot;creditCardPayments&quot;:&quot; Credit Card Payments&quot;,&quot;transfersBetweenownAccounts&quot;:&quot;Transfers Between own Accounts&quot;,&quot;aBMOtherCashWithdrawals&quot;:&quot; ABM &amp; Other Cash Withdrawals&quot;,&quot;uncategorizedTransfers&quot;:&quot;Uncategorized Transfers&quot;,&quot;lotteriesGambling&quot;:&quot;Lotteries &amp; Gambling&quot;,&quot;eyeCare&quot;:&quot;Eye Care&quot;,&quot;uncategorizedIncome&quot;:&quot;Miscellaneous Income&quot;,&quot;incomeTaxPaid&quot;:&quot;Income Tax Paid&quot;,&quot;musicandApps&quot;:&quot;Music and Apps&quot;,&quot;savingsAccountTransactions&quot;:&quot;Savings Account Transactions&quot;,&quot;allowancePocketMoneyEtc&quot;:&quot;Allowance, Pocket Money, Etc.&quot;,&quot;insurance&quot;:&quot;Insurance&quot;,&quot;retirementSavings&quot;:&quot;Retirement Savings&quot;,&quot;supportIncome&quot;:&quot;Support Income&quot;,&quot;coffeeShops&quot;:&quot;Coffee Shops&quot;,&quot;homeOffice&quot;:&quot;Home Office&quot;,&quot;dependants&quot;:&quot;Dependants&quot;,&quot;dental&quot;:&quot;Dental&quot;,&quot;nursingCareFacilities&quot;:&quot;Nursing &amp; Care Facilities&quot;,&quot;sportsApparel&quot;:&quot;Sports Apparel&quot;,&quot;schoolSupplies&quot;:&quot;School Supplies&quot;,&quot;entertainment&quot;:&quot;Entertainment&quot;,&quot;fieldtripsMiscellaneousExpenses&quot;:&quot;Fieldtrips &amp; Miscellaneous Expenses&quot;,&quot;travelAgenciesTourOperators&quot;:&quot;Travel Agencies &amp; Tour Operators&quot;,&quot;souvenirsGifts&quot;:&quot;Souvenirs &amp; Gifts &quot;,&quot;securities&quot;:&quot;Securities&quot;,&quot;rRSPs/RSPs&quot;:&quot;RRSPs/RSPs&quot;,&quot;tFSAs&quot;:&quot;TFSAs&quot;,&quot;trustFund&quot;:&quot;Trust Fund&quot;,&quot;rESPs&quot;:&quot;RESPs&quot;,&quot;travelInsurancePremiums&quot;:&quot;Travel Insurance Premiums&quot;,&quot;marineInsurancePremiums&quot;:&quot;Marine Insurance Premiums&quot;,&quot;petInsurancePremiums&quot;:&quot;Pet Insurance Premiums&quot;,&quot;charities&quot;:&quot; Charities&quot;,&quot;donations&quot;:&quot;Donations&quot;,&quot;gymSports&quot;:&quot;Gym &amp; Sports&quot;,&quot;uncategorized&quot;:&quot;Uncategorized&quot;,&quot;other&quot;:&quot;Other&quot;,&quot;interestCharge&quot;:&quot;Interest Charge&quot;,&quot;tangerineLoanPayments&quot;:&quot;Tangerine Loan Payments&quot;,&quot;tangerineMortgagePayments&quot;:&quot;Tangerine Mortgage Payments&quot;,&quot;tangerineMoneyBackRewards&quot;:&quot;Tangerine Money-Back Rewards&quot;,&quot;condoFees&quot;:&quot;Condo Fees&quot;,&quot;nonTangerineCreditCardPayments&quot;:&quot;Non-Tangerine Credit Card Payments&quot;,&quot;recipes&quot;:&quot;Money Rules&quot;}}}\r\n```\r\n\r\n\r\nI believe the logic would be something like this:\r\n```sh\r\njq --argfile cat_lookup categories.json --argfile cat_word en_CA.json \\\r\n&#39;if $cat_lookup.transactionsCategories.id == .category_id then .cat_desc = $cat_word[$cat_lookup.key] end&#39; \\ \r\n${START_YEAR}-transaction.json | head\r\n\r\njq: error: syntax error, unexpected end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\nif $cat_lookup.transactionsCategories.id == .category_id then .cat_desc = $cat_word[$cat_lookup.key] end                                                                                                     \r\njq: error: Possibly unterminated &#39;if&#39; statement at &lt;top-level&gt;, line 1:\r\nif $cat_lookup.transactionsCategories.id == .category_id then .cat_desc = $cat_word[$cat_lookup.key] end\r\njq: 2 compile errors\r\n```\r\n\r\nObviously this fails because my syntax is bad and there needs to be a search each for of all $cat_lookup.transactionsCategories and $cat_word values to match everything up...  \r\n\r\nwhat is the best way to accomplish that with jq?",
        "link": "https://stackoverflow.com/questions/69579355/how-to-do-a-two-step-lookup-using-jq",
        "title": "How to do a two-step lookup using jq?"
    },
    {
        "tags": [
            "json",
            "jq",
            "vivaldi"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 69488,
                    "reputation": 193,
                    "user_id": 202114,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9189f0752a1947ad8c2d239ccc0d7394?s=256&d=identicon&r=PG",
                    "display_name": "Stian Lund",
                    "link": "https://stackoverflow.com/users/202114/stian-lund"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634388967,
                "post_id": 69595774,
                "comment_id": 123013852,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1727270,
                    "reputation": 1005,
                    "user_id": 1581658,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ba81241548a044ebfbe853365c84e4ea?s=256&d=identicon&r=PG",
                    "display_name": "SamBob",
                    "link": "https://stackoverflow.com/users/1581658/sambob"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634389545,
                "post_id": 69595774,
                "comment_id": 123013978,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 69488,
                    "reputation": 193,
                    "user_id": 202114,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9189f0752a1947ad8c2d239ccc0d7394?s=256&d=identicon&r=PG",
                    "display_name": "Stian Lund",
                    "link": "https://stackoverflow.com/users/202114/stian-lund"
                },
                "reply_to_user": {
                    "account_id": 1727270,
                    "reputation": 1005,
                    "user_id": 1581658,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ba81241548a044ebfbe853365c84e4ea?s=256&d=identicon&r=PG",
                    "display_name": "SamBob",
                    "link": "https://stackoverflow.com/users/1581658/sambob"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634389800,
                "post_id": 69595774,
                "comment_id": 123014033,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1634391810,
                "creation_date": 1634391810,
                "answer_id": 69596133,
                "question_id": 69595774,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could add another constraint `startswith(&quot;data:image&quot;) | not` and `select` to keep only the elements whose `.key` does not match `or` whose `.value` does not start that way, resulting in: `select((.key | test(&quot;Thumbnail&quot;) | not) or (.value | startswith(&quot;data:image&quot;) | not))`. You could even apply De Morgan&#39;s laws and simplify it to `select(((.key | test(&quot;Thumbnail&quot;)) and (.value | startswith(&quot;data:image&quot;))) | not)`.\r\n\r\nHowever, there&#39;s a simpler approach: Assuming the overall structure is an array along the lines of\r\n```\r\n[\r\n  {\r\n    &quot;date_added&quot;: &quot;13215828073144281&quot;,\r\n    &quot;guid&quot;: &quot;3ace3174-ea60-42c5-88cf-e535a150ae38&quot;,\r\n    ...\r\n  },\r\n  {\r\n    &quot;date_added&quot;: &quot;13215828073144282&quot;,\r\n    &quot;guid&quot;: &quot;3ace3174-ea60-42c5-88cf-e535a150ae39&quot;,\r\n    ...\r\n  },\r\n  ...\r\n]\r\n```\r\n\r\nThen simply call\r\n```\r\njq &#39;map(del(.meta_info.Thumbnail | select(startswith(&quot;data:image&quot;))))&#39; Bookmarks\r\n```",
                "title": "Remove all objects containing a specific value from a JSON file using JQ?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1634391920,
                "creation_date": 1634391920,
                "answer_id": 69596148,
                "question_id": 69595774,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Something like this should do the trick:\r\n```\r\ndel(recurse | objects | select(has(&quot;Thumbnail&quot;)) .Thumbnail | select(startswith(&quot;data:image&quot;)))\r\n```",
                "title": "Remove all objects containing a specific value from a JSON file using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1634391920,
        "creation_date": 1634388858,
        "last_edit_date": 1634389505,
        "question_id": 69595774,
        "body_markdown": "The bookmarks file for the Vivaldi browser (based on Chromium) tends to accumulate a huge number of base64-encoded thumbnails taking up a lot of space, and I would like to remove these entries. The file is a JSON file and an entry looks like this:\r\n\r\n```\r\n{\r\n  &quot;date_added&quot;: &quot;13215828073144281&quot;,\r\n  &quot;guid&quot;: &quot;3ace3174-ea60-42c5-88cf-e535a150ae38&quot;,\r\n  &quot;id&quot;: &quot;74&quot;,\r\n  &quot;meta_info&quot;: {\r\n\t &quot;Thumbnail&quot;: &quot;data:image/jpeg;base64,/9j/4AAQSkZJRgA....AUpSgFKUoBSlKA//2Q==&quot;\r\n  },\r\n  &quot;name&quot;: &quot;RIPE WHOIS IP Address Database Search › Look up an IP addres… - iTools&quot;,\r\n  &quot;type&quot;: &quot;url&quot;,\r\n  &quot;url&quot;: &quot;http://itools.com/tool/ripe-whois-ip-address&quot;\r\n},\r\n```\r\n\r\nI already have a jq filter looking like this:\r\n\r\n`jq &#39;walk(if type == &quot;object&quot; then with_entries(select(.key | test(&quot;Thumbnail&quot;) | not)) else . end)&#39; Bookmarks &gt; Bookmarks2`\r\n\r\nThe problem is this also deletes entries containing custom thumbnails like this: \r\n\r\n`&quot;Thumbnail&quot;: &quot;chrome://vivaldi-data/local-image/aa0d8713-99c6-4fcb-a725-a29235c4e8b0&quot;,`\r\n\r\nSo the question is, how would I remove *only* the Thumbnail entries containing or starting with the string `data:image`?\r\n",
        "link": "https://stackoverflow.com/questions/69595774/remove-all-objects-containing-a-specific-value-from-a-json-file-using-jq",
        "title": "Remove all objects containing a specific value from a JSON file using JQ?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1634420971,
                "creation_date": 1634420971,
                "answer_id": 69599786,
                "question_id": 69599755,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to select the `data` field first: ```jq .data.aa[]```",
                "title": "How to parse this boolean contained JSON output with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1634420982,
        "creation_date": 1634420480,
        "question_id": 69599755,
        "body_markdown": "The JSON output I am trying to parse:\r\n```\r\n{\r\n  &quot;success&quot;: true,\r\n  &quot;data&quot;: {\r\n    &quot;aa&quot;: [\r\n      {\r\n        &quot;timestamp&quot;: 123456,\r\n        &quot;price&quot;: 1\r\n      },\r\n      {\r\n        &quot;timestamp&quot;: 123457,\r\n        &quot;price&quot;: 2\r\n    ],\r\n    &quot;bb&quot;: [\r\n      {\r\n        &quot;timestamp&quot;: 123456,\r\n        &quot;price&quot;: 3\r\n      },\r\n      {\r\n        &quot;timestamp&quot;: 123457,\r\n        &quot;price&quot;: 4\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nSo after banging my head against the wall a million times, I just removed the *&quot;success&quot;: true&quot;,* line from the output and I could easily do jq stuff with it. Otherwise if I ran for example:\r\n```\r\ncat jsonfile.json | jq -c .[].aa\r\n```\r\nI would get:\r\n\r\n&gt; Cannot index boolean with string &quot;aa&quot;\r\n\r\nWhich makes sense, since the first key is boolean. But I have no clue how to skip it while processing with jq.\r\n\r\nGoal is to filter only timestamp and price of &quot;aa&quot;, without giving any care about the &quot;success&quot;: true key/value pair.",
        "link": "https://stackoverflow.com/questions/69599755/how-to-parse-this-boolean-contained-json-output-with-jq",
        "title": "How to parse this boolean contained JSON output with jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634519107,
                "post_id": 69609625,
                "comment_id": 123038643,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634519520,
                "post_id": 69609625,
                "comment_id": 123038691,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22888643,
                    "reputation": 37,
                    "user_id": 17029123,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47928dbbfaf018117bc13687eb8f3adf?s=256&d=identicon&r=PG",
                    "display_name": "Ege",
                    "link": "https://stackoverflow.com/users/17029123/ege"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634586378,
                "post_id": 69609625,
                "comment_id": 123060198,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22888643,
                    "reputation": 37,
                    "user_id": 17029123,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47928dbbfaf018117bc13687eb8f3adf?s=256&d=identicon&r=PG",
                    "display_name": "Ege",
                    "link": "https://stackoverflow.com/users/17029123/ege"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634586547,
                "post_id": 69609625,
                "comment_id": 123060257,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1634529017,
                "last_edit_date": 1634529017,
                "creation_date": 1634522046,
                "answer_id": 69609991,
                "question_id": 69609625,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try something like this:\r\n\r\n```\r\njq --raw-output &#39;\r\n\r\n  .groups | to_entries[] | select(.key | IN(&quot;group_3&quot;) | not)\r\n  | [.key] + (.value | to_entries[] | [.key, .value[]])\r\n  | &quot;name: \\(.[1]), group: \\(.[0]), field_A_value: \\(.[2]), field_B_value: \\(.[3])&quot;\r\n\r\n&#39; input.json\r\n```\r\n\r\n[Demo](https://jqplay.org/s/9oT3vBM6Kb)\r\n\r\nIf you want to exclude more than just one group, change `IN(&quot;group_3&quot;)` to, say,  `IN(&quot;group_3&quot;, &quot;group_5&quot;, &quot;group_7&quot;)`\r\n\r\n",
                "title": "Get the output in the indicated format without selected data"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1634716416,
        "creation_date": 1634517293,
        "last_edit_date": 1634716416,
        "question_id": 69609625,
        "body_markdown": "Using `jq`, how to get the output in the indicated format without selected groups, e.g. group_3. All data is to be selected from each selected group: name_x.\r\n\r\nInput:\r\n\r\n    {\r\n      &quot;groups&quot;: {\r\n        &quot;group_1&quot;: {\r\n          &quot;name_1&quot;: {\r\n            &quot;field_111&quot;: &quot;value_111&quot;,\r\n            &quot;field_112&quot;: &quot;value_112&quot;,\r\n            &quot;field_11n&quot;: &quot;value_11n&quot;\r\n          },\r\n          &quot;name_2&quot;: {\r\n            &quot;field_121&quot;: &quot;value_121&quot;,\r\n            &quot;field_122&quot;: &quot;value_122&quot;,\r\n            &quot;field_12n&quot;: &quot;value_12n&quot;\r\n          }\r\n        },\r\n        &quot;group_2&quot;: {\r\n          &quot;name_3&quot;: {\r\n            &quot;field_231&quot;: &quot;value_231&quot;,\r\n            &quot;field_232&quot;: &quot;value_232&quot;,\r\n            &quot;field_23n&quot;: &quot;value_23n&quot;\r\n          }\r\n        },\r\n        &quot;group_3&quot;: {\r\n          &quot;name_4&quot;: {\r\n            &quot;field_341&quot;: &quot;value_341&quot;,\r\n            &quot;field_342&quot;: &quot;value_342&quot;,\r\n            &quot;field_34n&quot;: &quot;value_34n&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nOuptut:\r\n\r\n    name: name_1, group: group_1, field_A_value: value_111, field_B_value: value_112\r\n    name: name_2, group: group_1, field_A_value: value_121, field_B_value: value_122 \r\n    name: name_3, group: group_2, field_A_value: value_231, field_B_value: value_232\r\n    \r\n\r\n",
        "link": "https://stackoverflow.com/questions/69609625/get-the-output-in-the-indicated-format-without-selected-data",
        "title": "Get the output in the indicated format without selected data"
    },
    {
        "tags": [
            "json",
            "shell",
            "scripting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634547661,
                "post_id": 69611614,
                "comment_id": 123044847,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1634549971,
                "post_id": 69611614,
                "comment_id": 123045734,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1634551691,
                "creation_date": 1634551691,
                "answer_id": 69614257,
                "question_id": 69611614,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This seems to work on your test data:\r\n\r\n```sh\r\njq -nR &#39;\r\n   def offer:\r\n     . as $data |\r\n     [[], 0] | until([$data[.[1]]] | inside([&quot;ADD&quot;, &quot;REMOVE&quot;]) | not;\r\n       if $data[.[1]] == &quot;ADD&quot; then\r\n        [ .[0] + [{ Action: &quot;ADD&quot;, NewComponentOfferId: $data[.[1] + 1] }], .[1] + 2 ]\r\n       else\r\n        [ .[0] + [{ Action: &quot;REMOVE&quot;, ComponentOfferId: $data[.[1] + 1], \r\n          RemoveAddOnProductInstance: $data[.[1] + 2] }], .[1] + 3 ]\r\n       end);\r\n\r\n   def build:\r\n       (. / &quot;|&quot;) as $data | ($data | length) as $len |\r\n       [ { ExternalId: $data[0], ExternalIdType: $data[1], RPPI: $data[2],\r\n         NewPrimaryOfferId: $data[3] }, 4 ] |\r\n       until(.[1] &gt;= $len;\r\n             ($data[.[1]+1:] | offer) as $off |\r\n             [ .[0] + { ($data[.[1]]): $off[0] }, .[1] + 1 + $off[1] ]) |\r\n      .[0];\r\n\r\n  [ inputs | build ]&#39; data.txt\r\n```",
                "title": "Text file to json using JQ command"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1634560273,
                "last_edit_date": 1634560273,
                "creation_date": 1634559958,
                "answer_id": 69616033,
                "question_id": 69611614,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another approach:\r\n\r\n```\r\njq -Rn &#39;\r\n  [\r\n    inputs / &quot;|&quot; | reduce (.[4:] | while(. != [];.[6:])) as $prod (\r\n      .[:4] | with_entries(.key |= [&quot;ExternalId&quot;,&quot;ExternalIdType&quot;,&quot;RPPI&quot;,&quot;NewPrimaryOfferId&quot;][.]);\r\n      .[$prod[0]] = [\r\n        {Action:&quot;ADD&quot;, NewComponentOfferId:$prod[2]},\r\n        {Action:&quot;REMOVE&quot;, ComponentOfferId:$prod[4], RemoveAddOnProductInstance:$prod[5]}\r\n      ]\r\n    )\r\n  ]\r\n&#39; data.txt\r\n```\r\n[Demo](https://jqplay.org/s/SfG7bQ_8cI)\r\n",
                "title": "Text file to json using JQ command"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1634802489,
        "creation_date": 1634538419,
        "last_edit_date": 1634802489,
        "question_id": 69611614,
        "body_markdown": "I have a text file with data like below:\r\n\r\n~~~\r\n6111119268639|22|65024:3|2000225350|Samsung|ADD|234534643645|REMOVE|5645657|65067:3|Apple|ADD|234534643645|REMOVE|3432523|65023:3\r\n6111119268639|22|65024:3|2000225350|Apple|ADD|234534643645|REMOVE|3432523|65023:3\r\n6111119268639|22|65024:3|2000225350|Samsung|ADD|234534643645|REMOVE|3432523|65023:3\r\n~~~\r\n\r\nand so on ...\r\n\r\nI want want json output like this below:\r\n\r\n~~~\r\n[{\r\n\t&quot;ExternalId&quot;: &quot;6111119268639&quot;,\r\n\t&quot;ExternalIdType&quot;: &quot;22&quot;,\r\n\t&quot;RPPI&quot;: &quot;65024:3&quot;,\r\n\t&quot;NewPrimaryOfferId&quot;: &quot;2000225350&quot;,\r\n\t&quot;Samsung&quot;: [{\r\n\t\t\t&quot;Action&quot;: &quot;ADD&quot;,\r\n\t\t\t&quot;NewSecondaryOfferId&quot;: &quot;234534643645&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;Action&quot;: &quot;REMOVE&quot;,\r\n\t\t\t&quot;SecondaryProductOfferId&quot;: &quot;5645657&quot;,\r\n\t\t\t&quot;RemoveSecondaryProductInstance&quot;: &quot;65067:3&quot;\r\n\t\t}\r\n\t],\r\n\t&quot;Apple&quot;: [\r\n\t{\r\n\t\t\t&quot;Action&quot;: &quot;ADD&quot;,\r\n\t\t\t&quot;NewComponentOfferId&quot;: &quot;234534643645&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;Action&quot;: &quot;REMOVE&quot;,\r\n\t\t\t&quot;ComponentOfferId&quot;: &quot;3432523&quot;,\r\n\t\t\t&quot;RemoveAddOnProductInstance&quot;: &quot;65023:3&quot;\r\n\t\t}\r\n\t]\r\n}, \r\n{\r\n\t&quot;ExternalId&quot;: &quot;6111119268639&quot;,\r\n\t&quot;ExternalIdType&quot;: &quot;22&quot;,\r\n\t&quot;RPPI&quot;: &quot;65024:3&quot;,\r\n\t&quot;NewPrimaryOfferId&quot;: &quot;2000225350&quot;,\r\n\t&quot;Apple&quot;: [{\r\n\t\t\t&quot;Action&quot;: &quot;ADD&quot;,\r\n\t\t\t&quot;NewComponentOfferId&quot;: &quot;234534643645&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;Action&quot;: &quot;REMOVE&quot;,\r\n\t\t\t&quot;ComponentOfferId&quot;: &quot;3432523&quot;,\r\n\t\t\t&quot;RemoveAddOnProductInstance&quot;: &quot;65023:3&quot;\r\n\t\t}\r\n\t]\r\n}, \r\n{\r\n\t&quot;ExternalId&quot;: &quot;6111119268639&quot;,\r\n\t&quot;ExternalIdType&quot;: &quot;22&quot;,\r\n\t&quot;RPPI&quot;: &quot;65024:3&quot;,\r\n\t&quot;NewPrimaryOfferId&quot;: &quot;2000225350&quot;,\r\n\t&quot;Apple&quot;: [{\r\n\t\t\t&quot;Action&quot;: &quot;Samsung&quot;,\r\n\t\t\t&quot;NewComponentOfferId&quot;: &quot;234534643645&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;Action&quot;: &quot;REMOVE&quot;,\r\n\t\t\t&quot;ComponentOfferId&quot;: &quot;3432523&quot;,\r\n\t\t\t&quot;RemoveAddOnProductInstance&quot;: &quot;65023:3&quot;\r\n\t\t}\r\n\t]\r\n}\r\n]\r\n~~~\r\n\r\nHere **ExternalId,ExternalIdType,RPPI,NewPrimaryOfferId** are constant and will be there in every line.But **Samsung** and **Apple** can vary accordingly means there could be only &#39;**Samsung**&#39; in one line or there could be only **&#39;Apple&#39;** in one line or there could be **both** as shown in sample text.\r\n\r\nI have written a Jq command for this like below:\r\n~~~\r\njq -Rn &#39;[inputs / &quot;|&quot; | [[\r\n  \r\n  [&quot;ExternalId&quot;],[&quot;ExternalIdType&quot;],[&quot;RPPI&quot;],[&quot;NewPrimaryOfferId&quot;],\r\n  ((&quot;Samsung&quot;, &quot;Apple&quot;) as $p |\r\n    [$p, 0] + ([&quot;Action&quot;], [&quot;NewSecondaryOfferId&quot;]),\r\n    [$p, 1] + ([&quot;Action&quot;], [&quot;SecondaryProductOfferId&quot;], [&quot;RemoveSecondaryProductInstance&quot;])\r\n    )\r\n\r\n],.] | transpose | reduce .[] as $k ({}; setpath($k[0];$k[1]))]&#39; data.txt\r\n\r\n~~~\r\n\r\nBut seems like it is not giving me the desired output I want.Please suggest how can I write the jq command for this using if-else condition for products or any shell script to get the desired json output.Thanks in advance!",
        "link": "https://stackoverflow.com/questions/69611614/text-file-to-json-using-jq-command",
        "title": "Text file to json using JQ command"
    },
    {
        "tags": [
            "windows",
            "sqlite",
            "batch-file",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user7818749"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634553921,
                "post_id": 69614594,
                "comment_id": 123047228,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9045527,
                    "reputation": 38872,
                    "user_id": 6738015,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FYDxX.jpg?s=256",
                    "display_name": "Compo",
                    "link": "https://stackoverflow.com/users/6738015/compo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634554006,
                "post_id": 69614594,
                "comment_id": 123047265,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1634555876,
                "creation_date": 1634555876,
                "answer_id": 69615119,
                "question_id": 69614594,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From the [SQLite documentation](https://sqlite.org/cli.html#using_sqlite3_in_a_shell_script):\r\n\r\n&gt; One way to use sqlite3 in a shell script is to use &quot;echo&quot; or &quot;cat&quot; to generate a sequence of commands in a file, then invoke sqlite3 while redirecting input from the generated command file. This works fine and is appropriate in many circumstances. But as an added convenience, sqlite3 allows a single SQL command to be entered on the command line as a second argument after the database name. When the sqlite3 program is launched with two arguments, the second argument is passed to the SQLite library for processing, the query results are printed on standard output in list mode, and the program exits.\r\n\r\nSo you can do :\r\n\r\n    echo &quot;insert into ....&quot; | sqlite3 &quot;C:\\path\\2\\DB_Folder\\db1.sqlite&quot; \r\n\r\nor\r\n\r\n    sqlite3 &quot;C:\\path\\2\\DB_Folder\\db1.sqlite&quot; &quot;insert into ....&quot;\r\n\r\nIn both cases, mind the escaping/quoting rules for cmd.exe.\r\n\r\nAs a final alternative, you can use jq to convert the JSON into a CSV file and use the far simpler SQLite [.import command](https://sqlite.org/cli.html#importing_csv_files).\r\n\r\n    jq -r &quot;.[] | [ .col1, .col2, .col3, .col4 ] | @csv&quot; somedata.json &gt; somedata.csv\r\n    sqlite3 &quot;C:\\path\\2\\DB_Folder\\db1.sqlite&quot; &quot;.import somedata.csv mytable&quot;",
                "title": "How to insert data from JSON file into SQLite Database from Batch file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1634555876,
        "creation_date": 1634553254,
        "question_id": 69614594,
        "body_markdown": "i would like to insert data from a JSON-File into a SQLite-Databse with an existing table from a batch file.\r\n\r\nFirst i filter the flawed JSON-File with jq afterwards i open the database and try to insert the data, but after opening the database the batch file stops at receiving commands from sqlite3.\r\n\r\nThis how the batch file looks like:\r\n\r\n\r\n```\r\njq -r &quot;.[]&quot; D:\\path\\2\\json_file\\somedata.json &gt; D:\\path\\2\\json_file\\somedata_new.json\r\n\r\nsqlite3 &quot;C:\\path\\2\\DB_Folder\\db1.sqlite&quot; \r\n\r\nINSERT INTO mytable (col1, col2, col3, col4) SELECT json_extract(value, &#39;$.col1&#39;), json_extract(value, &#39;$.col2&#39;), json_extract(value, &#39;$.col3&#39;), json_extract(value, &#39;$.col4&#39;) FROM json_each(readfile(&#39;D:\\path\\2\\json_file\\somedata_new.json&#39;)); \r\n```\r\nBut after executing ```sqlite3 &quot;C:\\path\\2\\DB_Folder\\db1.sqlite&quot;``` the batch file stops at receiving commands for sqlite3 and the ```INSERT```-Statement is ignored.\r\n\r\nIf i execute the commands directly in the command line everything works fine.\r\n\r\nI tried to create a file like [here](https://stackoverflow.com/questions/58109426/how-to-execute-insert-query-on-a-sqlite-database-from-a-batch-file-knowing-the) with the ```INSERT```-Statement but  ```mytable``` remains empty.\r\n\r\nCan anybody help me?\r\n\r\nBtw it is necessary to input the data automatically without any users actions.\r\n\r\nThanks for help in advance.\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69614594/how-to-insert-data-from-json-file-into-sqlite-database-from-batch-file",
        "title": "How to insert data from JSON file into SQLite Database from Batch file"
    },
    {
        "tags": [
            "json",
            "shell",
            "kubernetes",
            "jq",
            "kubectl"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1634564204,
                "last_edit_date": 1634564204,
                "creation_date": 1634563672,
                "answer_id": 69616974,
                "question_id": 69616871,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Put parentheses around the value of the `claimName` field:\r\n\r\n```\r\n{\r\n  name: .metadata.name,\r\n  claimName: (.spec | if has(&quot;claimRef&quot;) then .claimRef.name else empty end)\r\n}\r\n```\r\n\r\nDepending on how much you simplified your example, you may consider reducing the the `if` statement to:\r\n\r\n```\r\n{\r\n  name: .metadata.name,\r\n  claimName: (.spec.claimRef.name? // empty)\r\n}\r\n```\r\n\r\nNote that in both cases not just `.claimName` but the whole object will disappear if the respective test is going to fail.",
                "title": "jq: error: syntax error, unexpected if, while checking for a object to be present and if not the adding default value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1634669625,
        "creation_date": 1634563236,
        "last_edit_date": 1634669625,
        "question_id": 69616871,
        "body_markdown": "Getting the error\r\n```\r\njq: error: syntax error, unexpected if (Unix shell quoting issues?) at &lt;top-level&gt; while parsing kubernetes kubectl command,\r\nkubectl get pv -o=json | jq -c &#39;.items[] | {name: .metadata.name, claimName: .spec | if has(&quot;claimRef&quot;) then .claimRef.name else empty end }&#39;\r\n```\r\n\r\nTrying to get the PV&#39;s which have PVC and if there are no PVC can be null of empty.\r\nFor it uilding a map of name and their respective PVC if there otherwise empty or null.\r\n\r\nBelow is a sample input to the jq command or the out put of the command `kubectl get pv -o=json`\r\n```\r\n{\r\n\t&quot;apiVersion&quot;: &quot;v1&quot;,\r\n\t&quot;items&quot;: [{\r\n\t\t\t&quot;apiVersion&quot;: &quot;v1&quot;,\r\n\t\t\t&quot;kind&quot;: &quot;PersistentVolume&quot;,\r\n\t\t\t&quot;metadata&quot;: {\r\n\t\t\t\t&quot;annotations&quot;: {\r\n\t\t\t\t\t&quot;meta.helm.sh/release-name&quot;: &quot;&quot;,\r\n\t\t\t\t\t&quot;meta.helm.sh/release-namespace&quot;: &quot;&quot;\r\n\t\t\t\t},\r\n\t\t\t\t&quot;creationTimestamp&quot;: &quot;&quot;,\r\n\t\t\t\t&quot;finalizers&quot;: [\r\n\t\t\t\t\t&quot;&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;labels&quot;: {\r\n\t\t\t\t\t&quot;app.kubernetes.io/managed-by&quot;: &quot;&quot;\r\n\t\t\t\t},\r\n\t\t\t\t&quot;name&quot;: &quot;&quot;,\r\n\t\t\t\t&quot;resourceVersion&quot;: &quot;&quot;,\r\n\t\t\t\t&quot;uid&quot;: &quot;&quot;\r\n\t\t\t},\r\n\t\t\t&quot;spec&quot;: {\r\n\t\t\t\t&quot;accessModes&quot;: [\r\n\t\t\t\t\t&quot;ReadWriteMany&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;capacity&quot;: {\r\n\t\t\t\t\t&quot;storage&quot;: &quot;&quot;\r\n\t\t\t\t},\r\n\t\t\t\t&quot;claimRef&quot;: {\r\n\t\t\t\t\t&quot;apiVersion&quot;: &quot;&quot;,\r\n\t\t\t\t\t&quot;kind&quot;: &quot;&quot;,\r\n\t\t\t\t\t&quot;name&quot;: &quot;&quot;,\r\n\t\t\t\t\t&quot;namespace&quot;: &quot;&quot;,\r\n\t\t\t\t\t&quot;resourceVersion&quot;: &quot;&quot;,\r\n\t\t\t\t\t&quot;uid&quot;: &quot;&quot;\r\n\t\t\t\t},\r\n\t\t\t\t&quot;csi&quot;: {\r\n\t\t\t\t\t&quot;driver&quot;: &quot;&quot;,\r\n\t\t\t\t\t&quot;volumeHandle&quot;: &quot;&quot;\r\n\t\t\t\t},\r\n\t\t\t\t&quot;persistentVolumeReclaimPolicy&quot;: &quot;&quot;,\r\n\t\t\t\t&quot;volumeMode&quot;: &quot;&quot;\r\n\t\t\t},\r\n\t\t\t&quot;status&quot;: {\r\n\t\t\t\t&quot;phase&quot;: &quot;&quot;\r\n\t\t\t}\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;apiVersion&quot;: &quot;v1&quot;,\r\n\t\t\t&quot;kind&quot;: &quot;PersistentVolume&quot;,\r\n\t\t\t&quot;metadata&quot;: {\r\n\t\t\t\t&quot;annotations&quot;: {\r\n\t\t\t\t\t&quot;meta.helm.sh/release-name&quot;: &quot;&quot;,\r\n\t\t\t\t\t&quot;meta.helm.sh/release-namespace&quot;: &quot;&quot;\r\n\t\t\t\t},\r\n\t\t\t\t&quot;creationTimestamp&quot;: &quot;&quot;,\r\n\t\t\t\t&quot;finalizers&quot;: [\r\n\t\t\t\t\t&quot;&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;labels&quot;: {\r\n\t\t\t\t\t&quot;app.kubernetes.io/managed-by&quot;: &quot;&quot;\r\n\t\t\t\t},\r\n\t\t\t\t&quot;name&quot;: &quot;&quot;,\r\n\t\t\t\t&quot;resourceVersion&quot;: &quot;&quot;,\r\n\t\t\t\t&quot;uid&quot;: &quot;&quot;\r\n\t\t\t},\r\n\t\t\t&quot;spec&quot;: {\r\n\t\t\t\t&quot;accessModes&quot;: [\r\n\t\t\t\t\t&quot;ReadWriteMany&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;capacity&quot;: {\r\n\t\t\t\t\t&quot;storage&quot;: &quot;&quot;\r\n\t\t\t\t},\r\n\t\t\t\t&quot;claimRef&quot;: {\r\n\t\t\t\t\t&quot;apiVersion&quot;: &quot;&quot;,\r\n\t\t\t\t\t&quot;kind&quot;: &quot;&quot;,\r\n\t\t\t\t\t&quot;name&quot;: &quot;&quot;,\r\n\t\t\t\t\t&quot;namespace&quot;: &quot;&quot;,\r\n\t\t\t\t\t&quot;resourceVersion&quot;: &quot;&quot;,\r\n\t\t\t\t\t&quot;uid&quot;: &quot;&quot;\r\n\t\t\t\t},\r\n\t\t\t\t&quot;csi&quot;: {\r\n\t\t\t\t\t&quot;driver&quot;: &quot;&quot;,\r\n\t\t\t\t\t&quot;volumeHandle&quot;: &quot;&quot;\r\n\t\t\t\t},\r\n\t\t\t\t&quot;persistentVolumeReclaimPolicy&quot;: &quot;&quot;,\r\n\t\t\t\t&quot;volumeMode&quot;: &quot;&quot;\r\n\t\t\t},\r\n\t\t\t&quot;status&quot;: {\r\n\t\t\t\t&quot;phase&quot;: &quot;&quot;\r\n\t\t\t}\r\n\t\t}\r\n\t],\r\n\t&quot;kind&quot;: &quot;List&quot;,\r\n\t&quot;metadata&quot;: {\r\n\t\t&quot;resourceVersion&quot;: &quot;&quot;,\r\n\t\t&quot;selfLink&quot;: &quot;&quot;\r\n\t}\r\n}\r\n```\r\n\r\nFor data security have removed the data and only kept the keys\r\nPlease help",
        "link": "https://stackoverflow.com/questions/69616871/jq-error-syntax-error-unexpected-if-while-checking-for-a-object-to-be-presen",
        "title": "jq: error: syntax error, unexpected if, while checking for a object to be present and if not the adding default value"
    },
    {
        "tags": [
            "json",
            "bash",
            "docker",
            "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": 1634574968,
                "post_id": 69619558,
                "comment_id": 123056327,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4381293,
                    "reputation": 210,
                    "user_id": 3572878,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://graph.facebook.com/532613925/picture?type=large",
                    "display_name": "SwissArmyKnife",
                    "link": "https://stackoverflow.com/users/3572878/swissarmyknife"
                },
                "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": 1634576130,
                "post_id": 69619558,
                "comment_id": 123056707,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 328876,
                    "reputation": 805,
                    "user_id": 3373429,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/LERZ2.jpg?s=256",
                    "display_name": "Steve Kline",
                    "link": "https://stackoverflow.com/users/3373429/steve-kline"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634576909,
                "post_id": 69619558,
                "comment_id": 123056968,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4381293,
                    "reputation": 210,
                    "user_id": 3572878,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://graph.facebook.com/532613925/picture?type=large",
                    "display_name": "SwissArmyKnife",
                    "link": "https://stackoverflow.com/users/3572878/swissarmyknife"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634583153,
                "post_id": 69619558,
                "comment_id": 123059175,
                "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": 1634584016,
                "post_id": 69619558,
                "comment_id": 123059418,
                "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": 1634584065,
                "post_id": 69619558,
                "comment_id": 123059431,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1634639123,
                "creation_date": 1634639123,
                "answer_id": 69629159,
                "question_id": 69619558,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The answer was simple enough. Needed to have the 1.6 version inside docker. To be able to do that i needed to install epel-release-latest-7.noarch.rpm before installing jq. Otherwise it installed 1.5 version of jq. So thanks Charles Duffy!",
                "title": "Map environment variabels in JSON with JQ inside docker"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1634639123,
        "creation_date": 1634574782,
        "question_id": 69619558,
        "body_markdown": "I have been banging my head against the wall for 8 hours now, but cant seem to fix this issue.\r\n\r\nI have a json looking like this:\r\n\r\n    {\r\n     &quot;connector.class&quot;: &quot;com.mongodb.kafka.connect.MongoSinkConnector&quot;,\r\n     &quot;tasks.max&quot;: 1,\r\n     &quot;key.converter&quot;: &quot;org.apache.kafka.connect.storage.StringConverter&quot;,\r\n     &quot;key.converter.schemas.enable&quot;: false,\r\n     &quot;value.converter&quot;: &quot;io.confluent.connect.avro.AvroConverter&quot;,\r\n     &quot;value.converter.schema.registry.url&quot;: &quot;CONNECTOR_SCHEMA_REGISTRY_URL&quot;,\r\n     &quot;value.converter.schemas.enable&quot;: true,\r\n     &quot;topics&quot;: &quot;CONNECTOR_TOPICS&quot;,\r\n     &quot;name&quot;: &quot;CONNECTOR_NAME&quot;,\r\n     &quot;connection.uri&quot;: &quot;CONNECTOR_MONGODB_CONNECTION_URI&quot;,\r\n     &quot;database&quot;: &quot;CONNECTOR_MONGODB_DATABASE_NAME&quot;,\r\n     &quot;collection&quot;: &quot;CONNECTOR_MONGODB_COLLECTION_NAME&quot;,\r\n     &quot;max.num.retries&quot;: 1,\r\n     &quot;retries.defer.timeout&quot;: 5000,\r\n     &quot;errors.log.include.messages&quot;: true,\r\n     &quot;document.id.strategy&quot;: \r\n     &quot;com.mongodb.kafka.connect.sink.processor.id.strategy.ProvidedInKeyStrategy&quot;,\r\n     &quot;document.id.strategy.overwrite.existing&quot;: true,\r\n     &quot;delete.on.null.values&quot;: true,\r\n     &quot;post.processor.chain&quot;: \r\n     &quot;com.az.ip.dmdp.commons.mongodb.kafka.connect.BsonOidProcessor, \r\n      com.az.ip.dmdp.commons.mongodb.kafka.connect.BsonTimestampProcessor&quot;,\r\n     &quot;writemodel.strategy&quot;: \r\n     &quot;com.mongodb.kafka.connect.sink.writemodel.strategy.UpdateOneTimestampsStrategy&quot;,\r\n     &quot;transforms&quot;: &quot;hoistKeyOid, hoistKeyId&quot;,\r\n     &quot;transforms.hoistKeyOid.type&quot;: &quot;org.apache.kafka.connect.transforms.HoistField$Key&quot;,\r\n     &quot;transforms.hoistKeyOid.field&quot;: &quot;oid&quot;,\r\n     &quot;transforms.hoistKeyId.type&quot;: &quot;org.apache.kafka.connect.transforms.HoistField$Key&quot;,\r\n     &quot;transforms.hoistKeyId.field&quot;: &quot;_id&quot;\r\n    }\r\nIm trying to replace the values starting with CONNECTOR using jq. I found this neet little trick: https://unix.stackexchange.com/questions/657466/how-to-update-given-environment-variable-values-in-json\r\n\r\nIt works perfectly, with a minor tweak in my terminal. As long as the vars are set in my terminal\r\n\r\n    jq &#39;with_entries( .value = ($ENV.&quot;\\(.value)&quot; // .value ) )&#39; device-connectorbody.json\r\nBut when i add the same row inside a bash script that executes inside a docker container, i get the following error message:\r\n\r\n    jq: error: ENV/0 is not defined at &lt;top-level&gt;, line 1:\r\n    with_entries( .value = ($ENV.&quot;\\(.value)&quot; // .value ) )                        \r\n    jq: 1 compile error\r\n\r\nFrom what i can understand about the error, it seems like it can&#39;t expand the ENV variabel, but WHY?!\r\n\r\nIf anyone have any idea on what i&#39;m doing wrong, please help.",
        "link": "https://stackoverflow.com/questions/69619558/map-environment-variabels-in-json-with-jq-inside-docker",
        "title": "Map environment variabels in JSON with JQ inside docker"
    },
    {
        "tags": [
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634577465,
                "post_id": 69619865,
                "comment_id": 123057166,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634663606,
                "post_id": 69619865,
                "comment_id": 123084311,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1634663468,
                "creation_date": 1634663468,
                "answer_id": 69635101,
                "question_id": 69619865,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In general, you can&#39;t do this:\r\n\r\n```\r\nMYVAR=12345 printf &quot;%s\\n&quot; &quot;$MYVAR&quot;\r\n```\r\n\r\nWhen you prefix a shell command with `MYVAR=12345` you are modifying the environment that is passed to that process, in this case `printf`. However, the `$MYVAR` expression is expanded in the shell and no `MYVAR` variable ever exists in the shell.\r\n\r\nFurthermore, when you set variables like this, they are only passed to _that command_, not the entire pipeline.\r\n\r\nSo in this example:\r\n\r\n```\r\nTS_SEC_START=1534574204 \\\r\nSERVICE_NAME=mysvc \\\r\nRELEASE_NAMESPACE=prod \\\r\nkubectl -n istio-system logs deployment/flagger --tail=50 | \\\r\n    grep &#39;^{&#39; | \\\r\n    jq \\\r\n        --arg TS_SEC_START 1534574204 \\\r\n        --arg SVC &quot;${SERVICE_NAME}.${RELEASE_NAMESPACE}&quot; \\\r\n        -s \\\r\n        &#39;\r\n          map(\r\n            select(\r\n              .ts |\r\n              (split(&quot;.&quot;)[0] + &quot;Z&quot;) |\r\n              fromdateiso8601 &gt; ($TS_SEC_START | tonumber)\r\n            ) |\r\n            select(.canary == $SVC)\r\n          )\r\n        &#39;\r\n```\r\n\r\nThe three environment variables are visible to `kubectl` and nothing else. They are not visible to `grep` or `jq` (although neither of them are looking for such environment variables in the first place) and they are not visible to the shell itself as it expands those commands.",
                "title": "Unable to use jq arg as select filter"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1634663540,
        "creation_date": 1634576381,
        "last_edit_date": 1634663540,
        "question_id": 69619865,
        "body_markdown": "I&#39;m trying to use jq&#39;s `--arg` syntax to pass a variable from the shell to a jq filter.\r\n\r\nIf I run the following command, the jq query works as expected:\r\n\r\n    TS_SEC_START=1534574204 \\\r\n    kubectl -n istio-system logs deployment/flagger --tail=50 | grep &#39;^{&#39; | \\\r\n    jq --arg TS_SEC_START 1534574204 --arg SVC &quot;${SERVICE_NAME}.${RELEASE_NAMESPACE}&quot; \\\r\n    -s &#39;map(select(.ts | (split(&quot;.&quot;)[0] + &quot;Z&quot;) | fromdateiso8601 &gt; ($TS_SEC_START | tonumber)) | select(.canary == &quot;mysvc.prod&quot;))&#39;\r\n\r\n--&gt;\r\n\r\n    Found 3 pods, using pod/flagger-6dc6fd7d85-z294g\r\n    [\r\n      {\r\n        &quot;level&quot;: &quot;error&quot;,\r\n        &quot;ts&quot;: &quot;2021-08-16T02:41:34.128Z&quot;,\r\n        &quot;caller&quot;: &quot;controller/scheduler.go:163&quot;,\r\n        &quot;msg&quot;: &quot;Canary mysvc.prod not found&quot;,\r\n        &quot;canary&quot;: &quot;mysvc.prod&quot;,\r\n        &quot;stacktrace&quot;: &quot;github.com/fluxcd/flagger/pkg/controller.(*Controller).advanceCanary\\n\\t/workspace/pkg/controller/scheduler.go:163\\ngithub.com/fluxcd/flagger/pkg/controller.CanaryJob.Start.func1\\n\\t/workspace/pkg/controller/job.go:39&quot;\r\n      }\r\n    ]\r\n\r\n\r\nHowever, when I try to pass `mysvc.prod` as an arg, I receive 0 responses.\r\n\r\n    TS_SEC_START=1534574204 SERVICE_NAME=mysvc RELEASE_NAMESPACE=prod \\\r\n    kubectl -n istio-system logs deployment/flagger --tail=50 | grep &#39;^{&#39; | \\\r\n    jq --arg TS_SEC_START 1534574204 --arg SVC &quot;${SERVICE_NAME}.${RELEASE_NAMESPACE}&quot; \\\r\n    -s &#39;map(select(.ts | (split(&quot;.&quot;)[0] + &quot;Z&quot;) | fromdateiso8601 &gt; ($TS_SEC_START | tonumber)) | select(.canary == $SVC))&#39;\r\n\r\nI&#39;ve tried a few different options here, e.g. `.canary == &quot;$SVC&quot;` and `.canary == &quot;$SERVICE_NAME.$RELEASE_NAMESPACE&quot; but I can&#39;t get it to work.\r\n\r\nWhat am I doing wrong?\r\n\r\n--&gt;\r\n\r\n    Found 3 pods, using pod/flagger-6dc6fd7d85-z294g\r\n    []\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69619865/unable-to-use-jq-arg-as-select-filter",
        "title": "Unable to use jq arg as select filter"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1083854,
                    "reputation": 14329,
                    "user_id": 1080064,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://graph.facebook.com/100000753306178/picture?type=large",
                    "display_name": "tkausl",
                    "link": "https://stackoverflow.com/users/1080064/tkausl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1634577156,
                "post_id": 69619968,
                "comment_id": 123057049,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1634577491,
                "creation_date": 1634577491,
                "answer_id": 69620071,
                "question_id": 69619968,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Once you&#39;ve fixed all the typos in your input (several commas and some curly braces were missing), this should work:\r\n\r\n```\r\njq &#39;map(.endpoints |= [.[][]])&#39;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/dPnG3xSoHW)",
                "title": "Way to convert json output jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1634654909,
        "creation_date": 1634576872,
        "last_edit_date": 1634654909,
        "question_id": 69619968,
        "body_markdown": "I have the following json output:\r\n```\r\n[\r\n  {\r\n    &quot;serviceid&quot;: &quot;service1&quot;,\r\n    &quot;endpoints&quot; : { \r\n      &quot;endpoint1&quot;: [\r\n        &quot;example1&quot;,\r\n        &quot;example2&quot;,\r\n        &quot;example3&quot;,\r\n        &quot;example4&quot;\r\n      ],\r\n      &quot;endpoint2&quot;: [\r\n        &quot;example3&quot;,\r\n        &quot;example4&quot;,\r\n        &quot;example5&quot;,\r\n        &quot;example6&quot;\r\n      ]\r\n    },\r\n    &quot;version&quot;: &quot;1.0&quot;\r\n  },\r\n  {\r\n    &quot;serviceid&quot;: &quot;service2&quot;,\r\n    &quot;endpoints&quot; : {\r\n      &quot;endpoint3&quot;: [\r\n        &quot;example7&quot;,\r\n        &quot;example8&quot;,\r\n        &quot;example9&quot;,\r\n        &quot;example10&quot;\r\n      ]\r\n    },\r\n    &quot;version&quot;: &quot;2.0&quot;\r\n  }\r\n]\r\n```\r\n\r\nSo I need to remove endpoint1, endpoint2 and endpoint3 and preserve their children as array.\r\nThis is the desired output:\r\n```\r\n[\r\n    {\r\n      &quot;serviceid&quot;: &quot;service1&quot;,\r\n      &quot;endpoints&quot; : [\r\n          &quot;example1&quot;,\r\n          &quot;example2&quot;,\r\n          &quot;example3&quot;,\r\n          &quot;example4&quot;\r\n          &quot;example3&quot;,\r\n          &quot;example4&quot;,\r\n          &quot;example5&quot;,\r\n          &quot;example6&quot;\r\n      ],\r\n      &quot;version&quot;: &quot;1.0&quot;\r\n      },\r\n      &quot;serviceid&quot;: &quot;service2&quot;,\r\n      &quot;endpoints&quot; : [\r\n          &quot;example7&quot;,\r\n          &quot;example8&quot;,\r\n          &quot;example9&quot;,\r\n          &quot;example10&quot;\r\n      ],\r\n      &quot;version&quot;: &quot;2.0&quot;\r\n    }\r\n]\r\n```\r\nI don&#39;t have any idea to face it, please could you help me?\r\nThanks in advance.\r\n",
        "link": "https://stackoverflow.com/questions/69619968/way-to-convert-json-output-jq",
        "title": "Way to convert json output jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5914193,
                    "reputation": 14886,
                    "user_id": 4653485,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/222d7d75a35af5276a54a657eda94f06?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "J&#233;r&#244;me",
                    "link": "https://stackoverflow.com/users/4653485/j%c3%a9r%c3%b4me"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634584165,
                "post_id": 69621147,
                "comment_id": 123059474,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22102763,
                    "reputation": 25,
                    "user_id": 16358960,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0c8dbfae215abab36b0c52ff8d7f1f95?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "robby",
                    "link": "https://stackoverflow.com/users/16358960/robby"
                },
                "reply_to_user": {
                    "account_id": 5914193,
                    "reputation": 14886,
                    "user_id": 4653485,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/222d7d75a35af5276a54a657eda94f06?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "J&#233;r&#244;me",
                    "link": "https://stackoverflow.com/users/4653485/j%c3%a9r%c3%b4me"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634751179,
                "post_id": 69621147,
                "comment_id": 123111870,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5914193,
                    "reputation": 14886,
                    "user_id": 4653485,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/222d7d75a35af5276a54a657eda94f06?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "J&#233;r&#244;me",
                    "link": "https://stackoverflow.com/users/4653485/j%c3%a9r%c3%b4me"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634803702,
                "post_id": 69621147,
                "comment_id": 123125474,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1634584689,
                "creation_date": 1634584689,
                "answer_id": 69621422,
                "question_id": 69621147,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming, your input data is an array\r\n```\r\n[\r\n  {\r\n    &quot;sepalLength&quot;: 5,\r\n    &quot;sepalWidth&quot;: 3.3,\r\n    &quot;petalLength&quot;: 1.4,\r\n    &quot;petalWidth&quot;: 0.2,\r\n    &quot;species&quot;: &quot;setosa&quot;\r\n  },\r\n  {\r\n    &quot;sepalLength&quot;: 7,\r\n    &quot;sepalWidth&quot;: 3.2,\r\n    &quot;petalLength&quot;: 4.7,\r\n    &quot;petalWidth&quot;: 1.4,\r\n    &quot;species&quot;: &quot;versicolor&quot;\r\n  },\r\n  ...\r\n]\r\n```\r\n\r\nThe following\r\n\r\n```\r\njq &#39;[(map(keys[]) | unique[]) as $key | {($key): map(.[$key])} ] | add&#39;\r\n```\r\n\r\nif fed with your sample data will produce something like\r\n\r\n```\r\n{\r\n  &quot;petalLength&quot;: [1.4,4.7,4.5],\r\n  &quot;petalWidth&quot;: [0.2,1.4,1.5],\r\n  &quot;sepalLength&quot;: [5,7,6.4],\r\n  &quot;sepalWidth&quot;: [3.3,3.2,3.2],\r\n  &quot;species&quot;: [&quot;setosa&quot;,&quot;versicolor&quot;,&quot;versicolor&quot;]\r\n}\r\n\r\n```",
                "title": "Get list of values for each unique key of json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1634584689,
        "creation_date": 1634583284,
        "question_id": 69621147,
        "body_markdown": "guys. There&#39;s the task: to get all unique keys and lists of matching values for these keys and then wrap them in {} \r\n\r\nThe json looks like:\r\n``` ...\r\n{\r\n    &quot;sepalLength&quot;: 5,\r\n    &quot;sepalWidth&quot;: 3.3,\r\n    &quot;petalLength&quot;: 1.4,\r\n    &quot;petalWidth&quot;: 0.2,\r\n    &quot;species&quot;: &quot;setosa&quot;\r\n  },\r\n  {\r\n    &quot;sepalLength&quot;: 7,\r\n    &quot;sepalWidth&quot;: 3.2,\r\n    &quot;petalLength&quot;: 4.7,\r\n    &quot;petalWidth&quot;: 1.4,\r\n    &quot;species&quot;: &quot;versicolor&quot;\r\n  },\r\n  {\r\n    &quot;sepalLength&quot;: 6.4,\r\n    &quot;sepalWidth&quot;: 3.2,\r\n    &quot;petalLength&quot;: 4.5,\r\n    &quot;petalWidth&quot;: 1.5,\r\n    &quot;species&quot;: &quot;versicolor&quot;\r\n  },\r\n...\r\n```\r\n\r\nAnd the result must look this way:\r\n```\r\n{\r\n    &quot;species&quot;: [&quot;setosa&quot;, &quot;setosa&quot;, ...],\r\n    &quot;petalWidth&quot;: [1.2, ...],\r\n    ...\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/69621147/get-list-of-values-for-each-unique-key-of-json-with-jq",
        "title": "Get list of values for each unique key of json with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1634694745,
                "creation_date": 1634694745,
                "answer_id": 69639427,
                "question_id": 69639335,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this\r\n\r\n```\r\n.attributes |= map(select(.key != &quot;that&quot;))\r\n```\r\n\r\n[Demo](https://jqplay.org/s/BWuBGRGS7o)",
                "title": "Manipulate json, remove two items in a group by key value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1634732210,
                "last_edit_date": 1634732210,
                "creation_date": 1634694854,
                "answer_id": 69639441,
                "question_id": 69639335,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Figured it out.\r\n\r\n```\r\njq &#39;del(.attributes[] | select(.key == &quot;that&quot;))&#39; test.json | sponge test.json\r\n```",
                "title": "Manipulate json, remove two items in a group by key value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1634732210,
        "creation_date": 1634693763,
        "question_id": 69639335,
        "body_markdown": "How can I manipulate this chunk of json:\r\n\r\n```\r\n{\r\n&quot;id&quot;: &quot;whatever&quot;,\r\n&quot;attributes&quot;: [\r\n    {\r\n      &quot;key&quot;: &quot;this&quot;,\r\n      &quot;value&quot;: &quot;A&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;that&quot;,\r\n      &quot;value&quot;: &quot;B&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;other&quot;,\r\n      &quot;value&quot;: &quot;C&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nSo that it matches on &quot;that&quot; and removes the key and value both in that grouping, leaving json like this:\r\n\r\n```\r\n{\r\n&quot;id&quot;: &quot;whatever&quot;,\r\n&quot;attributes&quot;: [\r\n    {\r\n      &quot;key&quot;: &quot;this&quot;,\r\n      &quot;value&quot;: &quot;A&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;other&quot;,\r\n      &quot;value&quot;: &quot;C&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nI am attempting to use jq on linux. \r\n",
        "link": "https://stackoverflow.com/questions/69639335/manipulate-json-remove-two-items-in-a-group-by-key-value",
        "title": "Manipulate json, remove two items in a group by key value"
    },
    {
        "tags": [
            "jq",
            "cartesian-product"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1634712475,
                "creation_date": 1634712475,
                "answer_id": 69641454,
                "question_id": 69639938,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Because thats how the [`,` operator][1] in `jq` works. When two filters are separated by `,` then the same input will be fed into both and the  output value streams will be concatenated in order. In your case, both the filters return the corresponding array elements at indices 0 and 1 respectively and the result is collected into an array.  \r\n\r\nAs for [Object construction][2], the manual makes it clear that, \r\n\r\n&gt; If one of the expressions produces multiple results, multiple dictionaries will be produced.\r\n\r\nOn an input\r\n\r\n```json\r\n{&quot;user&quot;:&quot;stedolan&quot;,&quot;titles&quot;:[&quot;JQ Primer&quot;, &quot;More JQ&quot;]}\r\n``` \r\n\r\nthe expression \r\n\r\n```none\r\n{user, title: .titles[]}\r\n````\r\n\r\nproduces two outputs, one for each value in the array `titles`\r\n\r\n```json\r\n{&quot;user&quot;:&quot;stedolan&quot;, &quot;title&quot;: &quot;JQ Primer&quot;}\r\n{&quot;user&quot;:&quot;stedolan&quot;, &quot;title&quot;: &quot;More JQ&quot;}\r\n```\r\n\r\nSo going back to your original attempts, \r\n\r\n 1. In the first case, each expression runs on the original input array separately and the results are just combined together into the bigger one\r\n 2. The third case falls into the case of object creation, when one of the expression produces multiple results. Since both your expressions generate multiple results, your result dictionary is formed as cartesian product of the two arrays \r\n 3. The second case is almost similar to 3), but the operations happen over string types i.e. each integer type converted to string before the cartesian product is generated. Note that this produces a result that is _neither_ a list or a dictionary\r\n\r\nYou can still generate cartesian product on the arrays, when you do this\r\n\r\n```none\r\n.[0][] as $x | .[1][] as $y | [$x,$y]\r\n```\r\n\r\nand put the whole thing into an array if you put the above filter inside `[..]` as\r\n\r\n```none\r\n[.[0][] as $x | .[1][] as $y | [$x,$y]]\r\n```\r\n\r\nThe reason this works, is because of [Variable binding operator][3] with the syntax `expression as $variable`. \r\n\r\nThe expression `exp as $x | ...` means for each value of expression `exp`, run the rest of the pipeline with the entire original input, and with `$x` set to that value. Thus as functions as something of a `foreach` loop. So with our example, for each value in `$x` and each value in `$y`, we form the result `[$x, $y]`, which will be the resulting cartesian product.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/v1.6/#Comma:,\r\n  [2]: https://stedolan.github.io/jq/manual/v1.6/#ObjectConstruction:%7B%7D\r\n  [3]: https://stedolan.github.io/jq/manual/v1.6/#Variable/SymbolicBindingOperator:...as$identifier%7C...",
                "title": "Why jq list contructor and object constructor behaves differently for generators?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1634902302,
        "creation_date": 1634699954,
        "last_edit_date": 1634902302,
        "question_id": 69639938,
        "body_markdown": "I want to get the Cartesian product of 2 lists, and tried following way:\r\n\r\n    echo [[1,2,3],[4,5,6]] | jq &#39;[.[0][],.[1][]]&#39;\r\n\r\nI expected to get [[1,4],[1,5],[1,6],[2,4],[2,5],....], but what I really get is [1,2,3,4,5,6]\r\n\r\nBut using the following 2 commands, I get the Cartesian product output,\r\n\r\n    echo [[1,2,3],[4,5,6]] | jq &#39;(.[0][] | tostring) + &quot;,&quot; + (.[1][] | tostring)&#39;\r\n    echo [[1,2,3],[4,5,6]] | jq &#39;{&quot;x&quot;: .[0][], &quot;y&quot;: .[1][]}&#39;\r\n\r\nMy questions is: why does comma behave differently from &quot;+&quot;?  why does list constructor behave differently from object constructor?",
        "link": "https://stackoverflow.com/questions/69639938/why-jq-list-contructor-and-object-constructor-behaves-differently-for-generators",
        "title": "Why jq list contructor and object constructor behaves differently for generators?"
    },
    {
        "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": 1634734579,
                "post_id": 69640189,
                "comment_id": 123104336,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1634869882,
                "last_edit_date": 1634869882,
                "creation_date": 1634772810,
                "answer_id": 69654160,
                "question_id": 69640189,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s a couple of approaches you could take, reduce over the indices so you could index into the array to check the values. But this requires keeping a separate reference to the original input.\r\n\r\nOtherwise using `foreach` allows you to keep track of the previous `igroup` through the accumulator.\r\n\r\n```\r\nforeach .result[].segments[].lines[] as {$igroup,$products} (\r\n  [null,false];    # init: pair of previous and current value\r\n  [.[1],$igroup];  # update: update values\r\n  [\r\n    &quot;line format&quot;,\r\n    if .[0] and .[0] == $igroup then &quot;SPACE&quot; else &quot;MARK&quot; end,\r\n    ([$products[].name] | join(&quot;,&quot;)),\r\n    &quot;end line format&quot;\r\n  ] # extract: the collection of values to output\r\n), [&quot;END&quot;,0] | join(&quot;|&quot;)\r\n```\r\n\r\n```\r\n&quot;line format|MARK|Should be MARK|end line format&quot;\r\n&quot;line format|MARK|Should be MARK,Addon to MARK|end line format&quot;\r\n&quot;line format|MARK|Should be MARK First igroup=true BROKEN!!!|end line format&quot;\r\n&quot;line format|SPACE|Should be SPACE !! After first igroup=true|end line format&quot;\r\n&quot;line format|SPACE|Should be SPACE until next igroup=false|end line format&quot;\r\n&quot;line format|MARK|Should be MARK|end line format&quot;\r\n&quot;END|0&quot;\r\n```\r\n\r\nTweak the output as needed.\r\n\r\n[jqplay](https://jqplay.org/s/OPFb4LgLMN)",
                "title": "remember previous json value in array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1634863895,
                "creation_date": 1634863895,
                "answer_id": 69670264,
                "question_id": 69640189,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I was able to make some progress on my own but am still not happy with the result. I was able to use the index to check the prev arrays value. I dont like the 3 deep if-then-else-end blocks but at least it works. What it does do is allows me access to the multitude of other fields in the segments and lines arrays that the test data doesn&#39;t show.\r\n\r\n```\r\n.result\r\n| keys[] as $c\r\n|\r\n  (\r\n\t  (.[$c].segments[0].lines | keys[]) as $l |\r\n\t  \t\t[\r\n\t\t\t( $l ),\r\n\t\t\t( if $l &gt; 0\r\n\t\t\t  then\r\n\t\t\t  ( if .[$c].segments[0].lines[$l].igroup\r\n\t\t\t    then\r\n\t\t\t     ( if .[$c].segments[0].lines[$l - 1].igroup\r\n\t\t\t\t    then &quot;SPACE&quot;\r\n\t\t\t\t\telse &quot;MARK&quot; end\r\n\t\t\t\t )\r\n\t\t\t\telse &quot;MARK&quot; end\r\n\t\t\t  )\r\n\t\t\t  else &quot;MARK&quot; end\r\n\t\t\t),\r\n\t\t\t\r\n\t\t\t&quot;line format&quot;,\r\n\t\t\t( [ .[$c].segments[0].lines[$l].products[].name ] | join(&quot;,&quot;)),\r\n\t\t\t&quot;end line format&quot;\r\n\t\t\t]\r\n  ),\r\n  [&quot;END&quot;,&quot;0&quot;]\r\n| join(&quot;|&quot;)\r\n```\r\nI will look into the solution above as an alternative.",
                "title": "remember previous json value in array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1634869882,
        "creation_date": 1634702659,
        "last_edit_date": 1634778303,
        "question_id": 69640189,
        "body_markdown": "I have a sorted array list and I wish to make a formatting decision depending on the value of a json bool in the previous iteration of the array. The code example uses the current value of igroup but I need to have a MARK on the first instance of igroup=true and then all subsequent igroup=true to be SPACE. To do this I need to know what the previous value of igroup was. It seems a variable to try and remember the prev value is not possible so I am at a loss as to how I can make this happen.\r\n\r\nCode:\r\n```\r\n.result\r\n| keys[] as $c\r\n|\r\n  (\r\n\t  (.[$c].segments[0].lines | keys[]) as $l |\r\n\t  \t\t[\r\n\t\t\t&quot;line format&quot;,\r\n\t\t\t( if .[$c].segments[0].lines[$l].igroup then &quot;SPACE&quot;\r\n\t\t\t  else &quot;MARK&quot; end ),\r\n\t\t\t( [ .[$c].segments[0].lines[$l].products[].name ] | join(&quot;,&quot;)),\r\n\t\t\t&quot;end line format&quot;\r\n\t\t\t]\r\n  ),\r\n  [&quot;END&quot;,&quot;0&quot;]\r\n| join(&quot;|&quot;)\r\n```\r\nexample data:\r\n```\r\n{\r\n  &quot;result&quot;: [\r\n    {\r\n      &quot;cn&quot;: &quot;abc&quot;,\r\n      &quot;segments&quot;: [\r\n        {\r\n          &quot;lines&quot;: [\r\n            {\r\n              &quot;igroup&quot;: false,\r\n              &quot;products&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;Should be MARK&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;igroup&quot;: false,\r\n              &quot;products&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;Should be MARK&quot;\r\n                },\r\n                {\r\n                  &quot;name&quot;: &quot;Addon to MARK&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;igroup&quot;: true,\r\n              &quot;products&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;Should be MARK First igroup=true BROKEN!!!&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;igroup&quot;: true,\r\n              &quot;products&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;Should be SPACE !! After first igroup=true&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;igroup&quot;: true,\r\n              &quot;products&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;Should be SPACE until next igroup=false&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;igroup&quot;: false,\r\n              &quot;products&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;Should be MARK&quot;\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ],\r\n  &quot;id&quot;: 1\r\n}\r\n\r\n```\r\nThe output:\r\n```\r\n&quot;line format|MARK|Should be MARK|end line format&quot;\r\n&quot;line format|MARK|Should be MARK,Addon to MARK|end line format&quot;\r\n&quot;line format|SPACE|Should be MARK First igroup=true BROKEN!!!|end line format&quot;\r\n&quot;line format|SPACE|Should be SPACE !! After first igroup=true|end line format&quot;\r\n&quot;line format|SPACE|Should be SPACE until next igroup=false|end line format&quot;\r\n&quot;line format|MARK|Should be MARK|end line format&quot;\r\n&quot;END|0&quot;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/69640189/remember-previous-json-value-in-array",
        "title": "remember previous json value in array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1684984,
                    "reputation": 32085,
                    "user_id": 1548468,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0745dce203d52699e63a575b3103ad70?s=256&d=identicon&r=PG",
                    "display_name": "Botje",
                    "link": "https://stackoverflow.com/users/1548468/botje"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634714820,
                "post_id": 69640429,
                "comment_id": 123095983,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1634800125,
                "last_edit_date": 1634800125,
                "creation_date": 1634715140,
                "answer_id": 69641980,
                "question_id": 69640429,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq -r &#39;.name as $name | .details[] | [$name, .weight, .State] | @csv&#39; foo.json\r\n```\r\ngives me:\r\n```\r\n&quot;johnDoe&quot;,&quot;150&quot;,&quot;NJ&quot;\r\n&quot;johnDoe&quot;,&quot;160&quot;,&quot;NC&quot;\r\n&quot;DanLee&quot;,&quot;180&quot;,&quot;NJ&quot;\r\n&quot;DanLee&quot;,&quot;190&quot;,&quot;NC&quot;\r\n&quot;DanLee&quot;,&quot;170&quot;,&quot;NY&quot;\r\n```\r\n\r\nBreakdown:\r\n- `.name as $name` remember the current name as `$name`\r\n- `.details[]` expand the details array one by one\r\n- `[$name, .weight, .State]` construct an array for every element of details\r\n- `@csv` use the built-in CSV conversion.\r\n- `-r`: don&#39;t wrap output in JSON strings again.",
                "title": "How do I convert a nested JSON into a comma separated file for analysis? Below are the details"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1634803346,
        "creation_date": 1634704947,
        "last_edit_date": 1634803346,
        "question_id": 69640429,
        "body_markdown": "Need to parse the following Json like the following- \r\n\r\nnew.json\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;johnDoe&quot;,\r\n  &quot;dept&quot;: 45,\r\n  &quot;details&quot;: [\r\n    {\r\n      &quot;salary&quot;: &quot;76566&quot;,\r\n      &quot;weight&quot;: &quot;150&quot;,\r\n      &quot;height&quot;: &quot;160&quot;,\r\n      &quot;sex&quot;: &quot;male&quot;,\r\n      &quot;country&quot;: &quot;Usa&quot;,\r\n      &quot;State&quot;: &quot;NJ&quot;\r\n    },\r\n    {\r\n      &quot;salary&quot;: &quot;76560&quot;,\r\n      &quot;weight&quot;: &quot;160&quot;,\r\n      &quot;height&quot;: &quot;180&quot;,\r\n      &quot;sex&quot;: &quot;male&quot;,\r\n      &quot;country&quot;: &quot;Usa&quot;,\r\n      &quot;State&quot;: &quot;NC&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;name&quot;: &quot;DanLee&quot;,\r\n  &quot;dept&quot;: 46,\r\n  &quot;details&quot;: [\r\n    {\r\n      &quot;salary&quot;: &quot;76566&quot;,\r\n      &quot;weight&quot;: &quot;180&quot;,\r\n      &quot;height&quot;: &quot;160&quot;,\r\n      &quot;sex&quot;: &quot;male&quot;,\r\n      &quot;country&quot;: &quot;Usa&quot;,\r\n      &quot;State&quot;: &quot;NJ&quot;\r\n    },\r\n    {\r\n      &quot;salary&quot;: &quot;76560&quot;,\r\n      &quot;weight&quot;: &quot;190&quot;,\r\n      &quot;height&quot;: &quot;180&quot;,\r\n      &quot;sex&quot;: &quot;male&quot;,\r\n      &quot;country&quot;: &quot;Usa&quot;,\r\n      &quot;State&quot;: &quot;NC&quot;\r\n    },\r\n    {\r\n      &quot;salary&quot;: &quot;87888&quot;,\r\n      &quot;weight&quot;: &quot;170&quot;,\r\n      &quot;height&quot;: &quot;160&quot;,\r\n      &quot;sex&quot;: &quot;male&quot;,\r\n      &quot;country&quot;: &quot;Usa&quot;,\r\n      &quot;State&quot;: &quot;NY&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nNeed name, weight and State information extracted from the above Json format and get a comma separated file for analysis like this:\r\n\r\n```csv\r\nname,weight,State\r\njohnDoe,150,NJ\r\njohnDoe,160,NC\r\nDanLee,180,NJ\r\nDanLee,190,NC\r\nDanLee,170,NY\r\n```\r\n\r\nI have just started to use Jq in Linux and would like to understand how such conversion can be done with a step by step explanation.\r\n\r\nThanks.\r\n",
        "link": "https://stackoverflow.com/questions/69640429/how-do-i-convert-a-nested-json-into-a-comma-separated-file-for-analysis-below-a",
        "title": "How do I convert a nested JSON into a comma separated file for analysis? Below are the details"
    },
    {
        "tags": [
            "curl",
            "awk",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1684984,
                    "reputation": 32085,
                    "user_id": 1548468,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0745dce203d52699e63a575b3103ad70?s=256&d=identicon&r=PG",
                    "display_name": "Botje",
                    "link": "https://stackoverflow.com/users/1548468/botje"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1634738097,
                "post_id": 69647247,
                "comment_id": 123106179,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1634820782,
                "last_edit_date": 1634820782,
                "creation_date": 1634742023,
                "answer_id": 69648430,
                "question_id": 69647247,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the awk statement below (which requires GNU awk for multi-char RS) is at the end of the command line, try adding this gsub function and see if you get what you want:\r\n\r\n    Current:\r\n    awk -v RS=&#39;,&quot;&#39; -F: &#39;/^uri/ {print $2}&#39;\r\n\r\nChange to:\r\n\r\n    awk -v RS=&#39;,&quot;&#39; -F: &#39;/^uri/ {gsub(&quot;/&quot;,&quot;-&quot;,$2);print $2}&#39;\r\n\r\n",
                "title": "Sed &amp; awk to replace string from JSON output"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1634758514,
                "last_edit_date": 1634758514,
                "creation_date": 1634744701,
                "answer_id": 69649148,
                "question_id": 69647247,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This might work for you (GNU sed):\r\n\r\n    sed -nE &#39;s#&quot;.*/(.*)&quot;#\\1#p&#39; file\r\nTurn off implicit printing `-n`, and turn on extended regexp `-E` (`-r` on some platforms).\r\n\r\nPattern match on the required string and replace it with the expected part and print the result.\r\n\r\nN.B. The `(...)` in the LHS of the substitution command is called a back reference and can be recalled in the RHS. Also the use of `#` as an alternative separator rather than the usual `/` which is part of the match.",
                "title": "Sed &amp; awk to replace string from JSON output"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1634820782,
        "creation_date": 1634737664,
        "last_edit_date": 1634738148,
        "question_id": 69647247,
        "body_markdown": "I am executing below command to get particular string from json output , here I am grepping with string &quot;uri&quot; which prints all the required fields.\r\n\r\n    # curl -X GET --insecure -H &quot;$(cat /token/.bearer_header)&quot; http://localhost:3000/api/search?query=% |  sed -e \r\n    &#39;s/[{}]/&#39;&#39;/g&#39; | awk -v RS=&#39;,&quot;&#39; -F: &#39;/^uri/ {print $2}&#39; \r\n      % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                     Dload  Upload   Total   Spent    Left  Speed\r\n    100  2410    0  2410    0     0  40166      0 --:--:-- --:--:-- --:--:-- 40847\r\n    &quot;ab/any-dashboard&quot;\r\n    &quot;ab/many-dashboard&quot;\r\n    &quot;ab/too-dashboard&quot;\r\n    &quot;ab/maximum-dashboard&quot;\r\n    &quot;ab/minimum-dashboard&quot;\r\n\r\nnow I want to replace for example &quot;ab/any-dashboard&quot; to only any-dashboard, which means above command should print like below\r\n\r\n    any-dashboard\r\n    many-dashboard\r\n    too-dashboard\r\n    maximum-dashboard\r\n    minimum-dashboard\r\n\r\ncan anyone help me here I tried several things with sed but not getting exact result, and I dont have knowledge in JQ.\r\n\r\nRegards,\r\nSAM\r\n",
        "link": "https://stackoverflow.com/questions/69647247/sed-awk-to-replace-string-from-json-output",
        "title": "Sed &amp; awk to replace string from JSON output"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634737975,
                "post_id": 69647260,
                "comment_id": 123106109,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634737998,
                "post_id": 69647260,
                "comment_id": 123106122,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 320713,
                    "reputation": 2302,
                    "user_id": 639133,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/4781a491e1923d56755de71fbec9d5d4?s=256&d=identicon&r=PG",
                    "display_name": "mozey",
                    "link": "https://stackoverflow.com/users/639133/mozey"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634739654,
                "post_id": 69647260,
                "comment_id": 123106968,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634740288,
                "post_id": 69647260,
                "comment_id": 123107273,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634747536,
                "post_id": 69647260,
                "comment_id": 123110507,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1634801657,
                "last_edit_date": 1634801657,
                "creation_date": 1634749086,
                "answer_id": 69650189,
                "question_id": 69647260,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Wouldn&#39;t it be simpler to do it this way:\r\n\r\nEncode your input with\r\n```\r\njq &#39;[path(.. | scalars) as $path | {($path | join(&quot;.&quot;)): getpath($path)}] | add&#39; nested.json\r\n{\r\n  &quot;0.a&quot;: &quot;a&quot;,\r\n  &quot;0.b.0.c&quot;: &quot;c&quot;,\r\n  &quot;1.a&quot;: &quot;a&quot;,\r\n  &quot;1.b.0.c&quot;: &quot;c&quot;\r\n}\r\n\r\n```\r\nAnd decode it with\r\n```\r\njq &#39;reduce to_entries[] as $item (null; setpath($item.key / &quot;.&quot; | map(tonumber? // .); $item.value))&#39; flat.json\r\n[\r\n  {\r\n    &quot;a&quot;: &quot;a&quot;,\r\n    &quot;b&quot;: [\r\n      {\r\n        &quot;c&quot;: &quot;c&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;a&quot;: &quot;a&quot;,\r\n    &quot;b&quot;: [\r\n      {\r\n        &quot;c&quot;: &quot;c&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nHowever, if you don&#39;t care about your _special dot notation_ (e.g. `&quot;0.b.0.c&quot;`) for the encoded keys, you can simply convert the path array into a JSON string instead, having albeit uglier virtually the same effect. Moreover, it would automatically enable the handling of input object field names that include dots (e.g. `{&quot;a.b&quot;:3}`) or look like numbers (e.g. `{&quot;42&quot;:&quot;Panic!&quot;}`).\r\n\r\nUsing JSON keys, encode your input with\r\n\r\n```\r\njq &#39;[path(.. | scalars) as $path | {($path | tojson): getpath($path)}] | add&#39; nested.json\r\n{\r\n  &quot;[0,\\&quot;a\\&quot;]&quot;: &quot;a&quot;,\r\n  &quot;[0,\\&quot;b\\&quot;,0,\\&quot;c\\&quot;]&quot;: &quot;c&quot;,\r\n  &quot;[1,\\&quot;a\\&quot;]&quot;: &quot;a&quot;,\r\n  &quot;[1,\\&quot;b\\&quot;,0,\\&quot;c\\&quot;]&quot;: &quot;c&quot;\r\n}\r\n```\r\n\r\nAnd decode it with\r\n```\r\njq &#39;reduce to_entries[] as $item (null; setpath($item.key | fromjson; $item.value))&#39; flat.json\r\n[\r\n  {\r\n    &quot;a&quot;: &quot;a&quot;,\r\n    &quot;b&quot;: [\r\n      {\r\n        &quot;c&quot;: &quot;c&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;a&quot;: &quot;a&quot;,\r\n    &quot;b&quot;: [\r\n      {\r\n        &quot;c&quot;: &quot;c&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```",
                "title": "Reverse flatten nested arrays with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1634893321,
        "creation_date": 1634737705,
        "last_edit_date": 1634893321,
        "question_id": 69647260,
        "body_markdown": "Suppose I have the following nested data structure\r\n```\r\ncat nested.json\r\n[\r\n    {\r\n        &quot;a&quot;: &quot;a&quot;,\r\n        &quot;b&quot;: [\r\n            {&quot;c&quot;: &quot;c&quot;}\r\n        ]\r\n    },\r\n    {\r\n        &quot;a&quot;: &quot;a&quot;,\r\n        &quot;b&quot;: [\r\n            {&quot;c&quot;: &quot;c&quot;}\r\n        ]\r\n    }\r\n]\r\n```\r\n\r\nI can flatten it like this\r\n```\r\ncat nested.json | jq &#39;\r\n  [. as $in | reduce paths(scalars) as $path ({};\r\n    . + { ($path | map(tostring) | join(&quot;.&quot;)): $in | getpath($path) }\r\n  )]\r\n&#39; &gt; flat.json\r\n\r\ncat flat.json\r\n[\r\n  {\r\n    &quot;0.a&quot;: &quot;a&quot;,\r\n    &quot;0.b.0.c&quot;: &quot;c&quot;,\r\n    &quot;1.a&quot;: &quot;a&quot;,\r\n    &quot;1.b.0.c&quot;: &quot;c&quot;\r\n  }\r\n]\r\n```\r\n\r\nTo reverse the flatten operation with `jq` I tried this\r\n```\r\ncat flat.json | jq &#39;\r\n  .[0] | reduce to_entries[] as $kv ({};\r\n    setpath($kv.key|split(&quot;.&quot;); $kv.value)\r\n  )\r\n&#39;\r\n\r\n{\r\n  &quot;0&quot;: {\r\n    &quot;a&quot;: &quot;a&quot;,\r\n    &quot;b&quot;: {\r\n      &quot;0&quot;: {\r\n        &quot;c&quot;: &quot;c&quot;\r\n      }\r\n    }\r\n  },\r\n  &quot;1&quot;: {\r\n    &quot;a&quot;: &quot;a&quot;,\r\n    &quot;b&quot;: {\r\n      &quot;0&quot;: {\r\n        &quot;c&quot;: &quot;c&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nHowever, I want to convert numbers in the `setpath` param to create arrays. This doesn&#39;t quite work, but I think it&#39;s close?\r\n```\r\ncat flat.json  | jq &#39;\r\n  def makePath($s): [split(&quot;.&quot;)[] | if (test(&quot;\\\\d+&quot;)) then tonumber else . end];\r\n  .[0] | reduce to_entries[] as $kv ({}; setpath(makePath($kv.key); $kv.value))\r\n&#39;\r\n\r\njq: error (at &lt;stdin&gt;:8): split input and separator must be strings\r\n```\r\n\r\nThe **desired output is the same as the original data** in `nested.json`",
        "link": "https://stackoverflow.com/questions/69647260/reverse-flatten-nested-arrays-with-jq",
        "title": "Reverse flatten nested arrays with jq"
    },
    {
        "tags": [
            "json",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1634765848,
                "post_id": 69653118,
                "comment_id": 123117252,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1634765501,
                "creation_date": 1634765501,
                "answer_id": 69653262,
                "question_id": 69653118,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `test` instead of `match` as you only need a boolean result. Then, to test if any item &quot;has `wkn` in their `host_name`&quot; the regex `wkn` should suffice. Lastly, as you &quot;need to retrieve the number of `host_name`&quot;, simply finalize with `length` (which needs an array, therefore I also changed `.[]` to `map`).\r\n\r\n```shell\r\n... | jq -r &#39;.items | map(select(.Hosts.host_name | test(&quot;wkn&quot;))) | length&#39;\r\n2\r\n```",
                "title": "JQ to search for a regex"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1634893306,
        "creation_date": 1634764557,
        "last_edit_date": 1634893306,
        "question_id": 69653118,
        "body_markdown": "I have the below JSON from the curl output and I need to retrieve the number of `host_name` (hosts) that has `wkn` in its hostname. In the below json we have two hosts that has `wkn` in their `host_name`.\r\n\r\n    {\r\n      &quot;href&quot;: &quot;http://10.10.0.10:8080&quot;,\r\n      &quot;Hosts&quot;: {\r\n        &quot;cluster_name&quot;: &quot;test&quot;,\r\n        &quot;host_name&quot;: &quot;testmasternode.example.test.com&quot;,\r\n        &quot;ip&quot;: &quot;10.10.0.10&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;href&quot;: &quot;http://10.10.0.10:8080&quot;,\r\n      &quot;Hosts&quot;: {\r\n        &quot;cluster_name&quot;: &quot;test&quot;,\r\n        &quot;host_name&quot;: &quot;testwkn01.example.test.com&quot;,\r\n        &quot;ip&quot;: &quot;10.10.0.11&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;href&quot;: &quot;http://10.10.0.10:8080&quot;,\r\n      &quot;Hosts&quot;: {\r\n        &quot;cluster_name&quot;: &quot;test&quot;,\r\n        &quot;host_name&quot;: &quot;testwkn02.example.test.com&quot;,\r\n        &quot;ip&quot;: &quot;10.10.0.12&quot;\r\n      }\r\n    }\r\n\r\nI tried a couple of ways \r\n\r\n1. This doesn&#39;t give any output\r\n```shell\r\ncurl -sH http://10.10.0.10:8080/api/v1/clusters/test/hosts?fields=Hosts/host_name,Hosts/ip \\\r\n| jq -r &#39;.items | .[] | select(.Hosts.host_name == (&quot;*wkn01.*&quot;))&#39; \r\n```\r\n2. This gives an error \r\n```shell\r\ncurl -sH http://10.10.0.10:8080/api/v1/clusters/test/hosts?fields=Hosts/host_name,Hosts/ip  \\\r\n| jq -r &#39;.items | .[] | select(.Hosts.host_name | match(&quot;*wkn01.*&quot;))&#39;\r\njq: error (at &lt;stdin&gt;:76): Regex failure: target of repeat operator is not specified\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/69653118/jq-to-search-for-a-regex",
        "title": "JQ to search for a regex"
    },
    {
        "tags": [
            "json",
            "jq",
            "aws-cli",
            "remove-if"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1634821254,
                "last_edit_date": 1634821254,
                "creation_date": 1634817639,
                "answer_id": 69661604,
                "question_id": 69661364,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try this :\r\n\r\n```\r\njq &#39;walk(if type==&quot;object&quot; and\r\n            (.Name|IN(&quot;OS-Command-Injection-01&quot;,&quot;SQL-Injection-03&quot;))\r\n         then empty\r\n         else . end)&#39; input-file\r\n```",
                "title": "jq conditional delete from array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1634827553,
                "creation_date": 1634827553,
                "answer_id": 69664083,
                "question_id": 69661364,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To delete objects from arrays, you could use the template:\r\n\r\n    walk(if type == &quot;array”\r\n         then map(select( \r\n          ( type==&quot;object&quot; and\r\n            (.Name|IN( ... ) ) ) | not ))\r\n         else . end)\r\n",
                "title": "jq conditional delete from array"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1634832555,
                "creation_date": 1634832555,
                "answer_id": 69665353,
                "question_id": 69661364,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`|=` is useful for modifying elements of a data structure.\r\n\r\n* The left-hand side should return the things to modify. (Use parens if it contains `|`.)\r\n* The right-hand side is evaluated as if `|` was used instead of `|=`.\r\n* The right-hand side should return the new value. (Use parens if it contains `|`.)\r\n* The whole returns `.` with the modifications made.\r\n\r\n```sh\r\njq &#39;\r\n   ( .[].Statement.ManagedRuleGroupStatement.ExcludedRules | arrays ) |=\r\n      map(select(.Name != &quot;OS-Command-Injection-01&quot;))\r\n&#39;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/O5rNubXvQy)\r\n",
                "title": "jq conditional delete from array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1634843101,
        "creation_date": 1634816522,
        "last_edit_date": 1634843101,
        "question_id": 69661364,
        "body_markdown": "I have this json i got from aws, this is just a test i created not my actual rules\r\n\r\n```\r\n[\r\n    {\r\n      &quot;Name&quot;: &quot;Fortinet-all_rules&quot;,\r\n      &quot;Priority&quot;: 0,\r\n      &quot;Statement&quot;: {\r\n        &quot;ManagedRuleGroupStatement&quot;: {\r\n          &quot;VendorName&quot;: &quot;Fortinet&quot;,\r\n          &quot;Name&quot;: &quot;all_rules&quot;,\r\n          &quot;ExcludedRules&quot;: [\r\n            {\r\n              &quot;Name&quot;: &quot;Database-Vulnerability-Exploit-01&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Database-Vulnerability-Exploit-02&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Database-Vulnerability-Exploit-03&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Malicious-Robot&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;OS-Command-Injection-01&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;OS-Command-Injection-02&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;SQL-Injection-01&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;SQL-Injection-02&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;SQL-Injection-03&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Source-Code-Disclosure&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Web-Application-Injection-01&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Web-Application-Injection-02&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Web-Application-Vulnerability-Exploit-01&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Web-Application-Vulnerability-Exploit-02&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Web-Application-Vulnerability-Exploit-03&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Web-Application-Vulnerability-Exploit-04&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Web-Application-Vulnerability-Exploit-05&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Web-Application-Vulnerability-Exploit-06&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Web-Application-Vulnerability-Exploit-07&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Web-Scanner-01&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Web-Scanner-02&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Web-Scanner-03&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Web-Server-Vulnerability-Exploit-01&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Web-Server-Vulnerability-Exploit-02&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Web-Server-Vulnerability-Exploit-03&quot;\r\n            },\r\n            {\r\n              &quot;Name&quot;: &quot;Web-Server-Vulnerability-Exploit-04&quot;\r\n            }\r\n          ],\r\n          &quot;ScopeDownStatement&quot;: {\r\n            &quot;RegexPatternSetReferenceStatement&quot;: {\r\n              &quot;ARN&quot;: &quot;&quot;,\r\n              &quot;FieldToMatch&quot;: {\r\n                &quot;UriPath&quot;: {}\r\n              },\r\n              &quot;TextTransformations&quot;: [\r\n                {\r\n                  &quot;Priority&quot;: 0,\r\n                  &quot;Type&quot;: &quot;NONE&quot;\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        }\r\n      },\r\n      &quot;OverrideAction&quot;: {\r\n        &quot;None&quot;: {}\r\n      },\r\n      &quot;VisibilityConfig&quot;: {\r\n        &quot;SampledRequestsEnabled&quot;: true,\r\n        &quot;CloudWatchMetricsEnabled&quot;: true,\r\n        &quot;MetricName&quot;: &quot;Fortinet-all_rules&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;DDOS_rate_rule&quot;,\r\n      &quot;Priority&quot;: 1,\r\n      &quot;Statement&quot;: {\r\n        &quot;RateBasedStatement&quot;: {\r\n          &quot;Limit&quot;: 350,\r\n          &quot;AggregateKeyType&quot;: &quot;FORWARDED_IP&quot;,\r\n          &quot;ScopeDownStatement&quot;: {\r\n            &quot;NotStatement&quot;: {\r\n              &quot;Statement&quot;: {\r\n                &quot;IPSetReferenceStatement&quot;: {\r\n                  &quot;ARN&quot;: &quot;&quot;,\r\n                  &quot;IPSetForwardedIPConfig&quot;: {\r\n                    &quot;HeaderName&quot;: &quot;X-Forwarded-For&quot;,\r\n                    &quot;FallbackBehavior&quot;: &quot;MATCH&quot;,\r\n                    &quot;Position&quot;: &quot;FIRST&quot;\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;ForwardedIPConfig&quot;: {\r\n            &quot;HeaderName&quot;: &quot;X-Forwarded-For&quot;,\r\n            &quot;FallbackBehavior&quot;: &quot;MATCH&quot;\r\n          }\r\n        }\r\n      },\r\n      &quot;Action&quot;: {\r\n        &quot;Block&quot;: {}\r\n      },\r\n      &quot;VisibilityConfig&quot;: {\r\n        &quot;SampledRequestsEnabled&quot;: true,\r\n        &quot;CloudWatchMetricsEnabled&quot;: true,\r\n        &quot;MetricName&quot;: &quot;DDOS_rate_rule&quot;\r\n      }\r\n    }\r\n  ]\r\n  ```\r\nSo what i want for example is to delete the element ```\r\n{\r\n  &quot;Name&quot;: &quot;OS-Command-Injection-01&quot;\r\n}```\r\n\r\nI need to do it conditionally\r\nSo i tried using select ```jq &#39;. |  select([].Statement.ManagedRuleGroupStatement.ExcludedRules[].Name == &quot;Malicious-Robot&quot;)&#39;``` \r\nproblem is it errors jq: error (at &lt;stdin&gt;:150): Cannot iterate over null (null)\r\nalso if i try to chain selects it doesn&#39;t work\r\nI will also need to delete several object at once, but if i can delete one i can run the query several times so that&#39;s not an issue\r\n    ",
        "link": "https://stackoverflow.com/questions/69661364/jq-conditional-delete-from-array",
        "title": "jq conditional delete from array"
    },
    {
        "tags": [
            "json",
            "bash",
            "gitlab",
            "gitlab-ci",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1634913806,
                "creation_date": 1634913806,
                "answer_id": 69678848,
                "question_id": 69678761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If it is okay for you to ignore the name of the problematic key, then you can substitute it with empty brackets:\r\n\r\n```\r\nRESULTS=$RESULTS | jq &#39;.scan_overview [] .scan_status&#39;\r\n```\r\n\r\nThis is a bit sloppy and may match more than you would like, but in your narrow example, it will successfully pull out the value of `.scan_status`.\r\n\r\nThe reason this works, in this case, is because the `application/vnd...` property is the _only_ property in the `scan_overview` object.\r\n\r\nA more confident match would be achievable by using more quotes:\r\n\r\n```\r\nRESULTS=$RESULTS | jq &#39;.scan_overview .&quot;application/vnd.scanner.adapter.vuln.report.harbor+json; version=1.0&quot; .scan_status&#39;\r\n```\r\n\r\n",
                "title": "Unable to parse JSON using jq tool due to node name containing unexpected character"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1634930290,
                "last_edit_date": 1634930290,
                "creation_date": 1634914222,
                "answer_id": 69678951,
                "question_id": 69678761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use square brackets and double quotes around the problematic key:\r\n\r\n    jq &#39;.scan_overview[&quot;application/vnd.scanner.adapter.vuln.report.harbor+json; version=1.0&quot;].scan_status&#39;\r\n\r\nAlso, this doesn&#39;t do what you think:\r\n\r\n    RESULTS=$RESULTS | tr &#39;application/vnd.scanner.adapter.vuln.report.harbor+json; &#39; &#39;myobject&#39;\r\n\r\nFirst of all, `tr` doesn&#39;t replace strings, it replaces characters. `sed` can replace strings.\r\n\r\nMoreover, the pipe `|` is used when the left hand side produces output. Variable assignment doesn&#39;t produce any output.\r\n\r\nFinally, to assign the output of a command to a variable, you need to use Command Substitution:\r\n\r\n    var=$(command)\r\n        ~~       ~",
                "title": "Unable to parse JSON using jq tool due to node name containing unexpected character"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1634914335,
                "creation_date": 1634914335,
                "answer_id": 69678977,
                "question_id": 69678761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Wrap the key in question inside barckets and quotes like so:\r\n\r\n```\r\n.scan_overview[&quot;application/vnd.scanner.adapter.vuln.report.harbor+json; version=1.0&quot;].scan_status\r\n```\r\n\r\n[Demo](https://jqplay.org/s/UgRiZB0jGh)",
                "title": "Unable to parse JSON using jq tool due to node name containing unexpected character"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1634989062,
                "last_edit_date": 1634989062,
                "creation_date": 1634916990,
                "answer_id": 69679574,
                "question_id": 69678761,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From a shell syntax perspective, this looks wrong:\r\n\r\n```sh\r\nRESULTS=$RESULTS | jq &#39;...&#39;\r\n```\r\n\r\nAssigning a variable produces no output, so `jq` on the other side of the pipe has no input.\r\n",
                "title": "Unable to parse JSON using jq tool due to node name containing unexpected character"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1634989062,
        "creation_date": 1634913493,
        "last_edit_date": 1634988882,
        "question_id": 69678761,
        "body_markdown": "I tried with [jq][1] to parse some JSON output inside my [GitLab CI][2] pipeline so I can extract needed information. I&#39;ve tried many different ways, but I can&#39;t get the desired information out of the target node, because it has special characters and when I get to that node, the pipeline fails in each case. This is the current state of my pipeline.\r\n\r\nThis is the problematic job:\r\n\r\n    get results (dev branch):\r\n      stage: Results of scanning image\r\n      variables:\r\n        RESULTS: &quot;&quot;\r\n        STATUS: &quot;&quot;\r\n        SEVERITY: &quot;&quot;\r\n      image: alpine\r\n      only:\r\n        refs:\r\n          - dev\r\n      allow_failure: true\r\n      before_script:\r\n        - apk update &amp;&amp; apk upgrade\r\n        - apk --no-cache add curl\r\n        - apk add jq\r\n      script:\r\n        - &#39;RESULTS=$(curl -H &quot;Authorization: Basic `echo -n ${HARBOR_USER}:${HARBOR_PASSWORD} | base64`&quot; -X GET &quot;https://url.to.registry/api/v2.0/projects/project/repositories/repo-name/artifacts/latest?page=1&amp;page_size=10&amp;with_tag=true&amp;with_label=true&amp;with_scan_overview=true&amp;with_signature=true&amp;with_immutable_status=true&quot;)&#39;\r\n        - echo $RESULTS\r\n        - RESULTS=$RESULTS | tr &#39;application/vnd.scanner.adapter.vuln.report.harbor+json; &#39; &#39;myobject&#39;\r\n        - echo $RESULTS\r\n        - &quot;STATUS=$RESULTS | jq &#39;.scan_overview .myobjectversion=1.0 .scan_status&#39;&quot;\r\n        - &quot;SEVERITY=$RESULTS | jq &#39;.scan_overview .myobjectversion=1.0 .severity&#39;&quot;\r\n        - echo &quot;Printing the results of the image scanning process on Harbor registry:&quot;\r\n        - echo &quot;status of scan:$STATUS&quot;\r\n        - echo &quot;severity of scan:$SEVERITY&quot;\r\n        - echo &quot;For more information of scan results please visit Harbor registry!&quot;\r\n      tags:\r\n        - dev\r\n        - docker\r\n\r\nThis is the JSON output that I get from the curl command:\r\n\r\n    {\r\n       &quot;addition_links&quot;:{\r\n          &quot;build_history&quot;:{\r\n             &quot;absolute&quot;:false,\r\n             &quot;href&quot;:&quot;...&quot;\r\n          },\r\n          &quot;vulnerabilities&quot;:{\r\n             &quot;absolute&quot;:false,\r\n             &quot;href&quot;:&quot;....&quot;\r\n          }\r\n       },\r\n       &quot;digest&quot;:&quot;sha256:bcd665be2b7c6725b410029db385d7c6c71a9ce557427cbd0f54d01a9&quot;,\r\n       &quot;extra_attrs&quot;:{\r\n          &quot;architecture&quot;:&quot;amd64&quot;,\r\n          &quot;author&quot;:null,\r\n          &quot;created&quot;:&quot;2021-10-22T10:28:46.058276455Z&quot;,\r\n          &quot;os&quot;:&quot;linux&quot;\r\n       },\r\n       &quot;icon&quot;:&quot;sha256:0048162a053ee7518615bef084403614f8bca43b40ae2e762e11e06&quot;,\r\n       &quot;id&quot;:362,\r\n       &quot;labels&quot;:null,\r\n       &quot;manifest_media_type&quot;:&quot;application/vnd.docker.distribution.manifest.v2+json&quot;,\r\n       &quot;media_type&quot;:&quot;application/vnd.docker.container.image.v1+json&quot;,\r\n       &quot;project_id&quot;:3,\r\n       &quot;pull_time&quot;:&quot;2021-10-22T10:28:55.305Z&quot;,\r\n       &quot;push_time&quot;:&quot;2021-10-22T10:28:49.341Z&quot;,\r\n       &quot;references&quot;:null,\r\n       &quot;repository_id&quot;:12,\r\n       &quot;scan_overview&quot;:{\r\n          &quot;application/vnd.scanner.adapter.vuln.report.harbor+json; version=1.0&quot;:{\r\n             &quot;complete_percent&quot;:100,\r\n             &quot;duration&quot;:8,\r\n             &quot;end_time&quot;:&quot;2021-10-22T10:28:57.356Z&quot;,\r\n             &quot;report_id&quot;:&quot;e83854eb-2304-4c58-85c9-a3e0fd9067a8&quot;,\r\n             &quot;scan_status&quot;:&quot;Success&quot;,\r\n             &quot;severity&quot;:&quot;Critical&quot;,\r\n             &quot;start_time&quot;:&quot;2021-10-22T10:28:49.827Z&quot;,\r\n             &quot;summary&quot;:{\r\n                &quot;summary&quot;:{\r\n                   &quot;Critical&quot;:7,\r\n                   &quot;High&quot;:47,\r\n                   &quot;Low&quot;:18,\r\n                   &quot;Medium&quot;:47\r\n                },\r\n                &quot;total&quot;:119\r\n             }\r\n          }\r\n       }\r\n    }\r\n\r\nMy initial idea was to using `jq` to extract `scan_status` and `severity` with this command:\r\n\r\n    RESULTS=$RESULTS | jq &#39;.scan_overview .application/vnd.scanner.adapter.vuln.report.harbor+json; version=1.0 .scan_status&#39;\r\n\r\nafter running that command I got this error:\r\n\r\n    jq: error: syntax error, unexpected &#39;;&#39;, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .scan_overview .application/vnd.scanner.adapter.vuln.report.harbor+json; version=1.0 .scan_status                                                                       \r\n    jq: 1 compile error\r\n\r\nNow I am trying text replacement, but that doesn&#39;t work either.\r\n\r\nHow should I proceed in this case?\r\n\r\n  [1]: https://stedolan.github.io/jq/\r\n  [2]: https://docs.gitlab.com/ee/ci/\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69678761/unable-to-parse-json-using-jq-tool-due-to-node-name-containing-unexpected-charac",
        "title": "Unable to parse JSON using jq tool due to node name containing unexpected character"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1635023191,
                "post_id": 69691269,
                "comment_id": 123186053,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1635023869,
                "creation_date": 1635023869,
                "answer_id": 69692144,
                "question_id": 69691269,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Make sure you have a valid JSON file: Remove the last comma `,` in each object to get this as your `input.json`:\r\n```json\r\n[{\r\n    &quot;host&quot;: &quot;cat&quot;,\r\n    &quot;ip&quot;: &quot;192.168.1.1&quot;,\r\n    &quot;id&quot;: &quot;cherry&quot;\r\n}, {\r\n    &quot;host&quot;: &quot;dog&quot;,\r\n    &quot;ip&quot;: &quot;192.168.1.1&quot;,\r\n    &quot;id&quot;: &quot;apple&quot;\r\n}, {\r\n    &quot;host&quot;: &quot;cat&quot;,\r\n    &quot;ip&quot;: &quot;192.168.1.2&quot;,\r\n    &quot;id&quot;: &quot;banana&quot;\r\n}]\r\n```\r\n\r\nThen, you only need one `jq` call:\r\n\r\n```\r\njq --raw-output &#39;group_by(.ip)[] | [first.ip, (.[] | .host, .id)] | join(&quot; &quot;)&#39; input.json\r\n```\r\n\r\n[Demo](https://jqplay.org/s/25uNzzwWE_)",
                "title": "How to select multiple items with duplicate items using jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1635024032,
                "creation_date": 1635024032,
                "answer_id": 69692162,
                "question_id": 69691269,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Once you fix your example so it&#39;s valid JSON, the `group_by` function is the key:\r\n\r\n```sh\r\n$  jq -r &#39;group_by(.ip)[] | [.[0].ip, map(.host, .id)[]] | @tsv&#39; input.json\r\n192.168.1.1     cat     cherry  dog     apple\r\n192.168.1.2     cat     banana\r\n```\r\n\r\nThat will combine all objects with the same ip field into an array of objects. The rest is just turning those array of objects into arrays of just the values you want, and finally outputting each new array as a line of tab-separated values.",
                "title": "How to select multiple items with duplicate items using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1635025584,
        "creation_date": 1635016493,
        "last_edit_date": 1635025584,
        "question_id": 69691269,
        "body_markdown": "I have a JSON file which contains a list like this;\r\n\r\n```json\r\n[{\r\n    &quot;host&quot;: &quot;cat&quot;,\r\n    &quot;ip&quot;: &quot;192.168.1.1&quot;,\r\n    &quot;id&quot;: &quot;cherry&quot;\r\n}, {\r\n    &quot;host&quot;: &quot;dog&quot;,\r\n    &quot;ip&quot;: &quot;192.168.1.1&quot;,\r\n    &quot;id&quot;: &quot;apple&quot;\r\n}, {\r\n    &quot;host&quot;: &quot;cat&quot;,\r\n    &quot;ip&quot;: &quot;192.168.1.2&quot;,\r\n    &quot;id&quot;: &quot;banana&quot;\r\n}]\r\n```\r\n\r\nI want to collect IPs and print `id` and `host` next to it but if `IP` is used multiple times then print multiple `id` and `host` next to instead of a new line. `IP` and `host` can be the same for multiple items but `id` is unique.\r\n\r\nSo the final output should look like this;\r\n```\r\n$ echo &lt;something&gt;\r\n192.168.1.1 cat cherry dog apple\r\n192.168.1.2 cat banana\r\n```\r\n\r\nHow can I do this using bash and jq?",
        "link": "https://stackoverflow.com/questions/69691269/how-to-select-multiple-items-with-duplicate-items-using-jq",
        "title": "How to select multiple items with duplicate items using jq?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 21845272,
                    "reputation": 175,
                    "user_id": 16138208,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bfcbdb1406f429206fd47d8a7d8ee9ec?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "icatalan",
                    "link": "https://stackoverflow.com/users/16138208/icatalan"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1635062122,
                "post_id": 69694427,
                "comment_id": 123190713,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1635062509,
                "post_id": 69694427,
                "comment_id": 123190762,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21845272,
                    "reputation": 175,
                    "user_id": 16138208,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bfcbdb1406f429206fd47d8a7d8ee9ec?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "icatalan",
                    "link": "https://stackoverflow.com/users/16138208/icatalan"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1635062907,
                "post_id": 69694427,
                "comment_id": 123190823,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1635063107,
                "post_id": 69694427,
                "comment_id": 123190850,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21845272,
                    "reputation": 175,
                    "user_id": 16138208,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bfcbdb1406f429206fd47d8a7d8ee9ec?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "icatalan",
                    "link": "https://stackoverflow.com/users/16138208/icatalan"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1635064318,
                "post_id": 69694427,
                "comment_id": 123191064,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1635064398,
                "post_id": 69694427,
                "comment_id": 123191079,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21845272,
                    "reputation": 175,
                    "user_id": 16138208,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bfcbdb1406f429206fd47d8a7d8ee9ec?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "icatalan",
                    "link": "https://stackoverflow.com/users/16138208/icatalan"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1635064441,
                "post_id": 69694427,
                "comment_id": 123191091,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21845272,
                    "reputation": 175,
                    "user_id": 16138208,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bfcbdb1406f429206fd47d8a7d8ee9ec?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "icatalan",
                    "link": "https://stackoverflow.com/users/16138208/icatalan"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1635064562,
                "post_id": 69694427,
                "comment_id": 123191111,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1635064675,
                "last_edit_date": 1635064675,
                "creation_date": 1635063290,
                "answer_id": 69694963,
                "question_id": 69694427,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This can be accomplished entirely within `jq` (although some constraints are not all clear, so please comment and I will update the code):\r\n\r\n```\r\njq --raw-output &#39;\r\n\r\n  group_by(.V2)[]\r\n  | if first.V2 == &quot;Male&quot; then &quot;Men&quot; else &quot;Women&quot; end,\r\n    &quot;--------------&quot;,\r\n    (\r\n      .[]\r\n      | select(.V9 == 3.3)    # this filters to matching records\r\n      | [.V1, .V2, .V9, .V8]\r\n      | join(&quot;,&quot;)\r\n    )\r\n\r\n&#39; csvjson.json\r\n```\r\n\r\n[Demo](https://jqplay.org/s/Dupidz6DRK)",
                "title": "How to get the content of a JSON without showing the names of the key values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1635069228,
                "creation_date": 1635069228,
                "answer_id": 69695594,
                "question_id": 69694427,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Demo stand-alone `jq` script and code bloc language highlight for use here in stack sites using [pmf](https://stackoverflow.com/a/69694963/7939871)&#39;s answer.\r\n\r\n```jq\r\n#!/usr/bin/env -S jq --raw-output --from-file\r\n\r\ngroup_by(.V2)[]\r\n| if first.V2 == &quot;Male&quot; then &quot;Men&quot; else &quot;Women&quot; end,\r\n  &quot;--------------&quot;,\r\n  (\r\n    .[]\r\n    | select(.V9 == 3.3)    # this filters to matching records\r\n    | [.V1, .V2, .V9, .V8]\r\n    | join(&quot;,&quot;)\r\n  )\r\n```",
                "title": "How to get the content of a JSON without showing the names of the key values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1635069228,
        "creation_date": 1635057663,
        "last_edit_date": 1635064449,
        "question_id": 69694427,
        "body_markdown": "I am new to Bash and I am currently trying to get the content of a JSON without showing the names of the key values.\r\n\r\nThis is how the JSON looks like (part of it):\r\n```json\r\n[\r\n  {\r\n    &quot;V1&quot;: 65,\r\n    &quot;V2&quot;: &quot;Female&quot;,\r\n    &quot;V3&quot;: 0.7,\r\n    &quot;V4&quot;: 0.1,\r\n    &quot;V5&quot;: 187,\r\n    &quot;V6&quot;: 16,\r\n    &quot;V7&quot;: 18,\r\n    &quot;V8&quot;: 6.8,\r\n    &quot;V9&quot;: 3.3,\r\n    &quot;V10&quot;: 0.9,\r\n    &quot;Class&quot;: 1\r\n  },\r\n  {\r\n    &quot;V1&quot;: 62,\r\n    &quot;V2&quot;: &quot;Male&quot;,\r\n    &quot;V3&quot;: 10.9,\r\n    &quot;V4&quot;: 5.5,\r\n    &quot;V5&quot;: 699,\r\n    &quot;V6&quot;: 64,\r\n    &quot;V7&quot;: 100,\r\n    &quot;V8&quot;: 7.5,\r\n    &quot;V9&quot;: 3.2,\r\n    &quot;V10&quot;: 0.74,\r\n    &quot;Class&quot;: 1\r\n  },\r\n  {\r\n    &quot;V1&quot;: 62,\r\n    &quot;V2&quot;: &quot;Male&quot;,\r\n    &quot;V3&quot;: 7.3,\r\n    &quot;V4&quot;: 4.1,\r\n    &quot;V5&quot;: 490,\r\n    &quot;V6&quot;: 60,\r\n    &quot;V7&quot;: 68,\r\n    &quot;V8&quot;: 7,\r\n    &quot;V9&quot;: 3.3,\r\n    &quot;V10&quot;: 0.89,\r\n    &quot;Class&quot;: 1\r\n  }\r\n]\r\n```\r\n\r\nThis is my script\r\n```bash\r\n#!/bin/bash\r\n\r\necho &quot;Albumin =3&quot;;\r\necho &quot;Age Sex Albumin  Proteins&quot;;\r\necho &quot;******&quot;;\r\necho &quot; &quot;\r\necho &quot;Women&quot;;\r\necho &quot;--------------&quot;;\r\ncat csvjson.json | jq -c &#39;.[] | {V1, V2, V8, V9} | select(.V9 ==3) | select(.V2 ==&quot;Female&quot;)&#39;;\r\necho &quot; &quot;\r\necho &quot;Men&quot;;\r\necho &quot;-------------&quot;;\r\ncat csvjson.json | jq -c &#39;.[] | {V1, V2, V8, V9} | select(.V9 ==3) | select(.V2 ==&quot;Male&quot;)&#39;;\r\n```\r\n\r\nThis is what the script shows\r\n```none\r\nWomen\r\n--------------\r\n{&quot;V1&quot;:38,&quot;V2&quot;:&quot;Female&quot;,&quot;V8&quot;:5.6,&quot;V9&quot;:3}\r\n{&quot;V1&quot;:38,&quot;V2&quot;:&quot;Female&quot;,&quot;V8&quot;:5.6,&quot;V9&quot;:3}\r\n{&quot;V1&quot;:32,&quot;V2&quot;:&quot;Female&quot;,&quot;V8&quot;:6,&quot;V9&quot;:3}\r\n{&quot;V1&quot;:31,&quot;V2&quot;:&quot;Female&quot;,&quot;V8&quot;:6,&quot;V9&quot;:3}\r\n{&quot;V1&quot;:19,&quot;V2&quot;:&quot;Female&quot;,&quot;V8&quot;:5.5,&quot;V9&quot;:3}\r\n{&quot;V1&quot;:38,&quot;V2&quot;:&quot;Female&quot;,&quot;V8&quot;:7,&quot;V9&quot;:3}\r\n{&quot;V1&quot;:20,&quot;V2&quot;:&quot;Female&quot;,&quot;V8&quot;:6.1,&quot;V9&quot;:3}\r\n{&quot;V1&quot;:32,&quot;V2&quot;:&quot;Female&quot;,&quot;V8&quot;:7,&quot;V9&quot;:3}\r\n{&quot;V1&quot;:42,&quot;V2&quot;:&quot;Female&quot;,&quot;V8&quot;:6.7,&quot;V9&quot;:3}\r\n \r\nMen\r\n-------------\r\n{&quot;V1&quot;:72,&quot;V2&quot;:&quot;Male&quot;,&quot;V8&quot;:7.4,&quot;V9&quot;:3}\r\n{&quot;V1&quot;:60,&quot;V2&quot;:&quot;Male&quot;,&quot;V8&quot;:6.3,&quot;V9&quot;:3}\r\n{&quot;V1&quot;:33,&quot;V2&quot;:&quot;Male&quot;,&quot;V8&quot;:5.4,&quot;V9&quot;:3}\r\n{&quot;V1&quot;:60,&quot;V2&quot;:&quot;Male&quot;,&quot;V8&quot;:6.8,&quot;V9&quot;:3}\r\n{&quot;V1&quot;:60,&quot;V2&quot;:&quot;Male&quot;,&quot;V8&quot;:7.4,&quot;V9&quot;:3}\r\n{&quot;V1&quot;:60,&quot;V2&quot;:&quot;Male&quot;,&quot;V8&quot;:7,&quot;V9&quot;:3}\r\n{&quot;V1&quot;:72,&quot;V2&quot;:&quot;Male&quot;,&quot;V8&quot;:6.2,&quot;V9&quot;:3}\r\n```\r\n\r\nAnd this is what I want to show\r\n```none\r\nWomen\r\n--------------\r\n38,Female,3, 5.6\r\n38,Female,3, 5.6\r\n32,Female,3, 6\r\n31,Female,3, 6\r\n19,Female,3, 5.5\r\n38,Female,3, 7\r\n20,Female,3, 6.1\r\n32,Female,3, 7\r\n42,Female,3, 6.7\r\n\r\nMen\r\n--------------\r\n72,Male,3, 7.4\r\n60,Male,3, 6.3\r\n33,Male,3, 5.4\r\n60,Male,3, 6.8\r\n60,Male,3, 7.4\r\n60,Male,3, 7\r\n72,Male,3, 6.2\r\n```\r\n\r\nSo, how can I hide the key values and only show the content of the JSON after doing the filters I did?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69694427/how-to-get-the-content-of-a-json-without-showing-the-names-of-the-key-values",
        "title": "How to get the content of a JSON without showing the names of the key values"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1635251441,
                "last_edit_date": 1635251441,
                "creation_date": 1635177305,
                "answer_id": 69711197,
                "question_id": 69710645,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I was able to figure out what i was doing wrong:\r\n\r\n```none\r\njq  &#39;.fields_selected = (.fields_selected | map({name : .measurement , aggregation : {step: .step , function: .aggregation}}))&#39; config-it-client.json \r\n```",
                "title": "Replace values inside list"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1635183415,
                "last_edit_date": 1635183415,
                "creation_date": 1635180977,
                "answer_id": 69711981,
                "question_id": 69710645,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d use the following:\r\n\r\n```jq\r\n.fields_selected[] |= { name: .measurement, aggregation: { function: .aggregation, step } }\r\n```\r\n\r\n---\r\n\r\nTo get it working, you were just missing parens.\r\n\r\n```jq\r\n.fields_selected = .fields_selected | ...\r\n```\r\n\r\nmeans\r\n\r\n```jq\r\n( .fields_selected = .fields_selected ) | ...\r\n```\r\n\r\nIt should be\r\n\r\n```jq\r\n.fields_selected = ( .fields_selected | ... )\r\n```\r\n\r\nThis gives us\r\n\r\n```jq\r\n.fields_selected = (\r\n   .fields_selected |\r\n   map({\r\n      name: .measurement,\r\n      aggregation: {\r\n         function: .aggregation,\r\n         step: .step\r\n      }\r\n   })\r\n)\r\n```\r\n\r\n[Demo on jqplay](https://jqplay.org/s/i_9x42fQZU)\r\n\r\n---\r\n\r\nBut we can improve this. `foo = ( foo | ... )` can generally be written as `foo |= ( ... )`.\r\n\r\n```jq\r\n.fields_selected |= map({\r\n   name: .measurement,\r\n   aggregation: {\r\n      function: .aggregation,\r\n      step: .step\r\n   }\r\n})\r\n```\r\n\r\nWe could modify the objects in the fields array instead of the array itself.\r\n\r\n```jq\r\n.fields_selected[] |= {\r\n   name: .measurement,\r\n   aggregation: {\r\n      function: .aggregation,\r\n      step: .step\r\n   }\r\n}\r\n```\r\n\r\nFinally, `{ foo: .foo, ... }` can be shortened to `{ foo, ... }`.\r\n\r\n\r\n```jq\r\n.fields_selected[] |= {\r\n   name: .measurement,\r\n   aggregation: {\r\n      function: .aggregation,\r\n      step\r\n   }\r\n}\r\n```\r\n\r\nAs a sh one-liner:\r\n\r\n```sh\r\njq &#39;.fields_selected[] |= { name: .measurement, aggregation: { function: .aggregation, step } }&#39;\r\n```\r\n\r\n[Demo on jqplay](https://jqplay.org/s/R8WCZ2LG1Q)\r\n",
                "title": "Replace values inside list"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1635251441,
        "creation_date": 1635175060,
        "question_id": 69710645,
        "body_markdown": "I have the following object : \r\n\r\n```json\r\n{\r\n    &quot;db_credentials&quot;: {\r\n        &quot;database&quot;: &quot;greengrass&quot;,\r\n        &quot;host&quot;: &quot;localhost&quot;,\r\n        &quot;password&quot;: &quot;yZqXJzXHLUsLlPm&quot;,\r\n        &quot;port&quot;: 7086,\r\n        &quot;username&quot;: &quot;greengrass&quot;\r\n    },\r\n    &quot;default_interval&quot;: 90000,\r\n    &quot;fields_selected&quot;: [\r\n        {\r\n            &quot;measurement&quot;: &quot;ABPLCGD-GD_AB1AirFlowCalc&quot;,\r\n            &quot;aggregation&quot;: &quot;last&quot;,\r\n            &quot;step&quot;: &quot;10m&quot;,\r\n            &quot;timeserie_physical&quot;: &quot;null&quot;,\r\n            &quot;timeserie_type&quot;: &quot;null&quot;,\r\n            &quot;timeserie_interpolation&quot;: &quot;null&quot;,\r\n            &quot;timeserie_unit&quot;: &quot;null&quot;,\r\n            &quot;timeserie_step&quot;: &quot;10&quot;\r\n        },\r\n        {\r\n            &quot;measurement&quot;: &quot;ABPLCGD-GD_AB1InletAirTempAct&quot;,\r\n            &quot;aggregation&quot;: &quot;last&quot;,\r\n            &quot;step&quot;: &quot;10m&quot;,\r\n            &quot;timeserie_physical&quot;: &quot;null&quot;,\r\n            &quot;timeserie_type&quot;: &quot;null&quot;,\r\n            &quot;timeserie_interpolation&quot;: &quot;null&quot;,\r\n            &quot;timeserie_unit&quot;: &quot;null&quot;,\r\n            &quot;timeserie_step&quot;: &quot;10&quot;\r\n        }\r\n    ]\r\n}\r\n\r\n\r\n```\r\nand i wish to transform it into : \r\n\r\n```json\r\n{\r\n  &quot;db_credentials&quot;: {\r\n    &quot;database&quot;: &quot;greengrass&quot;,\r\n    &quot;host&quot;: &quot;localhost&quot;,\r\n    &quot;password&quot;: &quot;yZqXJzXHLUsLlPm&quot;,\r\n    &quot;port&quot;: 7086,\r\n    &quot;username&quot;: &quot;greengrass&quot;\r\n  },\r\n  &quot;default_interval&quot;: 90000,\r\n  &quot;fields_selected&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;ABPLCGD-GD_AB1AirFlowCalc&quot;,\r\n        &quot;aggregation&quot;: {\r\n          &quot;step&quot;: &quot;10m&quot;,\r\n          &quot;function&quot;: &quot;last&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ABPLCGD-GD_AB1InletAirTempAct&quot;,\r\n        &quot;aggregation&quot;: {\r\n          &quot;step&quot;: &quot;10m&quot;,\r\n          &quot;function&quot;: &quot;last&quot;\r\n        }\r\n      }\r\n    ]\r\n}\r\n\r\n```\r\n\r\ni have tried multiple solution but this is the maximum where i can get : \r\n```\r\n jq  &#39; .fields_selected = .fields_selected | map({name : .measurement , aggregation : {step: .step , function: .aggregation}})&#39; config-it-client.json\r\n```\r\nbut i got always this error that **Cannot index number with string &quot;measurement&quot;** and i cant figure out what i&#39;m doing wrong\r\n",
        "link": "https://stackoverflow.com/questions/69710645/replace-values-inside-list",
        "title": "Replace values inside list"
    },
    {
        "tags": [
            "shell",
            "arguments",
            "expression",
            "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": 1635248070,
                "post_id": 69722281,
                "comment_id": 123240413,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6715526,
                    "reputation": 429,
                    "user_id": 5201707,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://i.sstatic.net/6nHwT.jpg?s=256",
                    "display_name": "shzyincu",
                    "link": "https://stackoverflow.com/users/5201707/shzyincu"
                },
                "reply_to_user": {
                    "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": 1635248222,
                "post_id": 69722281,
                "comment_id": 123240473,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1635248255,
                "post_id": 69722281,
                "comment_id": 123240482,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1635248627,
                "post_id": 69722281,
                "comment_id": 123240632,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6715526,
                    "reputation": 429,
                    "user_id": 5201707,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://i.sstatic.net/6nHwT.jpg?s=256",
                    "display_name": "shzyincu",
                    "link": "https://stackoverflow.com/users/5201707/shzyincu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1635249207,
                "post_id": 69722281,
                "comment_id": 123240886,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1635358361,
                "last_edit_date": 1635358361,
                "creation_date": 1635254414,
                "answer_id": 69723888,
                "question_id": 69722281,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\n# --arg root_path &quot;&quot;\r\n# --arg root_path &quot;new_settings&quot;\r\n\r\ngetpath( $root_path | split(&quot;.&quot;) ) |= (\r\n   .name                  = $_job_name |\r\n   .schedule.pause_status = $_parent\r\n)\r\n```\r\n\r\n---\r\n\r\nThe argument shouldn&#39;t be a piece of jq code. It would be a bad practice to accept a piece of jq code to pass to `eval`. But `jq` doesn&#39;t even have `eval`, so it&#39;s not even an option.\r\n\r\nWe could provide a path using a JSON array.\r\n\r\n```jq\r\n# --argjson root_path &#39;[]&#39;\r\n# --argjson root_path &#39;[&quot;new_settings&quot;]&#39;\r\n\r\ngetpath($root_path)\r\n```\r\n\r\nBut a dot-separated path is much nicer.\r\n\r\n```jq\r\n# --arg root_path &quot;&quot;\r\n# --arg root_path &quot;new_settings&quot;\r\n\r\ngetpath( $root_path | split(&quot;.&quot;) )                           # Supports objects\r\ngetpath( $root_path | split(&quot;.&quot;) | map( tonumber? // . ) )   # Supports objects &amp; arrays\r\n```\r\n\r\nThis gives us something like this:\r\n\r\n```jq\r\ngetpath( $root_path | split(&quot;.&quot;) ) as $root |\r\n( $root | .name                  ) |= $_job_name |\r\n( $root | .schedule.pause_status ) |= $_parent\r\n```\r\n\r\nExcept there&#39;s no point in using `$root` twice.\r\n\r\n```jq\r\ngetpath( $root_path | split(&quot;.&quot;) ) as $root |\r\n$root |= (\r\n   .name                  |= $_job_name |\r\n   .schedule.pause_status |= $_parent\r\n)\r\n```\r\n\r\nor just\r\n\r\n```jq\r\ngetpath( $root_path | split(&quot;.&quot;) ) |= (\r\n   .name                  |= $_job_name |\r\n   .schedule.pause_status |= $_parent\r\n)\r\n```\r\n\r\nThe only difference between `=` and `|=` is the context (`.`) provided to the right-hand side. The two previously-existing `|=` can therefore be simplified to `=`.\r\n\r\n```jq\r\ngetpath( $root_path | split(&quot;.&quot;) ) |= (\r\n   .name                  = $_job_name |\r\n   .schedule.pause_status = $_parent\r\n)\r\n```\r\n\r\n[Demo on jqplay](https://jqplay.org/s/KL3Qs8MSve) `Create.json`&lt;br&gt;\r\n[Demo on jqplay](https://jqplay.org/s/9hPne5kkyS) `Update.json`\r\n",
                "title": "Passing nested json argument variable as key to JQ json library"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1635358361,
        "creation_date": 1635247777,
        "question_id": 69722281,
        "body_markdown": "I have two JSON files that I am passing to the jq object, check below:\r\n\r\nCreate.json\r\n\r\n    {\r\n    \t&quot;email_notifications&quot;: {\r\n    \t\t&quot;on_failure&quot;: &quot;_&quot;\r\n    \t},\r\n    \t&quot;name&quot;: &quot;_&quot;,\r\n    \t&quot;schedule&quot;: {\r\n    \t\t&quot;quartz_cron_expression&quot;: &quot;_&quot;,\r\n    \t\t&quot;timezone_id&quot;: &quot;Europe/Amsterdam&quot;,\r\n    \t\t&quot;pause_status&quot;: &quot;_&quot;\r\n    \t}\r\n    }\r\n\r\nUpdate.json\r\n\r\n    {\r\n    \t&quot;job_id&quot;: &quot;_&quot;,\r\n    \t&quot;new_settings&quot;: {\r\n    \t\t&quot;email_notifications&quot;: {\r\n    \t\t\t&quot;on_failure&quot;: &quot;_&quot;\r\n    \t\t},\r\n    \t\t&quot;name&quot;: &quot;_&quot;,\r\n    \t\t&quot;schedule&quot;: {\r\n    \t\t\t&quot;quartz_cron_expression&quot;: &quot;_&quot;,\r\n    \t\t\t&quot;timezone_id&quot;: &quot;Europe/Amsterdam&quot;,\r\n    \t\t\t&quot;pause_status&quot;: &quot;_&quot;\r\n    \t\t}\r\n    }\r\n\r\nfor Create.json i can use below expression:\r\n\r\n    TEMPLATE=`cat $FILE | jq\r\n    --arg _parent &quot;$PARENT&quot;\r\n    --arg _job_name &quot;$JOB_NAME&quot;\r\n    &#39; ( . | .name ) |= $_job_name\r\n    | ( . | .schedule.pause_status) |= $_parent&#39;\r\n    `\r\n\r\nfor Update.json I need to use the expression to include the parent key name:\r\n\r\n    TEMPLATE=`cat $FILE | jq\r\n        --arg _parent &quot;$PARENT&quot;\r\n        --arg _job_name &quot;$JOB_NAME&quot;\r\n        &#39; ( .[&quot;new_settings&quot;] | .name ) |= $_job_name\r\n        | ( .[&quot;new_settings&quot;] | .schedule.pause_status) |= $_parent&#39;\r\n\r\nTo handle this I have used if else in the expression and it works perfectly:\r\n( if .job_id? then .[&quot;new_settings&quot;] else . end | .name ) |= $_job_name\r\n\r\nbut I want to pass the initial part as an argument, but it doesn&#39;t work and gives a syntax error. How can i make it dynamic that an argument becomes an expression on runtime when passed:\r\n\r\n    Filter=&quot;.&quot; OR Filter=&quot;.[&quot;new_settings&quot;]&quot;\r\n    TEMPLATE=`cat $FILE | jq\r\n        --arg filter &quot;$Filter&quot;\r\n        --arg _parent &quot;$PARENT&quot;\r\n        --arg _job_name &quot;$JOB_NAME&quot;\r\n        &#39; ( $filter | .name ) |= $_job_name\r\n        | ( $filter | .schedule.pause_status) |= $_parent&#39;",
        "link": "https://stackoverflow.com/questions/69722281/passing-nested-json-argument-variable-as-key-to-jq-json-library",
        "title": "Passing nested json argument variable as key to JQ json library"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1635450606,
                "post_id": 69760036,
                "comment_id": 123309088,
                "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": 1635586529,
                "post_id": 69760036,
                "comment_id": 123341879,
                "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": 1635673834,
                "post_id": 69760036,
                "comment_id": 123353992,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1635451222,
                "creation_date": 1635451222,
                "answer_id": 69760210,
                "question_id": 69760036,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "try it \r\n\r\n    jq &#39;.[].method += [$method]&#39;",
                "title": "How do I use jq to append an array to this json string?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1635451524,
                "creation_date": 1635451524,
                "answer_id": 69760261,
                "question_id": 69760036,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Referring to an array like `$arraynew` is equivalent to `${arraynew[0]}` -- you only get the first element.\r\n\r\n`jq` expects the `--arg` values to be strings, so we need to join the array into a single string, and then split it within jq:\r\n```bash\r\njq -n \\\r\n   --arg method &quot;$method&quot; \\\r\n   --arg array  &quot;$(printf &#39;%s\\n&#39; &quot;${arraynew[@]}&quot;)&quot; \\\r\n    &#39;\r\n        {\r\n            method: [$method],\r\n            values: ($array | split(&quot;\\n&quot;))\r\n        }    \r\n    &#39;\r\n```\r\n```none\r\n{\r\n  &quot;method&quot;: [\r\n    &quot;1234&quot;\r\n  ],\r\n  &quot;values&quot;: [\r\n    &quot;hello&quot;,\r\n    &quot;world&quot;\r\n  ]\r\n}\r\n```\r\n\r\n",
                "title": "How do I use jq to append an array to this json string?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1635453722,
                "last_edit_date": 1635453722,
                "creation_date": 1635453354,
                "answer_id": 69760604,
                "question_id": 69760036,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, convert your bash array into a json array using `jq`\r\n```bash\r\nprintf &#39;%s\\0&#39; &quot;${arraynew[@]}&quot; | jq -Rns &#39;input | split(&quot;\\u0000&quot;)&#39;\r\n```\r\n```json\r\n[\r\n  &quot;hello&quot;,\r\n  &quot;world&quot;\r\n]\r\n```\r\nThen, import it to your main `jq` script using `--argjson` instead of `--arg`\r\n```bash\r\njsonarray=&quot;$(\r\n  printf &#39;%s\\0&#39; &quot;${arraynew[@]}&quot; | jq -Rns &#39;input | split(&quot;\\u0000&quot;)&#39;\r\n)&quot;\r\n\r\njq -Rn \\\r\n  --arg method &quot;$method&quot; \\\r\n  --argjson array &quot;$jsonarray&quot; \\\r\n  &#39;{method: [$method], values: $array}&#39;\r\n```\r\n```json\r\n{\r\n  &quot;method&quot;: [\r\n    &quot;1234&quot;\r\n  ],\r\n  &quot;values&quot;: [\r\n    &quot;hello&quot;,\r\n    &quot;world&quot;\r\n  ]\r\n}\r\n```",
                "title": "How do I use jq to append an array to this json string?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1635454224,
                "creation_date": 1635454224,
                "answer_id": 69760774,
                "question_id": 69760036,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can either pass your array elements as positional arguments:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\nmethod=1234\r\narraynew=(hello world)\r\ndeclare -p arraynew\r\npayload=$(\r\n  jq -n &#39;{method: $method, values: $ARGS.positional}&#39; \\\r\n    --arg method &quot;$method&quot; \\\r\n    --args &quot;${arraynew[@]}&quot;\r\n)\r\nprintf &#39;%s\\n&#39; &quot;$payload&quot;\r\n```\r\nBut it has the limitation of system&#39;s maximum argument line length, so will work only with shorter arrays of small elements.\r\n\r\nOr you can pass your array as a `null`-delimited elements stream, and have `jq` read it into a string to be split on `null` delimiters into a JSON array like this:\r\n\r\n```\r\n#!/usr/bin/env bash\r\n\r\nmethod=1234\r\narraynew=(hello world)\r\ndeclare -p arraynew\r\n\r\npayload=$(\r\n  printf &#39;%s\\0&#39; &quot;${arraynew[@]}&quot; |\r\n  jq -Rs &#39;{method: $method, values: split(&quot;\\u0000&quot;)}&#39; \\\r\n    --arg method &quot;$method&quot;\r\n)\r\nprintf &#39;%s\\n&#39; &quot;$payload&quot;\r\n",
                "title": "How do I use jq to append an array to this json string?"
            }
        ],
        "is_answered": false,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1635454224,
        "creation_date": 1635450259,
        "question_id": 69760036,
        "body_markdown": "I want to append this array to this json string using jq. My result only adds the hello element\r\n\r\n```\r\nmethod=1234\r\narraynew=(hello world)\r\necho $arraynew\r\nPAYLOAD=$( jq -Rn \\\r\n                  --arg method $method \\\r\n                  --arg array $arraynew \\\r\n                  &#39;{method: [$method], values: $array}&#39; )\r\n```\r\n\r\nI get this return:\r\n```\r\n{ &quot;method&quot;: [ &quot;1234&quot; ], &quot;values&quot;: &quot;hello&quot; }\r\n```",
        "link": "https://stackoverflow.com/questions/69760036/how-do-i-use-jq-to-append-an-array-to-this-json-string",
        "title": "How do I use jq to append an array to this json string?"
    },
    {
        "tags": [
            "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": 1635451004,
                "post_id": 69760130,
                "comment_id": 123309220,
                "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": 1635452536,
                "post_id": 69760130,
                "comment_id": 123309721,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1635451192,
                "creation_date": 1635451192,
                "answer_id": 69760204,
                "question_id": 69760130,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to determine if any value in a sequence is true for a predicate, this is a job for `any()`. If you want to do an exact string comparison, `==` is the right tool for that job.\r\n\r\n```\r\njq -c \\\r\n  --arg tgt &quot;192.0.2.0/16&quot; \\\r\n  &#39;.IPSet.Addresses | any(. == $tgt)&#39; \\\r\n  &lt;&lt;&lt;&quot;$single_ip_set&quot;\r\n```\r\n\r\n...is true, whereas:\r\n\r\n```\r\njq -c \\\r\n  --arg tgt &quot;255.255.255.8&quot; \\\r\n  &#39;.IPSet.Addresses | any(. == $tgt)&#39; \\\r\n  &lt;&lt;&lt;&quot;$single_ip_set&quot;\r\n```\r\n\r\n...is false.",
                "title": "JQ Check if Array Contains an Element"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1635451192,
        "creation_date": 1635450796,
        "question_id": 69760130,
        "body_markdown": "I&#39;ve looked through many other stack overflow questions that are similar, but can&#39;t find exactly what I&#39;m looking for. This seems simple, but I cannot get the syntax quite right and I&#39;m tired of throwing spaghetti at the wall. Given this return from the AWS CLI:\r\n\r\n```\r\n{\r\n    &quot;IPSet&quot;:{\r\n        &quot;Description&quot;:&quot;&quot;,\r\n        &quot;Name&quot;:&quot;testip&quot;,\r\n        &quot;IPAddressVersion&quot;:&quot;IPV4&quot;,\r\n        &quot;Id&quot;:&quot;a1b2c3d4-5678-90ab-cdef-EXAMPLE1111&quot;,\r\n        &quot;ARN&quot;:&quot;arn:aws:wafv2:us-west-2:123456789012:regional/ipset/testip/a1b2c3d4-5678-90ab-cdef-EXAMPLE1111&quot;,\r\n        &quot;Addresses&quot;:[\r\n            &quot;192.0.2.0/16&quot;\r\n        ]\r\n    },\r\n    &quot;LockToken&quot;:&quot;447e55ac-2396-4c6d-b9f9-86b67c17f8b5&quot;\r\n}\r\n```\r\n\r\nHow would use JQ to determine if it contained a certain IP address? This is my closest guess so far, but not quite right.\r\n\r\n```\r\necho ${single_ip_set} | jq -c &#39;.IPSet.Addresses[] | contains(&quot;255.255.255.8&quot;)&#39;\r\n```\r\n\r\nsingle_ip_set is my variable name. This checks every element in the array and gives a response. So does this:\r\n\r\n```\r\necho ${single_ip_set} | jq -c &#39;.IPSet.Addresses[] | index(&quot;255.255.255.8&quot;)&#39;\r\n```\r\n\r\nI really just want one final answer as whether or not the array contains one instance. of my requested IP.",
        "link": "https://stackoverflow.com/questions/69760130/jq-check-if-array-contains-an-element",
        "title": "JQ Check if Array Contains an Element"
    },
    {
        "tags": [
            "javascript",
            "json",
            "bash",
            "jq",
            "binaryfiles"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1635537559,
                "last_edit_date": 1635537559,
                "creation_date": 1635456905,
                "answer_id": 69761212,
                "question_id": 69761040,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one option:\r\n\r\n```sh\r\nhexdump -ve &#39;1/1 &quot;%u\\n&quot;&#39; foo.bin | jq -s &#39;{content: .}&#39;\r\n```\r\n\r\nHere, I use `jq`&#39;s `-s` flag (&quot;slurp&quot;) to read in all the lines of stdin as a single array, then simply use that array as the value of `content`.\r\n\r\nFor example:\r\n\r\n```sh\r\n$ python -c &#39;open(&quot;foo.bin&quot;, &quot;wb&quot;).write(b&quot;abc&quot;)&#39;\r\n$ hexdump -ve &#39;1/1 &quot;%u\\n&quot;&#39; foo.bin | jq -s &#39;{content: .}&#39;\r\n{\r\n  &quot;content&quot;: [\r\n    97,\r\n    98,\r\n    99\r\n  ]\r\n}\r\n```",
                "title": "Dump binary file contents in a JSON array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1635462052,
                "last_edit_date": 1635462052,
                "creation_date": 1635460247,
                "answer_id": 69761670,
                "question_id": 69761040,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` can read raw input using `-R` (or `--raw-input`) and convert it to its codepoint numbers using the `explode` [builtin](https://stedolan.github.io/jq/manual/v1.6/#Builtinoperatorsandfunctions):\r\n\r\n```sh\r\njq -Rs &#39;{content: explode}&#39; foo.bin\r\n```\r\n\r\nIf the binary file is not too large, you can also read it into a variable using `--arg` and then apply `explode` on that.\r\n\r\n```sh\r\njq -n --arg bin &quot;$(cat foo.bin)&quot; &#39;{content: $bin | explode}&#39;\r\n```\r\n\r\nNote: `jq` operates on Unicode codepoints, whereas your current `hexdump` approach translates single byte counts, so the results may differ to this regard.",
                "title": "Dump binary file contents in a JSON array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1635464801,
                "last_edit_date": 1635464801,
                "creation_date": 1635464447,
                "answer_id": 69762092,
                "question_id": 69761040,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `perl`:\r\n\r\n```sh\r\n$ printf &quot;\\x00\\x17\\x2d&quot; &gt; foo.bin\r\n$ perl -0777 -nE &#39;@bytes = map { ord } split //, $_;\r\n                  $&quot; = &quot;,&quot;; # Delimiter when inserting an array into a string\r\n                  say qq/{&quot;content&quot;:[@bytes]}/&#39; foo.bin\r\n{&quot;content&quot;:[0,23,45]}\r\n```\r\n\r\nReads the entire file at once (`-O777 -n`) and splits it into an array of bytes, and then outputs the JSON with those byte values.",
                "title": "Dump binary file contents in a JSON array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1635635162,
        "creation_date": 1635455826,
        "last_edit_date": 1635635162,
        "question_id": 69761040,
        "body_markdown": "I have a binary file that I would like to pack as a JSON array like so:\r\n\r\n```\r\n{\r\n  &quot;content&quot;: [0, 23, 45,...]\r\n}\r\n```\r\n\r\nRight now I dump the file using hexdump into a separate file (to print as unsigned u8&#39;s with commas)and manually paste those contents in the array:\r\n\r\n```\r\nhexdump -ve &#39;1/1 &quot;%u,&quot; foo.bin &gt; foo_arr\r\n```\r\n\r\nLooking for a better way to achieve this preferably over the command line (jq, standard *nix tools), JavaScript could work as well but I&#39;d rather avoid it.",
        "link": "https://stackoverflow.com/questions/69761040/dump-binary-file-contents-in-a-json-array",
        "title": "Dump binary file contents in a JSON array"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1635617244,
                "last_edit_date": 1635617244,
                "creation_date": 1635613635,
                "answer_id": 69780392,
                "question_id": 69779787,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `reduce` on the first file&#39;s items (`$i`) to successively build up the result object using `setpath` with fields from the item and values as a matching map on the secondary dictionary file (`$d`).\r\n\r\n```sh\r\njq -s --slurpfile d file2 &#39;\r\n  reduce .[] as $i ({}; setpath(\r\n    [$i.id, $i.name];\r\n    [$d[] | select(.key == $i.key).name]\r\n  ))\r\n&#39; file1\r\n```",
                "title": "Parse 2 files based on key value and recreate another json file [JQ]"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1635635042,
                "last_edit_date": 1635635042,
                "creation_date": 1635634022,
                "answer_id": 69782697,
                "question_id": 69779787,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For efficiency, the following solution first constructs a &quot;dictionary&quot; based on file2; furthermore, it does so without having to &quot;slurp&quot; it.\r\n\r\n```\r\n&lt; file2 jq -nc --slurpfile file1 file1 &#39;\r\n  (reduce inputs as {$name, $key} ({};\r\n      .[$key] += [$name])) as $dict\r\n  | reduce $file1[] as {$name, $key, $id} ({};\r\n      .[$id] += [ {($name): $dict[$key]} ] )\r\n&#39;\r\n```\r\n",
                "title": "Parse 2 files based on key value and recreate another json file [JQ]"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1635635047,
        "creation_date": 1635598268,
        "last_edit_date": 1635635047,
        "question_id": 69779787,
        "body_markdown": "I am new to JQ. \r\nI need to make a json file based on another 2 files.\r\nI am worked with it whole day and stack here. Badly need this. \r\n\r\nHere is file 1\r\n\r\n    {\r\n    &quot;name&quot;: &quot;foo&quot;,\r\n      &quot;key&quot;: &quot;1&quot;,\r\n      &quot;id&quot;: &quot;x&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;bar&quot;,\r\n      &quot;key&quot;: &quot;2&quot;,\r\n      &quot;id&quot;: &quot;x&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;baz&quot;,\r\n      &quot;key&quot;: &quot;3&quot;,\r\n      &quot;id&quot;: &quot;y&quot;\r\n    }\r\n\r\nfile 2\r\n\r\n    {\r\n    &quot;name&quot;: &quot;a&quot;,\r\n      &quot;key&quot;: &quot;1&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;b&quot;,\r\n      &quot;key&quot;: &quot;1&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;c&quot;,\r\n      &quot;key&quot;: &quot;2&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;d&quot;,\r\n      &quot;key&quot;: &quot;2&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;e&quot;,\r\n      &quot;key&quot;: &quot;3&quot;\r\n    }\r\n\r\nExpected Result:\r\n\r\n    {\r\n    &quot;x&quot;: {\r\n        &quot;foo&quot;: [\r\n          &quot;a&quot;,\r\n          &quot;b&quot;\r\n        ],\r\n        &quot;bar&quot;: [\r\n          &quot;c&quot;,\r\n          &quot;d&quot;\r\n        ]\r\n      },\r\n      &quot;y&quot;: {\r\n        &quot;baz&quot;: [\r\n          &quot;e&quot;\r\n        ]\r\n      }\r\n    }\r\n\r\nI can do it with python script but I need it with jq.\r\n\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/69779787/parse-2-files-based-on-key-value-and-recreate-another-json-file-jq",
        "title": "Parse 2 files based on key value and recreate another json file [JQ]"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1635723120,
                "creation_date": 1635723120,
                "answer_id": 69791371,
                "question_id": 69791344,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would just use string manipulation, either adding 3 strings : \r\n\r\n    jq --raw-output &#39;.Items[] | .id.S + &quot;, &quot; + .type.S&#39; file\r\n\r\nor using string interpolation :\r\n\r\n    jq --raw-output &#39;.Items[] | &quot;\\(.id.S), \\(.type.S)&quot;&#39; file\r\n\r\nYou can [try it here](https://jqplay.org/s/NHzb0MJ1tH).",
                "title": "How can I print multiple values in one line by `jq`?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1635723120,
        "creation_date": 1635722807,
        "question_id": 69791344,
        "body_markdown": "I have json data like below:\r\n\r\n```json\r\n{\r\n    &quot;Items&quot;: [\r\n        {\r\n            &quot;id&quot;: {\r\n                &quot;S&quot;: &quot;c921e4eb-5958-424a-ae3a-b9cada0d9481&quot;\r\n            },\r\n            &quot;type&quot;: {\r\n                &quot;S&quot;: &quot;transaction.1612878877726&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;id&quot;: {\r\n                &quot;S&quot;: &quot;355057f0-4327-49c7-979f-5a27410d81ba&quot;\r\n            },\r\n            &quot;type&quot;: {\r\n                &quot;S&quot;: &quot;transaction.1612345630260&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;id&quot;: {\r\n                &quot;S&quot;: &quot;664dc02f-0ad8-484a-98a5-a403beea775b&quot;\r\n            },\r\n            &quot;type&quot;: {\r\n                &quot;S&quot;: &quot;transaction.1612164919232&quot;\r\n            }\r\n        },\r\n...\r\n  ]\r\n}\r\n```\r\n\r\nI&#39;d like to print the value `id` and `type` in one line per item from the `Items` array, e.g.\r\n\r\n```\r\nc921e4eb-5958-424a-ae3a-b9cada0d9481, transaction.1612878877726\r\n355057f0-4327-49c7-979f-5a27410d81ba, transaction.1612345630260\r\n...\r\n```\r\n\r\nI tried `cat file | jq  &#39;.Items[].id.S, .Items[].type.S&#39;` but it prints `id` and `type` in separate lines. How can I achieve it with jq?",
        "link": "https://stackoverflow.com/questions/69791344/how-can-i-print-multiple-values-in-one-line-by-jq",
        "title": "How can I print multiple values in one line by `jq`?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1635794510,
                "post_id": 69801232,
                "comment_id": 123383700,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1635796738,
                "last_edit_date": 1635796738,
                "creation_date": 1635795602,
                "answer_id": 69801989,
                "question_id": 69801232,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Without the whole knowledge of the JSON, something like this should work when using `path` family of functions i.e. `getpath/1`\r\n\r\n```none\r\n( paths | select(.[-1] == &quot;guid&quot;) ) as $p | \r\n  if getpath($p)  == &quot;_0no-4e9woLW&quot; then getpath($p[:-1] + [&quot;children&quot;])[].title else empty end\r\n```\r\n\r\nThe construct above means, select all those paths containing the leaf key named `guid` and store them in a variable and filter only the path whose value turns out to be `&quot;_0no-4e9woLW&quot;`. On the selected path, trim the child node(`$p[:-1]` removes `&quot;guid&quot;`) and add the node `&quot;children&quot;` and get the value at the new path constructed (using `getpath/1`). Extract the `.title` field from the JSON value\r\n\r\n&lt;sup&gt;[jqplay demo][1]&lt;/sup&gt;\r\n\r\n\r\n  [1]: https://jqplay.org/s/NFZGlkzeGP",
                "title": "get full path up to given element"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1635810309,
                "last_edit_date": 1635810309,
                "creation_date": 1635796460,
                "answer_id": 69802149,
                "question_id": 69801232,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "* To access a node by guid:\r\n\r\n    ```jq\r\n    .. | objects | select( .guid == … )\r\n    ```\r\n\r\n    So you&#39;d use the following to get the title of `_0no-4e9woLW`&#39;s children:\r\n\r\n    ```\r\n    .. | objects | select( .guid == &quot;_0no-4e9woLW&quot; ) | .children[].title\r\n    ```\r\n\r\n    [Demo on jqplay](https://jqplay.org/s/K7xs_qZyrA)\r\n\r\n* To save a path:\r\n\r\n    ```jq\r\n    path( … )               # As JSON\r\n    ```\r\n    ```jq\r\n    path( … ) | join(&quot;.&quot;)   # As dotted path\r\n    ```\r\n\r\n    Replace `…` with an expression that returns the node(s) for which you want the path.\r\n\r\n    For example,\r\n\r\n    ```jq\r\n    path( .. | objects | select( .guid == &quot;_0no-4e9woLW&quot; ) )   # [ &quot;foo&quot;, &quot;bar&quot;, &quot;zoo&quot; ]\r\n    ```\r\n\r\n    [Demo on jqplay](https://jqplay.org/s/JpOFbdirZW)\r\n\r\n    ```jq\r\n    path( .. | objects | select( .guid == &quot;_0no-4e9woLW&quot; ) ) | join(&quot;.&quot;)   # &quot;foo.bar.zoo&quot;\r\n    ```\r\n\r\n    [Demo on jqplay](https://jqplay.org/s/vthDqCY5L5)\r\n\r\n\r\n* To grab an object using its path:\r\n\r\n    ```jq\r\n    getpath( … )                                      # From JSON\r\n    ```\r\n    ```jq\r\n    getpath( … | split(&quot;.&quot;) | map(tonumber? // .) )   # From dotted path\r\n    ```\r\n\r\n    Replace `…` with an expression that returns the previously saved path.\r\n\r\n    For example,\r\n\r\n    ```jq\r\n    getpath( [ &quot;foo&quot;, &quot;bar&quot;, &quot;zoo&quot; ] ).children[].title\r\n    ```\r\n\r\n    [Demo on jqplay](https://jqplay.org/s/6iMljl5rYI)\r\n\r\n    ```jq\r\n    getpath( &quot;foo.bar.zoo&quot; | split(&quot;.&quot;) | map(tonumber? // .) ).children[].title\r\n    ```\r\n\r\n    [Demo on jqplay](https://jqplay.org/s/g1YS1v6GPI)\r\n",
                "title": "get full path up to given element"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1635797285,
                "creation_date": 1635797285,
                "answer_id": 69802265,
                "question_id": 69801232,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `recurse` allows to get to the object easily :\r\n\r\n```\r\njq -r &#39;recurse |\r\n       select(type==&quot;object&quot; and .guid == &quot;_0no-4e9woLW&quot;)\r\n       .children[].title&#39; firefox.json\r\n```",
                "title": "get full path up to given element"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1635970678,
                "last_edit_date": 1635970678,
                "creation_date": 1635970348,
                "answer_id": 69831170,
                "question_id": 69801232,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    json2jqpath.jq file.json \r\n    .\r\n    .foo\r\n    .foo|.bar\r\n    .foo|.bar|.zoo\r\n    .foo|.bar|.zoo|.children\r\n    .foo|.bar|.zoo|.children|.[]\r\n    .foo|.bar|.zoo|.children|.[]|.dateAdded\r\n    .foo|.bar|.zoo|.children|.[]|.guid\r\n    .foo|.bar|.zoo|.children|.[]|.id\r\n    .foo|.bar|.zoo|.children|.[]|.index\r\n    .foo|.bar|.zoo|.children|.[]|.lastModified\r\n    .foo|.bar|.zoo|.children|.[]|.title\r\n    .foo|.bar|.zoo|.children|.[]|.type\r\n    .foo|.bar|.zoo|.children|.[]|.typeCode\r\n    .foo|.bar|.zoo|.children|.[]|.uri\r\n    .foo|.bar|.zoo|.dateAdded\r\n    .foo|.bar|.zoo|.guid\r\n    .foo|.bar|.zoo|.id\r\n    .foo|.bar|.zoo|.index\r\n    .foo|.bar|.zoo|.lastModified\r\n    .foo|.bar|.zoo|.title\r\n    .foo|.bar|.zoo|.type\r\n    .foo|.bar|.zoo|.typeCode\r\n    \r\nShows `guid`  appears as a leaf in more than one unique path.\r\nIf there were only one you would be done \r\n(assuming you knew the value existed) \r\nwith multiple paths you need to check that the value exists \r\nand it is to your object of interest.\r\n  \r\n    \r\n    json2jqpath.jq file.json | grep guid\r\n    .foo|.bar|.zoo|.children|.[]|.guid\r\n    .foo|.bar|.zoo|.guid\r\n    \r\n    \r\nAppending your given value to the paths returns objects containg them\r\n \r\n     \r\n    jq &#39;.foo|.bar|.zoo|.children|.[]|.guid=&quot;_0no-4e9woLW&quot;&#39; file.json \r\n\t{\r\n\t  &quot;guid&quot;: &quot;_0no-4e9woLW&quot;,\r\n\t  &quot;title&quot;: &quot;css child override parent style&quot;,\r\n\t  &quot;index&quot;: 0,\r\n\t  &quot;dateAdded&quot;: 1614198648005000,\r\n\t  &quot;lastModified&quot;: 1614198648005000,\r\n\t  &quot;id&quot;: 16519,\r\n\t  &quot;typeCode&quot;: 1,\r\n\t  &quot;type&quot;: &quot;text/x-moz-place&quot;,\r\n\t  &quot;uri&quot;: &quot;https://www.google.com/search?client=firefox-b-d&amp;q=css+child+override+parent+style&quot;\r\n\t}\r\n\t{\r\n\t  &quot;guid&quot;: &quot;_0no-4e9woLW&quot;,\r\n\t  &quot;title&quot;: &quot;css child parent inheritance&quot;,\r\n\t  &quot;index&quot;: 1,\r\n\t  &quot;dateAdded&quot;: 1614198648096000,\r\n\t  &quot;lastModified&quot;: 1614198648096000,\r\n\t  &quot;id&quot;: 16520,\r\n\t  &quot;typeCode&quot;: 1,\r\n\t  &quot;type&quot;: &quot;text/x-moz-place&quot;,\r\n\t  &quot;uri&quot;: &quot;https://www.google.com/search?client=firefox-b-d&amp;q=css+child+parent+inheritance&quot;\r\n\t}\r\n\t\r\n\t\r\n\tjq &#39;.foo|.bar|.zoo|.guid=&quot;_0no-4e9woLW&quot;&#39; file.json \r\n\t{\r\n\t  &quot;guid&quot;: &quot;_0no-4e9woLW&quot;,\r\n\t  &quot;title&quot;: &quot;frontend&quot;,\r\n\t  &quot;index&quot;: 3,\r\n\t  &quot;dateAdded&quot;: 1614198626454000,\r\n\t  &quot;lastModified&quot;: 1619505016472000,\r\n\t  &quot;id&quot;: 16518,\r\n\t  &quot;typeCode&quot;: 2,\r\n\t  &quot;type&quot;: &quot;text/x-moz-place-container&quot;,\r\n\t  &quot;children&quot;: [\r\n\t    {\r\n\t      &quot;guid&quot;: &quot;2L7ZsYTM2RX0&quot;,\r\n\t      &quot;title&quot;: &quot;css child override parent style&quot;,\r\n\t      &quot;index&quot;: 0,\r\n\t      &quot;dateAdded&quot;: 1614198648005000,\r\n\t      &quot;lastModified&quot;: 1614198648005000,\r\n\t      &quot;id&quot;: 16519,\r\n\t      &quot;typeCode&quot;: 1,\r\n\t      &quot;type&quot;: &quot;text/x-moz-place&quot;,\r\n\t      &quot;uri&quot;: &quot;https://www.google.com/search?client=firefox-b-d&amp;q=css+child+override+parent+style&quot;\r\n\t    },\r\n\t    {\r\n\t      &quot;guid&quot;: &quot;x3JHTAezzyI8&quot;,\r\n\t      &quot;title&quot;: &quot;css child parent inheritance&quot;,\r\n\t      &quot;index&quot;: 1,\r\n\t      &quot;dateAdded&quot;: 1614198648096000,\r\n\t      &quot;lastModified&quot;: 1614198648096000,\r\n\t      &quot;id&quot;: 16520,\r\n\t      &quot;typeCode&quot;: 1,\r\n\t      &quot;type&quot;: &quot;text/x-moz-place&quot;,\r\n\t      &quot;uri&quot;: &quot;https://www.google.com/search?client=firefox-b-d&amp;q=css+child+parent+inheritance&quot;\r\n\t    }\r\n\t  ]\r\n\t}\r\n\t\r\n\t\r\n\t\r\n[json2jqpath.jq](https://github.com/TomConlin/json_to_paths)\t",
                "title": "get full path up to given element"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1635970678,
        "creation_date": 1635791442,
        "last_edit_date": 1635798545,
        "question_id": 69801232,
        "body_markdown": "I have exported bookmarks from Firefox which in my case is quiet large JSON. I&#39;m interested in the object with guid `_0no-4e9woLW` in a JSON such as this one:\r\n\r\n```\r\n{\r\n  &quot;foo&quot;: {\r\n    &quot;bar&quot;: {\r\n      &quot;zoo&quot;: {\r\n        &quot;guid&quot;: &quot;_0no-4e9woLW&quot;,\r\n        &quot;title&quot;: &quot;frontend&quot;,\r\n        &quot;index&quot;: 3,\r\n        &quot;dateAdded&quot;: 1614198626454000,\r\n        &quot;lastModified&quot;: 1619505016472000,\r\n        &quot;id&quot;: 16518,\r\n        &quot;typeCode&quot;: 2,\r\n        &quot;type&quot;: &quot;text/x-moz-place-container&quot;,\r\n        &quot;children&quot;: [\r\n          {\r\n            &quot;guid&quot;: &quot;2L7ZsYTM2RX0&quot;,\r\n            &quot;title&quot;: &quot;css child override parent style&quot;,\r\n            &quot;index&quot;: 0,\r\n            &quot;dateAdded&quot;: 1614198648005000,\r\n            &quot;lastModified&quot;: 1614198648005000,\r\n            &quot;id&quot;: 16519,\r\n            &quot;typeCode&quot;: 1,\r\n            &quot;type&quot;: &quot;text/x-moz-place&quot;,\r\n            &quot;uri&quot;: &quot;https://www.google.com/search?client=firefox-b-d&amp;q=css+child+override+parent+style&quot;\r\n          },\r\n          {\r\n            &quot;guid&quot;: &quot;x3JHTAezzyI8&quot;,\r\n            &quot;title&quot;: &quot;css child parent inheritance&quot;,\r\n            &quot;index&quot;: 1,\r\n            &quot;dateAdded&quot;: 1614198648096000,\r\n            &quot;lastModified&quot;: 1614198648096000,\r\n            &quot;id&quot;: 16520,\r\n            &quot;typeCode&quot;: 1,\r\n            &quot;type&quot;: &quot;text/x-moz-place&quot;,\r\n            &quot;uri&quot;: &quot;https://www.google.com/search?client=firefox-b-d&amp;q=css+child+parent+inheritance&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n\r\nIs it possible to get somehow full path up to `&quot;guid&quot;: &quot;_0no-4e9woLW&quot;`? guid keys are uniq in JSON. My goal is to type something like `jq &#39;[&quot;full path I&#39;ve somehow previously obtained&quot;][&quot;children&quot;].title&#39;`\r\n\r\nAnd I will obtain:\r\n```\r\ncss child override parent style\r\ncss child parent inheritance\r\n```\r\n\r\nOf course I could do this manually but I&#39;m too lazy.",
        "link": "https://stackoverflow.com/questions/69801232/get-full-path-up-to-given-element",
        "title": "get full path up to given element"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1635881321,
                "last_edit_date": 1635881321,
                "creation_date": 1635839457,
                "answer_id": 69806919,
                "question_id": 69806317,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With assumptions based on your description provided, I guess you are looking to do this\r\n\r\n```none\r\n.scan_info + ( .warnings[] | del(.location, .render_path) )\r\n```\r\nIf you want the entire results packed into an array, enclose the above filter within square brackets(`[ ]`)\r\n\r\n[jqplay demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/qnmh1qTPPw",
                "title": "Flatten JSON data with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1635881321,
        "creation_date": 1635835468,
        "question_id": 69806317,
        "body_markdown": "I have output brakeman scan results to a json file and want to flatten the structure. \r\n\r\nBrakeman json output sample looks like this\r\n\r\n```json\r\n{\r\n    &quot;scan_info&quot;: {\r\n      &quot;security_warnings&quot;: 9,\r\n      &quot;start_time&quot;: &quot;2021-11-01 14:44:58 +1100&quot;,\r\n      &quot;end_time&quot;: &quot;2021-11-01 14:45:13 +1100&quot;,\r\n      &quot;brakeman_version&quot;: &quot;5.1.2&quot;\r\n    },\r\n    &quot;warnings&quot;: [\r\n      {\r\n        &quot;warning_type&quot;: &quot;Redirect&quot;,\r\n        &quot;warning_code&quot;: 18,\r\n        &quot;fingerprint&quot;: &quot;cae2f2cfd8&quot;,\r\n        &quot;check_name&quot;: &quot;Redirect&quot;,\r\n        &quot;message&quot;: &quot;Possible unprotected redirect&quot;,\r\n        &quot;file&quot;: &quot;app/controllers/my/controller.rb&quot;,\r\n        &quot;line&quot;: 24,\r\n        &quot;link&quot;: &quot;https://brakemanscanner.org/docs/warning_types/redirect/&quot;,\r\n        &quot;code&quot;: &quot;redirect_to....&quot;,\r\n        &quot;render_path&quot;: null,\r\n        &quot;location&quot;: {\r\n          &quot;type&quot;: &quot;method&quot;,\r\n          &quot;class&quot;: &quot;My::Controller&quot;,\r\n          &quot;method&quot;: &quot;request_token&quot;\r\n        },\r\n        &quot;user_input&quot;: &quot;my.base_url&quot;,\r\n        &quot;confidence&quot;: &quot;High&quot;\r\n      },\r\n      {.....}\r\n    ],\r\n    &quot;ignored_warnings&quot;: [],\r\n    &quot;errors&quot;: [],\r\n    &quot;obsolete&quot;: [&quot;xxx&quot;,&quot;yyyy&quot;]\r\n  }\r\n```\r\n\r\nI want to flatten the output into an array of objects similar to this. I want most data from the `warnings` array except `.location` and `.render_path`.\r\n```json\r\n[\r\n{\r\n  &quot;brakeman_version&quot;: &quot;5.1.2&quot;,\r\n  &quot;warning_type&quot;: &quot;Redirect&quot;,\r\n  &quot;warning_code&quot;: 18,\r\n  &quot;fingerprint&quot;: &quot;cae2f0d2cfd8&quot;,\r\n  &quot;check_name&quot;: &quot;Redirect&quot;,\r\n  &quot;message&quot;: &quot;Possible unprotected redirect&quot;,\r\n  &quot;line&quot;: 24,\r\n  &quot;link&quot;: &quot;https://brakemanscanner.org/docs/warning_types/redirect/&quot;,\r\n  &quot;code&quot;: &quot;redirect_to...&quot;,\r\n  &quot;confidence&quot;: &quot;High&quot;\r\n },\r\n {\r\n  &quot;brakeman_version&quot;: &quot;5.1.2&quot;,\r\n  &quot;warning_type&quot;: &quot;SQL Injection&quot;,\r\n  &quot;check_name&quot;: &quot;SQL&quot;,\r\n  &quot;message&quot;: &quot;Possible SQL injection&quot;,\r\n  &quot;warning_code&quot;: 35,\r\n  ....\r\n  &quot;confidence&quot;: &quot;High&quot;\r\n  }\r\n]\r\n```\r\n\r\nSomething like this gives a nested object for each item in the `warnings` array but I&#39;d like to move them up a level\r\n`jq &#39;{brakeman_version: .scan_info.brakeman_version, start_time: .scan_info.start_time, warnings: .warnings[]}&#39; ./brakeman.json`\r\n\r\nResult\r\n```json\r\n{\r\n  &quot;brakeman_version&quot;: &quot;5.1.2&quot;,\r\n  &quot;start_time&quot;: &quot;2021-11-01 14:44:58 +1100&quot;,\r\n  &quot;warnings&quot;: {\r\n    &quot;warning_type&quot;: &quot;Redirect&quot;,\r\n    &quot;warning_code&quot;: 18,\r\n    &quot;fingerprint&quot;: &quot;xxxx&quot;,\r\n    &quot;check_name&quot;: &quot;Redirect&quot;,\r\n    &quot;message&quot;: &quot;Possible unprotected redirect&quot;,\r\n    &quot;line&quot;: 24,\r\n    &quot;link&quot;: &quot;https://brakemanscanner.org/docs/warning_types/redirect/&quot;,\r\n    &quot;confidence&quot;: &quot;High&quot;\r\n  },\r\n  {...}\r\n}\r\n```\r\n\r\nSomething like this flattens the `.scan_info` part similarly but still leaves me with an array for `warnings` which is what was there in the first place.\r\n```bash\r\njq &#39;{\r\nrails_version: .scan_info.rails_version,\r\nsecurity_warnings: .scan_info.security_warnings,\r\nstart_time: .scan_info.start_time,\r\nbrakeman_version: .scan_info.brakeman_version,\r\nwarnings: [.warnings[] | {warning_type: .warning_type,\r\nwarning_code: .warning_code,\r\nfingerprint: .fingerprint,\r\ncheck_name: .check_name,\r\nconfidence: .confidence} ],\r\nobsolete: (.obsolete | join(&quot;,&quot;)),\r\n}&#39; ./brakeman.json\r\n```\r\nResults\r\n```json\r\n{\r\n  &quot;rails_version&quot;: &quot;6.1.4.1&quot;,\r\n  &quot;security_warnings&quot;: 9,\r\n  &quot;start_time&quot;: &quot;2021-11-01 14:44:58 +1100&quot;,\r\n  &quot;warnings&quot;: [\r\n    {\r\n      &quot;warning_type&quot;: &quot;SQL Injection&quot;,\r\n      &quot;warning_code&quot;: 0,\r\n      &quot;fingerprint&quot;: &quot;xx&quot;,\r\n      &quot;check_name&quot;: &quot;SQL&quot;,\r\n      &quot;message&quot;: &quot;Possible SQL injection&quot;,\r\n      &quot;line&quot;: 178,\r\n      &quot;link&quot;: &quot;https://brakemanscanner.org/docs/warning_types/sql_injection/&quot;,\r\n      &quot;confidence&quot;: &quot;Medium&quot;\r\n    },\r\n    {\r\n      &quot;warning_type&quot;: &quot;Format Validation&quot;,\r\n      &quot;warning_code&quot;: 30,\r\n      &quot;fingerprint&quot;: &quot;xxx&quot;,\r\n      &quot;check_name&quot;: &quot;ValidationRegex&quot;,\r\n      &quot;line&quot;: 92,\r\n      &quot;link&quot;: &quot;https://brakemanscanner.org/docs/warning_types/format_validation/&quot;,\r\n      &quot;code&quot;: null,\r\n      &quot;user_input&quot;: null,\r\n      &quot;confidence&quot;: &quot;High&quot;\r\n    },\r\n  ]\r\n}\r\n```\r\n\r\nUsing jq how do I correctly flatten the structure to output as desired?\r\n\r\nI&#39;ve tried some suggestions found on SO like \r\n```\r\njq &#39;{\r\nrails_version: .scan_info.rails_version,\r\nbrakeman_version: .scan_info.brakeman_version,\r\n.warnings[] as $in | $in | del(.location, .render_path) as $in2 | $in2,\r\nobsolete: (.obsolete | join(&quot;,&quot;)),\r\n}&#39; ./brakeman.json\r\n```\r\nbut have been going around in circles at this stage. ",
        "link": "https://stackoverflow.com/questions/69806317/flatten-json-data-with-jq",
        "title": "Flatten JSON data with jq"
    },
    {
        "tags": [
            "json",
            "git",
            "batch-file",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1635870362,
                "post_id": 69813151,
                "comment_id": 123405690,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1635870494,
                "post_id": 69813151,
                "comment_id": 123405760,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1635870573,
                "post_id": 69813151,
                "comment_id": 123405801,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1671926589,
                "creation_date": 1671926589,
                "answer_id": 74910934,
                "question_id": 69813151,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "just use something like this this:\r\n\r\n    $ jq -r &lt; /tmp/o &#39;.components[] | select( .version != &quot;^&quot; ) | &quot;git submodule init \\(.URL):\\(.version)&quot;&#39;\r\n    git submodule init https://my.git.repo/Standard:X\r\n\r\n\r\nI&#39;m not much versed in the bat language, but you may have some luck with: \r\n\r\n- https://superuser.com/questions/652492/windows-equivalent-to-xargs",
                "title": "Automate inclusion of Git submodules based on JSON file"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1671926589,
        "creation_date": 1635867668,
        "question_id": 69813151,
        "body_markdown": "This question may be too open-ended for Stack Overflow, but I&#39;m getting nowhere on my own.  I am looking for a way to use automate the use of designated Git submodules based on values in a text file.  My company generates a lot of projects, but we reuse a lot of code.  We use submodules and tags for this, but the volume is starting to get unwieldy.\r\n\r\nI was thinking it would make sense to use something similar to an NPM packages.json file.  Maybe like this:\r\n\r\n```\r\n{\r\n    &quot;name&quot;: &quot;Custom Development Components&quot;,\r\n    &quot;description&quot;: &quot;Reusable objects to increase the efficiency and quality of custom development&quot;,\r\n    &quot;components&quot;: [\r\n                    {\r\n                        &quot;name&quot;: &quot;stats&quot;,\r\n                        &quot;description&quot;: &quot;Statistics&quot;,\r\n                        &quot;URL&quot;: &quot;https://my.git.repo/Statistics&quot;,\r\n                        &quot;folder-name&quot;: &quot;STATS&quot;,\r\n                        &quot;version&quot;: &quot;^&quot;\r\n                    },\r\n                    {\r\n                        &quot;name&quot;: &quot;standard&quot;,\r\n                        &quot;description&quot;: &quot;Standard&quot;,\r\n                        &quot;URL&quot;: &quot;https://my.git.repo/Standard&quot;,\r\n                        &quot;folder-name&quot;: &quot;STANDARD&quot;,\r\n                        &quot;version&quot;: &quot;X&quot;\r\n                    },\r\n                    {\r\n                        &quot;name&quot;: &quot;helpers&quot;,\r\n                        &quot;description&quot;: &quot;Helper Objects and Scripts&quot;,\r\n                        &quot;URL&quot;: &quot;https://my.git.repo/Helpers&quot;,\r\n                        &quot;folder-name&quot;: &quot;HELPERS&quot;,\r\n                        &quot;version&quot;: &quot;^&quot;\r\n                    }\r\n    ]\r\n}\r\n```\r\n\r\nBut I haven&#39;t been able to figure out how to parse the JSON and turn it into Git commands.  I&#39;ve fiddled around with using JQ in a Windows batch file (we&#39;re all working in Windows environments), but I haven&#39;t gotten very far with it.  Basically, I&#39;m looking to be able to step through the JSON, find components where the version is a string other than ^ (which may or may not be a specific tag), and import the URL for the submodule.    \r\n\r\nAny guidance here would be appreciated.",
        "link": "https://stackoverflow.com/questions/69813151/automate-inclusion-of-git-submodules-based-on-json-file",
        "title": "Automate inclusion of Git submodules based on JSON file"
    },
    {
        "tags": [
            "json",
            "jq",
            "filenames"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1635930450,
                "creation_date": 1635930450,
                "answer_id": 69822186,
                "question_id": 69822085,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `cat *` destroys any filename information that exists. Modify your pipeline to\r\n```\r\njq -r &#39;...&#39; *\r\n```\r\nand `input_filename` will evaluate to the current filename.",
                "title": "How to add the name of the json file while using cat &amp; select through multiple json files"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1635963299,
        "creation_date": 1635929966,
        "last_edit_date": 1635963299,
        "question_id": 69822085,
        "body_markdown": "I&#39;m new to JQ and work on an Events Data Set. I select specific events (shot.type.id==88) from a folder with multiple json files after concatenating them. Then I choose some variables of interest (id, index, player_id,...). See the following code:\r\n```bash\r\ncat * | jq -r &#39;.[] | select(.shot.type.id==88) | {id:.id, index:.index, player_id:.player.id,striker_name:.player.name} &#39; \r\n```\r\nConcerning the output: I&#39;d like to add the name of the json file, from which the event is taken. I&#39;ve tried input_filename within the &quot;{}&quot; but had no success. Any help is much appreciated! ",
        "link": "https://stackoverflow.com/questions/69822085/how-to-add-the-name-of-the-json-file-while-using-cat-select-through-multiple-j",
        "title": "How to add the name of the json file while using cat &amp; select through multiple json files"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1635937384,
                "post_id": 69823661,
                "comment_id": 123423334,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1635948274,
                "post_id": 69823661,
                "comment_id": 123428014,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1635937791,
                "creation_date": 1635937791,
                "answer_id": 69823809,
                "question_id": 69823661,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    echo &#39;...&#39; | jq &#39;with_entries(select([.key] | inside([&quot;apples&quot;, &quot;cherries&quot;])))&#39;\r\n\r\nThanks https://stackoverflow.com/a/46293052/9216229",
                "title": "JQ: How to get just part of a JSON object?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1728645725,
                "last_edit_date": 1728645725,
                "creation_date": 1635945178,
                "answer_id": 69825482,
                "question_id": 69823661,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "# Try jq &#39;{apples, cherries}&#39;\r\n\r\nTurns out the dots were wrong:\r\n* `jq &#39;{.apples, .cherries}&#39;` &lt;= Does NOT work.\r\n* `jq &#39;{apples, cherries}&#39;` &lt;= Works.\r\n\r\nWithout the dots it works just fine:\r\n\r\n````\r\n$ echo &#39;{\r\n  &quot;apples&quot;:   { &quot;color&quot;:&quot;green&quot;,  &quot;count&quot;: 3 },\r\n  &quot;bananas&quot;:  { &quot;color&quot;:&quot;yellow&quot;, &quot;count&quot;: 4 },\r\n  &quot;cherries&quot;: { &quot;color&quot;:&quot;red&quot; }\r\n}&#39; | jq &#39;{apples, cherries}&#39;\r\n{\r\n  &quot;apples&quot;: {\r\n    &quot;color&quot;: &quot;green&quot;,\r\n    &quot;count&quot;: 3\r\n  },\r\n  &quot;cherries&quot;: {\r\n    &quot;color&quot;: &quot;red&quot;\r\n  }\r\n}\r\n````\r\n\r\n*Related:* https://stackoverflow.com/questions/34834519/how-do-i-select-multiple-fields-in-jq",
                "title": "JQ: How to get just part of a JSON object?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1728645725,
        "creation_date": 1635937048,
        "last_edit_date": 1728645429,
        "question_id": 69823661,
        "body_markdown": "How can I get my wanted output? I can&#39;t figure out how to preserve the object names (keys).\r\n\r\nI&#39;m new to jq and I tried several flavors of jq&#39;s select/flatten/map/&quot;,&quot;/&quot;keys as $k&quot;.../etc. but I&#39;m not getting anywhere.\r\n\r\n## Input\r\n````\r\n$ echo &#39;{&quot;apples&quot;: {&quot;color&quot;:&quot;green&quot;,  &quot;count&quot;:3}, &quot;bananas&quot;: {&quot;color&quot;:&quot;yellow&quot;, &quot;count&quot;:4}, &quot;cherries&quot;: {&quot;color&quot;:&quot;red&quot;}}&#39; \\  \r\n  | jq .\r\n{\r\n  &quot;apples&quot;: {\r\n    &quot;color&quot;: &quot;green&quot;,\r\n    &quot;count&quot;: 3\r\n  },\r\n  &quot;bananas&quot;: {\r\n    &quot;color&quot;: &quot;yellow&quot;,\r\n    &quot;count&quot;: 4\r\n  },\r\n  &quot;cherries&quot;: {\r\n    &quot;color&quot;: &quot;red&quot;\r\n  }\r\n}\r\n````\r\n\r\n## Actual Output\r\nThis is the best I got but the object names are gone:\r\n````\r\n$ echo &#39;{&quot;apples&quot;: {&quot;color&quot;:&quot;green&quot;,  &quot;count&quot;:3}, &quot;bananas&quot;: {&quot;color&quot;:&quot;yellow&quot;, &quot;count&quot;:4}, &quot;cherries&quot;: {&quot;color&quot;:&quot;red&quot;}}&#39; \\  \r\n  | jq &#39;.apples, .cherries&#39;\r\n{\r\n  &quot;color&quot;: &quot;green&quot;,\r\n  &quot;count&quot;: 3\r\n}\r\n{\r\n  &quot;color&quot;: &quot;red&quot;\r\n}\r\n````\r\n\r\n## Expected Output\r\nThis is what I want: input and expected output: What is the `jq #some-jq-magic-here`?\r\n````\r\n$ echo &#39;{&quot;color&quot;:&quot;yellow&quot;, &quot;count&quot;:4}, &quot;cherries&quot;: {&quot;color&quot;:&quot;red&quot;}}&#39; \\  \r\n  | jq #some-jq-magic-here\r\n{\r\n  &quot;apples&quot;: {\r\n    &quot;color&quot;: &quot;green&quot;,\r\n    &quot;count&quot;: 3\r\n  },\r\n  &quot;cherries&quot;: {\r\n    &quot;color&quot;: &quot;red&quot;\r\n  }\r\n}\r\n````\r\n\r\n\r\n**EDIT:** ANSWER: The `jq #some-jq-magic-here` is this: `jq &#39;{apples, cherries}&#39;`. From own answer. See below.",
        "link": "https://stackoverflow.com/questions/69823661/jq-how-to-get-just-part-of-a-json-object",
        "title": "JQ: How to get just part of a JSON object?"
    },
    {
        "tags": [
            "string",
            "concatenation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1635986345,
                "creation_date": 1635986345,
                "answer_id": 69833295,
                "question_id": 69832505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can keep the two items in a list, then join them together :\r\n\r\n```\r\nlscpu -J | jq -r &#39;.lscpu |\r\n                  map(select(.field |\r\n                             IN(&quot;CPU(s):&quot;,&quot;Model name:&quot;)\r\n                            ).data\r\n                     ) |\r\n                  join(&quot; x &quot;)&#39;\r\n```",
                "title": "Try to customize output with jq with string concatenation"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1635986345,
        "creation_date": 1635978866,
        "question_id": 69832505,
        "body_markdown": "I&#39;d like the output of this command to be on a single line :\r\n\r\n    $ lscpu -J | jq -r &#39;.lscpu[] | select(.field==&quot;CPU(s):&quot;).data + &quot; x &quot;, select(.field==&quot;Model name:&quot;).data&#39; \r\n    4 x \r\n    AMD A4-6210 APU with AMD Radeon R3 Graphics\r\n\r\nSo I tried this but it outputs ... nothing : \r\n\r\n    $ lscpu -J | jq -r &#39;.lscpu[] | select(.field==&quot;CPU(s):&quot;).data + &quot; x &quot; + select(.field==&quot;Model name:&quot;).data&#39; \r\n\r\n",
        "link": "https://stackoverflow.com/questions/69832505/try-to-customize-output-with-jq-with-string-concatenation",
        "title": "Try to customize output with jq with string concatenation"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636043744,
                "post_id": 69842607,
                "comment_id": 123458290,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23240363,
                    "reputation": 27,
                    "user_id": 17329770,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/567bc99033cd005b76c5e5b673c8eadd?s=256&d=identicon&r=PG",
                    "display_name": "mifogon",
                    "link": "https://stackoverflow.com/users/17329770/mifogon"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636044353,
                "post_id": 69842607,
                "comment_id": 123458564,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1636053558,
                "last_edit_date": 1636053558,
                "creation_date": 1636045014,
                "answer_id": 69843051,
                "question_id": 69842607,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use a named capture:\r\n\r\n```shell\r\n$ echo &quot;[\\&quot;&#39;mysql&#39;\\&quot;, \\&quot;&#39;whatever&#39;\\&quot;]&quot; \\\r\n| jq &#39;.[] | sub(&quot;&#39;\\&#39;&#39;(?&lt;s&gt;[^&#39;\\&#39;&#39;]+)&#39;\\&#39;&#39;&quot;; .s)&#39;\r\n&quot;mysql&quot;\r\n&quot;whatever&quot;\r\n```\r\n\r\nExplanation:\r\n\r\n- `&#39;\\&#39;&#39;`  a single quote (escaped for the shell)\r\n- `(?&lt;s&gt;` start of a capture group named `s`\r\n- `[^&#39;\\&#39;&#39;]+` one or more characters other than `&#39;` (escaped for the shell)\r\n- `)` end of the capture group\r\n- `&#39;\\&#39;&#39;` a single quote (escaped again for the shell)\r\n\r\n",
                "title": "Replace symbol in string with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1636059455,
        "creation_date": 1636043197,
        "last_edit_date": 1636053426,
        "question_id": 69842607,
        "body_markdown": "I have some problems transforming a string like this `&quot;&#39;mysql&#39;&quot;` to `&quot;mysql&quot;`. For this specific case, I was able to use ```sub```: \r\n\r\n```sub(&quot;&#39;\\&#39;mysql\\&#39;&#39;&quot;;&quot;mysql&quot;)```\r\n\r\nBut I need a more universal jq rule to remove single-quotes, e.g. `&quot;&#39;mystring&#39;&quot;` =&gt; `&quot;mystring&quot;`\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69842607/replace-symbol-in-string-with-jq",
        "title": "Replace symbol in string with jq"
    },
    {
        "tags": [
            "shell",
            "jq",
            "slack"
        ],
        "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": 1636044995,
                "post_id": 69842972,
                "comment_id": 123458852,
                "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": 1636045041,
                "post_id": 69842972,
                "comment_id": 123458866,
                "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": 1636045103,
                "post_id": 69842972,
                "comment_id": 123458886,
                "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": 1636045182,
                "post_id": 69842972,
                "comment_id": 123458913,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2395171,
                    "reputation": 53,
                    "user_id": 2094105,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ooirQ.jpg?s=256",
                    "display_name": "Dustin",
                    "link": "https://stackoverflow.com/users/2094105/dustin"
                },
                "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": 1636045661,
                "post_id": 69842972,
                "comment_id": 123459110,
                "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": 1636045664,
                "post_id": 69842972,
                "comment_id": 123459111,
                "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": 1636046300,
                "post_id": 69842972,
                "comment_id": 123459356,
                "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": 1636047153,
                "post_id": 69842972,
                "comment_id": 123459696,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2395171,
                    "reputation": 53,
                    "user_id": 2094105,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ooirQ.jpg?s=256",
                    "display_name": "Dustin",
                    "link": "https://stackoverflow.com/users/2094105/dustin"
                },
                "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": 1636048989,
                "post_id": 69842972,
                "comment_id": 123460376,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1636052910,
                "last_edit_date": 1636052910,
                "creation_date": 1636046503,
                "answer_id": 69843349,
                "question_id": 69842972,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "More efficient is to feed jq all your channels to delete at once, rather than one-at-a-time.\r\n\r\n```\r\n# you need to comment one of these out for out.json to not be an empty list\r\ninactive_channels=(\r\n  &quot;announcements&quot;\r\n  &quot;general&quot;\r\n)\r\n\r\njq --rawfile inactive_channel_stream &lt;(printf &#39;%s\\0&#39; &quot;${inactive_channels[@]}&quot;) &#39;\r\n  # generate an object mapping keys to delete to a truthy value\r\n  INDEX($inactive_channel_stream | split(&quot;\\u0000&quot;)[]; .) as $inactive_channels\r\n\r\n  | map(select(($inactive_channels[.name] // false) | not))\r\n&#39; &lt;in.json &gt;out.json\r\n```",
                "title": "How can I iterate over a shell array of objects and delete them from a JSON file with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1636052910,
        "creation_date": 1636044689,
        "last_edit_date": 1636045493,
        "question_id": 69842972,
        "body_markdown": "I&#39;m trying to cleanup inactive channels from a list of json objects in a channels.json file from Slack. I got the list of inactive channels (defined as not updated in last 90 days) by checking the timestamp of the last message in the channel directory in my export and writing the list of inactive channels to an array as this data is not available in the json objects themselves. Only problem is I don&#39;t know how to arrange it so that each of the channels in my array are removed from the input before writing to a new output file. See the `missing something important here` comment in my function code below.\r\n\r\nHere&#39;s my current function.\r\n```\r\nexclude-inactive-channels () {\r\n# Check for a valid argument\r\n  if [ -z $1 ]; then\r\n    echo &quot;No arguments supplied.&quot;\r\n    return 1\r\n  elif [ $# -gt 1 ]; then\r\n    echo &quot;Too many arguments supplied.&quot;\r\n    return 1\r\n  elif [ ! -f $1 ]; then\r\n    echo &quot;File doesn&#39;t exist.&quot;\r\n    return 1\r\n  fi\r\n\r\n  cutoff_epoch=$(gdate  -d &quot;90 days ago&quot; +&#39;%s&#39;)\r\n  inactive_channels=()\r\n  for channel in $(jq -r &#39;.[] | select(.is_archived == false) | .name&#39; $1); do \r\n    if [[ -d $channel ]]; then\r\n      last_post=$(ls -1 $channel |sort -n |tail -1 |awk -F&#39;.&#39; &#39;{print $1}&#39;)\r\n      last_post_epoch=$(gdate -d &quot;$last_post&quot; +&#39;%s&#39;)\r\n      if [[ $last_post_epoch -lt $cutoff_epoch ]]; then\r\n          inactive_channels+=(&quot;$channel&quot;)\r\n          echo -n &quot;Removing $channel directory. Last post is $last_post.&quot;\r\n          #rm -rf $channel\r\n          echo -e &quot;\\033[0;32m[OK]\\033[0m&quot;\r\n      fi\r\n    fi\r\n  done\r\n\r\n  echo &quot;Removing inactive channels from $1 and writing output to new-$1.&quot;\r\n  for inactive_channel in ${inactive_channels[@]}; do\r\n    # Next line is untested pseudo code\r\n    jq -r &#39;.[] | del(.name == $inactive_channel)&#39; $1 #missing something important here\r\n  done | jq -s &gt; new-${1}\r\n\r\n  echo &quot;Replacing $1 with new-$1.&quot;\r\n  # mv new-${1} $1\r\n}\r\n```\r\n\r\nCalling this function:\r\n\r\n```\r\nexclude-inactive-channels channels.json\r\n```\r\n\r\nExample Input:\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;&quot;,\r\n    &quot;name&quot;: &quot;announcements&quot;,\r\n    &quot;created&quot;: 1500000000,\r\n    &quot;creator&quot;: &quot;&quot;,\r\n    &quot;is_archived&quot;: false,\r\n    &quot;is_general&quot;: true,\r\n    &quot;members&quot;: [\r\n      &quot;&quot;,\r\n  ],\r\n    &quot;pins&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;&quot;,\r\n        &quot;type&quot;: &quot;C&quot;,\r\n        &quot;created&quot;: 1500000000,\r\n        &quot;user&quot;: &quot;&quot;,\r\n        &quot;owner&quot;: &quot;&quot;\r\n      },\r\n      ],\r\n    &quot;topic&quot;: {\r\n      &quot;value&quot;: &quot;&quot;,\r\n      &quot;creator&quot;: &quot;&quot;,\r\n      &quot;last_set&quot;: 0\r\n    },\r\n    &quot;purpose&quot;: {\r\n      &quot;value&quot;: &quot;company wide announcements&quot;,\r\n      &quot;creator&quot;: &quot;&quot;,\r\n      &quot;last_set&quot;: 1500000000\r\n    }\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;&quot;,\r\n    &quot;name&quot;: &quot;general&quot;,\r\n    &quot;created&quot;: 1500000000,\r\n    &quot;creator&quot;: &quot;&quot;,\r\n    &quot;is_archived&quot;: false,\r\n    &quot;is_general&quot;: true,\r\n    &quot;members&quot;: [\r\n      &quot;&quot;,\r\n  ],\r\n    &quot;pins&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;&quot;,\r\n        &quot;type&quot;: &quot;C&quot;,\r\n        &quot;created&quot;: 1500000000,\r\n        &quot;user&quot;: &quot;&quot;,\r\n        &quot;owner&quot;: &quot;&quot;\r\n      },\r\n      ],\r\n    &quot;topic&quot;: {\r\n      &quot;value&quot;: &quot;&quot;,\r\n      &quot;creator&quot;: &quot;&quot;,\r\n      &quot;last_set&quot;: 0\r\n    },\r\n    &quot;purpose&quot;: {\r\n      &quot;value&quot;: &quot;general&quot;,\r\n      &quot;creator&quot;: &quot;&quot;,\r\n      &quot;last_set&quot;: 1500000000\r\n    }\r\n  },\r\n]",
        "link": "https://stackoverflow.com/questions/69842972/how-can-i-iterate-over-a-shell-array-of-objects-and-delete-them-from-a-json-file",
        "title": "How can I iterate over a shell array of objects and delete them from a JSON file with jq?"
    },
    {
        "tags": [
            "jq",
            "hadoop-yarn"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1636062621,
                "creation_date": 1636062621,
                "answer_id": 69846241,
                "question_id": 69846016,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would use the following :\r\n\r\n    jq -r &#39;map(.event | (.AMStarted.startTime // .JobQueueChange.jobQueueName // .JobInited[])) | @csv&#39;\r\n\r\n\r\n`map` applies a mapping to every element of your input array ; we access their event, then try to access either `.AMStarted.startTime`, `.JobQueueChange.jobQueueName` or `.JobInited` which we split into its components. The `@csv` filter outputs the resulting array in your expected format.\r\n\r\nNote that this disregards the filter you wanted on the object&#39;s `.type`, I assume this is ok given that the object held by `.event` is just as specific.\r\n\r\nYou can [try it here](https://jqplay.org/s/OPgp2HWpMe).",
                "title": "jq filter and select multiple conditions and columns"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1636135377,
                "last_edit_date": 1636135377,
                "creation_date": 1636062917,
                "answer_id": 69846289,
                "question_id": 69846016,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is the answer to the original question:\r\n&gt; From type AM_STARTED &#39;json/index/row&#39;, I want event.AMStarted.startTime&lt;br&gt;\r\nFrom type JOB_QUEUE_CHANGED, I want event.JobQueueChange.jobQueueName&lt;br&gt;\r\nFrom type JOB_INITED, I want event.JobInited.{launchTime, totalMaps, totalReduces}\r\n\r\n```sh\r\njq --raw-output &#39;\r\n  map(\r\n    select(.type == &quot;AM_STARTED&quot;).event.AMStarted.startTime,\r\n    select(.type == &quot;JOB_QUEUE_CHANGED&quot;).event.JobQueueChange.jobQueueName,\r\n    select(.type == &quot;JOB_INITED&quot;).event.JobInited[&quot;launchTime&quot;, &quot;totalMaps&quot;, &quot;totalReduces&quot;]\r\n  )\r\n| @csv&#39;\r\n```\r\n\r\nTry it [here](https://jqplay.org/s/IdWJmYk4fZ).\r\n\r\n---\r\n\r\nThis is the answer to the updated question:\r\n&gt; From type AM_STARTED &#39;json/index/row&#39;, I want event.AMStarted.startTime&lt;br&gt;\r\nIgnore TASK_STARTED - I do not want anything that has &#39;TASK&#39; in type&lt;br&gt;\r\nFrom JOB_INITED, I want all fields&lt;br&gt;\r\nFrom JOB_FINISHED, I want finishTime, and values of FILE_BYTES_READ &amp; FILE_BYTES_WRITTEN\r\n\r\n```sh\r\njq --raw-output &#39;\r\n  map(\r\n    select(.type == &quot;AM_STARTED&quot;).event.AMStarted.startTime,\r\n    select(.type == &quot;JOB_INITED&quot;).event.JobInited[],\r\n    (\r\n      select(.type == &quot;JOB_FINISHED&quot;).event.JobFinished\r\n      | .finishTime,\r\n      (\r\n        .totalCounters.groups[].counts[] | (\r\n          select(.name == &quot;FILE_BYTES_READ&quot;).value,\r\n          select(.name == &quot;FILE_BYTES_WRITTEN&quot;).value\r\n        )\r\n      )\r\n    )\r\n  )\r\n  | @csv\r\n&#39; \r\n```\r\n\r\nTry it [here](https://jqplay.org/s/4U5H-Ml47i).\r\n",
                "title": "jq filter and select multiple conditions and columns"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1636135377,
        "creation_date": 1636061159,
        "last_edit_date": 1636132713,
        "question_id": 69846016,
        "body_markdown": "I want to parse Hadoop Yarn job history files into csv/sql format to query them easily.\r\n\r\nI extracted the AVRO schema from .jhist files, converted avro data files to stream-of-jsons using avro-tools-*.jar, combined the stream into a single json using jq, and now I need to extract certain fields from certain individual jsons\r\n\r\n    [\r\n      {\r\n        &quot;type&quot;: &quot;AM_STARTED&quot;,\r\n        &quot;event&quot;: {\r\n          &quot;AMStarted&quot;: {\r\n            &quot;startTime&quot;: 1636039435822,\r\n            &quot;nodeManagerPort&quot;: 8041\r\n          }\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;TASK_STARTED&quot;,\r\n        &quot;event&quot;: {\r\n          &quot;TaskStarted&quot;: {\r\n            &quot;taskid&quot;: &quot;task_1351&quot;,\r\n            &quot;jobStatus&quot;: &quot;Started&quot;\r\n          }\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;JOB_INITED&quot;,\r\n        &quot;event&quot;: {\r\n          &quot;JobInited&quot;: {\r\n            &quot;launchTime&quot;: 1636039438569,\r\n            &quot;totalMaps&quot;: 356,\r\n            &quot;totalReduces&quot;: 100\r\n          }\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;JOB_FINISHED&quot;,\r\n        &quot;event&quot;: {\r\n          &quot;JobFinished&quot;: {\r\n            &quot;jobid&quot;: &quot;job_1636039105678_0061&quot;,\r\n            &quot;finishTime&quot;: 1636043211181,\r\n            &quot;totalCounters&quot;: {\r\n              &quot;name&quot;: &quot;TOTAL_COUNTERS&quot;,\r\n              &quot;groups&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;org.apache.hadoop.mapreduce.FileSystemCounter&quot;,\r\n                  &quot;displayName&quot;: &quot;File System Counters&quot;,\r\n                  &quot;counts&quot;: [\r\n                    {\r\n                      &quot;name&quot;: &quot;FILE_BYTES_READ&quot;,\r\n                      &quot;displayName&quot;: &quot;FILE: Number of bytes read&quot;,\r\n                      &quot;value&quot;: 1156766568459\r\n                    },\r\n                    {\r\n                      &quot;name&quot;: &quot;FILE_BYTES_WRITTEN&quot;,\r\n                      &quot;displayName&quot;: &quot;FILE: Number of bytes written&quot;,\r\n                      &quot;value&quot;: 1720873364662\r\n                    },\r\n                    {\r\n                      &quot;name&quot;: &quot;RANDOM_BYTES&quot;,\r\n                      &quot;displayName&quot;: &quot;RANDOM: Bytes&quot;,\r\n                      &quot;value&quot;: 1720873311162\r\n                    }\r\n                    ]\r\n                }\r\n                ]\r\n            }\r\n          }\r\n        }\r\n      }\r\n    ]\r\n\r\nFrom type AM_STARTED &#39;json/index/row&#39;, I want *event.AMStarted.startTime*  \r\nIgnore TASK_STARTED - I do not want anything that has &#39;TASK&#39; in type  \r\nFrom JOB_INITED, I want all fields  \r\nFrom JOB_FINISHED, I want finishTime, and values of FILE_BYTES_READ &amp; FILE_BYTES_WRITTEN\r\n\r\nI want all these to be comma-separated (and maybe &quot;quoted&quot;), so I can load them into a csv and then into a sql table.\r\n\r\nExpected Output :  \r\n\r\n&gt; 1636039435822, 1636039438569, 356, 100, 1636043211181, 1156766568459, 1720873364662\r\n\r\nWhat&#39;s the syntax for [this](https://jqplay.org/s/T6HtocRjGW)?",
        "link": "https://stackoverflow.com/questions/69846016/jq-filter-and-select-multiple-conditions-and-columns",
        "title": "jq filter and select multiple conditions and columns"
    },
    {
        "tags": [
            "arrays",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1636116628,
                "last_edit_date": 1636116628,
                "creation_date": 1636075011,
                "answer_id": 69847653,
                "question_id": 69847625,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Split your bash array into `NUL`-delimited items using `printf &#39;%s\\0&#39;`, then read the raw stream using `-R` or `--raw-input` and within your `jq` filter split them into an array using `split` and the delimiter `&quot;\\u0000&quot;`:\r\n\r\n```sh\r\nprintf &#39;%s\\0&#39; &quot;${IDS[@]}&quot; | jq -Rs &#39;\r\n  split(&quot;\\u0000&quot;) | map({id:., names: [&quot;bob&quot;, &quot;sally&quot;]})\r\n&#39;\r\n```",
                "title": "Creating Array of Objects from Bash Array using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1636075201,
                "creation_date": 1636075201,
                "answer_id": 69847668,
                "question_id": 69847625,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nfor id in &quot;${IDS[@]}&quot; ; do\r\n  echo &quot;$id&quot;\r\ndone | jq -nR &#39;[ {id: inputs, names: [&quot;bob&quot;, &quot;sally&quot;]} ]&#39;\r\n```\r\n\r\nor as a one-liner:\r\n```\r\nprintf &quot;%s\\n&quot; &quot;${IDS[@]}&quot; | jq -nR &#39;[{id: inputs, names: [&quot;bob&quot;, &quot;sally&quot;]}]&#39;\r\n```",
                "title": "Creating Array of Objects from Bash Array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1636116628,
        "creation_date": 1636074729,
        "question_id": 69847625,
        "body_markdown": "I am trying to create an array of objects in bash given an array in bash using jq.\r\n\r\nHere is where I am stuck:\r\n\r\n    IDS=(&quot;baf3eca8-c4bd-4590-bf1f-9b1515d521ba&quot; &quot;ef2fa922-2038-445c-9d32-8c1f23511fe4&quot;)\r\n    echo &quot;${IDS[@]}&quot; | jq -R &#39;[{id: ., names: [&quot;bob&quot;, &quot;sally&quot;]}]&#39;\r\n\r\nResults in:    \r\n\r\n    [\r\n       {\r\n         &quot;id&quot;: &quot;baf3eca8-c4bd-4590-bf1f-9b1515d521ba ef2fa922-2038-445c-9d32-8c1f23511fe4&quot;,\r\n         &quot;names&quot;: [\r\n           &quot;bob&quot;,\r\n           &quot;sally&quot;\r\n         ]\r\n       }\r\n    ]\r\n\r\nMy desired result:\r\n\r\n    [\r\n       {\r\n         &quot;id&quot;: &quot;baf3eca8-c4bd-4590-bf1f-9b1515d521ba&quot;,\r\n         &quot;names&quot;: [\r\n           &quot;bob&quot;,\r\n           &quot;sally&quot;\r\n         ]\r\n       },\r\n       {\r\n         &quot;id&quot;: &quot;ef2fa922-2038-445c-9d32-8c1f23511fe4&quot;,\r\n         &quot;names&quot;: [\r\n           &quot;bob&quot;,\r\n           &quot;sally&quot;\r\n         ]\r\n       }\r\n    ]\r\n\r\n\r\nAny help would be much appreciated. \r\n ",
        "link": "https://stackoverflow.com/questions/69847625/creating-array-of-objects-from-bash-array-using-jq",
        "title": "Creating Array of Objects from Bash Array using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1636114928,
                "creation_date": 1636114928,
                "answer_id": 69853173,
                "question_id": 69852741,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to escape `(` :\r\n\r\n```\r\njq -r &#39; .THINGS | keys[] as $k | &quot;\\($k)@\\(.[$k].revision)&quot; &#39; things.json\r\n```",
                "title": "Using jq to fetch key-value pairs from a json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1636482164,
        "creation_date": 1636112629,
        "last_edit_date": 1636482164,
        "question_id": 69852741,
        "body_markdown": "I am trying to get *key@value* pairs of JSON file below using ***jq***\r\n```json\r\n{\r\n  &quot;STUFF_RELATED1&quot;: &quot;STUFF_RELATED1&quot;,\r\n  &quot;STUFF_RELATED2&quot;: &quot;STUFF_RELATED2&quot;,\r\n  &quot;THINGS&quot;: {\r\n    &quot;THING_2&quot;: {\r\n      &quot;details&quot;: {\r\n        &quot;stuff_branch&quot;: &quot;user/dev&quot;\r\n      },\r\n      &quot;repository&quot;: &quot;path/to/repo&quot;,\r\n      &quot;branch&quot;: &quot;master&quot;,\r\n      &quot;revision&quot;: &quot;dsfkes4s34jlis4jsj4lis4sli3&quot;\r\n    },\r\n    &quot;THING_1&quot;: {\r\n      &quot;details&quot;: {\r\n        &quot;stuff_branch&quot;: &quot;master&quot;\r\n      },\r\n      &quot;repository&quot;: &quot;path/to/repo&quot;,\r\n      &quot;branch&quot;: &quot;master&quot;,\r\n      &quot;revision&quot;: &quot;dsfkes4s34jlis4jsj4lis4sli3&quot;\r\n    }\r\n  },\r\n  &quot;STUFF&quot;: {\r\n    &quot;revision&quot;: &quot;4u324i324iy32g&quot;,\r\n    &quot;branch&quot;: &quot;master&quot;\r\n  }\r\n}\r\n```\r\nThe *key@value* pair should look like this: \r\n\r\n`THING_1@dsfkes4s34jlis4jsj4lis4sli3` \r\n\r\nCurrently I have tried this on my own: \r\n\r\n    jq -r &#39; .THINGS | keys[] as $k | &quot;($k)@(.[$k].revision)&quot; &#39; things.json\r\n\r\nBut it does not give the resul that I really want.:( Thanks in advance!",
        "link": "https://stackoverflow.com/questions/69852741/using-jq-to-fetch-key-value-pairs-from-a-json-file",
        "title": "Using jq to fetch key-value pairs from a json file"
    },
    {
        "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": 1636139869,
                "post_id": 69858213,
                "comment_id": 123486168,
                "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": 1636139908,
                "post_id": 69858213,
                "comment_id": 123486187,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636140040,
                "post_id": 69858213,
                "comment_id": 123486237,
                "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": 1636140239,
                "post_id": 69858213,
                "comment_id": 123486299,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16380158,
                    "reputation": 394,
                    "user_id": 11831397,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/2588592331151376/picture?type=large",
                    "display_name": "S&#233;bastien Serre",
                    "link": "https://stackoverflow.com/users/11831397/s%c3%a9bastien-serre"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636141447,
                "post_id": 69858213,
                "comment_id": 123486679,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1636316655,
                "post_id": 69858213,
                "comment_id": 123518442,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1636139790,
        "creation_date": 1636139790,
        "question_id": 69858213,
        "body_markdown": "I would like to modify a json file using JQ in a Bash script. Here is what I tried to proceed:\r\n\r\n```bash\r\nvar=&quot;test-54342&quot;\r\necho &quot;$( jq &#39;.context[&quot;customer-name&quot;] = &quot;$var&quot;&#39; cdk.json )&quot; &gt; cdk.json\r\n```\r\n\r\nI also tried this but it&#39;s not working as well:\r\n\r\n```bash\r\nvar=&quot;test-54342&quot;\r\necho `$( jq &#39;.context[&quot;customer-name&quot;] = &quot;$var&quot;&#39; cdk.json )` &gt; cdk.json\r\n```\r\n\r\nHere is what my json file looks like:\r\n```json\r\n{\r\n  &quot;app&quot;: &quot;mySuperApp&quot;,\r\n  &quot;context&quot;: {\r\n    &quot;customer-name&quot;: &quot;text-I-want-to-modify&quot;\r\n  }\r\n}\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/69858213/how-to-modify-a-json-file-by-a-variable-using-jq-in-a-bash-script",
        "title": "How to modify a json file by a variable using JQ in a Bash script?"
    },
    {
        "tags": [
            "json",
            "merge",
            "command-line-interface",
            "jq",
            "jtc"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1636188155,
                "creation_date": 1636188155,
                "answer_id": 69862564,
                "question_id": 69862320,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In case any of the files has more than one key:\r\n```\r\njq -n &#39;reduce inputs as $in ({}; \r\n        reduce ($in|keys_unsorted)[] as $k (.;\r\n         .[$k] += $in[$k]))&#39;  file1 file2 file3 # ...\r\n```\r\n\r\nYou might want to tweak this so it doesn&#39;t fail if the value associated with a key is unexpectedly not an array.\r\n\r\nAnd if you use gojq (the Go implementation of jq), you would use `keys` rather than `keys_unsorted`.",
                "title": "Merge JSON arrays based on arbitrary keys to arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1636225204,
        "creation_date": 1636185296,
        "last_edit_date": 1636225204,
        "question_id": 69862320,
        "body_markdown": "Using `jq` or `jtc`, I&#39;d like to take a list of json files as inputs and generate a single json file based on the keys to the arrays found in each input file. Example:\r\n\r\n1st file:\r\n\r\n```json\r\n{\r\n  &quot;key1&quot;: [\r\n    &quot;key1-out1&quot;\r\n  ]\r\n}\r\n```\r\n\r\n2nd file:\r\n\r\n```json\r\n{\r\n  &quot;key1&quot;: [\r\n    &quot;key1-out2&quot;\r\n  ]\r\n}\r\n```\r\n\r\n3rd file:\r\n\r\n```json\r\n{\r\n  &quot;key2&quot;: [\r\n    &quot;key2-out1&quot;\r\n  ]\r\n}\r\n```\r\n\r\nExpected output:\r\n\r\n```json\r\n{\r\n  &quot;key1&quot;: [\r\n    &quot;key1-out1&quot;\r\n    &quot;key1-out2&quot;\r\n  ],\r\n  &quot;key2&quot;: [\r\n    &quot;key2-out1&quot;\r\n  ]\r\n}\r\n```\r\n\r\nI encountered [this almost perfectly good answer](https://unix.stackexchange.com/a/433687/135796) but I can&#39;t use it directly because I don&#39;t know what keys I will get in each input file.",
        "link": "https://stackoverflow.com/questions/69862320/merge-json-arrays-based-on-arbitrary-keys-to-arrays",
        "title": "Merge JSON arrays based on arbitrary keys to arrays"
    },
    {
        "tags": [
            "syntax",
            "duplicates",
            "jq",
            "export-to-csv"
        ],
        "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": 1636403352,
                "post_id": 69889510,
                "comment_id": 123542892,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19502150,
                    "reputation": 67,
                    "user_id": 14267941,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a6e6ef8399e15a23e36ab996786b5440?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "gamer_rulez",
                    "link": "https://stackoverflow.com/users/14267941/gamer-rulez"
                },
                "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": 1636403757,
                "post_id": 69889510,
                "comment_id": 123543031,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1636404471,
                "last_edit_date": 1636404471,
                "creation_date": 1636403855,
                "answer_id": 69889682,
                "question_id": 69889510,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Are you looking for this?\r\n\r\n```sh\r\n jq -r &#39;.colors | unique_by(.color)[] | [.color, .category, .type] | @csv&#39;\r\n```\r\n```\r\n&quot;black&quot;,&quot;hue&quot;,&quot;primary&quot;\r\n&quot;red&quot;,&quot;hue&quot;,&quot;primary&quot;\r\n&quot;white&quot;,&quot;value&quot;,\r\n&quot;yellow&quot;,&quot;hue&quot;,&quot;primary&quot;\r\n```\r\n[Demo](https://jqplay.org/s/RltBZOUFAj)\r\n\r\n---\r\n\r\nTo add a default value (and make every line have the same amount of values), add `// &quot;&lt;default_value&gt;&quot;` when creating the final array. For instance, with `&quot;&quot;` as default, it&#39;d be:\r\n\r\n```sh\r\n jq -r &#39;.colors | unique_by(.color)[] | [.color//&quot;&quot;, .category//&quot;&quot;, .type//&quot;&quot;] | @csv&#39;\r\n```\r\n```\r\n&quot;black&quot;,&quot;hue&quot;,&quot;primary&quot;\r\n&quot;red&quot;,&quot;hue&quot;,&quot;primary&quot;\r\n&quot;white&quot;,&quot;value&quot;,&quot;&quot;\r\n&quot;yellow&quot;,&quot;hue&quot;,&quot;primary&quot;\r\n```\r\n[Demo](https://jqplay.org/s/8ubHc5cIoe)",
                "title": "Remove duplicates in JSON to CSV values using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1636441363,
        "creation_date": 1636402932,
        "last_edit_date": 1636441363,
        "question_id": 69889510,
        "body_markdown": "Here I&#39;m trying to convert json to csv. Also, I&#39;m trying to ignore duplicate values of &#39;color&#39; attribute in same command. I have tried with below jq cmd and getting *bash: syntax error near unexpected token `(&#39;* error. Please help me to resolve this error.\r\n\r\n     jq -r &#39;[&quot;color&quot;,&quot;category&quot;,&quot;type&quot;], ([].colors | &#39;unique_by(.color)&#39; | [.color, .category, .type]) | @csv&#39; test.json &gt; test.csv\r\n\r\nMy JSON file:    \r\n\r\n    {\r\n      &quot;colors&quot;: [\r\n        {\r\n          &quot;color&quot;: &quot;black&quot;,\r\n          &quot;category&quot;: &quot;hue&quot;,\r\n          &quot;type&quot;: &quot;primary&quot;,\r\n          &quot;code&quot;: {\r\n            &quot;rgba&quot;: [255,255,255,1],\r\n            &quot;hex&quot;: &quot;#000&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;color&quot;: &quot;white&quot;,\r\n          &quot;category&quot;: &quot;value&quot;,\r\n          &quot;code&quot;: {\r\n            &quot;rgba&quot;: [0,0,0,1],\r\n            &quot;hex&quot;: &quot;#FFF&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;color&quot;: &quot;red&quot;,\r\n          &quot;category&quot;: &quot;hue&quot;,\r\n          &quot;type&quot;: &quot;primary&quot;,\r\n          &quot;code&quot;: {\r\n            &quot;rgba&quot;: [255,0,0,1],\r\n            &quot;hex&quot;: &quot;#FF0&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;color&quot;: &quot;black&quot;,\r\n          &quot;category&quot;: &quot;hue&quot;,\r\n          &quot;type&quot;: &quot;primary&quot;,\r\n          &quot;code&quot;: {\r\n            &quot;rgba&quot;: [0,0,255,1],\r\n            &quot;hex&quot;: &quot;#00F&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;color&quot;: &quot;yellow&quot;,\r\n          &quot;category&quot;: &quot;hue&quot;,\r\n          &quot;type&quot;: &quot;primary&quot;,\r\n          &quot;code&quot;: {\r\n            &quot;rgba&quot;: [255,255,0,1],\r\n            &quot;hex&quot;: &quot;#FF0&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;color&quot;: &quot;white&quot;,\r\n          &quot;category&quot;: &quot;hue&quot;,\r\n          &quot;type&quot;: &quot;secondary&quot;,\r\n          &quot;code&quot;: {\r\n            &quot;rgba&quot;: [0,255,0,1],\r\n            &quot;hex&quot;: &quot;#0F0&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69889510/remove-duplicates-in-json-to-csv-values-using-jq",
        "title": "Remove duplicates in JSON to CSV values using jq"
    },
    {
        "tags": [
            "syntax",
            "duplicates",
            "jq",
            "export-to-csv"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636462427,
                "post_id": 69898423,
                "comment_id": 123558606,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1636463815,
                "post_id": 69898423,
                "comment_id": 123559147,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19502150,
                    "reputation": 67,
                    "user_id": 14267941,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a6e6ef8399e15a23e36ab996786b5440?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "gamer_rulez",
                    "link": "https://stackoverflow.com/users/14267941/gamer-rulez"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636475495,
                "post_id": 69898423,
                "comment_id": 123564689,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662586265,
                "creation_date": 1662586265,
                "answer_id": 73641650,
                "question_id": 69898423,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use slurp and flatten:\r\n\r\n```\r\njq -rs &#39;[&quot;Name&quot;,&quot;Address&quot;,&quot;Status&quot;],\r\n(flatten(1) | unique_by(.address)[] | [.name, .address, .status])\r\n| @csv&#39; sample.json &gt; sample.csv\r\n```\r\n\r\nwhich will output:\r\n\r\n```\r\n&quot;Name&quot;,&quot;Address&quot;,&quot;Status&quot;\r\n&quot;Adam&quot;,&quot;Bangalore&quot;,&quot;inactive&quot;\r\n&quot;Kishore&quot;,&quot;Hyderabad&quot;,&quot;active&quot;\r\n&quot;Manu&quot;,&quot;Kerala&quot;,&quot;active&quot;\r\n&quot;Ram&quot;,&quot;Kolkata&quot;,&quot;active&quot;\r\n```\r\n\r\nAnother solution was suggested by [pmf](https://stackoverflow.com/users/2158479/pmf) in the comments: replace `.` with [`inputs`](https://stedolan.github.io/jq/manual/v1.6/#inputs):\r\n\r\n```\r\njq -r &#39;[&quot;Name&quot;,&quot;Address&quot;,&quot;Status&quot;], (inputs | unique_by(.address)[] | [.name, .address, .status]) | @csv&#39; sample.json &gt; sample.csv\r\n```",
                "title": "Remove duplicates using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1662586265,
        "creation_date": 1636462074,
        "last_edit_date": 1636469590,
        "question_id": 69898423,
        "body_markdown": "Here I&#39;m trying to convert my json to csv with these conditions:- 1) ignore duplicate values of &#39;address&#39; attribute using jq cmd. 2) Also, I have to ignore the duplicate json []. I have tried with below jq cmd, address attribute is getting ignored, *but duplicate json[] is not*. Please help on this.\r\n\r\nMy jq cmd: \r\n\r\n    jq -r &#39;[&quot;Name&quot;,&quot;Address&quot;,&quot;Status&quot;], (.| unique_by(.address)[] | [.name, .address, .status]) | @csv&#39; sample.json &gt; sample.csv\r\n\r\nMy JSON:\r\n   \r\n     [\r\n          {\r\n        \t&quot;id&quot;: 1,\r\n        \t&quot;name&quot;: &quot;Ram&quot;,\r\n        \t&quot;address&quot;: &quot;Kolkata&quot;,\r\n        \t&quot;status&quot;: &quot;active&quot;\r\n           },\r\n           {\r\n        \t&quot;id&quot;: 3,\r\n        \t&quot;name&quot;: &quot;Rahul&quot;,\r\n        \t&quot;address&quot;: &quot;Kolkata&quot;,\r\n        \t&quot;status&quot;: &quot;inactive&quot;\r\n           },\r\n           {\r\n        \t&quot;id&quot;: 2,\r\n        \t&quot;name&quot;: &quot;Kishore&quot;,\r\n        \t&quot;address&quot;: &quot;Hyderabad&quot;,\r\n        \t&quot;status&quot;: &quot;active&quot;\r\n           },\r\n           {\r\n        \t&quot;id&quot;: 4,\r\n        \t&quot;name&quot;: &quot;Manu&quot;,\r\n        \t&quot;address&quot;: &quot;Kerala&quot;,\r\n        \t&quot;status&quot;: &quot;active&quot;\r\n           },\r\n           {\r\n        \t&quot;id&quot;: 5,\r\n        \t&quot;name&quot;: &quot;Adam&quot;,\r\n        \t&quot;address&quot;: &quot;Bangalore&quot;,\r\n        \t&quot;status&quot;: &quot;inactive&quot;\r\n           }\r\n        ]\r\n        [\r\n          {\r\n        \t&quot;id&quot;: 1,\r\n        \t&quot;name&quot;: &quot;Ram&quot;,\r\n        \t&quot;address&quot;: &quot;Kolkata&quot;,\r\n        \t&quot;status&quot;: &quot;active&quot;\r\n           },\r\n           {\r\n        \t&quot;id&quot;: 3,\r\n        \t&quot;name&quot;: &quot;Rahul&quot;,\r\n        \t&quot;address&quot;: &quot;Kolkata&quot;,\r\n        \t&quot;status&quot;: &quot;inactive&quot;\r\n           },\r\n           {\r\n        \t&quot;id&quot;: 2,\r\n        \t&quot;name&quot;: &quot;Kishore&quot;,\r\n        \t&quot;address&quot;: &quot;Hyderabad&quot;,\r\n        \t&quot;status&quot;: &quot;active&quot;\r\n           },\r\n           {\r\n        \t&quot;id&quot;: 4,\r\n        \t&quot;name&quot;: &quot;Manu&quot;,\r\n        \t&quot;address&quot;: &quot;Kerala&quot;,\r\n        \t&quot;status&quot;: &quot;active&quot;\r\n           },\r\n           {\r\n        \t&quot;id&quot;: 5,\r\n        \t&quot;name&quot;: &quot;Adam&quot;,\r\n        \t&quot;address&quot;: &quot;Bangalore&quot;,\r\n        \t&quot;status&quot;: &quot;inactive&quot;\r\n           }\r\n        ]\r\n\r\nO/P:\r\n\r\n    &quot;Name&quot;,&quot;Address&quot;,&quot;Status&quot;\r\n    &quot;Adam&quot;,&quot;Bangalore&quot;,&quot;inactive&quot;\r\n    &quot;Kishore&quot;,&quot;Hyderabad&quot;,&quot;active&quot;\r\n    &quot;Manu&quot;,&quot;Kerala&quot;,&quot;active&quot;\r\n    &quot;Ram&quot;,&quot;Kolkata&quot;,&quot;active&quot;\r\n    &quot;Name&quot;,&quot;Address&quot;,&quot;Status&quot;\r\n    &quot;Adam&quot;,&quot;Bangalore&quot;,&quot;inactive&quot;\r\n    &quot;Kishore&quot;,&quot;Hyderabad&quot;,&quot;active&quot;\r\n    &quot;Manu&quot;,&quot;Kerala&quot;,&quot;active&quot;\r\n    &quot;Ram&quot;,&quot;Kolkata&quot;,&quot;active&quot;\r\n\r\nExpected O/P:\r\n \r\n\r\n    &quot;Name&quot;,&quot;Address&quot;,&quot;Status&quot;\r\n    &quot;Adam&quot;,&quot;Bangalore&quot;,&quot;inactive&quot;\r\n    &quot;Kishore&quot;,&quot;Hyderabad&quot;,&quot;active&quot;\r\n    &quot;Manu&quot;,&quot;Kerala&quot;,&quot;active&quot;\r\n    &quot;Ram&quot;,&quot;Kolkata&quot;,&quot;active&quot;",
        "link": "https://stackoverflow.com/questions/69898423/remove-duplicates-using-jq",
        "title": "Remove duplicates using jq"
    },
    {
        "tags": [
            "git",
            "shell",
            "makefile",
            "jq",
            "package.json"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6391567,
                    "reputation": 2626,
                    "user_id": 4957508,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-wBY-4a1-0jo/AAAAAAAAAAI/AAAAAAAAAfc/4BCoMMK1rqg/s256-rj/photo.jpg",
                    "display_name": "Jeff Schaller",
                    "link": "https://stackoverflow.com/users/4957508/jeff-schaller"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636472189,
                "post_id": 69900533,
                "comment_id": 123563166,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11902904,
                    "reputation": 6439,
                    "user_id": 8710344,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/b1f198f79adde1ffb8df546153d903a7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "HardcoreHenry",
                    "link": "https://stackoverflow.com/users/8710344/hardcorehenry"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1636472200,
                "post_id": 69900533,
                "comment_id": 123563173,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6391567,
                    "reputation": 2626,
                    "user_id": 4957508,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-wBY-4a1-0jo/AAAAAAAAAAI/AAAAAAAAAfc/4BCoMMK1rqg/s256-rj/photo.jpg",
                    "display_name": "Jeff Schaller",
                    "link": "https://stackoverflow.com/users/4957508/jeff-schaller"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636472404,
                "post_id": 69900533,
                "comment_id": 123563266,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11902904,
                    "reputation": 6439,
                    "user_id": 8710344,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/b1f198f79adde1ffb8df546153d903a7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "HardcoreHenry",
                    "link": "https://stackoverflow.com/users/8710344/hardcorehenry"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1636472911,
                "post_id": 69900533,
                "comment_id": 123563516,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1432080,
                    "reputation": 1038,
                    "user_id": 1354282,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/vyer0.jpg?s=256",
                    "display_name": "danielcooperxyz",
                    "link": "https://stackoverflow.com/users/1354282/danielcooperxyz"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1636473839,
                "post_id": 69900533,
                "comment_id": 123563969,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1432080,
                    "reputation": 1038,
                    "user_id": 1354282,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/vyer0.jpg?s=256",
                    "display_name": "danielcooperxyz",
                    "link": "https://stackoverflow.com/users/1354282/danielcooperxyz"
                },
                "reply_to_user": {
                    "account_id": 11902904,
                    "reputation": 6439,
                    "user_id": 8710344,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/b1f198f79adde1ffb8df546153d903a7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "HardcoreHenry",
                    "link": "https://stackoverflow.com/users/8710344/hardcorehenry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636536051,
                "post_id": 69900533,
                "comment_id": 123580446,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11902904,
                    "reputation": 6439,
                    "user_id": 8710344,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/b1f198f79adde1ffb8df546153d903a7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "HardcoreHenry",
                    "link": "https://stackoverflow.com/users/8710344/hardcorehenry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636555446,
                "post_id": 69900533,
                "comment_id": 123588700,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1432080,
                    "reputation": 1038,
                    "user_id": 1354282,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/vyer0.jpg?s=256",
                    "display_name": "danielcooperxyz",
                    "link": "https://stackoverflow.com/users/1354282/danielcooperxyz"
                },
                "reply_to_user": {
                    "account_id": 11902904,
                    "reputation": 6439,
                    "user_id": 8710344,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/b1f198f79adde1ffb8df546153d903a7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "HardcoreHenry",
                    "link": "https://stackoverflow.com/users/8710344/hardcorehenry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636661889,
                "post_id": 69900533,
                "comment_id": 123623578,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1636489366,
                "creation_date": 1636489366,
                "answer_id": 69904609,
                "question_id": 69900533,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try this to remove \\r:\r\n\r\n```\r\nPKG_VERSION=$(shell echo v$$(jq .version package.json | tr -d $$\\&#39;\\\\r\\&#39;))\r\n```\r\n\r\nYou may need to apply the pipe to LATEST_TAG as well.",
                "title": "Makefile: compare two version string values from git tag and package.json"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1636577306,
                "last_edit_date": 1636577306,
                "creation_date": 1636555577,
                "answer_id": 69915308,
                "question_id": 69900533,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do the comparison in the shell command instead of inside of an `ifeq` as so:\r\n\r\n```\r\nPKG_VERSION=$(shell echo v$$(jq .version package.json))\r\nLATEST_TAG=$(shell git describe --tags --abbrev=0 $$(git rev-list --tags --max-count=1))\r\nenforce-versions:\r\n    @echo &quot;Comparing \\&quot;$(PKG_VERSION)\\&quot; &amp; \\&quot;$(LATEST_TAG)\\&quot;&quot;\r\n    @[ &quot;$(PKG_VERSION)&quot; = &quot;$(LATEST_TAG)&quot; ]\r\n```\r\n\r\nNotice you don&#39;t need the explicit `exit 0` or `exit 1` in this case.   If the tags are not equal, the command will return false, which will cause make to fail the recipe line, and return 1",
                "title": "Makefile: compare two version string values from git tag and package.json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1636577306,
        "creation_date": 1636470530,
        "question_id": 69900533,
        "body_markdown": "I&#39;m trying to compare version values between the pacakge.json latest git tag so that I can fail the CI build if the versions do not match. I&#39;ve created a make target that will take the two version values and do a string comparison to make sure they are the same, although I&#39;m open to numeric comparsions if possible.\r\n\r\n```\r\nPKG_VERSION=$(shell echo v$$(jq .version package.json))\r\nLATEST_TAG=$(shell git describe --tags --abbrev=0 $$(git rev-list --tags --max-count=1))\r\nenforce-versions:\r\n\t@echo &quot;Comparing \\&quot;$(PKG_VERSION)\\&quot; &amp; \\&quot;$(LATEST_TAG)\\&quot;&quot;\r\nifeq ($(PKG_VERSION), $(LATEST_TAG))\r\n\texit 0;\r\nelse\r\n\texit 1;\r\nendif\r\n```\r\n\r\nOutput:\r\n```\r\n$ make enforce-versions \r\nComparing &quot;v1.0.0&quot; &amp; &quot;v1.1.0&quot;\r\nexit 1;\r\nmake: *** [enforce-versions] Error 1\r\n$ make enforce-versions\r\nComparing &quot;v1.1.0&quot; &amp; &quot;v1.1.0&quot;\r\nexit 1;\r\nmake: *** [enforce-versions] Error 1\r\n```",
        "link": "https://stackoverflow.com/questions/69900533/makefile-compare-two-version-string-values-from-git-tag-and-package-json",
        "title": "Makefile: compare two version string values from git tag and package.json"
    },
    {
        "tags": [
            "linux",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1636553379,
                "post_id": 69914737,
                "comment_id": 123587696,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18346196,
                    "reputation": 101,
                    "user_id": 13361345,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6ac73c4b366b11477bc37abc951862ba?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "benevolent",
                    "link": "https://stackoverflow.com/users/13361345/benevolent"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636553459,
                "post_id": 69914737,
                "comment_id": 123587725,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636553540,
                "post_id": 69914737,
                "comment_id": 123587777,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2570367,
                    "reputation": 10875,
                    "user_id": 2229272,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oisED.png?s=256",
                    "display_name": "jas",
                    "link": "https://stackoverflow.com/users/2229272/jas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636553595,
                "post_id": 69914737,
                "comment_id": 123587798,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1636555319,
                "creation_date": 1636555319,
                "answer_id": 69915246,
                "question_id": 69914737,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    $ cat file.json | jq -r .Instances[].PrivateIpAddress\r\n    10.245.247.21\r\n\r\n    $ cat file.json | jq -r .Instances[].InstanceId\r\n    i-123548874\r\n\r\nOr\r\n\r\n    $ jq -r .Instances[].PrivateIpAddress file.json\r\n    10.245.247.21\r\n\r\n    $ jq -r .Instances[].InstanceId file.json\r\n    i-123548874",
                "title": "How to fetch array values using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1636555319,
        "creation_date": 1636553249,
        "question_id": 69914737,
        "body_markdown": "file.json&lt;br&gt;\r\n\r\n```\r\n{\r\n   &quot;Groups&quot;:[\r\n      \r\n   ],\r\n   &quot;Instances&quot;:[\r\n      {\r\n         &quot;AmiLaunchIndex&quot;:0,\r\n         &quot;ImageId&quot;:&quot;ami-id&quot;,\r\n         &quot;InstanceId&quot;:&quot;i-123548874&quot;,\r\n         &quot;InstanceType&quot;:&quot;c5.4xlarge&quot;,\r\n         &quot;KeyName&quot;:&quot;kay&quot;,\r\n         &quot;LaunchTime&quot;:&quot;dateValue&quot;,\r\n         &quot;Monitoring&quot;:{\r\n            &quot;State&quot;:&quot;disabled&quot;\r\n         },\r\n         &quot;Placement&quot;:{\r\n            &quot;AvailabilityZone&quot;:&quot;zone value&quot;,\r\n            &quot;GroupName&quot;:&quot;&quot;,\r\n            &quot;Tenancy&quot;:&quot;default&quot;\r\n         },\r\n         &quot;PrivateDnsName&quot;:&quot;ip address&quot;,\r\n         &quot;PrivateIpAddress&quot;:&quot;10.245.247.21&quot;,\r\n         &quot;ProductCodes&quot;:[\r\n            \r\n         ], \r\nand more json...\r\n\r\n```\r\n\r\nThere is only one item in the array.I want to fetch **InstanceId** and **PrivateIpAddress** from json. I am using below command to fetch value:\r\n\r\n```\r\nfile.json | jq -r .Instances[].InstanceId\r\nfile.json | jq -r .Instances[].PrivateIpAddress\r\n\r\n```\r\n&lt;br&gt;\r\nBut I am getting nothing in the response.\r\n\r\nI have tried various ways mentioned in other stack overflow questions and I am still not getting proper response. \r\n\r\nI am expecting below response&lt;br&gt;\r\n\r\n```\r\ni-123548874\r\n10.245.247.21\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/69914737/how-to-fetch-array-values-using-jq",
        "title": "How to fetch array values using jq"
    },
    {
        "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": 1,
                "creation_date": 1636557032,
                "post_id": 69915675,
                "comment_id": 123589436,
                "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": 1636557117,
                "post_id": 69915675,
                "comment_id": 123589472,
                "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": 1636560661,
                "post_id": 69915675,
                "comment_id": 123591138,
                "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": 1636560722,
                "post_id": 69915675,
                "comment_id": 123591163,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1636557407,
                "last_edit_date": 1636557407,
                "creation_date": 1636557228,
                "answer_id": 69915755,
                "question_id": 69915675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The second command reads from `report.empty.json` instead of the already-modified `report.json`.\r\n\r\nYou could chain the `jq`\r\n\r\n```sh\r\njq --arg totalArg &quot;$PAGE_SIZE&quot; &#39;.total = $totalArg&#39; report.empty.json |\r\njq --arg projectKey &quot;${PROJECT_KEY}&quot; &#39;.project = $projectKey&#39; &gt;report.json\r\n```\r\n\r\n\r\nBut a better solution is to use just use one command.\r\n\r\n```sh\r\njq --arg totalArg &quot;$PAGE_SIZE&quot; --arg projectKey &quot;$PROJECT_KEY&quot; &#39;\r\n   .total = $totalArg | .project = $projectKey\r\n&#39; report.empty.json &gt;report.json\r\n```\r\n",
                "title": "Can&#39;t set different json values with different values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1636562059,
                "creation_date": 1636562059,
                "answer_id": 69916942,
                "question_id": 69915675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### My proposal for *How to populate JSON values, using `jq`*\r\n\r\nThinking about **How to process *arrays* using jq**, here is my modified version of your script. (Of course, you could keep `empty.json` out of script)...\r\n\r\n    #!/bin/bash\r\n    \r\n    declare -r  projectKey=MY_PROJECT\r\n    declare -ir pageSize=500\r\n    \r\n    declare -a issueList=()\r\n    declare -i issueCnt=0\r\n    declare issueStr=&#39;&#39; jqCmd=&#39;.project = $projArg | .total = $totArg | .issues=[ &#39;\r\n    declare promptMessage=&#39;Enter issue (or [return] if none): &#39;\r\n    while read -rp &quot;$promptMessage&quot; issue &amp;&amp; [ &quot;$issue&quot; ];do\r\n        promptMessage=&#39;Enter next issue (or [return] if no more): &#39;\r\n        issueCnt+=1\r\n        issueList+=(--arg is$issueCnt &quot;$issue&quot;)\r\n        issueStr+=&quot;\\$is$issueCnt, &quot;\r\n    done\r\n    jqCmd+=&quot;${issueStr%, } ]&quot;\r\n    \r\n    jq --arg totArg &quot;$pageSize&quot; --arg projArg &quot;$projectKey&quot; \\\r\n       &quot;${issueList[@]}&quot; &quot;( $jqCmd )&quot; &lt;&lt;-EoEmptyJson\r\n    {\r\n        &quot;total&quot;: 0,\r\n        &quot;project&quot;: &quot;&quot;,\r\n        &quot;Severity&quot;: [],\r\n        &quot;issues&quot;: []\r\n    }\r\n    EoEmptyJson\r\n\r\nSample run (I want to add two issues):\r\n\r\n&lt;!-- language: lang-none --&gt;\r\n    ./reportJson\r\n    Enter issue (or [return] if none): Foo\r\n    Enter next issue (or [return] if no more): Bar Baz\r\n    Enter next issue (or [return] if no more): \r\n    {\r\n      &quot;total&quot;: &quot;500&quot;,\r\n      &quot;project&quot;: &quot;MY_PROJECT&quot;,\r\n      &quot;Severity&quot;: [],\r\n      &quot;issues&quot;: [\r\n        &quot;Foo&quot;,\r\n        &quot;Bar Baz&quot;\r\n      ]\r\n    }\r\n\r\n    ",
                "title": "Can&#39;t set different json values with different values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1636570122,
                "creation_date": 1636570122,
                "answer_id": 69918688,
                "question_id": 69915675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "No answer (so far) accounts for the requirement that `total` be of type `int`. This can be accomplished by using `--argjson` instead of `--arg`. Here&#39;s my two cents:\r\n\r\n```sh\r\njq --argjson total 500 --arg project &quot;MY_PROJECT&quot; &#39;. + {$total, $project}&#39; report.json\r\n```\r\n```json\r\n{\r\n  &quot;total&quot;: 500,\r\n  &quot;project&quot;: &quot;MY_PROJECT&quot;,\r\n  &quot;Severity&quot;: [],\r\n  &quot;issues&quot;: []\r\n}\r\n```",
                "title": "Can&#39;t set different json values with different values"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1636570122,
        "creation_date": 1636556937,
        "last_edit_date": 1636557046,
        "question_id": 69915675,
        "body_markdown": "Linux Mint 20.2\r\n\r\n\r\nHere **report.empty.json**\r\n\r\n\r\n    {\r\n      &quot;total&quot;: 0,\r\n      &quot;project&quot;: &quot;&quot;,\r\n      &quot;Severity&quot;: [],\r\n      &quot;issues&quot;: []\r\n    }\r\n\r\n\r\nI want to set value = 500 (int value) to &quot;total&quot; and &quot;MY_PROJECT&quot;.\r\n\r\nTo do this I use tool &quot;jq&quot;\r\n\r\nHere by bash script file:\r\n\r\n    #!/bin/bash\r\n    \r\n    readonly PROJECT_KEY=MY_PROJECT\r\n    readonly PAGE_SIZE=500\r\n    \r\n    jq --arg totalArg &quot;$PAGE_SIZE&quot; &#39;.total = $totalArg&#39; report.empty.json &gt; report.json\r\n    jq --arg projectKey &quot;${PROJECT_KEY}&quot; &#39;.project = $projectKey&#39; report.empty.json &gt; report.json\r\n    \r\n    echo &quot;Done&quot;\r\n\r\n\r\nBut it set only key **project**. The key **total** is not changed. \r\nContent of file **report.json**\r\n\r\n    {\r\n      &quot;total&quot;: 0,\r\n      &quot;project&quot;: &quot;MY_PROJECT&quot;,\r\n      &quot;Severity&quot;: [],\r\n      &quot;issues&quot;: []\r\n    }\r\n\r\nBut I need to update **BOTH KEYS**.\r\n\r\nThe result must be:\r\n\r\n    {\r\n      &quot;total&quot;: 500,\r\n      &quot;project&quot;: &quot;MY_PROJECT&quot;,\r\n      &quot;Severity&quot;: [],\r\n      &quot;issues&quot;: []\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69915675/cant-set-different-json-values-with-different-values",
        "title": "Can&#39;t set different json values with different values"
    },
    {
        "tags": [
            "bash",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1636560083,
                "post_id": 69915972,
                "comment_id": 123590890,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1636578567,
                "last_edit_date": 1636578567,
                "creation_date": 1636562988,
                "answer_id": 69917166,
                "question_id": 69915972,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use:\r\n1) `--output` option to specify your output filename\r\n2) `--write-out` option to get HTTP code response\r\n\r\nLike this:\r\n```bash\r\n#! /bin/bash\r\n\r\nfunction callServer() {\r\n\r\n  local API_KEY=&quot;$1&quot;\r\n  local PAYLOAD=&quot;$2&quot;\r\n  local OUTPUT_FILENAME=&quot;$3&quot;\r\n  local -n HTTP_RESPONSE_CODE=&quot;$4&quot;\r\n\r\n  HTTP_RESPONSE_CODE=$(curl --request POST \\\r\n    --url https://myservice.example.com \\\r\n    --header &quot;Authorization: ${API_KEY}&quot; \\\r\n    --header &#39;Content-Type: application/json&#39; \\\r\n    --data &quot;${PAYLOAD}&quot; \\\r\n    --output &quot;${OUTPUT_FILENAME}&quot; \\\r\n    --write-out &quot;%response_code&quot; \\\r\n  )\r\n\r\n}\r\n\r\ndeclare HTTP_CODE=\r\ncallServer &quot;theApikey&quot; &#39;{&quot;flim&quot;:&quot;flam&quot;}&#39; &quot;theOutputFileName&quot; HTTP_CODE\r\n\r\necho &quot;The HTTP code is ${HTTP_CODE}&quot;\r\necho &quot;Filename content:&quot;\r\ncat theOutputFileName\r\necho &quot;.&quot;\r\n\r\n```",
                "title": "Checking curl response code and returning results from inside a bash function"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1636578567,
        "creation_date": 1636557995,
        "question_id": 69915972,
        "body_markdown": "I have a bash script that makes a ton of RESTful HTTP calls (via `curl`) to the many different endpoints of the same service. I want to write a bash function that makes a configurable curl request and verifies that the status is HTTP 200. If its not, the entire script should exit with an error code. If it is, the function should return the JSON that is returned by the HTTP response coming back from the REST API.\r\n\r\nMy best attempt thus far is:\r\n```\r\nfunction callServer() {\r\n\r\n  payload=$1\r\n\r\n  curl --request POST \\\r\n    --url https://myservice.example.com \\\r\n    --header &#39;Authorization: $API_KEY&#39; \\\r\n    --header &#39;Content-Type: application/json&#39; \\\r\n    --data &#39;$payload&#39; &gt; jsonResp\r\n\r\n}\r\n```\r\n\r\nAn example usage from inside the script might be:\r\n```\r\n$getWidgetsJson=callServer &#39;{&quot;flim&quot;:&quot;flam&quot;}&#39;\r\n```\r\nor:\r\n```\r\n$launchMissiles=callServer &#39;{&quot;fizz&quot;:&quot;buzz&quot;,&quot;num&quot;:50}&#39;\r\n```\r\n\r\nI think I&#39;m close but having trouble seeing the forest through the trees here. How can I check 200-status on the response in the curl, and either fail the script or return the JSON from the function accordingly?",
        "link": "https://stackoverflow.com/questions/69915972/checking-curl-response-code-and-returning-results-from-inside-a-bash-function",
        "title": "Checking curl response code and returning results from inside a bash function"
    }
]