[
    {
        "tags": [
            "linux",
            "unix",
            "pipe",
            "jq",
            "less-unix"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 220462,
                    "reputation": 181667,
                    "user_id": 477878,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/qounX.jpg?s=256",
                    "display_name": "Joachim Isaksson",
                    "link": "https://stackoverflow.com/users/477878/joachim-isaksson"
                },
                "edited": false,
                "score": 9,
                "creation_date": 1594278287,
                "post_id": 62809196,
                "comment_id": 111071033,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18447694,
                    "reputation": 843,
                    "user_id": 13438554,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-dakwU3k5eFo/AAAAAAAAAAI/AAAAAAAAAAA/AAKWJJNC5iJQuk1WSgcJXgJ7py5Me04Okw/s256-rj/photo.jpg",
                    "display_name": "filipg g",
                    "link": "https://stackoverflow.com/users/13438554/filipg-g"
                },
                "reply_to_user": {
                    "account_id": 220462,
                    "reputation": 181667,
                    "user_id": 477878,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/qounX.jpg?s=256",
                    "display_name": "Joachim Isaksson",
                    "link": "https://stackoverflow.com/users/477878/joachim-isaksson"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1594364605,
                "post_id": 62809196,
                "comment_id": 111105339,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 220462,
                    "reputation": 181667,
                    "user_id": 477878,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/qounX.jpg?s=256",
                    "display_name": "Joachim Isaksson",
                    "link": "https://stackoverflow.com/users/477878/joachim-isaksson"
                },
                "edited": false,
                "score": 7,
                "creation_date": 1594444506,
                "post_id": 62809196,
                "comment_id": 111134815,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 128,
                "is_accepted": true,
                "score": 128,
                "last_activity_date": 1594278536,
                "last_edit_date": 1594278536,
                "creation_date": 1594278353,
                "answer_id": 62809275,
                "question_id": 62809196,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is `jq` that is suppressing the colours. From the `man` page\r\n```\r\n       o   --color-output / -C and --monochrome-output / -M:\r\n\r\n           By default, jq outputs colored JSON if writing to a terminal.\r\nYou can force it to produce color even if writing to a pipe or a file\r\nusing -C, and disable color with -M\r\n```\r\nSo, just use:\r\n\r\n    jq -C &quot;.&quot; /tmp/myfile.json | less -R\r\n\r\n\r\nand it will output colours regardless. The `less` command doesn&#39;t need the `-R` switch on my version, but I believe it does on older versions. If you see the `ESC...` codes, you will need that switch.",
                "title": "How do I keep colors when piping &quot;jq&quot; output to &quot;less&quot;?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 83,
        "last_activity_date": 1614021427,
        "creation_date": 1594278060,
        "last_edit_date": 1614021427,
        "question_id": 62809196,
        "body_markdown": "I have a simple json file and if I pipe the output of &quot;jq&quot; into &quot;less&quot;, the colors get removed.\r\n\r\nThis works:\r\n```bash\r\n# yey, lots of colors\r\njq &quot;.&quot; /tmp/myfile.json\r\n```\r\n\r\nThis doesn&#39;t work:\r\n```bash\r\n# ugly output :( , no colors\r\njq &quot;.&quot; /tmp/myfile.json | less -R\r\n```\r\n\r\nAny ideas on how to make &quot;less&quot; keep the colors?",
        "link": "https://stackoverflow.com/questions/62809196/how-do-i-keep-colors-when-piping-jq-output-to-less",
        "title": "How do I keep colors when piping &quot;jq&quot; output to &quot;less&quot;?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1594305641,
                "last_edit_date": 1594305641,
                "creation_date": 1594299802,
                "answer_id": 62815483,
                "question_id": 62815281,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [`readarray`](https://www.gnu.org/software/bash/manual/html_node/Bash-Builtins.html#index-readarray) instead.\r\n```\r\n$ readarray -t test_cases &lt; &lt;(jq -c &#39;.[]&#39; file)\r\n$ declare -p test_cases\r\ndeclare -a test_cases=([0]=&quot;{\\&quot;USERID\\&quot;:\\&quot;TMCCP\\&quot;,\\&quot;CREATED_DATE\\&quot;:\\&quot;31/01/2020 17:52\\&quot;}&quot; [1]=&quot;{\\&quot;USERID\\&quot;:\\&quot;TMCCP\\&quot;,\\&quot;CREATED_DATE\\&quot;:\\&quot;31/01/2020 17:52\\&quot;}&quot;)\r\n```\r\nAnd `read` can be used as shown below where `readarray` is unavailable.\r\n```\r\nIFS=$&#39;\\n&#39; read -d &#39;&#39; -a test_cases &lt; &lt;(jq -c &#39;.[]&#39; file)\r\n```",
                "title": "convert JSON array to bash array preserving whitespaces"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1594301486,
                "last_edit_date": 1594301486,
                "creation_date": 1594299810,
                "answer_id": 62815490,
                "question_id": 62815281,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `readarray` to populate the array, rather than using an unquoted command substitution; `bash` doesn&#39;t care about JSON quoting when it splits the result into separate words.\r\n\r\n    readarray -t test_cases &lt; &lt;(jq -c &#39;.[]&#39; data.json)\r\n\r\nIn `bash` 3.2 (which is what you appear to be stuck with), you need something slightly more unwieldy\r\n\r\n    while IFS= read -r line; do\r\n        test_cases+=(&quot;$line&quot;)\r\n    done &lt; &lt;(jq -c &#39;.[]&#39; data.json)",
                "title": "convert JSON array to bash array preserving whitespaces"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1594305641,
        "creation_date": 1594299187,
        "last_edit_date": 1594299980,
        "question_id": 62815281,
        "body_markdown": "I want to transform JSON file into bash array of strings that i will later be able to iterate over. My JSON structure is as follows:\r\n\r\n    [\r\n      {\r\n        &quot;USERID&quot;: &quot;TMCCP&quot;,\r\n        &quot;CREATED_DATE&quot;: &quot;31/01/2020 17:52&quot;\r\n      },\r\n      {\r\n        &quot;USERID&quot;: &quot;TMCCP&quot;,\r\n        &quot;CREATED_DATE&quot;: &quot;31/01/2020 17:52&quot;\r\n      }\r\n    ]\r\nAnd this is my bash script:\r\n\r\n    test_cases=($(jq -c &#39;.[]&#39; data.json))\r\n    echo ${test_cases[0]}\r\n    echo ${test_cases[1]}\r\n    echo ${test_cases[2]}\r\n    echo ${test_cases[3]}\r\nAs you can see it returns array with 4 elements instead of 2. Output:\r\n\r\n    {&quot;USERID&quot;:&quot;TMCCP&quot;,&quot;CREATED_DATE&quot;:&quot;31/01/2020\r\n    17:52&quot;}\r\n    {&quot;USERID&quot;:&quot;TMCCP&quot;,&quot;CREATED_DATE&quot;:&quot;31/01/2020\r\n    17:52&quot;}\r\nFor some reason having whitespace in date field causes some parsing issues. Any idea how to get over this?",
        "link": "https://stackoverflow.com/questions/62815281/convert-json-array-to-bash-array-preserving-whitespaces",
        "title": "convert JSON array to bash array preserving whitespaces"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594308461,
                "post_id": 62818307,
                "comment_id": 111087047,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1594309726,
                "creation_date": 1594309726,
                "answer_id": 62818754,
                "question_id": 62818307,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use something like the following :\r\n\r\n    .NetworkAcls[] | [.Associations, .Entries] | combinations | \\\r\n    &quot;\\(.[0].NetworkAclId) \\(.[1].RuleNumber) \\(.[1].Egress) \\(.[1].Protocol) \\(.[1].PortRange.From) \\(.[1].PortRange.To) \\(.[1].CidrBlock) \\(.[1].RuleAction)&quot;\r\n\r\n[Try it here](https://jqplay.org/s/L2PUyy4J6J)\r\n\r\nThis returns 8 elements as there are two NetworkAcls elements with each two associations and two entries.",
                "title": "jq: produce table containing parent and associated children elements"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1594316390,
                "creation_date": 1594316390,
                "answer_id": 62820612,
                "question_id": 62818307,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I found a formulation to output the data you want as CSV:\r\n```bash\r\njq -r &#39;\r\n    .NetworkAcls[] | range(.Associations | length) as $i | [\r\n        .Associations[$i].NetworkAclId,\r\n        (.Entries[$i] |\r\n            .RuleNumber,\r\n            .Egress,\r\n            .Protocol,\r\n            .PortRange.From,\r\n            .PortRange.To,\r\n            .CidrBlock,\r\n            .RuleAction\r\n        )\r\n    ] | @csv\r\n&#39; file.json\r\n```\r\n```none\r\n&quot;acl-09811190de1965cd4&quot;,100,true,&quot;6&quot;,80,80,&quot;0.0.0.0/0&quot;,&quot;allow&quot;\r\n&quot;acl-09811190de1965cd4&quot;,200,true,&quot;6&quot;,443,443,&quot;0.0.0.0/0&quot;,&quot;allow&quot;\r\n&quot;acl-0f1c265110106d23d&quot;,100,false,&quot;6&quot;,80,80,&quot;0.0.0.0/0&quot;,&quot;deny&quot;\r\n&quot;acl-0f1c265110106d23d&quot;,200,true,&quot;7&quot;,443,443,&quot;0.0.0.0/0&quot;,&quot;deny&quot;\r\n```\r\n\r\nI figure it&#39;s easier to ask how to turn CSV into a table than JSON.",
                "title": "jq: produce table containing parent and associated children elements"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1594370282,
        "creation_date": 1594308224,
        "last_edit_date": 1594370282,
        "question_id": 62818307,
        "body_markdown": "I have json like this \r\n```\r\n{\r\n    &quot;NetworkAcls&quot;: [\r\n        {\r\n            &quot;Associations&quot;: [\r\n                {\r\n                    &quot;NetworkAclAssociationId&quot;: &quot;aclassoc-0360bceb2b4788870&quot;,\r\n                    &quot;NetworkAclId&quot;: &quot;acl-09811190de1965cd4&quot;,\r\n                    &quot;SubnetId&quot;: &quot;subnet-9fa0aac4&quot;\r\n                },\r\n                {\r\n                    &quot;NetworkAclAssociationId&quot;: &quot;aclassoc-08ceb0c1375cb9729&quot;,\r\n                    &quot;NetworkAclId&quot;: &quot;acl-09811190de1965cd4&quot;,\r\n                    &quot;SubnetId&quot;: &quot;subnet-db2de5bd&quot;\r\n                }\r\n            ],\r\n            &quot;Entries&quot;: [\r\n                {\r\n                    &quot;CidrBlock&quot;: &quot;0.0.0.0/0&quot;,\r\n                    &quot;Egress&quot;: true,\r\n                    &quot;PortRange&quot;: {\r\n                        &quot;From&quot;: 80,\r\n                        &quot;To&quot;: 80\r\n                    },\r\n                    &quot;Protocol&quot;: &quot;6&quot;,\r\n                    &quot;RuleAction&quot;: &quot;allow&quot;,\r\n                    &quot;RuleNumber&quot;: 100\r\n                },\r\n                {\r\n                    &quot;CidrBlock&quot;: &quot;0.0.0.0/0&quot;,\r\n                    &quot;Egress&quot;: true,\r\n                    &quot;PortRange&quot;: {\r\n                        &quot;From&quot;: 443,\r\n                        &quot;To&quot;: 443\r\n                    },\r\n                    &quot;Protocol&quot;: &quot;6&quot;,\r\n                    &quot;RuleAction&quot;: &quot;allow&quot;,\r\n                    &quot;RuleNumber&quot;: 200\r\n                }\r\n            ],\r\n            &quot;IsDefault&quot;: false,\r\n            &quot;NetworkAclId&quot;: &quot;acl-09811190de1965cd4&quot;,\r\n            &quot;VpcId&quot;: &quot;vpc-12345678&quot;,\r\n            &quot;OwnerId&quot;: &quot;1234567890&quot;\r\n        },\r\n        {\r\n            &quot;Associations&quot;: [\r\n                {\r\n                    &quot;NetworkAclAssociationId&quot;: &quot;aclassoc-0531b6837ee6948dc&quot;,\r\n                    &quot;NetworkAclId&quot;: &quot;acl-0f1c265110106d23d&quot;,\r\n                    &quot;SubnetId&quot;: &quot;subnet-7f23eb19&quot;\r\n                },\r\n                {\r\n                    &quot;NetworkAclAssociationId&quot;: &quot;aclassoc-01314abbaca73ae21&quot;,\r\n                    &quot;NetworkAclId&quot;: &quot;acl-0f1c265110106d23d&quot;,\r\n                    &quot;SubnetId&quot;: &quot;subnet-44bdb71f&quot;\r\n                }\r\n            ],\r\n            &quot;Entries&quot;: [\r\n                {\r\n                    &quot;CidrBlock&quot;: &quot;0.0.0.0/0&quot;,\r\n                    &quot;Egress&quot;: false,\r\n                    &quot;PortRange&quot;: {\r\n                        &quot;From&quot;: 80,\r\n                        &quot;To&quot;: 80\r\n                    },\r\n                    &quot;Protocol&quot;: &quot;6&quot;,\r\n                    &quot;RuleAction&quot;: &quot;deny&quot;,\r\n                    &quot;RuleNumber&quot;: 100\r\n                },\r\n                {\r\n                    &quot;CidrBlock&quot;: &quot;0.0.0.0/0&quot;,\r\n                    &quot;Egress&quot;: true,\r\n                    &quot;PortRange&quot;: {\r\n                        &quot;From&quot;: 443,\r\n                        &quot;To&quot;: 443\r\n                    },\r\n                    &quot;Protocol&quot;: &quot;7&quot;,\r\n                    &quot;RuleAction&quot;: &quot;deny&quot;,\r\n                    &quot;RuleNumber&quot;: 200\r\n                }\r\n            ],\r\n            &quot;IsDefault&quot;: false,\r\n            &quot;NetworkAclId&quot;: &quot;acl-0f1c265110106d23d&quot;,\r\n            &quot;VpcId&quot;: &quot;vpc-12345678&quot;,\r\n            &quot;OwnerId&quot;: &quot;1234567890&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nand I need to produce a table like this\r\n```\r\n| NetworkAclId            | RuleNumber    | Egress    | Protocol  | PortRange.From    | PortRange.To  | CidrBlock | RuleAction  |\r\n|-------------------------|---------------|-----------|-----------|-------------------|---------------|-----------|-------------|\r\n| acl-09811190de1965cd4   | 100           | true      | 6         | 80                | 80            | 0.0.0.0/0 | allow       |\r\n| acl-09811190de1965cd4   | 200           | true      | 6         | 443               | 443           | 0.0.0.0/0 | allow       |\r\n| acl-0f1c265110106d23d   | 100           | false     | 6         | 80                | 80            | 0.0.0.0/0 | deny        |\r\n| acl-0f1c265110106d23d   | 200           | true      | 7         | 443               | 443           | 0.0.0.0/0 | deny        |\r\n```\r\n\r\nThe Entries.* should only correspond to the NetworkAclId of its parent. \r\n\r\nThe closest I got was this but it produces so much duplication that I have to kill it.\r\n```\r\n.[][] | &quot;\\(.Associations[].NetworkAclId) \\(.Associations[].SubnetId) \\(.Entries[] | .CidrBlock) \\(.Entries[] | .Egress) \\(.Entries[] | .PortRange.From) \\(.Entries[] | .PortRange.To) \\(.Entries[] | .Protocol) \\(.Entries[] | .RuleAction) \\(.Entries[] | .RuleNumber)&quot;\r\n```\r\n\r\nSomething I don&#39;t get about jq is why every new field I add seems to produce exponentially increasing results.\r\n \r\nFor example this produces 4 results as expected:\r\n```\r\n.[][] | &quot;\\(.Associations[].NetworkAclId)&quot;\r\n```\r\n\r\nBut this produces 42 instead of the expected 4.\r\n```\r\n.[][] | &quot;\\(.Associations[].NetworkAclId) \\(.Entries[] | .RuleNumber)&quot;\r\n```\r\n\r\nHow do I get jq to keep the associations of children to parent without associating every possible permutation of values in the input?\r\n\r\nThank you",
        "link": "https://stackoverflow.com/questions/62818307/jq-produce-table-containing-parent-and-associated-children-elements",
        "title": "jq: produce table containing parent and associated children elements"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 14851325,
                    "reputation": 421,
                    "user_id": 10725180,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/7ILCL.jpg?s=256",
                    "display_name": "Jack Collins",
                    "link": "https://stackoverflow.com/users/10725180/jack-collins"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1594314000,
                "post_id": 62819335,
                "comment_id": 111089896,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1594314915,
                "last_edit_date": 1594314915,
                "creation_date": 1594314606,
                "answer_id": 62820126,
                "question_id": 62819335,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were close. To select *accounts* whose *owner*&#39;s *id* is `12345`, and extract their (*account*&#39;s, not *owner*&#39;s) *id*s, you can use this one:\r\n```\r\n$ jq &#39;.accounts | map(select(.owner.id == 12345) .id)&#39; file\r\n[\r\n  1234\r\n]\r\n```",
                "title": "How to use JQ to filter an object based on a value, and return an array of different values?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1594316092,
                "creation_date": 1594316092,
                "answer_id": 62820528,
                "question_id": 62819335,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another option could be\r\n\r\n    .accounts[]| select(.owner.id == 12345).id \r\n\r\nwhich outputs:\r\n\r\n    1234",
                "title": "How to use JQ to filter an object based on a value, and return an array of different values?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1594316092,
        "creation_date": 1594311697,
        "last_edit_date": 1594314676,
        "question_id": 62819335,
        "body_markdown": "I have a call that returns a large array of objects.\r\n\r\nThe objects looks like:\r\n\r\n```\r\n{\r\n  &quot;accounts&quot;: [\r\n    {\r\n      &quot;id&quot;: 1234,\r\n      &quot;name&quot;: &quot;Sample Name&quot;,\r\n      &quot;status&quot;: &quot;upgraded&quot;,\r\n      &quot;subscription&quot;: {\r\n        &quot;id&quot;: 4567,\r\n        &quot;products&quot;: [\r\n          {\r\n            &quot;product_id&quot;: 5,\r\n            &quot;name&quot;: &quot;Awesome Product&quot;,\r\n            &quot;units&quot;: 1,\r\n            &quot;price&quot;: 1\r\n          },\r\n          {\r\n            &quot;product_id&quot;: 1,\r\n            &quot;name&quot;: &quot;Another Awesome Product&quot;,\r\n            &quot;units&quot;: 1,\r\n            &quot;price&quot;: 1\r\n          }\r\n        ]\r\n      },\r\n      &quot;owner&quot;: {\r\n        &quot;id&quot;: 12345,\r\n        &quot;email&quot;: &quot;email@email.com&quot;,\r\n        &quot;first_name&quot;: &quot;John&quot;,\r\n        &quot;last_name&quot;: &quot;Doe&quot;,\r\n        &quot;state&quot;: &quot;active&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nIn this array there are many different objects with many different *owners*, and I want to return an array that only contains the id (first property of the object) IF the *owner* property is 12345.\r\n\r\nSo far I have \r\n\r\n```\r\n| jq -r &#39;.accounts[] | [.id]&#39;\r\n```\r\n\r\nwhich returns ALL of the &quot;id&quot;s in the object, but I&#39;m having trouble filtering this array based on the &quot;owner&quot; value\r\n\r\nI&#39;ve tried adding:\r\n\r\n```\r\n| jq -r &#39;.accounts[] | [.id] | select(.id == 12345)&#39;\r\n```\r\n\r\nBut I&#39;m currently getting the error\r\n\r\n```\r\nCannot index array with string &quot;id&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/62819335/how-to-use-jq-to-filter-an-object-based-on-a-value-and-return-an-array-of-diffe",
        "title": "How to use JQ to filter an object based on a value, and return an array of different values?"
    },
    {
        "tags": [
            "bash",
            "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": 1594330767,
                "post_id": 62824080,
                "comment_id": 111097114,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4293796,
                    "reputation": 67,
                    "user_id": 3509380,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/70cb576c380ab5b557fcbf631ee4c989?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "gatech-kid",
                    "link": "https://stackoverflow.com/users/3509380/gatech-kid"
                },
                "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": 1594330936,
                "post_id": 62824080,
                "comment_id": 111097160,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1594331155,
                "creation_date": 1594331155,
                "answer_id": 62824209,
                "question_id": 62824080,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `tonumber`. You need to use parentheses not to change the context for the remaining elements of the array.\r\n\r\n    [($date | tonumber), .totalTimeSpent, .totalRecords, .totalDuplicates]\r\n\r\nWithout the parentheses, the expression is equivalent to\r\n\r\n    [$date | (tonumber, .totalTimeSpent, .totalRecords, .totalDuplicates)]\r\n",
                "title": "Remove double quotes from part of string JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1594331155,
        "creation_date": 1594330535,
        "question_id": 62824080,
        "body_markdown": "I’m having trouble removing double quotes from the date I pass in to JQ.\r\nAny idea how I can do that? -r doesn’t seem to do the trick.\r\n\r\n```\r\ncurl SOMETHING | jq -r --arg date $(date +&quot;%s&quot;) &#39;.payload.overallStatus | [$date, .totalTimeSpent, .totalRecords, .totalDuplicates]&#39;\r\n  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                 Dload  Upload   Total   Spent    Left  Speed\r\n100   607  100   607    0     0  10649      0 --:--:-- --:--:-- --:--:-- 10649\r\n[\r\n  &quot;1594330317&quot;,\r\n  15802,\r\n  89004346,\r\n  10\r\n]\r\n\r\n```\r\n(I plan to add the | @csv option to convert the output to a line of csv)",
        "link": "https://stackoverflow.com/questions/62824080/remove-double-quotes-from-part-of-string-jq",
        "title": "Remove double quotes from part of string JQ"
    },
    {
        "tags": [
            "json",
            "sed",
            "split",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1594352364,
                "post_id": 62825963,
                "comment_id": 111102017,
                "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": 2,
                "creation_date": 1594352518,
                "post_id": 62825963,
                "comment_id": 111102044,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5088217,
                    "reputation": 23807,
                    "user_id": 4082052,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/i6vlc.jpg?s=256",
                    "display_name": "Sundeep",
                    "link": "https://stackoverflow.com/users/4082052/sundeep"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1594355828,
                "post_id": 62825963,
                "comment_id": 111102750,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3743061,
                    "reputation": 475,
                    "user_id": 3112403,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/jCImM.jpg?s=256",
                    "display_name": "sal17",
                    "link": "https://stackoverflow.com/users/3112403/sal17"
                },
                "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": 1594355915,
                "post_id": 62825963,
                "comment_id": 111102780,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "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": 1,
                "creation_date": 1594401100,
                "post_id": 62825963,
                "comment_id": 111123726,
                "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": 1594456758,
                "post_id": 62825963,
                "comment_id": 111137253,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1666792573,
                "last_edit_date": 1666792573,
                "creation_date": 1602833599,
                "answer_id": 64384785,
                "question_id": 62825963,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq&#39;s *streaming* parser (the one invoked with the --stream command-line option) intentionally sacrifices speed for the sake of reduced memory requirements, as illustrated below in the metrics section.  A tool which strikes a different balance (one which seems to be closer to what you&#39;re looking for) is `jstream`, the homepage of which is  https://github.com/bcicen/jstream \r\n\r\n\r\nRunning the sequence of commands in a bash or bash-like shell:\r\n```\r\ncd\r\ngo get github.com/bcicen/jstream\r\ncd go/src/github.com/bcicen/jstream/cmd/jstream/\r\ngo build\r\n```\r\n\r\nwill result in an executable, which you can invoke like so:\r\n\r\n```\r\njstream -d 1 &lt; INPUTFILE &gt; STREAM\r\n```\r\n\r\nAssuming INPUTFILE contains a (possibly ginormous) JSON array, the above will behave like jq&#39;s `.[]`, with jq&#39;s -c (compact) command-line option.  In fact, this is also the case if INPUTFILE contains a stream of JSON arrays, or a stream of JSON non-scalars ...\r\n\r\n## Illustrative space-time metrics\r\n\r\n### Summary \r\n\r\nFor the task at hand (streaming the top-level items of an array):\r\n```\r\n                  mrss   u+s\r\njq --stream:      2 MB   447\r\njstream    :      8 MB   114\r\njm         :     13 MB   109\r\njq         :  5,582 MB    39\r\n```\r\nIn words:\r\n\r\n1. `space`: jstream is economical with memory, but not as much as jq&#39;s streaming parser.\r\n\r\n2. `time`: jstream runs slightly slower than jq&#39;s regular parser\r\nbut about 4 times faster than jq&#39;s streaming parser.\r\n\r\nInterestingly, space*time is about the same for jstream and jq&#39;s streaming parser.\r\n\r\n### Characterization of the test file\r\n\r\nThe test file consists of an array of 10,000,000 simple objects:\r\n```\r\n[\r\n{&quot;key_one&quot;: 0.13888342355537053, &quot;key_two&quot;: 0.4258700286271502, &quot;key_three&quot;: 0.8010012924267487}\r\n,{&quot;key_one&quot;: 0.13888342355537053, &quot;key_two&quot;: 0.4258700286271502, &quot;key_three&quot;: 0.8010012924267487}\r\n...\r\n]\r\n```\r\n```\r\n$ ls -l input.json\r\n-rw-r--r--  1 xyzzy  staff  980000002 May  2  2019 input.json\r\n\r\n$ wc -l input.json\r\n 10000001 input.json\r\n```\r\n### jq times and mrss\r\n``` \r\n$ /usr/bin/time -l jq empty input.json\r\n       43.91 real        37.36 user         4.74 sys\r\n4981452800  maximum resident set size\r\n\r\n$ /usr/bin/time -l jq length input.json\r\n10000000\r\n       48.78 real        41.78 user         4.41 sys\r\n4730941440  maximum resident set size\r\n\r\n/usr/bin/time -l jq type input.json\r\n&quot;array&quot;\r\n       37.69 real        34.26 user         3.05 sys\r\n5582196736  maximum resident set size\r\n\r\n/usr/bin/time -l jq &#39;def count(s): reduce s as $i (0;.+1); count(.[])&#39; input.json\r\n10000000\r\n       39.40 real        35.95 user         3.01 sys\r\n5582176256  maximum resident set size\r\n\r\n/usr/bin/time -l jq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39; input.json | wc -l\r\n      449.88 real       444.43 user         2.12 sys\r\n   2023424  maximum resident set size\r\n 10000000\r\n```\r\n### jstream times and mrss\r\n```\r\n$ /usr/bin/time -l jstream -d 1 &lt; input.json &gt; /dev/null\r\n       61.63 real        79.52 user        16.43 sys\r\n   7999488  maximum resident set size\r\n\r\n$ /usr/bin/time -l jstream -d 1 &lt; input.json | wc -l\r\n       77.65 real        93.69 user        20.85 sys\r\n   7847936  maximum resident set size\r\n 10000000\r\n\r\n```\r\n\r\n### jm times and mrss\r\n[jm][1] is another command-line utility for &quot;streaming&quot; JSON arrays and objects, using minimal memory. \r\n```\r\n$ /usr/bin/time -lp jm --count input.json\r\n       real 110.75       user 107.67       sys 1.22\r\n13 295 616  maximum resident set size\r\n 7 303 168  peak memory footprint\r\n 10000000\r\n\r\n```\r\n\r\n\r\n  [1]: https://github.com/pkoppstein/jm",
                "title": "Improving performance when using jq to process large files"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1603164340,
                "last_edit_date": 1603164340,
                "creation_date": 1603097254,
                "answer_id": 64423960,
                "question_id": 62825963,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## Restrictions\r\n\r\nIn the general case, JSON needs parsing with a tool that can understand JSON. You could make an exception and follow these suggestions, only if you are sure that:\r\n\r\n- You have an array with **flat** JSON objects (like in the use case) without nested objects.\r\n\r\n- Curly braces do not exist anywhere inside the objects, that means you don&#39;t have any content like this: `{id:1, name:&quot;foo{bar}&quot;}`.\r\n\r\n&lt;hr&gt;\r\n\r\n## Use the shell\r\n\r\nIf the above conditions are met, you can use the shell to convert to JSONL and split to smaller files, and it would be many times faster than JSON parsing or full text-processing. Additonally it can be almost memoryless, especially if you use core-utils with or without some `sed` or `awk`.\r\n\r\nEven the simpler approach:\r\n\r\n```bash\r\ngrep -o &#39;{[^}]*}&#39; file.json\r\n```\r\n\r\nwill be faster, but will need some memory (less than `jq`).\r\n\r\nAnd the `sed` commands you have tried are fast, but need memory, because `sed`, the stream editor, is reading line by line, and if the file has no newlines at all, it will load all of it into memory, `sed` needs 2-3 times the size of the maximum line of the stream. But if you first split the stream with newlines, using core-utils like `tr`, `cut` etc, then memory usage is extremely low, with great perfomance.\r\n\r\n&lt;hr&gt;\r\n\r\n## Solution\r\n\r\nAfter some testing, I found this one to be faster and memoryless. Besides that, it doesn&#39;t depend on the extra characters outside the objects, like comma and a few spaces, or comma alone etc. It will only match the objects `{...}` and print each of them to a new line.\r\n\r\n```bash\r\n#!/bin/sh -\r\nLC_ALL=C &lt; &quot;$1&quot; cut -d &#39;}&#39; -f1- --output-delimiter=&quot;}&quot;$&#39;\\n&#39; |\\\r\n    cut -sd &#39;{&#39; -f2 | sed &#39;s/^/{/&#39; &gt; &quot;$2&quot;\r\n```\r\nto split the JSONL, use `-l` rather than `-c`, to ensure you don&#39;t split any object, use something like this:\r\n\r\n```bash\r\nsplit -l 1000 -d --additional-suffix=&#39;.json&#39; - path/to/file/prefix\r\n```\r\nor all together\r\n\r\n```bash\r\n#!/bin/sh -\r\nn=1000\r\nLC_ALL=C &lt; &quot;$1&quot; cut -d &#39;}&#39; -f1- --output-delimiter=&quot;}&quot;$&#39;\\n&#39; |\\\r\n    cut -sd &#39;{&#39; -f2 | sed &#39;s/^/{/&#39; |\\\r\n    split -l &quot;$n&quot; -d --additional-suffix=&#39;.json&#39; - &quot;$2&quot;\r\n```\r\n\r\nUsage: \r\n\r\n```bash\r\nsh script.sh input.json path/to/new/files/output\r\n```\r\n\r\nwill create files output1.json, output2.json etc in the selected path.\r\n\r\n**Note:** If your stream contains non UTF-8 multi-bute characters, remove `LC_ALL=C`, it is just a small speed optimization which is not necessary.\r\n\r\n**Note:** I have assumed input with no newlines at all, or with newlines like in your first use case. To generalize and include any newlines anywhere in the file, I add a small modification. In this version `tr` will truncate all newlines initially, with almost no impact to perfomance:\r\n\r\n```bash\r\n#!/bin/sh -\r\nn=1000\r\nLC_ALL=C &lt; &quot;$1&quot; tr -d $&#39;\\n&#39; |\\\r\n    cut -d &#39;}&#39; -f1- --output-delimiter=&quot;}&quot;$&#39;\\n&#39; |\\\r\n    cut -sd &#39;{&#39; -f2 | sed &#39;s/^/{/&#39; &gt; &quot;$2&quot;\r\n```\r\n\r\n&lt;hr&gt;\r\n\r\n## Testing\r\n\r\nHere are some testing results. They are representative, times were similar for all executions.\r\n\r\nHere is the script I used, with input for various values of `n`:\r\n\r\n```bash\r\n#!/bin/bash\r\n\r\nmake_json() {\r\n    awk -v n=2000000 &#39;BEGIN{\r\n        x = &quot;{\\&quot;id\\&quot;: 1, \\&quot;name\\&quot;: \\&quot;foo\\&quot;}&quot;\r\n        printf &quot;[&quot;\r\n        for (i=1;i&lt;n;i++) { printf x &quot;, &quot; }\r\n        printf x&quot;]&quot;\r\n    }&#39; &gt; big.json\r\n    return 0\r\n}\r\n\r\ntf=&quot;Real: %E  System: %S  User: %U  CPU%%: %P  Maximum Memory: %M KB\\n&quot;\r\nmake_json\r\n\r\nfor i in {1..7}; do\r\n    printf &quot;\\n==&gt; &quot;\r\n    cat &quot;${i}.sh&quot;\r\n    command time -f &quot;$tf&quot; sh &quot;${i}.sh&quot; big.json &quot;output${i}.json&quot;\r\ndone\r\n```\r\n\r\nI used small files when testing together with `jq` because it gets early into swap. Then with larger files using only the efficient solutions.\r\n\r\n```bash\r\n==&gt; LC_ALL=C jq -c &#39;.[]&#39; &quot;$1&quot; &gt; &quot;$2&quot;\r\nReal: 0:16.26  System: 1.46  User: 14.74  CPU%: 99%  Maximum Memory: 1004200 KB\r\n\r\n\r\n==&gt; LC_ALL=C jq length &quot;$1&quot; &gt; /dev/null\r\nReal: 0:09.19  System: 1.30  User: 7.85  CPU%: 99%  Maximum Memory: 1002912 KB\r\n\r\n\r\n==&gt; LC_ALL=C &lt; &quot;$1&quot; sed &#39;s/^\\[//; s/}[^}]*{/}\\n{/g; s/]$//&#39; &gt; &quot;$2&quot;\r\nReal: 0:02.21  System: 0.33  User: 1.86  CPU%: 99%  Maximum Memory: 153180 KB\r\n\r\n\r\n==&gt; LC_ALL=C &lt; &quot;$1&quot; grep -o &#39;{[^}]*}&#39; &gt; &quot;$2&quot;\r\nReal: 0:02.08  System: 0.34  User: 1.71  CPU%: 99%  Maximum Memory: 103064 KB\r\n\r\n\r\n==&gt; LC_ALL=C &lt; &quot;$1&quot; awk -v RS=&quot;}, {&quot; -v ORS=&quot;}\\n{&quot; &#39;1&#39; |\\\r\n    head -n -1 | sed &#39;1 s/^\\[//; $ s/]}$//&#39; &gt; &quot;$2&quot;\r\nReal: 0:01.38  System: 0.32  User: 1.52  CPU%: 134%  Maximum Memory: 3468 KB\r\n\r\n\r\n==&gt; LC_ALL=C &lt; &quot;$1&quot; cut -d &quot;}&quot; -f1- --output-delimiter=&quot;}&quot;$&#39;\\n&#39; |\\\r\n    sed &#39;1 s/\\[//; s/^, //; $d;&#39; &gt; &quot;$2&quot;\r\nReal: 0:00.94  System: 0.24  User: 0.99  CPU%: 131%  Maximum Memory: 3488 KB\r\n\r\n\r\n==&gt; LC_ALL=C &lt; &quot;$1&quot; cut -d &#39;}&#39; -f1- --output-delimiter=&quot;}&quot;$&#39;\\n&#39; |\\\r\n    cut -sd &#39;{&#39; -f2 | sed &#39;s/^/{/&#39; &gt; &quot;$2&quot;\r\nReal: 0:00.63  System: 0.28  User: 0.86  CPU%: 181%  Maximum Memory: 3448 KB\r\n\r\n# Larger files testing\r\n\r\n==&gt; LC_ALL=C &lt; &quot;$1&quot; grep -o &#39;{[^}]*}&#39; &gt; &quot;$2&quot;\r\nReal: 0:20.99  System: 2.98  User: 17.80  CPU%: 99%  Maximum Memory: 1017304 KB\r\n\r\n\r\n==&gt; LC_ALL=C &lt; &quot;$1&quot; awk -v RS=&quot;}, {&quot; -v ORS=&quot;}\\n{&quot; &#39;1&#39; |\\\r\n    head -n -1 | sed &#39;1 s/^\\[//; $ s/]}$//&#39; &gt; &quot;$2&quot;\r\nReal: 0:16.44  System: 2.96  User: 15.88  CPU%: 114%  Maximum Memory: 3496 KB\r\n\r\n\r\n==&gt; LC_ALL=C &lt; &quot;$1&quot; cut -d &quot;}&quot; -f1- --output-delimiter=&quot;}&quot;$&#39;\\n&#39; |\\\r\n    sed &#39;1 s/\\[//; s/^, //; $d;&#39; &gt; &quot;$2&quot;\r\nReal: 0:09.34  System: 1.93  User: 10.27  CPU%: 130%  Maximum Memory: 3416 KB\r\n\r\n\r\n==&gt; LC_ALL=C &lt; &quot;$1&quot; cut -d &#39;}&#39; -f1- --output-delimiter=&quot;}&quot;$&#39;\\n&#39; |\\\r\n    cut -sd &#39;{&#39; -f2 | sed &#39;s/^/{/&#39; &gt; &quot;$2&quot;\r\nReal: 0:07.22  System: 2.79  User: 8.74  CPU%: 159%  Maximum Memory: 3380 KB\r\n\r\n```\r\n\r\n  [1]: https://en.wikipedia.org/wiki/List_of_GNU_Core_Utilities_commands\r\n",
                "title": "Improving performance when using jq to process large files"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641509525,
                "creation_date": 1641509525,
                "answer_id": 70614580,
                "question_id": 62825963,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think the [answer](https://stackoverflow.com/a/64423960) by thanasisp is great and covers a lot of the problems. The use of `cut` is very clever to address the `sed`  memory problems.\r\n\r\n&gt; the sed commands you have tried are fast, but need memory, because sed, the stream editor, is reading line by line, and if the file has no newlines at all, it will load all of it into memory, sed needs 2-3 times the size of the maximum line of the stream\r\n\r\nHowever, as noted in the answer, that `sed` script only works for very simple JSON objects (no nested objects and no `}` anywhere except to denote end of first level objects.\r\n\r\n# A more advanced `sed` script\r\n\r\nThis can improved with a more sophisticated `sed` script which in addition to the patterns posted handles.\r\n\r\n```json\r\n[{&quot;id&quot;: 1, &quot;name&quot;: &quot;foo&quot;}\r\n,{&quot;id&quot;: 2, &quot;name&quot;: &quot;bar&quot;}\r\n,{&quot;id&quot;: 3, &quot;name&quot;: &quot;baz&quot;}\r\n,{&quot;id&quot;:4, &quot;name&quot;: 10}\r\n,{&quot;id&quot;:5, &quot;name&quot;:&quot;\\\\\\&quot; },{&quot;}\r\n,{&quot;id&quot;: {&quot;a&quot;:6}, &quot;name&quot;: 10}]\r\n```\r\n\r\nWe achieve this mainly by taking advantage of the fact that `{`/`}` and `&quot;` come in pairs.\r\n\r\n### json-newline-json.sed\r\n```none\r\n#!/bin/sed -nf\r\n\r\n# Skip empty lines\r\n/^$/d\r\n\r\n# From first line to first line starting with [\r\n0 , /\\[/ {\r\n# Replace opening [ if exists\r\n# + stripping leading whitespace\r\n\t/^[[:space:]]*\\[/  s@^[[:space:]]*\\[@,@\r\n}\r\n\r\n# Line starts with comma\r\n/^\\,/ {\r\n# Strip it\t\r\n}\r\n\r\n# Start of loop\r\n: x\r\n\r\n# Save to hold\r\nh\r\n\r\n# delete all chars except &quot; and \\\r\ns@[^&quot;\\\\]@@g\r\n# Delete all reverse solidi and non-escaped &quot; chars\r\ns@\\(\\\\&quot;\\|\\\\\\)@@g\r\n\r\n# Even match\r\n/^\\(&quot;&quot;\\)\\+$/ {\r\n\t# Fetch hold\r\n\tg\r\n\t# Delete everything between &quot;..&quot;\r\n\ts@&quot;[^&quot;]*&quot;@@g\r\n\t# Delete all chars except {}\r\n\ts@[^{}]@@g\r\n\t# Match even {} pairs\r\n\t/^\\([{}][{}]\\)\\+$/ {\r\n\t\t# The hold space contains our assembled ,{..} object\r\n\t\tg\r\n\t\t# Strip the leading comma\r\n\t\ts@^\\,@@\r\n\t\t# Print\r\n\t\tp\r\n\t\t# Skip to next line\r\n\t\td\r\n\t}\r\n\t# The hold space contains our partial ,{.. object\r\n\tg\r\n\tN\r\n\ts@\\n@@\r\n\tt x\r\n}\r\n\r\n# Odd match\r\n/^\\(&quot;&quot;\\)*&quot;$/ {\r\n\t# The hold space contains our partial ,{..&quot; object\r\n\tg\r\n\t# Fetch the next line to append\r\n\tN\r\n\t# Delete the newline added by N (append without newline)\r\n\ts@\\n@@\r\n\t# Restart loop x\r\n\tt x\r\n}\r\n\r\n```\r\n\r\nCombining with `cut` we do\r\n\r\n```sh\r\n&lt; huge.json cut -d &#39;}&#39; -f1- --output-delimeter=&quot;}&quot;$&#39;\\n&#39; |\\\r\n json-newline-json.sed |\\\r\n split ...\r\n```\r\n\r\n# NB\r\n\r\nIf you have relatively well defined (and non weird) JSON input, solving your problem with `sed` is powerful, portable and fast. However, it&#39;s precarious. The downside is that neither the input or output is validated. Parsing serialized formats is best done with more care. So for most intents and purposes I&#39;d probably stick with `jq`.",
                "title": "Improving performance when using jq to process large files"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 22,
        "last_activity_date": 1666792573,
        "creation_date": 1594343871,
        "question_id": 62825963,
        "body_markdown": "# Use Case\r\n\r\nI need to split large files (`~5G`) of JSON data into smaller files with [newline-delimited JSON][1] in a memory efficient way (i.e., without having to read the entire JSON blob into memory). The JSON data in each source file is an array of objects.\r\n\r\nUnfortunately, the source data is **not** [newline-delimited JSON][1] and in some cases there are no newlines in the files at all. This means I can&#39;t simply use the `split` command to split the large file into smaller chunks by newline. Here are examples of how the source data is stored in each file:\r\n\r\nExample of a source file with newlines.\r\n\r\n    [{&quot;id&quot;: 1, &quot;name&quot;: &quot;foo&quot;}\r\n    ,{&quot;id&quot;: 2, &quot;name&quot;: &quot;bar&quot;}\r\n    ,{&quot;id&quot;: 3, &quot;name&quot;: &quot;baz&quot;}\r\n    ...\r\n    ,{&quot;id&quot;: 9, &quot;name&quot;: &quot;qux&quot;}]\r\n\r\nExample of a source file without newlines.\r\n\r\n    [{&quot;id&quot;: 1, &quot;name&quot;: &quot;foo&quot;}, {&quot;id&quot;: 2, &quot;name&quot;: &quot;bar&quot;}, ...{&quot;id&quot;: 9, &quot;name&quot;: &quot;qux&quot;}]\r\n\r\nHere&#39;s an example of the desired format for a single output file:\r\n\r\n    {&quot;id&quot;: 1, &quot;name&quot;: &quot;foo&quot;}\r\n    {&quot;id&quot;: 2, &quot;name&quot;: &quot;bar&quot;}\r\n    {&quot;id&quot;: 3, &quot;name&quot;: &quot;baz&quot;}\r\n\r\n# Current Solution\r\n\r\nI&#39;m able to achieve the desired result by using [`jq`][2] and `split` as described in this [SO Post][3]. This approach is memory efficient thanks to the [`jq` streaming parser][4]. Here&#39;s the command that achieves the desired result:\r\n\r\n    cat large_source_file.json \\\r\n      | jq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39; \\\r\n      | split --line-bytes=1m --numeric-suffixes - split_output_file\r\n\r\n# The Problem\r\n\r\nThe command above takes `~47 mins` to process through the entire source file. This seems quite slow, especially when compared to `sed` which can produce the same output much faster.\r\n\r\nHere are some performance benchmarks to show processing time with `jq` vs. `sed`.\r\n\r\n\r\n    export SOURCE_FILE=medium_source_file.json  # smaller 250MB\r\n\r\n    # using jq\r\n    time cat ${SOURCE_FILE} \\\r\n      | jq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39; \\\r\n      | split --line-bytes=1m - split_output_file\r\n\r\n    real\t2m0.656s\r\n    user\t1m58.265s\r\n    sys\t    0m6.126s\r\n\r\n    # using sed\r\n    time cat ${SOURCE_FILE} \\\r\n      | sed -E &#39;s#^\\[##g&#39; \\\r\n      | sed -E &#39;s#^,\\{#\\{#g&#39; \\\r\n      | sed -E &#39;s#\\]$##g&#39; \\\r\n      | sed &#39;s#},{#}\\n{#g&#39; \\\r\n      | split --line-bytes=1m - sed_split_output_file\r\n\r\n    real\t0m25.545s\r\n    user\t0m5.372s\r\n    sys\t    0m9.072s\r\n\r\n\r\n# Questions\r\n\r\n1. Is this slower processing speed expected for `jq` compared to `sed`? It makes sense `jq` would be slower given it&#39;s doing a lot of validation under the hood, but 4X slower doesn&#39;t seem right.\r\n2. Is there anything I can do to improve the speed at which `jq` can process this file? I&#39;d prefer to use `jq` to process files because I&#39;m confident it could seamlessly handle other line output formats, but given I&#39;m processing thousands of files each day, it&#39;s hard to justify the speed difference I&#39;ve observed.\r\n\r\n  [1]: http://jsonlines.org/\r\n  [2]: https://stedolan.github.io/jq/\r\n  [3]: https://stackoverflow.com/a/49809249/3112403\r\n  [4]: https://github.com/stedolan/jq/wiki/FAQ#streaming-json-parser",
        "link": "https://stackoverflow.com/questions/62825963/improving-performance-when-using-jq-to-process-large-files",
        "title": "Improving performance when using jq to process large files"
    },
    {
        "tags": [
            "json",
            "conditional-statements",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1594353199,
                "creation_date": 1594353199,
                "answer_id": 62827074,
                "question_id": 62826775,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If it is acceptable to print all &quot;sessionKey&quot; values, then the simplest would probably be:\r\n```\r\n.. | objects | select(has(&quot;sessionKey&quot;)) | .sessionKey\r\n```\r\n\r\nOtherwise you could use an `if ... then ... else ... end` approach.\r\n",
                "title": "Handling the optional arrays with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1594368884,
        "creation_date": 1594350671,
        "last_edit_date": 1594368884,
        "question_id": 62826775,
        "body_markdown": "I am receiving this json file that lists one or more records. When there are multiple records, records are placed in an array. Otherwise, there is no array. I am trying to extract the sessionkey from the records using jq. Is there a generic way to match both cases:\r\n\r\nSample #1: message with multiple records:\r\n\r\n    {\r\n      &quot;message&quot;: {\r\n        &quot;header&quot;: {\r\n          &quot;response&quot;: {\r\n            &quot;result&quot;: &quot;SUCCESS&quot;,\r\n            &quot;gsbStatus&quot;: &quot;PRIMARY&quot;\r\n          }\r\n        },\r\n        &quot;body&quot;: {\r\n          &quot;bodyContent&quot;: {\r\n            &quot;type&quot;: &quot;history:lstmeetingusageHistoryResponse&quot;,\r\n            &quot;meetingUsageHistory&quot;: [\r\n              {\r\n                &quot;sessionKey&quot;: &quot;1263859083&quot;,\r\n                &quot;meetingUUID&quot;: &quot;603f5595dc8e4c7a9c2esdfsdf494cfae91815&quot;,\r\n                &quot;confName&quot;: &quot;sdfsdf setup for Dsdfdf alerts&quot;,\r\n                &quot;meetingStartTime&quot;: &quot;07/09/2020 14:00:17&quot;,\r\n                &quot;meetingEndTime&quot;: &quot;07/09/2020 15:01:53&quot;,\r\n                &quot;duration&quot;: &quot;62&quot;,\r\n                &quot;timezone&quot;: &quot;GMT-05:00, Central (Chicago)&quot;,\r\n                &quot;timeZoneID&quot;: &quot;7&quot;,\r\n                &quot;timeZoneWithDST&quot;: &quot;Chicago (Central Daylight Time, GMT-05:00)&quot;,\r\n                &quot;trackingCode&quot;: null,\r\n                &quot;meetingType&quot;: &quot;PRO&quot;,\r\n                &quot;hostWebExID&quot;: &quot;conferenceroom01@abc.com&quot;,\r\n                &quot;hostName&quot;: &quot;test Tech&quot;,\r\n                &quot;hostEmail&quot;: &quot;conferenceroom01@abc.com&quot;,\r\n                &quot;totalCallInMinutes&quot;: &quot;0&quot;,\r\n                &quot;totalPeopleMinutes&quot;: &quot;192&quot;,\r\n                &quot;totalCallInTollfreeMinutes&quot;: &quot;0&quot;,\r\n                &quot;totalCallOutDomestic&quot;: &quot;0&quot;,\r\n                &quot;totalCallOutInternational&quot;: &quot;0&quot;,\r\n                &quot;totalCallOutInternal&quot;: &quot;0&quot;,\r\n                &quot;totalCallInInternational&quot;: &quot;0&quot;,\r\n                &quot;tollCallInInternational&quot;: &quot;0&quot;,\r\n                &quot;tollfreeCallInInternational&quot;: &quot;0&quot;,\r\n                &quot;totalVoipMinutes&quot;: &quot;192&quot;,\r\n                &quot;userID&quot;: &quot;544798712&quot;,\r\n                &quot;totalParticipants&quot;: &quot;4&quot;,\r\n                &quot;totalParticipantsVoip&quot;: &quot;4&quot;,\r\n                &quot;totalParticipantsCallIn&quot;: &quot;0&quot;,\r\n                &quot;totalParticipantsCallOut&quot;: &quot;0&quot;,\r\n                &quot;confID&quot;: &quot;166058947180001507&quot;,\r\n                &quot;peakAttendee&quot;: &quot;4&quot;,\r\n                &quot;assistService&quot;: null\r\n              },\r\n              {\r\n                &quot;sessionKey&quot;: &quot;623922696&quot;,\r\n                &quot;meetingUUID&quot;: &quot;503dsfsdfsdfd4280e4a452e03b9c75dce0f26&quot;,\r\n                &quot;confName&quot;: &quot;test Tech&#39;s Personal Room&quot;,\r\n                &quot;meetingStartTime&quot;: &quot;06/24/2020 19:21:57&quot;,\r\n                &quot;meetingEndTime&quot;: &quot;06/24/2020 20:11:42&quot;,\r\n                &quot;duration&quot;: &quot;50&quot;,\r\n                &quot;timezone&quot;: &quot;GMT-05:00, Central (Chicago)&quot;,\r\n                &quot;timeZoneID&quot;: &quot;7&quot;,\r\n                &quot;timeZoneWithDST&quot;: &quot;Chicago (Central Daylight Time, GMT-05:00)&quot;,\r\n                &quot;trackingCode&quot;: null,\r\n                &quot;meetingType&quot;: &quot;PRO&quot;,\r\n                &quot;hostWebExID&quot;: &quot;conferenceroom01@abc.com&quot;,\r\n                &quot;hostName&quot;: &quot;test Tech&quot;,\r\n                &quot;hostEmail&quot;: &quot;conferenceroom01@abc.com&quot;,\r\n                &quot;totalCallInMinutes&quot;: &quot;0&quot;,\r\n                &quot;totalPeopleMinutes&quot;: &quot;100&quot;,\r\n                &quot;totalCallInTollfreeMinutes&quot;: &quot;0&quot;,\r\n                &quot;totalCallOutDomestic&quot;: &quot;0&quot;,\r\n                &quot;totalCallOutInternational&quot;: &quot;0&quot;,\r\n                &quot;totalCallOutInternal&quot;: &quot;0&quot;,\r\n                &quot;totalCallInInternational&quot;: &quot;0&quot;,\r\n                &quot;tollCallInInternational&quot;: &quot;0&quot;,\r\n                &quot;tollfreeCallInInternational&quot;: &quot;0&quot;,\r\n                &quot;totalVoipMinutes&quot;: &quot;100&quot;,\r\n                &quot;userID&quot;: &quot;544798712&quot;,\r\n                &quot;totalParticipants&quot;: &quot;2&quot;,\r\n                &quot;totalParticipantsVoip&quot;: &quot;2&quot;,\r\n                &quot;totalParticipantsCallIn&quot;: &quot;0&quot;,\r\n                &quot;totalParticipantsCallOut&quot;: &quot;0&quot;,\r\n                &quot;confID&quot;: &quot;164945117836245416&quot;,\r\n                &quot;peakAttendee&quot;: &quot;2&quot;,\r\n                &quot;assistService&quot;: null\r\n              }\r\n            ],\r\n            &quot;matchingRecords&quot;: {\r\n              &quot;total&quot;: &quot;2&quot;,\r\n              &quot;returned&quot;: &quot;2&quot;,\r\n              &quot;startFrom&quot;: &quot;1&quot;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nSample #2: message with a single record:\r\n\r\n    {\r\n      &quot;message&quot;: {\r\n        &quot;header&quot;: {\r\n          &quot;response&quot;: {\r\n            &quot;result&quot;: &quot;SUCCESS&quot;,\r\n            &quot;gsbStatus&quot;: &quot;PRIMARY&quot;\r\n          }\r\n        },\r\n        &quot;body&quot;: {\r\n          &quot;bodyContent&quot;: {\r\n            &quot;type&quot;: &quot;history:lstmeetingusageHistoryResponse&quot;,\r\n            &quot;meetingUsageHistory&quot;: {\r\n              &quot;sessionKey&quot;: &quot;297115075&quot;,\r\n              &quot;meetingUUID&quot;: &quot;sdsadfdsfsfsfdsfsdf&quot;,\r\n              &quot;confName&quot;: &quot;abc&#39;s Personal Room&quot;,\r\n              &quot;meetingStartTime&quot;: &quot;07/09/2020 20:58:37&quot;,\r\n              &quot;meetingEndTime&quot;: &quot;07/09/2020 22:38:15&quot;,\r\n              &quot;duration&quot;: &quot;100&quot;,\r\n              &quot;timezone&quot;: &quot;GMT-05:00, Central (Chicago)&quot;,\r\n              &quot;timeZoneID&quot;: &quot;7&quot;,\r\n              &quot;timeZoneWithDST&quot;: &quot;Chicago (Central Daylight Time, GMT-05:00)&quot;,\r\n              &quot;trackingCode&quot;: null,\r\n              &quot;meetingType&quot;: &quot;PRO&quot;,\r\n              &quot;hostWebExID&quot;: &quot;asdsad@abc.com&quot;,\r\n              &quot;hostName&quot;: &quot;asdasdasdasd&quot;,\r\n              &quot;hostEmail&quot;: &quot;asdsad@abc.com&quot;,\r\n              &quot;totalCallInMinutes&quot;: &quot;0&quot;,\r\n              &quot;totalPeopleMinutes&quot;: &quot;197&quot;,\r\n              &quot;totalCallInTollfreeMinutes&quot;: &quot;0&quot;,\r\n              &quot;totalCallOutDomestic&quot;: &quot;0&quot;,\r\n              &quot;totalCallOutInternational&quot;: &quot;0&quot;,\r\n              &quot;totalCallOutInternal&quot;: &quot;0&quot;,\r\n              &quot;totalCallInInternational&quot;: &quot;0&quot;,\r\n              &quot;tollCallInInternational&quot;: &quot;0&quot;,\r\n              &quot;tollfreeCallInInternational&quot;: &quot;0&quot;,\r\n              &quot;totalVoipMinutes&quot;: &quot;197&quot;,\r\n              &quot;userID&quot;: &quot;487886288&quot;,\r\n              &quot;totalParticipants&quot;: &quot;3&quot;,\r\n              &quot;totalParticipantsVoip&quot;: &quot;3&quot;,\r\n              &quot;totalParticipantsCallIn&quot;: &quot;0&quot;,\r\n              &quot;totalParticipantsCallOut&quot;: &quot;0&quot;,\r\n              &quot;confID&quot;: &quot;166305919935739955&quot;,\r\n              &quot;peakAttendee&quot;: &quot;2&quot;,\r\n              &quot;assistService&quot;: null\r\n            },\r\n            &quot;matchingRecords&quot;: {\r\n              &quot;total&quot;: &quot;1&quot;,\r\n              &quot;returned&quot;: &quot;1&quot;,\r\n              &quot;startFrom&quot;: &quot;1&quot;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/62826775/handling-the-optional-arrays-with-jq",
        "title": "Handling the optional arrays with jq"
    },
    {
        "tags": [
            "json",
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1594748628,
                "last_edit_date": 1594748628,
                "creation_date": 1594405438,
                "answer_id": 62840241,
                "question_id": 62839937,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Okay I spent 3 hours trying to solve this yesterday then this morning I posted this question and subsequently figured it out!\r\n\r\nHere is the solution which uses the `|=` operator which modifies an element in place.\r\n\r\n```sh\r\njq &#39;.annotations |= map(select(.category_id | contains(1,2)))&#39; instances_val2017.json\r\n```\r\n\r\nAs per the suggestion of @peak, here is the command with `==` instead of `contains`.\r\n\r\n```sh\r\njq &#39;.annotations |= map(select(.category_id == (1,2)))&#39; instances_val2017.json\r\n```",
                "title": "jq to filter inner array elements but return the whole JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1594748628,
        "creation_date": 1594404167,
        "question_id": 62839937,
        "body_markdown": "**TL;DR** \r\n\r\nHow can I return the whole JSON after filtering inner array elements of a top-level key?\r\n\r\n**Detailed explanation**\r\n\r\nI have a JSON describing the COCO image database and it is formatted as follows (irrelevant elements truncated as `...`).\r\n\r\n```\r\n{\r\n  &quot;info&quot;: {\r\n    &quot;description&quot;: &quot;COCO 2017 Dataset&quot;,\r\n    ...\r\n  },\r\n  &quot;licenses&quot;: [\r\n    {\r\n      &quot;url&quot;: &quot;http://creativecommons.org/licenses/by-nc-sa/2.0/&quot;,\r\n      ...\r\n    },\r\n    ...\r\n  ],\r\n  &quot;images&quot;: [\r\n    {\r\n      &quot;license&quot;: 4,\r\n      ...\r\n    },\r\n  &quot;annotations&quot;: [\r\n    {\r\n      &quot;segmentation&quot;: [\r\n        [\r\n          510.66,\r\n          ...\r\n        ]\r\n      ],\r\n      &quot;area&quot;: 702.1057499999998,\r\n      &quot;iscrowd&quot;: 0,\r\n      &quot;image_id&quot;: 289343,\r\n      &quot;bbox&quot;: [\r\n        473.07,\r\n        395.93,\r\n        38.65,\r\n        28.67\r\n      ],\r\n      &quot;category_id&quot;: 18,\r\n      &quot;id&quot;: 1768\r\n    },\r\n  &quot;categories&quot;: [\r\n    {\r\n      &quot;supercategory&quot;: &quot;person&quot;,\r\n      ...\r\n    },\r\n  ]\r\n}\r\n```\r\n\r\nI need to filter `annotations` where `category_id` has one of several values, for example `1, 2`.\r\n\r\nI can successfully filter such `category_id`s with \r\n\r\n```\r\njq -C &#39; .annotations[] | select( .category_id == 1 or .category_id == 2 ) &#39; instances_val2017.json | less -R\r\n```\r\n\r\nHowever, what is returned are only the annotations element of the total JSON as below.\r\n\r\n```\r\n{\r\n  &quot;segmentation&quot;: [\r\n    [\r\n      162.72,\r\n      ...\r\n    ]\r\n  ],\r\n  &quot;area&quot;: 426.9120499999995,\r\n  &quot;iscrowd&quot;: 0,\r\n  &quot;image_id&quot;: 45596,\r\n  &quot;bbox&quot;: [\r\n    161.52,\r\n    507.18,\r\n    46.45,\r\n    19.16\r\n  ],\r\n  &quot;category_id&quot;: 2,\r\n  &quot;id&quot;: 124742\r\n}\r\n{\r\n...\r\n{\r\n```\r\n\r\nI know it&#39;s possible to return these elements as an array by wrapping the expression in `[]` but how can I return the entire original JSON after filtering the specified category ids? \r\n",
        "link": "https://stackoverflow.com/questions/62839937/jq-to-filter-inner-array-elements-but-return-the-whole-json",
        "title": "jq to filter inner array elements but return the whole JSON"
    },
    {
        "tags": [
            "json",
            "iteration",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1594433808,
                "last_edit_date": 1594433808,
                "creation_date": 1594424416,
                "answer_id": 62843674,
                "question_id": 62842963,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your input already has the array you want, so your jq program can be as simple as:\r\n```\r\n{subcategories: .category.subcategory }\r\n```\r\nor, if you only want to retain the &quot;id&quot; and &quot;val&quot; keys:\r\n```\r\n{subcategories: .category.subcategory | map({id,val}) }\r\n```\r\nIf (and/or when) you choose to use iteration, make sure you don&#39;t have too many iterators.\r\n",
                "title": "Iterating over a array and getting multiple values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1594507759,
        "creation_date": 1594419010,
        "last_edit_date": 1594507759,
        "question_id": 62842963,
        "body_markdown": "I have a json file with the following structure:\r\n```\r\n{\r\n\t&quot;category&quot;: \r\n\t{\r\n\t\t&quot;subcategory&quot;: \r\n\t\t\t[\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;id&quot;: &quot;1&quot;, \r\n\t\t\t\t\t&quot;val&quot;: &quot;blue&quot;,\r\n\t\t\t\t\t&quot;foo&quot;: &quot;blahblah&quot;, \r\n\t\t\t\t\t&quot;bar&quot;: &quot;blahblah&quot;\r\n\r\n\t\t\t\t},\r\n\t\t\t\t{\t\r\n\t\t\t\t\t&quot;id&quot;: &quot;2&quot;, \r\n\t\t\t\t\t&quot;val&quot;: &quot;red&quot;\r\n\t\t\t\t\t&quot;foo&quot;: &quot;blahblah&quot;, \r\n\t\t\t\t\t&quot;bar&quot;: &quot;blahblah&quot;\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t}\r\n}\r\n```\r\n I want to transform it to is:\r\n\r\n```\r\n{\t\r\n\tsubcategories\r\n\t[\r\n\t\t{&quot;id&quot;: &quot;1&quot;,&quot;val&quot;: &quot;blue&quot;}\r\n\t\t{&quot;id&quot;: &quot;2&quot;,&quot;val&quot;: &quot;red&quot;}\r\n\t]\r\n\r\n}\r\n```\r\nThe closest I have been able to get it is with \r\n```\r\ncat input.json | jq -c &#39;.[] | \\\r\n    {id: .category.subcategory[].id, \\\r\n    value: .category.subcategory[].val}&#39; \\\r\n    &gt; output.json\r\n```\r\nIt doesn&#39;t works, but it&#39;s close:\r\n1. I don&#39;t have the ``` subcategories``` node.\r\n2. The ```id``` is always the first value - IOW, ```1```\r\n\r\nAny help would be awesome!\r\n\r\nthanks!!!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/62842963/iterating-over-a-array-and-getting-multiple-values",
        "title": "Iterating over a array and getting multiple values"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1594621839,
                "post_id": 62870293,
                "comment_id": 111177779,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1594621921,
                "post_id": 62870293,
                "comment_id": 111177801,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1594673905,
                "creation_date": 1594673905,
                "answer_id": 62884150,
                "question_id": 62870293,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an approach which starts by filtering out `.users` which do not meet your criteria:\r\n```\r\n.users |= map(select(\r\n  (.first == &quot;Stevie&quot;) and (.last == &quot;Wonder&quot;)\r\n))\r\n```\r\nif you [Try it online!](https://tio.run/##dczBCoJAEAbg@z7FsCcXRDMrKPAFgk4dOkSHTSfaMq3dLQjz2bdx0S4hDAPz/8x3eTgXPQ1qA58MbvIeGCwxtwEDCKKT0sZClgHfWnwp5AJkVVBRyj7f1VWBmgsmhHMNPXGP8RXs6QBo/KbYUxQPUjgUHdXlvfTLj0rbcyHfXTdJYppkOZtzX7fhCL5R@Vli@a@vZX41dTXCp/E0JX6R9jztA2vZFw &quot;jq – Try It Online&quot;) you will observe it simplifies your data to just\r\n```\r\n{\r\n  &quot;users&quot;: [\r\n    {\r\n      &quot;first&quot;: &quot;Stevie&quot;,\r\n      &quot;last&quot;: &quot;Wonder&quot;,\r\n      &quot;birthday&quot;: &quot;01/01/1945&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nThen you can add more filters if you want particular elements (e.g. .birthday):\r\n```\r\n  .users |= map(select(\r\n    (.first == &quot;Stevie&quot;) and (.last == &quot;Wonder&quot;)\r\n  ))\r\n| .users[].birthday\r\n```\r\nto obtain\r\n[Try it online!](https://tio.run/##dcxBC4IwGMbx@z7Fy04ORDMrKPALBJ06dBAPSxeuTGtbQZiffb0u7RLCeGH/B37nu7XBQwul4Z3Ald88LSqRG48AeMFJKm0gSYDujXhKQRnwusCh4kM/NHUhFGWEMfKGr5RmwVEqUxb8ZW2LEHWZbiDFD0DrLmbHYx51fxx6vu@D/usj22@zKMQXrRdL6ubOn8B3Mi@5qP71Lc8vuqkn@Dicx8iv4oHHm5GOfAA &quot;jq – Try It Online&quot;)\r\n```\r\n&quot;01/01/1945&quot;\r\n```\r\n\r\nThis may seem needlessly redundant but may be easier if you are experimenting without precise requirements.",
                "title": "Extract the jq record only when match the first and last name"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1594673905,
        "creation_date": 1594621601,
        "last_edit_date": 1594622722,
        "question_id": 62870293,
        "body_markdown": "I can get the first and birthday, \r\n\r\n```\r\n{\r\n  &quot;users&quot;: [\r\n    {\r\n      &quot;first&quot;: &quot;Stevie&quot;,\r\n      &quot;last&quot;: &quot;Wonder&quot;,\r\n      &quot;birthday&quot;: &quot;01/01/1945&quot;\r\n    },\r\n    {\r\n      &quot;first&quot;: &quot;Michael&quot;,\r\n      &quot;last&quot;: &quot;Jackson&quot;,\r\n      &quot;birthday&quot;: &quot;03/23/1963&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nSo with this jq command, I can get the record:\r\n\r\n\r\n```\r\n$ cat a.json |jq &#39;.users[] | .first + &quot; &quot; + .last + &quot; &quot; + .birthday&#39;\r\n&quot;Stevie Wonder 01/01/1945&quot;\r\n&quot;Michael Jackson 03/23/1963&quot;\r\n```\r\n\r\nAnd I am close to the answer to match the first name\r\n\r\n```\r\n$ cat a.json |jq &#39;.users[] | select(.first==&quot;Stevie&quot;) | .birthday &#39;\r\n&quot;01/01/1945&quot;\r\n```\r\n\r\nBut how to get the output which matched both first and last name?",
        "link": "https://stackoverflow.com/questions/62870293/extract-the-jq-record-only-when-match-the-first-and-last-name",
        "title": "Extract the jq record only when match the first and last name"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1594630511,
                "post_id": 62871446,
                "comment_id": 111181536,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17834753,
                    "reputation": 11,
                    "user_id": 13920989,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/784cd42b2ec65102e2975d20f8cfa0fa?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ferrari456",
                    "link": "https://stackoverflow.com/users/13920989/ferrari456"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1594637945,
                "post_id": 62871446,
                "comment_id": 111184951,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594645284,
                "post_id": 62871446,
                "comment_id": 111188732,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1594673062,
                "creation_date": 1594673062,
                "answer_id": 62883968,
                "question_id": 62871446,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution which uses [update assignment |=](https://stedolan.github.io/jq/manual/#Update-assignment:|=), [map](https://stedolan.github.io/jq/manual/#map\\(x\\),map_values\\(x\\)) and [select](https://stedolan.github.io/jq/manual/#select\\(boolean_expression\\)) to update `.data`.\r\nNote it avoids an undesirable cartesian product if multiple `.matchers` meet the criteria by using [any](https://stedolan.github.io/jq/manual/#any,any\\(condition\\),any\\(generator;condition\\)).\r\n\r\n```\r\n.data |= map(select(\r\n  (.matchers | any(.value==&quot;dev-stack&quot;)) and (.status.state==&quot;active&quot;)\r\n))\r\n```\r\n\r\n[Try it online!](https://tio.run/##rVHLbsIwELznKyyfEgmivEwaSxzaT2g5teJg7KVNS9IQOwgEfHtqOw2BtqIXLsl6Z2Y93nlft60vmGLoMEUFq1wJK@DKRa5fMMXfoJYHVu5cf8NWDaDpFGEBm7FUjH9gz0OsFJqqj6qR9tdxGFf5BrCHPK9t9w7CHQNTXTWcg5R4pLvmYt17cRBCe/NBCOfCsBYE0uUdEYZm272bno4GicVLVoAdb52NzhDr3ECD8XM4l4/wCltNUHUDPXDsinl/vdbVSt4rMycKomAcpOMwngUpDVMaT55PPqEUP2nE0ghNkoHWVPrtIP4cSCjJ/EkSTzINxIOG12A0DzujYVU@AJ9FAaUd9ZSvoOSAz3x3ez/tyrbsPr5DcoYHH0e/kwiXgrFkQW6ZxJrdNohgFsY0zGgYXQ3C0qKAEuKTMEjjLMmy/yK5rrl1JLCt8hrERSamctDcOX4B &quot;jq – Try It Online&quot;)",
                "title": "Conditional select using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1594673062,
        "creation_date": 1594626768,
        "last_edit_date": 1594630495,
        "question_id": 62871446,
        "body_markdown": "I have this below json format, I want to take the list of &quot;id&quot; which satisfies the condition \r\n\r\nin this below I want to take the **id** which has matchers.value as **dev-stack**  and status.state as **active**\r\n\r\n ```\r\n{\r\n  &quot;status&quot;: &quot;success&quot;,\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;b5e7f85d&quot;,\r\n      &quot;matchers&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;stack&quot;,\r\n          &quot;value&quot;: &quot;dev-stack&quot;,\r\n          &quot;isRegex&quot;: true\r\n        }\r\n      ],\r\n      &quot;startsAt&quot;: &quot;2020-07-13T07:17:36Z&quot;,\r\n      &quot;endsAt&quot;: &quot;2020-07-15T07:15:44Z&quot;,\r\n      &quot;updatedAt&quot;: &quot;2020-07-13T07:15:59.643692023Z&quot;,\r\n      &quot;createdBy&quot;: &quot;api&quot;,\r\n      &quot;comment&quot;: &quot;Silence&quot;,\r\n      &quot;status&quot;: {\r\n        &quot;state&quot;: &quot;active&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;1fdaa4b5&quot;,\r\n      &quot;matchers&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;stack&quot;,\r\n          &quot;value&quot;: &quot;qa-stack&quot;,\r\n          &quot;isRegex&quot;: true\r\n        }\r\n      ],\r\n      &quot;startsAt&quot;: &quot;2020-07-10T13:19:12Z&quot;,\r\n      &quot;endsAt&quot;: &quot;2020-07-10T13:20:55.510739499Z&quot;,\r\n      &quot;updatedAt&quot;: &quot;2020-07-10T13:20:55.510739499Z&quot;,\r\n      &quot;createdBy&quot;: &quot;api&quot;,\r\n      &quot;comment&quot;: &quot;Silence&quot;,\r\n      &quot;status&quot;: {\r\n        &quot;state&quot;: &quot;expired&quot;\r\n      }\r\n    }    \r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/62871446/conditional-select-using-jq",
        "title": "Conditional select using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594643299,
                "post_id": 62875625,
                "comment_id": 111187662,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18027076,
                    "reputation": 33,
                    "user_id": 13102734,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3895141eac9ce1b9647c28d744f97566?s=256&d=identicon&r=PG",
                    "display_name": "greiginsydney",
                    "link": "https://stackoverflow.com/users/13102734/greiginsydney"
                },
                "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": 1594672381,
                "post_id": 62875625,
                "comment_id": 111202137,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1594713487,
                "last_edit_date": 1594713487,
                "creation_date": 1594642991,
                "answer_id": 62875768,
                "question_id": 62875625,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "That&#39;s a good attempt. The key here is to use the `select()` function to identify the object you are going to update and overwrite the overall array using `|=` operator, i.e.\r\n\r\n    .platforms |= ( map(select(.name == &quot;CBus&quot;).accessories += [{ &quot;values&quot; : &quot;NEW&quot; }]  ) )\r\n\r\nFor the snippet in your jq-play link (now removed), you need to do\r\n\r\n    .gcp_price_list.&quot;CP-COMPUTEENGINE-OS&quot; \r\n        |= with_entries(select(.value.cores == &quot;shared&quot;).value.cores = &quot;0.5&quot;)\r\n\r\nOr if you want to be even more specific, and keep the entry in `gcp_price_list` configurable, do\r\n\r\n    .gcp_price_list |= \r\n    with_entries ( \r\n      select(.key == &quot;CP-COMPUTEENGINE-OS&quot;).value  |=  \r\n    with_entries(\r\n      select(.value.cores == &quot;shared&quot;).value.cores = &quot;0.5&quot;) )",
                "title": "Add values to a JSON array if outer array&#39;s name == &#39;something&#39;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1594713487,
        "creation_date": 1594642432,
        "last_edit_date": 1594672347,
        "question_id": 62875625,
        "body_markdown": "I&#39;m passing a JSON object to jq and want to add extra objects to an inner array (&#39;accessories&#39;) if its parent array (&#39;platforms&#39;) matches a certain name.\r\n\r\nHere&#39;s my source JSON:\r\n```\r\n    {\r\n        &quot;bridge&quot;: {\r\n            &quot;name&quot;: &quot;Homebridge&quot;,\r\n            &quot;port&quot;: 51395\r\n        },\r\n        &quot;accessories&quot;: [],\r\n        \r\n        &quot;platforms&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;Config&quot;,\r\n                &quot;port&quot;: 8581,\r\n                &quot;platform&quot;: &quot;config&quot;\r\n            },\r\n            {\r\n                &quot;platform&quot;: &quot;homebridge-cbus.CBus&quot;,\r\n                &quot;name&quot;: &quot;CBus&quot;,\r\n                &quot;client_ip_address&quot;: &quot;127.0.0.1&quot;,\r\n                &quot;accessories&quot;: [\r\n                    {\r\n                      &quot;values&quot;: &quot;existing&quot;\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    } \r\n\r\n```\r\n\r\nThis works beautifully:\r\n\r\n```\r\n    jq &#39;.platforms[1].accessories +=  [{ &quot;values&quot; : &quot;NEW&quot; }]&#39;\r\n```\r\n\r\n... but of course it&#39;s poor form to expect platforms[1] to always the be array I want to append to, so I set about trying to form the right syntax for a search or if/then/else to only act on the .name of the appropriate one.\r\n\r\nI thought this was my solution:\r\n```\r\n    jq &#39;.platforms[] | if ( .name==&quot;CBus&quot; ) then .accessories += [{ &quot;values&quot; : &quot;NEW&quot; }] else . end&#39;\r\n```\r\n\r\n... until I realised it was only passing the &#39;platforms&#39; through and eating the &#39;bridge&#39; object and empty outer &#39;accessories&#39; array, which I need to retain.\r\n\r\nMy issue looks to be similar to https://stackoverflow.com/questions/47774666/jq-updating-array-element-selected-by-select, but I&#39;ve tried LOTS of combinations but just can&#39;t break through.\r\n\r\nEdit: Here&#39;s the *correct* JQPlay I&#39;ve been working with:\r\n\r\nhttps://jqplay.org/s/dGDswqAEte\r\n\r\nThanks for any help.\r\n",
        "link": "https://stackoverflow.com/questions/62875625/add-values-to-a-json-array-if-outer-arrays-name-something",
        "title": "Add values to a JSON array if outer array&#39;s name == &#39;something&#39;"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1594726287,
                "last_edit_date": 1594726287,
                "creation_date": 1594724759,
                "answer_id": 62893765,
                "question_id": 62893671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your idea was right, but you missed the selecting the object desired inside `with_entries()`, hence your delete operation was attempted on _all_ the objects in your JSON. \r\n\r\nSince the `parents` record is an array type and not an object , the `del` function throws out an error that its not able to index the array with the given name. You need to do\r\n\r\n    with_entries( select(.key == &quot;modules&quot;).value |= del(.b) )\r\n\r\nThe `select()` function filters that object keyed by name `&quot;modules&quot;` and applies the delete action on that object alone.\r\n\r\n&lt;sup&gt;[jq-play snippet](https://jqplay.org/s/X6vgw8aPd3)&lt;/sup&gt;",
                "title": "JQ: remove nested key and keep other main array key intact"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1594726287,
        "creation_date": 1594724453,
        "question_id": 62893671,
        "body_markdown": "I have a json file looking like this:\r\n\r\n```\r\n{\r\n  &quot;parents&quot;: [{\r\n    // array of objects\r\n  }],\r\n  &quot;modules&quot;: {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: 2\r\n  }\r\n}\r\n```\r\n\r\nI want to remove they key `b` of the object modules. \r\n\r\nI am running this command: `jq &quot;with_entries(.value |= del(.b))&quot;`\r\n\r\nBut this fails when the `parents` array is present. I get \r\n\r\n&gt; Cannot index array with string &quot;b&quot;\r\n\r\nHow can I make the command ignore the parents array and only work on the modules object?",
        "link": "https://stackoverflow.com/questions/62893671/jq-remove-nested-key-and-keep-other-main-array-key-intact",
        "title": "JQ: remove nested key and keep other main array key intact"
    },
    {
        "tags": [
            "json",
            "grep",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1594785572,
                "last_edit_date": 1594785572,
                "creation_date": 1594784239,
                "answer_id": 62907224,
                "question_id": 62907100,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do it all with jq:\r\n\r\n```sh\r\njq -r &#39;.results[] | select(.status == 200).url&#39;\r\n```\r\n\r\nreturns the `url` field for all array element where `status` is `200`.\r\n",
                "title": "Extract value from JSON based on another value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1594787903,
        "creation_date": 1594783366,
        "last_edit_date": 1594787903,
        "question_id": 62907100,
        "body_markdown": "I have a result as shown below in json format. I parsed the respective text file using jq.\r\n\r\n```cat file.txt | jq```\r\n\r\nResults\r\n```\r\n{\r\n  &quot;results&quot;: [\r\n    {\r\n      &quot;input&quot;: {\r\n        &quot;FUZZ&quot;: &quot;fuzzerhere&quot;\r\n      },\r\n      &quot;position&quot;: 53,\r\n      &quot;status&quot;: 403,\r\n      &quot;length&quot;: 670,\r\n      &quot;words&quot;: 105,\r\n      &quot;lines&quot;: 9,\r\n      &quot;redirectlocation&quot;: &quot;&quot;,\r\n      &quot;resultfile&quot;: &quot;&quot;,\r\n      &quot;url&quot;: &quot;https://www.example.com/fuzzerhere&quot;,\r\n      &quot;host&quot;: &quot;www.example.com&quot;\r\n    },\r\n    {\r\n      &quot;input&quot;: {\r\n        &quot;FUZZ&quot;: &quot;newfuzz&quot;\r\n      },\r\n      &quot;position&quot;: 53,\r\n      &quot;status&quot;: 200,\r\n      &quot;length&quot;: 670,\r\n      &quot;words&quot;: 105,\r\n      &quot;lines&quot;: 9,\r\n      &quot;redirectlocation&quot;: &quot;&quot;,\r\n      &quot;resultfile&quot;: &quot;&quot;,\r\n      &quot;url&quot;: &quot;https://www.example.com/newfuzz&quot;,\r\n      &quot;host&quot;: &quot;www.example.com&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nRequirement: I want to grep or extract from the output satisfying a condition. &lt;br&gt;\r\nCondition: status == 200 &lt;br&gt;\r\nOutput: The respective output should contain all urls which has a status 200, considering the below example, the output has to be \r\n```https://www.example.com/newfuzz```\r\n\r\nI tried using grep \r\n```cat file.txt | jq | grep &#39;&quot;status&quot;: 403&#39;```\r\n\r\nThe above command gave me the line status only , then I realised extracting from an array of objects in json is different.",
        "link": "https://stackoverflow.com/questions/62907100/extract-value-from-json-based-on-another-value",
        "title": "Extract value from JSON based on another value"
    },
    {
        "tags": [
            "json",
            "split",
            "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": 1594804987,
                "post_id": 62911272,
                "comment_id": 111252214,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9025803,
                    "reputation": 527,
                    "user_id": 6800122,
                    "user_type": "registered",
                    "accept_rate": 58,
                    "profile_image": "https://www.gravatar.com/avatar/f75282cc7bda14095fb7c3f9299f83c0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "herhuf",
                    "link": "https://stackoverflow.com/users/6800122/herhuf"
                },
                "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": 1594805960,
                "post_id": 62911272,
                "comment_id": 111252787,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1594819717,
                "post_id": 62911272,
                "comment_id": 111260170,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1594806443,
                "creation_date": 1594806443,
                "answer_id": 62912100,
                "question_id": 62911272,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An alternate version using `split()` on the `\\n` and trimming string `- ` on the left, would be to do\r\n\r\n    .[].stuff.properties.stuff_list[].description |= \r\n      if . != null then \r\n        split(&quot;\\n&quot;) | map(ltrimstr(&quot;- &quot;)) \r\n      else \r\n        . \r\n      end\r\n\r\n&lt;sup&gt;[jqplay - Demo](https://jqplay.org/s/DSsu9Q1ASQ)&lt;/sup&gt;\r\n",
                "title": "Split a string and trim a known prefix from each part in a complex JSON structure"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1594806443,
        "creation_date": 1594803668,
        "last_edit_date": 1594806207,
        "question_id": 62911272,
        "body_markdown": "I&#39;m dealing with a fairly complex JSON-structure in which a single entry needs to be edited in several places. For example:\r\n\r\n```json\r\n[\r\n\t{\r\n\t\t&quot;name&quot;: &quot;test 1&quot;,\r\n\t\t&quot;stuff&quot;: {\r\n\t\t\t&quot;properties&quot;: {\r\n\t\t\t\t&quot;id&quot;: 0,\r\n\t\t\t\t&quot;stuff_list&quot;: [\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;entryId&quot;: 1,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;- item 1\\n- item 2\\n- item 3&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;entryId&quot;: 2,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;- item 1\\n- item 2\\n- item 3&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t}\r\n\t},\r\n\t{\r\n\t\t&quot;name&quot;: &quot;test 2&quot;,\r\n\t\t&quot;stuff&quot;: {\r\n\t\t\t&quot;properties&quot;: {\r\n\t\t\t\t&quot;id&quot;: 1,\r\n\t\t\t\t&quot;stuff_list&quot;: [\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;entryId&quot;: 1,\r\n\t\t\t\t\t\t&quot;description&quot;: null\r\n\t\t\t\t\t},\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\t&quot;entryId&quot;: 2,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;- item 1\\n- item 2\\n- item 3&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n]\r\n```\r\n\r\nHere I would like to edit each `&quot;description&quot;`-element: The string needs to be split at each `\\n` and the substrings `&quot;^\\n?-\\s&quot;` of each resulting array element need to be removed. So it should result in:\r\n\r\n```json\r\n{\r\n\t&quot;entryId&quot;: 1,\r\n\t&quot;description&quot;: [&quot;item 1&quot;, &quot;item 2&quot;, &quot;item 3&quot;]\r\n}\r\n```\r\n\r\n\r\n\r\nMy first approach is:\r\n\r\n```bash\r\njq &#39;.[].stuff.properties.stuff_list[].description | split(&quot;\\n&quot;)&#39; the_file.json\r\n```\r\n\r\nbut that&#39;s not working in the first place becaue of the `null` values that can occur at some places. So now I wonder: how can I achieve what I want?",
        "link": "https://stackoverflow.com/questions/62911272/split-a-string-and-trim-a-known-prefix-from-each-part-in-a-complex-json-structur",
        "title": "Split a string and trim a known prefix from each part in a complex JSON structure"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1594811233,
                "post_id": 62913414,
                "comment_id": 111255626,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6173257,
                    "reputation": 713,
                    "user_id": 8552543,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IcebT.gif?s=256",
                    "display_name": "23w4ertfgyhj",
                    "link": "https://stackoverflow.com/users/8552543/23w4ertfgyhj"
                },
                "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": 1594811521,
                "post_id": 62913414,
                "comment_id": 111255772,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1594811889,
                "creation_date": 1594811889,
                "answer_id": 62913671,
                "question_id": 62913414,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    aws --region &lt;region&gt; cloudtrail lookup-events --lookup-attributes AttributeKey=EventName,AttributeValue=ConsoleLogin --max-items 1 --output json | \\\r\n    jq -r .Events[].CloudTrailEvent | \\\r\n    jq &#39;.userIdentity.userName, .eventTime, .awsRegion, .sourceIPAddress, .responseElements.ConsoleLogin, .eventID&#39;",
                "title": "Get multiple fields from aws cloudtrail json using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1594811889,
        "creation_date": 1594810908,
        "question_id": 62913414,
        "body_markdown": "I need to extract some fields from below json. This is from aws cloudtrail, and I&#39;m having a really hard time figuring this out.\r\n\r\nThe fields I need are:\r\n\r\n    userIdentity.userName\r\n    eventTime\r\n    awsRegion\r\n    sourceIPAddress\r\n    responseElements.ConsoleLogin\r\n    eventID\r\n\r\n\r\nJSON\r\n\r\n    {\r\n      &quot;eventVersion&quot;: &quot;x.xx&quot;,\r\n      &quot;userIdentity&quot;: {\r\n        &quot;type&quot;: &quot;xxxxxxxxxx&quot;,\r\n        &quot;principalId&quot;: &quot;xxxxxxxxxx&quot;,\r\n        &quot;arn&quot;: &quot;xxxxxxxxxx&quot;,\r\n        &quot;accountId&quot;: &quot;xxxxxxxxxx&quot;,\r\n        &quot;userName&quot;: &quot;xxxxxxxxxx&quot;\r\n      },\r\n      &quot;eventTime&quot;: &quot;2020-07-15T08:50:35Z&quot;,\r\n      &quot;eventSource&quot;: &quot;signin.amazonaws.com&quot;,\r\n      &quot;eventName&quot;: &quot;ConsoleLogin&quot;,\r\n      &quot;awsRegion&quot;: &quot;xxxxxxxxxx&quot;,\r\n      &quot;sourceIPAddress&quot;: &quot;xxxxxxxxxx&quot;,\r\n      &quot;userAgent&quot;: &quot;xxxxxxxxxx&quot;,\r\n      &quot;requestParameters&quot;: null,\r\n      &quot;responseElements&quot;: {\r\n        &quot;ConsoleLogin&quot;: &quot;Success&quot;\r\n      },\r\n      &quot;additionalEventData&quot;: {\r\n        &quot;LoginTo&quot;: &quot;xxxxxxxxxx&quot;,\r\n        &quot;MobileVersion&quot;: &quot;xxxxxxxxxx&quot;,\r\n        &quot;MFAUsed&quot;: &quot;xxxxxxxxxx&quot;\r\n      },\r\n      &quot;eventID&quot;: &quot;xxxxxxxxxx&quot;,\r\n      &quot;eventType&quot;: &quot;xxxxxxxxxx&quot;,\r\n      &quot;recipientAccountId&quot;: &quot;xxxxxxxxxx&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/62913414/get-multiple-fields-from-aws-cloudtrail-json-using-jq",
        "title": "Get multiple fields from aws cloudtrail json using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1594842240,
                "creation_date": 1594842240,
                "answer_id": 62922674,
                "question_id": 62921945,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try:\r\n\r\n    .report.api_http[]|{name:values[0][&quot;name&quot;],api:values[1]}\r\n\r\nMy output is:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;lookproduct1&quot;,\r\n      &quot;api&quot;: &quot;http://testapi.api.com&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;lookproduct2&quot;,\r\n      &quot;api&quot;: &quot;http://testapi2.api.com&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;lookproduct3&quot;,\r\n      &quot;api&quot;: &quot;http://testapi3.api.com&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;lookproduct4&quot;,\r\n      &quot;api&quot;: &quot;http://testapi.api.com&quot;\r\n    }\r\n\r\n",
                "title": "Use jq extract two values and build new output"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1594842328,
                "creation_date": 1594842328,
                "answer_id": 62922691,
                "question_id": 62921945,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the -c command-line option in conjunction with the following jq filter:\r\n```\r\n.report.api_http[]\r\n| {name: .[0].name, api: .[1]}\r\n```\r\n",
                "title": "Use jq extract two values and build new output"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1594843200,
        "creation_date": 1594839340,
        "question_id": 62921945,
        "body_markdown": "Looking to extract values from api_http array. I am looking for output that looks like the following. Each element should have the name and the url value attached a key called api.\r\n\r\n    { &quot;name&quot;: &quot;lookproduct1&quot;, &quot;api&quot;: &quot;http://testapi.api.com&quot;}\r\n    { &quot;name&quot;: &quot;lookproduct2&quot;, &quot;api&quot;: &quot;http://testapi2.api.com&quot;}\r\n    { &quot;name&quot;: &quot;lookproduct3&quot;, &quot;api&quot;: &quot;http://testapi3.api.com&quot;}\r\n    { &quot;name&quot;: &quot;lookproduct4&quot;, &quot;api&quot;: &quot;http://testapi4.api.com&quot;}\r\n\r\n**the JSON data:**\r\n\r\n\r\n\r\n    {\r\n        &quot;meta&quot;: {\r\n          &quot;details&quot;: {\r\n            &quot;value&quot;: &quot;Details&quot;\r\n          },\r\n          &quot;network&quot;: {\r\n            &quot;label&quot;: &quot;Network:&quot;,\r\n            &quot;value&quot;: &quot;test&quot;\r\n          },\r\n          &quot;title&quot;: {\r\n            &quot;value&quot;: &quot;Test Report&quot;\r\n          },\r\n          &quot;update&quot;: {\r\n            &quot;label&quot;: &quot;Validation last update:&quot;,\r\n            &quot;value&quot;: &quot;2020-07-15 17:40 UTC&quot;\r\n          }\r\n        },\r\n        &quot;report&quot;: {\r\n          &quot;api_http&quot;: [\r\n            [\r\n              {\r\n                &quot;html_name&quot;: &quot;Product 1&quot;,\r\n                &quot;name&quot;: &quot;lookproduct1&quot;,\r\n                &quot;rank&quot;: 3\r\n              },\r\n              &quot;http://testapi.api.com&quot;,\r\n              &quot;GB&quot;,\r\n              &quot;TEST&quot;\r\n            ],\r\n            [\r\n                {\r\n                  &quot;html_name&quot;: &quot;Product 2&quot;,\r\n                  &quot;name&quot;: &quot;lookproduct2&quot;,\r\n                  &quot;rank&quot;: 3\r\n                },\r\n                &quot;http://testapi2.api.com&quot;,\r\n                &quot;GB&quot;,\r\n                &quot;TEST&quot;\r\n              ],\r\n              [\r\n                {\r\n                  &quot;html_name&quot;: &quot;Product 3&quot;,\r\n                  &quot;name&quot;: &quot;lookproduct3&quot;,\r\n                  &quot;rank&quot;: 3\r\n                },\r\n                &quot;http://testapi3.api.com&quot;,\r\n                &quot;GB&quot;,\r\n                &quot;TEST&quot;\r\n              ],\r\n              [\r\n                {\r\n                  &quot;html_name&quot;: &quot;Product 4&quot;,\r\n                  &quot;name&quot;: &quot;lookproduct4&quot;,\r\n                  &quot;rank&quot;: 3\r\n                },\r\n                &quot;http://testapi.api.com&quot;,\r\n                &quot;GB&quot;,\r\n                &quot;TEST&quot;\r\n              ]\r\n          ]\r\n        }\r\n     }\r\n\r\n  \r\n\r\nI got the following, but unsure to extract those final two values and create the new output.\r\n\r\n    .report[] | .[] \r\n\r\n",
        "link": "https://stackoverflow.com/questions/62921945/use-jq-extract-two-values-and-build-new-output",
        "title": "Use jq extract two values and build new output"
    },
    {
        "tags": [
            "python",
            "json",
            "ubuntu",
            "base64",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594879746,
                "post_id": 62928437,
                "comment_id": 111282145,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10922723,
                    "reputation": 41,
                    "user_id": 11625565,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/NWema.jpg?s=256",
                    "display_name": "Hugo Z&#225;rate",
                    "link": "https://stackoverflow.com/users/11625565/hugo-z%c3%a1rate"
                },
                "reply_to_user": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594880207,
                "post_id": 62928437,
                "comment_id": 111282305,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594880668,
                "post_id": 62928437,
                "comment_id": 111282473,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1594880117,
                "last_edit_date": 1594880117,
                "creation_date": 1594879756,
                "answer_id": 62928541,
                "question_id": 62928437,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a way to do that in Python: \r\n\r\n    import base64\r\n    import json\r\n    with open(&quot;sample_data.json&quot;) as f: \r\n        text = f.read()\r\n        d = json.loads(text)\r\n        data = base64.b64decode(d[&quot;data&quot;])\r\n\r\nThe variable `data` now contains the decoded content of the relevant item in the json file. \r\n\r\n",
                "title": "How can I decode a json File using base64 decode?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1594880247,
                "creation_date": 1594880247,
                "answer_id": 62928644,
                "question_id": 62928437,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Considering that you have loaded the json data into an object. You can then try the following: \r\n\r\n    import json\r\n    import base64\r\n\r\n    json_obj = {\r\n        &quot;equno&quot;: &quot;229151246954324320&quot;,\r\n        &quot;data&quot;: &quot;CdwL703m6njjyJ7tdEXdRoYKKv49oatv9UWvdLONpWgd407fakXNfbt18j+qKb/toYgHZvj34ig7iu4XN7BfrqTf/wNsIdVNJ67cH9hCyIfULWLgyT01vQ7u5zS5vSB9hazXTQHRYGxpV+eCrVFMEdxHId54sJDn+KL8hea93WyQKlFwMDO0QQD5X2lK02Y88uI7MehBUFXzK5jNTgKmLtUE9KoM4xF6bEzm2oNMrxz0QwOB4b/tvRvhThb/r+Wgb32gV3UBZBZ/RP4ID+lc7JE7TLVRyeGCNA+uV11/no358XZdGo/E5Aq7KZ95W+rQ8TE3/PLbodAhWZ+1wAcXvfuxJxpIm0giOZv3Dys/pZesM5wbdwaNrFnD+ngHfXB67IxiBM3oRRxC7CBHoFvQFjC8g2E3dk1ELP6VPex24lPJY1JeBwuy8DQroN7rxa4bwLAE6Z3SyL16dpwYdMmAB2YN2h4nMGfl1TMXPGsJKxcSv4tBLj905WTGYgDKG3sQ0AR4YHoPKni7/rUZQb/hM25wXFKYNRzGU6EIleCTP4fl1vqASLFUHDS0GqjwcYkCOilvDbb3PqNqDzPEI84L7XDidiWQ8XKfzw7ryjuIaw1b1ODqN3+ctnny88WXTzANzwA5wjqfhDJDGpHr58fQgi1/j2QIsFBt+VoOslxvx1YQvbubDTwM7dTEwWDY0U5+l8KvSv9fYIMbNYxjwXU3tR2SFhClumNjisUE0lHgCBAfkbTA5Fw9eW3+QRZdB5rY/7DWgxlRnBORZ54c5xxTnsk2ntFm14zQA8HN7zv09FQW+sMk6B767cyzi5HoEkf+PjnNh78OrIPVOFtigMYUb5PdDWDzjDCu2+9dN4mm5aml+/SIOFDUHg6aX+GLj7c0tI0thMFAR6dKP6QtmVbUanF7gSt+L2c4qRq48s3QYMlrTr++PqeoCYNuhWIo2iXllvzERarLDU/pxZNfGB39bFmjmiAnLwmDqNZuVTi40/A38AI+r4f39Y/eywskz/rco1CZGUXxd0FJj0pwdO9H0eedwVgXAmi3KYy3j5MZBWeObqs/ufvRpHjDeh54Bq91DrxcKPya/b6FGDxH73jIgB9Y9x/mbZq2h20H9fbbV+hTk8XIA5ItY+2N9J7FHiJ+NyQbl4UNZT/GVF4HS+NXplgzEAEIlzgRwrNoY0GJzeocxZlAa5f5ANu7OHltqpSTAZ0PzVCopG1NgwaQEpS08mVAtgXo7jq34VejdNuHiTo+/ht3Dn+C+WzKXHZIABkhHjGg1Bv4hJHuLXIpQjIE0xwQo2UcTmcAYvrGO6FcHZz+eRUmJyrtsJczwZK7nimfgJ6T/iuggPVwyn9pifU9VA==&quot;\r\n    }\r\n    \r\n    print(base64.b64decode(json_obj[&quot;data&quot;]))",
                "title": "How can I decode a json File using base64 decode?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1594890793,
                "creation_date": 1594890793,
                "answer_id": 62931339,
                "question_id": 62928437,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the string in .data were a valid base64 encoding of a UTF-8 string, the following would be equivalent:\r\n\r\n    jq -r .data input.json | base64 -D\r\n\r\nand\r\n\r\n    jq -r &#39;.data|@base64d&#39; input.json\r\n\r\nAs it happens, with the given JSON, `base64` shows there is a problem:\r\n\r\n    $ jq -r .data input.json | base64 -D\r\n    Invalid character in input stream.\r\n",
                "title": "How can I decode a json File using base64 decode?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1594890793,
        "creation_date": 1594879272,
        "last_edit_date": 1594879572,
        "question_id": 62928437,
        "body_markdown": "I have a json file and I have to extract only the value of the key &quot;data&quot; and decode the base64-encoded.\r\n\r\nThis is the json file\r\n\r\n    {\r\n    \t&quot;equno&quot;: &quot;229151246954324320&quot;,\r\n    \t&quot;data&quot;:\t&quot;CdwL703m6njjyJ7tdEXdRoYKKv49oatv9UWvdLONpWgd407fakXNfbt18j+qKb/toYgHZvj34ig7iu4XN7BfrqTf/wNsIdVNJ67cH9hCyIfULWLgyT01vQ7u5zS5vSB9hazXTQHRYGxpV+eCrVFMEdxHId54sJDn+KL8hea93WyQKlFwMDO0QQD5X2lK02Y88uI7MehBUFXzK5jNTgKmLtUE9KoM4xF6bEzm2oNMrxz0QwOB4b/tvRvhThb/r+Wgb32gV3UBZBZ/RP4ID+lc7JE7TLVRyeGCNA+uV11/no358XZdGo/E5Aq7KZ95W+rQ8TE3/PLbodAhWZ+1wAcXvfuxJxpIm0giOZv3Dys/pZesM5wbdwaNrFnD+ngHfXB67IxiBM3oRRxC7CBHoFvQFjC8g2E3dk1ELP6VPex24lPJY1JeBwuy8DQroN7rxa4bwLAE6Z3SyL16dpwYdMmAB2YN2h4nMGfl1TMXPGsJKxcSv4tBLj905WTGYgDKG3sQ0AR4YHoPKni7/rUZQb/hM25wXFKYNRzGU6EIleCTP4fl1vqASLFUHDS0GqjwcYkCOilvDbb3PqNqDzPEI84L7XDidiWQ8XKfzw7ryjuIaw1b1ODqN3+ctnny88WXTzANzwA5wjqfhDJDGpHr58fQgi1/j2QIsFBt+VoOslxvx1YQvbubDTwM7dTEwWDY0U5+l8KvSv9fYIMbNYxjwXU3tR2SFhClumNjisUE0lHgCBAfkbTA5Fw9eW3+QRZdB5rY/7DWgxlRnBORZ54c5xxTnsk2ntFm14zQA8HN7zv09FQW+sMk6B767cyzi5HoEkf+PjnNh78OrIPVOFtigMYUb5PdDWDzjDCu2+9dN4mm5aml+/SIOFDUHg6aX+GLj7c0tI0thMFAR6dKP6QtmVbUanF7gSt+L2c4qRq48s3QYMlrTr++PqeoCYNuhWIo2iXllvzERarLDU/pxZNfGB39bFmjmiAnLwmDqNZuVTi40/A38AI+r4f39Y/eywskz/rco1CZGUXxd0FJj0pwdO9H0eedwVgXAmi3KYy3j5MZBWeObqs/ufvRpHjDeh54Bq91DrxcKPya/b6FGDxH73jIgB9Y9x/mbZq2h20H9fbbV+hTk8XIA5ItY+2N9J7FHiJ+NyQbl4UNZT/GVF4HS+NXplgzEAEIlzgRwrNoY0GJzeocxZlAa5f5ANu7OHltqpSTAZ0PzVCopG1NgwaQEpS08mVAtgXo7jq34VejdNuHiTo+/ht3Dn+C+WzKXHZIABkhHjGg1Bv4hJHuLXIpQjIE0xwQo2UcTmcAYvrGO6FcHZz+eRUmJyrtsJczwZK7nimfgJ6T/iuggPVwyn9pifU9VA==&quot;\r\n    }\r\n\r\nI tried using jq\r\n\r\n     jq -r &#39;.[].data&#39; &lt; test.json | base64 --decode\r\nBut I got this error:\r\n\r\n    jq: error (at &lt;stdin&gt;:3): Cannot index string with string &quot;data&quot;\r\n\r\nI have no idea how to resolve this error. I also tried using python but I couldn&#39;t decode it.\r\nHelp me, please!",
        "link": "https://stackoverflow.com/questions/62928437/how-can-i-decode-a-json-file-using-base64-decode",
        "title": "How can I decode a json File using base64 decode?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1594901550,
                "post_id": 62933806,
                "comment_id": 111292948,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1594899594,
                "creation_date": 1594899594,
                "answer_id": 62933899,
                "question_id": 62933806,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can pass variables/arguments to `jq` using:\r\n\r\n    jq -r --arg first $1\r\n\r\n\r\n - **$1** being your variable (which you can do: `_fileContents=&quot;$( cat step-a.txt )&quot;` )\r\n - **first** is the variable name you want to create (which you can use inside the `jq` command like a bash variable ( `$_fileContents` );\r\n\r\nAn example from one of my scripts:\r\n\r\n    export techUser=$(jq -r --arg first $1 &#39;.Environment[].Servers[] | select (.Address | contains($first)) | .&quot;Technical User&quot;&#39; $serverlist)\r\n\r\nI hope this has helped you finding a way to make it work ;)",
                "title": "Is it possible to dynamically inject text file contents to JSON array objects using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1594905762,
                "last_edit_date": 1594905762,
                "creation_date": 1594904392,
                "answer_id": 62935310,
                "question_id": 62933806,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `input_filename` to achieve the goal very simply and efficiently.\r\n\r\nFor example, with the following in program.jq\r\n```\r\n# program.jq\r\n(reduce inputs as $step ( {}; .[input_filename | rtrimstr(&quot;.txt&quot;)] = $step )) as $dict\r\n| $a\r\n| map(. + {message: $dict[.name] })\r\n```\r\n\r\nthe following invocation would yield the expected result:\r\n```\r\njq -n -f program.jq --argfile a array.json step-*.txt\r\n```\r\n## An alternative\r\n\r\nDepending on your requirements, you might like to replace the last line of program.jq as given above by:\r\n\r\n    | map(.message = ($dict[.name] // .message))\r\n\r\n## Alternatives to `--argfile`\r\nIf you prefer not to use `--argfile`, feel free to use `--argjson` or even `--slurpfile`, with appropriate adjustments to the above.",
                "title": "Is it possible to dynamically inject text file contents to JSON array objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1594905762,
        "creation_date": 1594899239,
        "last_edit_date": 1594904255,
        "question_id": 62933806,
        "body_markdown": "## Summary\r\nStarting from a JSON array, I&#39;d like to replace an attribute of each item by the contents of a text file.\r\n\r\n**Example:**\r\n\r\nWe have this initial JSON array:\r\n\r\n```javascript\r\n[ \r\n    { &quot;name&quot;: &quot;step-a&quot;, &quot;message&quot;: &quot;step-a message placeholder&quot; },\r\n    { &quot;name&quot;: &quot;step-b&quot;, &quot;message&quot;: &quot;step-b message placeholder&quot; }\r\n]\r\n```\r\n\r\nAnd two text files matching the `name` attribute values (with an added `.txt`):\r\n```\r\n.\r\n├── step-a.txt  # contains the text: &quot;Step A error logs ...&quot;\r\n└── step-b.txt  # contains the text: &quot;Step B error logs ...&quot;\r\n```\r\n\r\nThe goal is to perform the replacement and end up with this JSON array:\r\n```javascript\r\n[ \r\n    { &quot;name&quot;: &quot;step-a&quot;, &quot;message&quot;: &quot;Step A error logs ...&quot; },\r\n    { &quot;name&quot;: &quot;step-b&quot;, &quot;message&quot;: &quot;Step B error logs ...&quot; }\r\n]\r\n```\r\n&lt;br&gt;\r\n\r\n## Attempt\r\n\r\nI tried something like this:\r\n\r\n```bash\r\n# the variable $INITIAL contains the initial JSON array\r\necho $INITIAL | jq -c &#39;.[] | .message = &quot;$(cat .displayName+&quot;.txt&quot;)&quot;&#39;\r\n```\r\n\r\nIs there a way to perform an operation like this with `jq` or is using extra bash logic necessary?\r\nThank you.",
        "link": "https://stackoverflow.com/questions/62933806/is-it-possible-to-dynamically-inject-text-file-contents-to-json-array-objects-us",
        "title": "Is it possible to dynamically inject text file contents to JSON array objects using jq"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "precision",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10929,
                    "reputation": 565808,
                    "user_id": 20860,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/iavmP.jpg?s=256",
                    "display_name": "Bill Karwin",
                    "link": "https://stackoverflow.com/users/20860/bill-karwin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594915668,
                "post_id": 62938833,
                "comment_id": 111300933,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6942471,
                    "reputation": 5575,
                    "user_id": 5328289,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/f7a945aec5e093f2db54b8dec251ad8b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "M.E.",
                    "link": "https://stackoverflow.com/users/5328289/m-e"
                },
                "reply_to_user": {
                    "account_id": 10929,
                    "reputation": 565808,
                    "user_id": 20860,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/iavmP.jpg?s=256",
                    "display_name": "Bill Karwin",
                    "link": "https://stackoverflow.com/users/20860/bill-karwin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594915792,
                "post_id": 62938833,
                "comment_id": 111301002,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1594915904,
                "creation_date": 1594915904,
                "answer_id": 62938966,
                "question_id": 62938833,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution:\r\n\r\n    jq -r &#39;.ticks[] | [.b, .a, .t] | join(&quot;,&quot;)&#39; test2\r\n    \r\n    1.14105,1.14106,1594771200000\r\n    1.14105,1.14106,1594771201000\r\n    1.14103,1.14104,1594771202000\r\n    1.141,1.1413,1594771203000\r\n    1.14103,1.14104,1594771205000\r\n    1.14094,1.14095,1594778803000\r\n\r\nIt doesn&#39;t do the padding to 5 digits. I have no idea how to do that in `jq`. I still think another language would be easier.",
                "title": "How do I extract a JSON list into a CSV in command line using JQ?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1594964137,
                "last_edit_date": 1594964137,
                "creation_date": 1594923402,
                "answer_id": 62941119,
                "question_id": 62938833,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can very well write your own padding function for this. First extract the number of digits following the decimal digit and decide on the padding digits accordingly.\r\n\r\nYou can put together a script, name it `script.jq` and do below. Note that the logic below will _not_ work for numbers in scientific notation.\r\n\r\n\r\n    #!/usr/bin/jq -f\r\n    \r\n    def pad($len): \r\n      tostring | \r\n      match(&quot;^([0-9]*).([0-9]+)$&quot;).captures[1].length as $dec |\r\n      ($len - $dec) as $l  |\r\n      . + (&quot;0&quot; * ($l)) [:$l];\r\n    \r\n    .ticks[] | [ (.b|pad(5)), (.a|pad(5)), .t ] | join(&quot;,&quot;)\r\n\r\nand call it with the `jq` executable\r\n\r\n    jq -r -f script.jq json\r\n\r\nwhich now produces a properly padded output\r\n\r\n    1.14105,1.14106,1594771200000\r\n    1.14105,1.14106,1594771201000\r\n    1.14103,1.14104,1594771202000\r\n    1.14100,1.14130,1594771203000\r\n    1.14103,1.14104,1594771205000\r\n    1.14094,1.14095,1594778803000\r\n\r\nNote: The `pad($len)` is inspired from [pkoppstein&#39;s comment][1] from [stedolan/jq - pad function #2033][2]\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/2033#issuecomment-586083471\r\n  [2]: https://github.com/stedolan/jq/issues/2033",
                "title": "How do I extract a JSON list into a CSV in command line using JQ?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1594924869,
                "creation_date": 1594924869,
                "answer_id": 62941504,
                "question_id": 62938833,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an idiomatic jq-only solution to the problem, understood to require that the number of digits to the right of a decimal point, if present, be as specified.  The -r command-line option should be used.\r\n```\r\n# format numbers whose tostring representation has a decimal point\r\n# so that the number of digits to the right of the decimal point is $dd\r\n# assuming $dd &gt;= 0\r\ndef format($dd):\r\n  def rpad: (. + $dd * &quot;0&quot;) | .[:$dd];\r\n  tostring\r\n  | index(&quot;.&quot;) as $dec\r\n  | if $dec then .[0:$dec+1] + (.[$dec+1:]|rpad)\r\n    else .\r\n    end ;\r\n\r\n.ticks[]\r\n| [(.b | format(1)), (.a | format(5)), .t ]\r\n| join(&quot;,&quot;)\r\n```",
                "title": "How do I extract a JSON list into a CSV in command line using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1594964137,
        "creation_date": 1594915466,
        "last_edit_date": 1594927765,
        "question_id": 62938833,
        "body_markdown": "I have the following JSON data:\r\n\r\n    % cat test2 \r\n\r\n    {&quot;day&quot;:&quot;2020-07-15&quot;,&quot;map&quot;:\r\n    {&quot;a&quot;:&quot;ask&quot;,&quot;b&quot;:&quot;bid&quot;,&quot;t&quot;:&quot;timestamp&quot;},&quot;msLatency&quot;:52,&quot;pair&quot;:&quot;EUR/USD&quot;,&quot;status&quot;:&quot;success&quot;,&quot;ticks&quot;:[\r\n    {&quot;b&quot;:1.14105,&quot;a&quot;:1.14106,&quot;x&quot;:48,&quot;t&quot;:1594771200000},\r\n    {&quot;b&quot;:1.14105,&quot;a&quot;:1.14106,&quot;x&quot;:48,&quot;t&quot;:1594771201000},\r\n    {&quot;b&quot;:1.14103,&quot;a&quot;:1.14104,&quot;x&quot;:48,&quot;t&quot;:1594771202000},\r\n    {&quot;b&quot;:1.141,&quot;a&quot;:1.1413,&quot;x&quot;:48,&quot;t&quot;:1594771203000},\r\n    {&quot;b&quot;:1.14103,&quot;a&quot;:1.14104,&quot;x&quot;:48,&quot;t&quot;:1594771205000},\r\n    {&quot;b&quot;:1.14094,&quot;a&quot;:1.14095,&quot;x&quot;:48,&quot;t&quot;:1594778803000}],&quot;type&quot;:&quot;forex&quot;}\r\n\r\nAnd I want to get:\r\n\r\n    1.14105,1.14106,1594771200000\r\n    1.14105,1.14106,1594771201000\r\n    1.14103,1.14104,1594771202000\r\n    1.141,1.1413,1594771203000\r\n    1.14103,1.14104,1594771205000\r\n    1.14094,1.14095,1594778803000\r\n\r\nIdeally the output shall also pad with zeros, with 1 and 5 being parameters to specify that the first two columns are numbers with 1 natural place and 5 decimal places (although this step can be done easily with `awk`):\r\n\r\n    1.14105,1.14106,1594771200000\r\n    1.14105,1.14106,1594771201000\r\n    1.14103,1.14104,1594771202000\r\n    1.14100,1.14130,1594771203000\r\n    1.14103,1.14104,1594771205000\r\n    1.14094,1.14095,1594778803000\r\n\r\nI have tried this with JQ:\r\n\r\n     % cat test2 | jq &#39;.ticks&#39;\r\n    [\r\n      {\r\n        &quot;b&quot;: 1.14105,\r\n        &quot;a&quot;: 1.14106,\r\n        &quot;x&quot;: 48,\r\n        &quot;t&quot;: 1594771200000\r\n      },\r\n      {\r\n        &quot;b&quot;: 1.14105,\r\n        &quot;a&quot;: 1.14106,\r\n        &quot;x&quot;: 48,\r\n        &quot;t&quot;: 1594771201000\r\n      },\r\n      {\r\n        &quot;b&quot;: 1.14103,\r\n        &quot;a&quot;: 1.14104,\r\n        &quot;x&quot;: 48,\r\n        &quot;t&quot;: 1594771202000\r\n      },\r\n      {\r\n        &quot;b&quot;: 1.141,\r\n        &quot;a&quot;: 1.1413,\r\n        &quot;x&quot;: 48,\r\n        &quot;t&quot;: 1594771203000\r\n      },\r\n      {\r\n        &quot;b&quot;: 1.14103,\r\n        &quot;a&quot;: 1.14104,\r\n        &quot;x&quot;: 48,\r\n        &quot;t&quot;: 1594771205000\r\n      },\r\n      {\r\n        &quot;b&quot;: 1.14094,\r\n        &quot;a&quot;: 1.14095,\r\n        &quot;x&quot;: 48,\r\n        &quot;t&quot;: 1594778803000\r\n      }\r\n    ]\r\n\r\nBut I am stuck on how to turn this into a CSV.\r\n\r\nEDIT:\r\nJust as reference, I previously had the following parsing, using JQ here is much simpler option:\r\n\r\n    cat test2 |\r\n    sed -e &#39;s/{\\&quot;/#{\\&quot;/g&#39; |\r\n    tr &#39;#&#39; &#39;\\n&#39; |\r\n    grep -v &quot;timestamp&quot; |\r\n    grep -v &quot;day&quot; |\r\n    sed &#39;/^[[:space:]]*$/d&#39; |\r\n    sed &#39;s/].*$//g&#39; |\r\n    sed &#39;s/{//g&#39; |\r\n    sed &#39;s/},//g&#39; |\r\n    sed &#39;s/}//g&#39; |\r\n    sed &#39;s/\\&quot;//g&#39; |\r\n    awk -F &#39;[:,]&#39; -v decimal_places=5 -v integer_places=1 &#39;{\r\n            for(i=1; i&lt;=NF; i=i+2) {\r\n                    value[$i]=$(i+1);\r\n            };\r\n            format_price=&quot;%0&quot; integer_places &quot;.&quot; decimal_places &quot;f&quot;\r\n            format=format_price &quot; &quot; format_price &quot; %d\\n&quot;\r\n            printf(format,value[&quot;b&quot;],value[&quot;a&quot;],value[&quot;t&quot;]);\r\n    }&#39;\r\n",
        "link": "https://stackoverflow.com/questions/62938833/how-do-i-extract-a-json-list-into-a-csv-in-command-line-using-jq",
        "title": "How do I extract a JSON list into a CSV in command line using JQ?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2310808,
                    "reputation": 27,
                    "user_id": 7958715,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6aa334676af63223879518a2b660ba72?s=256&d=identicon&r=PG",
                    "display_name": "Diego Lima",
                    "link": "https://stackoverflow.com/users/7958715/diego-lima"
                },
                "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": 1594924915,
                "post_id": 62941158,
                "comment_id": 111305411,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1594925630,
                "last_edit_date": 1594925630,
                "creation_date": 1594923902,
                "answer_id": 62941258,
                "question_id": 62941158,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your idea was right, but by virtue of using `+` on the object at first index, you lost the objects at other indices. You need to use the append operator `+=`\r\n\r\nIf its the &quot;first&quot; object to be added, use the object designator `.[0]` to add the records of your choice.\r\n\r\nAlso using a shell variable with double quotes is not a right way to import JSON shell content to your `jq` program. Use the `--argjson` option to import directly\r\n\r\n    jq --argjson new &#39;{ &quot;newProperty&quot;:&quot;new_value&quot;, &quot;anotherNewProperty&quot;:&quot;another_new_value&quot; }&#39; \\\r\n        &#39;.[0].properties.hardwareProfile += $new&#39; json\r\n\r\nor with a variable wrapping the JSON content under single quotes\r\n\r\n    VM_SIZE_INFO=&#39;{ &quot;newProperty&quot;:&quot;new_value&quot;, &quot;anotherNewProperty&quot;:&quot;another_new_value&quot; }&#39;\r\n\r\nand doing\r\n\r\n    jq --argjson new &quot;$VM_SIZE_INFO&quot; &#39;.[0].properties.hardwareProfile += $new&#39; json\r\n\r\n",
                "title": "Add records to an array element at a specific index using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1594925630,
        "creation_date": 1594923537,
        "last_edit_date": 1594925338,
        "question_id": 62941158,
        "body_markdown": "I&#39;m trying to add values to a specific key inside a specific array element using jq. I have the following JSON:\r\n```\r\n[\r\n   {\r\n      &quot;name&quot;:&quot;element1&quot;,\r\n      &quot;properties&quot;:{\r\n         &quot;hardwareProfile&quot;:{\r\n            &quot;vmSize&quot;:&quot;vm_size&quot;\r\n         }\r\n      }\r\n   },\r\n   {\r\n      &quot;name&quot;:&quot;element2&quot;,\r\n      &quot;properties&quot;:{\r\n         &quot;hardwareProfile&quot;:{\r\n            &quot;vmSize&quot;:&quot;vm_size&quot;\r\n         }\r\n      }\r\n   }\r\n]\r\n```\r\n\r\nAnd I&#39;d like to add information to the `properties.hardwareProfile` key inside the first element so it becomes:\r\n```\r\n[\r\n   {\r\n      &quot;name&quot;:&quot;element1&quot;,\r\n      &quot;properties&quot;:{\r\n         &quot;hardwareProfile&quot;:{\r\n            &quot;vmSize&quot;:&quot;vm_size&quot;,\r\n            &quot;newProperty&quot;:&quot;new_value&quot;,\r\n            &quot;anotherNewProperty&quot;:&quot;another_new_value&quot;\r\n         }\r\n      }\r\n   },\r\n   {\r\n      &quot;name&quot;:&quot;element2&quot;,\r\n      &quot;properties&quot;:{\r\n         &quot;hardwareProfile&quot;:{\r\n            &quot;vmSize&quot;:&quot;vm_size&quot;\r\n         }\r\n      }\r\n   }\r\n]\r\n```\r\n\r\nI&#39;ve had limited success adding the information doing this:\r\n```\r\n$ VM_SIZE_INFO=&quot;{newProperty:\\&quot;new_value\\&quot;, anotherNewProperty:\\&quot;another_new_value\\&quot;}&quot;\r\n\r\n$ jq &quot;[.[0].properties.hardwareProfile + $VM_SIZE_INFO]&quot; resources.json\r\n[\r\n  {\r\n    &quot;vmSize&quot;: &quot;Standard_B8ms&quot;,\r\n    &quot;newProperty&quot;: &quot;new_value&quot;,\r\n    &quot;anotherNewProperty&quot;: &quot;another_new_value&quot;\r\n  }\r\n]\r\n```\r\nBut this doesn&#39;t really work for me since I need the full json on the output.\r\n\r\nHow can I do this? Thanks!",
        "link": "https://stackoverflow.com/questions/62941158/add-records-to-an-array-element-at-a-specific-index-using-jq",
        "title": "Add records to an array element at a specific index using jq"
    },
    {
        "tags": [
            "bash",
            "jenkins",
            "awk",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1594932705,
                "post_id": 62943209,
                "comment_id": 111308597,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 262968,
                    "reputation": 789094,
                    "user_id": 548225,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/dab08478b226280d4a30894c9a7ed719?s=256&d=identicon&r=PG",
                    "display_name": "anubhava",
                    "link": "https://stackoverflow.com/users/548225/anubhava"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1594932762,
                "post_id": 62943209,
                "comment_id": 111308622,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1594932875,
                "post_id": 62943209,
                "comment_id": 111308662,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8657192,
                    "reputation": 473,
                    "user_id": 6481062,
                    "user_type": "registered",
                    "accept_rate": 29,
                    "profile_image": "https://www.gravatar.com/avatar/bb7b0edf2794bf21cfc37b8d0836b9ce?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user6481062",
                    "link": "https://stackoverflow.com/users/6481062/user6481062"
                },
                "reply_to_user": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594933378,
                "post_id": 62943209,
                "comment_id": 111308852,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "reply_to_user": {
                    "account_id": 262968,
                    "reputation": 789094,
                    "user_id": 548225,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/dab08478b226280d4a30894c9a7ed719?s=256&d=identicon&r=PG",
                    "display_name": "anubhava",
                    "link": "https://stackoverflow.com/users/548225/anubhava"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594933493,
                "post_id": 62943209,
                "comment_id": 111308892,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8657192,
                    "reputation": 473,
                    "user_id": 6481062,
                    "user_type": "registered",
                    "accept_rate": 29,
                    "profile_image": "https://www.gravatar.com/avatar/bb7b0edf2794bf21cfc37b8d0836b9ce?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user6481062",
                    "link": "https://stackoverflow.com/users/6481062/user6481062"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594933517,
                "post_id": 62943209,
                "comment_id": 111308899,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594933575,
                "post_id": 62943209,
                "comment_id": 111308924,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594933827,
                "post_id": 62943209,
                "comment_id": 111309034,
                "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": 1594933917,
                "post_id": 62943209,
                "comment_id": 111309062,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8657192,
                    "reputation": 473,
                    "user_id": 6481062,
                    "user_type": "registered",
                    "accept_rate": 29,
                    "profile_image": "https://www.gravatar.com/avatar/bb7b0edf2794bf21cfc37b8d0836b9ce?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user6481062",
                    "link": "https://stackoverflow.com/users/6481062/user6481062"
                },
                "reply_to_user": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594936705,
                "post_id": 62943209,
                "comment_id": 111310037,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594938154,
                "post_id": 62943209,
                "comment_id": 111310461,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594938303,
                "post_id": 62943209,
                "comment_id": 111310505,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8657192,
                    "reputation": 473,
                    "user_id": 6481062,
                    "user_type": "registered",
                    "accept_rate": 29,
                    "profile_image": "https://www.gravatar.com/avatar/bb7b0edf2794bf21cfc37b8d0836b9ce?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user6481062",
                    "link": "https://stackoverflow.com/users/6481062/user6481062"
                },
                "reply_to_user": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594938490,
                "post_id": 62943209,
                "comment_id": 111310557,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594938547,
                "post_id": 62943209,
                "comment_id": 111310569,
                "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": 1594942605,
                "post_id": 62943209,
                "comment_id": 111311582,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1594943196,
                "creation_date": 1594943196,
                "answer_id": 62945094,
                "question_id": 62943209,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. It would appear that you should be using `read -r`.\r\n\r\n2. It also appears that it would be much simpler if you focused on using curl and jq to extract the information, without any grep or tr invocation and without any shell looping.  Assuming you can arrange for the output of `curl` to be valid JSON(*), a single invocation of jq along the following lines should do the job:\r\n```\r\njq -c &#39;.allBuilds[] | .fullDisplayName | gsub(&quot;&#187;&quot;;&quot;&quot;)&#39;\r\n```\r\n\r\n(*) To check whether the output of `curl` is valid, you can pipe the output of your `curl` command into `jq empty`:\r\n\r\n    curl ... | jq empty",
                "title": "Bash get value of matching substring in a long string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1594943196,
        "creation_date": 1594932278,
        "last_edit_date": 1594935891,
        "question_id": 62943209,
        "body_markdown": "I&#39;m working on a bash script and having hard time extracting value from a matching substring.\r\nI cannot share curl command as it has sensitive information but updating i value(1)(updated to mimic real value) that I&#39;m having problem with. jq gives parse error\r\n\r\n\r\n    curl -s -g &quot;$line&quot; | jq -c &#39;.allBuilds[]&#39; | while read i; do\r\n       job_name=$(echo &quot;$i&quot; | jq .fullDisplayName | tr -d &#39;&#187;&#39; | tr -s &quot; &quot; | sed &#39;s/ /,/g&#39; | tr -d &#39;&quot;&#39;)\r\n    done\r\n\r\nexpected output\r\n```Hello,Java,World,master,#47```\r\n    \r\nI get expected output on most of the i values but some error out \r\n    \r\nBelow are sample i values. \r\n\r\n\r\n1\r\n```    \r\n{&quot;_class&quot;:&quot;org.jenkinsci.plugins.workflow.job.WorkflowRun&quot;,&quot;actions&quot;:[{&quot;_class&quot;:&quot;hudson.model.CauseAction&quot;},{},{&quot;_class&quot;:&quot;hudson.model.ParametersAction&quot;,&quot;parameters&quot;:[{&quot;_class&quot;:&quot;hudson.model.StringParameterValue&quot;,&quot;name&quot;:&quot;environment&quot;,&quot;value&quot;:&quot;DE&quot;},{&quot;_class&quot;:&quot;hudson.model.BooleanParameterValue&quot;,&quot;name&quot;:&quot;update&quot;,&quot;value&quot;:false},{&quot;_class&quot;:&quot;hudson.model.BooleanParameterValue&quot;,&quot;name&quot;:&quot;black&quot;,&quot;value&quot;:false},{&quot;_class&quot;:&quot;hudson.model.StringParameterValue&quot;,&quot;name&quot;:&quot;description&quot;,&quot;value&quot;:&quot;DE&quot;},{&quot;_class&quot;:&quot;hudson.model.StringParameterValue&quot;,&quot;name&quot;:&quot;number&quot;,&quot;value&quot;:&quot;&quot;},{&quot;_class&quot;:&quot;hudson.model.StringParameterValue&quot;,&quot;name&quot;:&quot;config&quot;,&quot;value&quot;:&quot;{ &quot;E&quot;: &quot;DE&quot;, &quot;Exp&quot;: &quot;1111&quot;, &quot;Pr&quot;: &quot;D&quot;, &quot;Man&quot;: { &quot;Se&quot;: &quot;arn:aws:secretsmanager:region:111111111111:secret:DE/A/Se-B8SKMz&quot;, &quot;OR&quot;: &quot;arn:aws:secretsmanager:region:111111111111:secret:DE/A/OR-kvJ2lJ&quot;, &quot;AR&quot;: &quot;arn:aws:secretsmanager:region:111111111111:secret:A/DE/SA/rds&quot;, &quot;User&quot;: &quot;arn:aws:secretsmanager:region:111111111111:secret:DE/A/mUixbWY&quot;, &quot;sales&quot;: &quot;arn:aws:secretsmanager:region:111111111111:secret:DE/A/saELY&quot;, &quot;vau&quot;: &quot;arn:aws:secretsmanager:region:111111111111:secret:DE/A/vNRR7BO&quot;, &quot;sc&quot;: &quot;&quot;, &quot;exAd&quot;: &quot;arn:aws:secretsmanager:region:111111111111:secret:BA/A/ExyBoYL&quot;, &quot;exp&quot;: &quot;arn:aws:secretsmanager:region:111111111111:secret:BA/A/Exl67GE&quot;, &quot;sec&quot;: &quot;arn:aws:secretsmanager:region:111111111111:secret:DE/A/Secle06a&quot;, &quot;Secu&quot;: &quot;arn:aws:secretsmanager:region:111111111111:secret:DE/A/Seia&quot; }, &quot;s3&quot;: { &quot;buckets&quot;: { &quot;hello&quot;: { &quot;name&quot;: &quot;helloDEBA&quot;, &quot;region&quot;: &quot;region&quot;, &quot;account&quot;: &quot;111111111111&quot; }, &quot;mlt&quot;: { &quot;name&quot;: &quot;sacdhbd&quot;, &quot;region&quot;: &quot;region&quot;, &quot;account&quot;: &quot;111111111111&quot; }, &quot;devo&quot;: { &quot;name&quot;:&quot;devvvvv&quot;, &quot;region&quot;: &quot;region&quot;, &quot;account&quot;: &quot;5555555&quot; } } }, &quot;roles&quot;: { &quot;lam&quot;: &quot;arn:aws:iam::111111111111:role/lam&quot;, &quot;lambd&quot;: &quot;arn:aws:iam::111111111111:role/lambd&quot;, &quot;la&quot;: &quot;arn:aws:iam::111111111111:role/lam&quot;, &quot;la&quot;: &quot;arn:aws:iam::111111111111:role/la&quot;, &quot;la&quot;: &quot;arn:aws:iam::111111111111:role/la&quot;,&quot;lasds&quot;: &quot;arn:aws:iam::111111111111:role/lafgg&quot;, &quot;lafdg&quot;: &quot;arn:aws:iam::111111111111:role/dfsdv&quot;, &quot;acc&quot;: &quot;arn:aws:iam::111111111111:role/acc&quot; }, &quot;vpc&quot;: { &quot;subnets&quot;: { &quot;private&quot;: { &quot;1a&quot;: &quot;subnet-111111&quot;, &quot;1b&quot;: &quot;subnet-22222&quot;, &quot;1c&quot;: &quot;subnet-33333&quot; } }, &quot;securityGroupIds&quot;: { &quot;lambda&quot;: &quot;sg-1111&quot; }, &quot;endpoints&quot;: { &quot;e&quot;: &quot;&quot; }, &quot;links&quot;: { &quot;b&quot;: &quot;&quot; } }, &quot;securi&quot;: { &quot;level&quot;: &quot;FAILURE&quot;, &quot;s&quot;: true }, &quot;log&quot;: &quot;debug&quot;, &quot;se&quot;: &quot;hello.com&quot;, &quot;sa&quot;: { &quot;env&quot;: &quot;--DE&quot; }, &quot;lam&quot;: { &quot;sss&quot;: { &quot;environment&quot;: { &quot;variables&quot;: { &quot;test&quot;: &quot;hello.com&quot;, &quot;PhoneNumber&quot;: &quot;11111&quot; } } } } }&quot;},{&quot;_class&quot;:&quot;hudson.model.BooleanParameterValue&quot;,&quot;name&quot;:&quot;scan&quot;,&quot;value&quot;:false},{&quot;_class&quot;:&quot;hudson.model.BooleanParameterValue&quot;,&quot;name&quot;:&quot;ch&quot;,&quot;value&quot;:false}]},{&quot;_class&quot;:&quot;jenkins.scm.A.SCMRevisionAction&quot;},{},{&quot;_class&quot;:&quot;hudson.plugins.git.util.BuildData&quot;},{&quot;_class&quot;:&quot;hudson.plugins.git.GitTagAction&quot;},{},{},{},{&quot;_class&quot;:&quot;org.jenkinsci.plugins.workflow.cps.EnvActionImpl&quot;},{&quot;_class&quot;:&quot;hudson.plugins.git.util.BuildData&quot;},{},{},{},{},{},{&quot;_class&quot;:&quot;org.jenkinsci.plugins.pipeline.modeldefinition.actions.RestartDeclarativePipelineAction&quot;},{},{&quot;_class&quot;:&quot;org.jenkinsci.plugins.workflow.job.views.FlowGraphAction&quot;},{},{},{},{}],&quot;fullDisplayName&quot;:&quot;Hello &#187; Java &#187; World &#187; master #25&quot;,&quot;id&quot;:&quot;25&quot;,&quot;number&quot;:25,&quot;timestamp&quot;:1575582153372}\r\n```\r\n2\r\n```\r\n{&quot;_class&quot;:&quot;org.jenkinsci.plugins.workflow.job.WorkflowRun&quot;,&quot;actions&quot;:[{&quot;_class&quot;:&quot;hudson.model.CauseAction&quot;},{&quot;_class&quot;:&quot;hudson.model.ParametersAction&quot;,&quot;parameters&quot;:[{&quot;_class&quot;:&quot;hudson.model.BooleanParameterValue&quot;,&quot;name&quot;:&quot;helo-world&quot;,&quot;value&quot;:false},{&quot;_class&quot;:&quot;hudson.model.StringParameterValue&quot;,&quot;name&quot;:&quot;environment&quot;,&quot;value&quot;:&quot;hello&quot;},{&quot;_class&quot;:&quot;hudson.model.StringParameterValue&quot;,&quot;name&quot;:&quot;config&quot;,&quot;value&quot;:&quot;&quot;},{&quot;_class&quot;:&quot;hudson.model.StringParameterValue&quot;,&quot;name&quot;:&quot;description&quot;,&quot;value&quot;:&quot;&quot;},{&quot;_class&quot;:&quot;hudson.model.BooleanParameterValue&quot;,&quot;name&quot;:&quot;hello&quot;,&quot;value&quot;:false},{&quot;_class&quot;:&quot;hudson.model.BooleanParameterValue&quot;,&quot;name&quot;:&quot;hello2&quot;,&quot;value&quot;:false},{&quot;_class&quot;:&quot;hudson.model.BooleanParameterValue&quot;,&quot;name&quot;:&quot;scan&quot;,&quot;value&quot;:false},{&quot;_class&quot;:&quot;hudson.model.StringParameterValue&quot;,&quot;name&quot;:&quot;hello3&quot;,&quot;value&quot;:&quot;&quot;}]},{&quot;_class&quot;:&quot;jenkins.scm.api.SCMRevisionAction&quot;},{},{&quot;_class&quot;:&quot;hudson.plugins.git.util.BuildData&quot;},{&quot;_class&quot;:&quot;hudson.plugins.git.GitTagAction&quot;},{},{},{},{&quot;_class&quot;:&quot;org.jenkinsci.plugins.workflow.cps.EnvActionImpl&quot;},{&quot;_class&quot;:&quot;hudson.plugins.git.util.BuildData&quot;},{},{},{},{},{},{&quot;_class&quot;:&quot;org.jenkinsci.plugins.pipeline.modeldefinition.actions.RestartDeclarativePipelineAction&quot;},{},{&quot;_class&quot;:&quot;org.jenkinsci.plugins.workflow.job.views.FlowGraphAction&quot;},{},{},{},{}],&quot;fullDisplayName&quot;:&quot;Hello&#187;Java&#187;World&#187;master#21&quot;,&quot;id&quot;:&quot;21&quot;,&quot;number&quot;:21,&quot;timestamp&quot;:1574705384077}\r\n```\r\nI&#39;m trying to extract fullDisplayName value and I have tried some options like\r\n\r\n    printf &#39;%s\\n&#39; &quot;$i&quot; | grep fullDisplayName\r\n\r\nprintf &#39;%s\\n&#39; &lt;insert i value here&gt; gives output in new lines when tried in shell but in script its different behavior \r\n\r\n```\r\n{}\r\n{}\r\n{}]\r\nfullDisplayName:Hello &#187; Java &#187; World &#187; master #25\r\nid:25\r\nnumber:25\r\ntimestamp:1575582153372\r\n```",
        "link": "https://stackoverflow.com/questions/62943209/bash-get-value-of-matching-substring-in-a-long-string",
        "title": "Bash get value of matching substring in a long string"
    },
    {
        "tags": [
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1594970753,
                "last_edit_date": 1594970753,
                "creation_date": 1594959531,
                "answer_id": 62947055,
                "question_id": 62946697,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I was able to resolve that ..\r\n------------------\r\n\r\n```\r\n TASK_ID=$(aws ecs list-tasks --cluster $CLUSTER_NAME |  jq .taskArns[0])\r\n```\r\nand then\r\n```\r\necho &quot;Task ID is $TASK_ID&quot;\r\n```",
                "title": "AWS CLI and jq : Error when fetching Task ID using ecs list-tasks"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1594971005,
                "creation_date": 1594971005,
                "answer_id": 62949183,
                "question_id": 62946697,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do this with `aws-cli` query parameter then one should use `jq`?\r\n\r\n```\r\naws ecs list-tasks --cluster demo --region us-west-2 --query &quot;taskArns&quot; --output text\r\n\r\n```",
                "title": "AWS CLI and jq : Error when fetching Task ID using ecs list-tasks"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1594971005,
        "creation_date": 1594957144,
        "question_id": 62946697,
        "body_markdown": "I&#39;m trying to fetch the Task ID from the list-tasks response using jq, and am running into an error. \r\n\r\n```\r\n\r\n[Container] 2020/07/17 02:20:27 Running command aws ecs list-tasks --cluster $CLUSTER_NAME\r\n{\r\n    &quot;taskArns&quot;: [\r\n        &quot;arn:aws:ecs:us-west-2:420785284875:task/f6a58bda-d564-4213-8ac9-bccb82244f16&quot;\r\n    ]\r\n}\r\n\r\n[Container] 2020/07/17 02:20:27 Running command TASK_ID=$(aws ecs list-tasks --cluster $CLUSTER_NAME |  jq .taskArns|.[0])\r\n/codebuild/output/tmp/script.sh: line 4: .[0]: command not found\r\n\r\n[Container] 2020/07/17 02:20:28 Command did not exit successfully TASK_ID=$(aws ecs list-tasks --cluster $CLUSTER_NAME |  jq .taskArns|.[0]) exit status 127\r\n[Container] 2020/07/17 02:20:28 Phase complete: BUILD State: FAILED\r\n[Container] 2020/07/17 02:20:28 Phase context status code: COMMAND_EXECUTION_ERROR Message: Error while executing command: TASK_ID=$(aws ecs list-tasks --cluster $CLUSTER_NAME |  jq .taskArns|.[0]). Reason: exit status 127\r\n\r\n```\r\nI&#39;m not sure what I&#39;m doing wrong here. ",
        "link": "https://stackoverflow.com/questions/62946697/aws-cli-and-jq-error-when-fetching-task-id-using-ecs-list-tasks",
        "title": "AWS CLI and jq : Error when fetching Task ID using ecs list-tasks"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1594969195,
                "last_edit_date": 1594969195,
                "creation_date": 1594968579,
                "answer_id": 62948599,
                "question_id": 62948269,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the `payload` object is nested in multiple levels in each of the object, you can apply [Recursive Descent `..`][1] and ignore if the key is not present\r\n\r\n    jq -r &#39;..| .payload? // empty | [ .id, .var2 ] | @csv&#39; file\r\n\r\n&lt;sup&gt;[jqplay - Online demo][2]&lt;/sup&gt;\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#RecursiveDescent:..\r\n  [2]: https://jqplay.org/s/DyCqCde4ok",
                "title": "Extract fields from object present in multiple nested levels using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1594969904,
                "last_edit_date": 1594969904,
                "creation_date": 1594969862,
                "answer_id": 62948904,
                "question_id": 62948269,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "BTW i figured following works too:\r\n\r\n```\r\njq -r &#39;if .input then .input.payload else .payload end | [.id, .var2] | @csv&#39; file &gt; newFile\r\n```",
                "title": "Extract fields from object present in multiple nested levels using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1594973386,
        "creation_date": 1594966990,
        "last_edit_date": 1594973364,
        "question_id": 62948269,
        "body_markdown": "I have a text file having data records as below:\r\n\r\n```\r\n{&quot;input&quot;:{&quot;payload&quot;:{&quot;id&quot;:&quot;rec1&quot;,&quot;var2&quot;:&quot;imp_val1&quot;,&quot;var3&quot;:&quot;&quot;,&quot;var4&quot;:&quot;000000&quot;},&quot;recordName&quot;:&quot;typeABC&quot;}}\r\n{&quot;input&quot;:{&quot;recordName&quot;:&quot;typeBCD&quot;,&quot;payload&quot;:{&quot;var5&quot;:&quot;val_var66&quot;,&quot;recordType&quot;:&quot;typeA&quot;,&quot;id&quot;:&quot;rec2&quot;,&quot;var2&quot;:&quot;imp_val2&quot;,&quot;var3&quot;:&quot;&quot;,&quot;var4&quot;:&quot;000000&quot;}}}\r\n{&quot;recordName&quot;:&quot;typeEFG&quot;,&quot;payload&quot;:{&quot;var5&quot;:&quot;val_var55&quot;,&quot;recordType&quot;:&quot;typeA&quot;,&quot;id&quot;:&quot;rec3&quot;,&quot;var2&quot;:&quot;imp_val3&quot;,&quot;var3&quot;:&quot;&quot;,&quot;var4&quot;:&quot;&quot;}}\r\n{&quot;payload&quot;:{&quot;id&quot;:&quot;rec4&quot;,&quot;var2&quot;:&quot;imp_val4&quot;,&quot;var3&quot;:&quot;&quot;,&quot;var4&quot;:&quot;000000&quot;},&quot;recordName&quot;:&quot;typeABC&quot;}\r\n```\r\n\r\nThere is a recordName and payload key which has my values of interest. Some records are wrapped inside another key input.\r\nWhat i want to extract is id and var2 from all these records into a new csv file.\r\n\r\nI figured if the data format were uniform, i could do:\r\n```\r\ncat file | jq -r &quot;[.payload.id, .payload.var2] | @csv&quot; &gt; newFile\r\n```\r\nOR\r\n```\r\ncat file | jq -r &quot;[.input.payload.id, .input.payload.var2] | @csv&quot; &gt; newFile\r\n```\r\n\r\nAny pointers?",
        "link": "https://stackoverflow.com/questions/62948269/extract-fields-from-object-present-in-multiple-nested-levels-using-jq",
        "title": "Extract fields from object present in multiple nested levels using jq"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3989434,
                    "reputation": 60764,
                    "user_id": 3288890,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://i.sstatic.net/sSQpx.jpg?s=256",
                    "display_name": "Adiii",
                    "link": "https://stackoverflow.com/users/3288890/adiii"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594989388,
                "post_id": 62953962,
                "comment_id": 111327343,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7343074,
                    "reputation": 21,
                    "user_id": 5591809,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5b01375a37884c3d9a554d76f04a0e57?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Matthew Wimpelberg",
                    "link": "https://stackoverflow.com/users/5591809/matthew-wimpelberg"
                },
                "reply_to_user": {
                    "account_id": 3989434,
                    "reputation": 60764,
                    "user_id": 3288890,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://i.sstatic.net/sSQpx.jpg?s=256",
                    "display_name": "Adiii",
                    "link": "https://stackoverflow.com/users/3288890/adiii"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1594989907,
                "post_id": 62953962,
                "comment_id": 111327602,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1594990411,
                "creation_date": 1594990411,
                "answer_id": 62954400,
                "question_id": 62953962,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do this with `aws-cli` query parameters, try the below and it should work.\r\n\r\n\r\n\r\n```\r\naws ec2 describe-security-groups --query &#39;SecurityGroups[].{Tags:Tags[?Key==`Name`].Value|[0],GroupName:GroupName}&#39;\r\n```\r\n\r\noutput\r\n```\r\n    {\r\n        &quot;Tags&quot;: &quot;demo&quot;,\r\n        &quot;GroupName&quot;: &quot;demo&quot;\r\n    }\r\n```",
                "title": "Parsing AWS JSON with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1595031396,
        "creation_date": 1594988835,
        "last_edit_date": 1595031396,
        "question_id": 62953962,
        "body_markdown": "I&#39;m trying to parse JSON output from the AWS CLI.  What I&#39;m looking for are security group names with specific tags below them.  The two commands that work are\r\n\r\n    $aws ec2 describe-security-groups | jq  -r &#39;.SecurityGroups[].GroupName&#39;\r\n    default\r\n    mysqlsg\r\n    apachesg\r\n    default\r\n\r\nThen I run\r\n\r\n    $ aws ec2 describe-security-groups | jq  -r &#39;.SecurityGroups[].Tags[]|select(.Key == &quot;Service&quot;)&#39;\r\n    {\r\n      &quot;Key&quot;: &quot;Service&quot;,\r\n      &quot;Value&quot;: &quot;default&quot;\r\n    }\r\n    {\r\n      &quot;Key&quot;: &quot;Service&quot;,\r\n      &quot;Value&quot;: &quot;MySQL&quot;\r\n    }\r\n    {\r\n      &quot;Key&quot;: &quot;Service&quot;,\r\n      &quot;Value&quot;: &quot;Apache&quot;\r\n    }\r\n    {\r\n      &quot;Key&quot;: &quot;Service&quot;,\r\n      &quot;Value&quot;: &quot;default&quot;\r\n    }\r\n\r\nI&#39;d like each group to have the Service Tag below it so I tried this but it didn&#39;t work.\r\n\r\n    $ aws ec2 describe-security-groups | jq  -r &#39;.SecurityGroups[].GroupName,.SecurityGroups[].Tags[]|select(.Key == &quot;Service&quot;)&#39;\r\n    jq: error (at &lt;stdin&gt;:225): Cannot index string with string &quot;Key&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/62953962/parsing-aws-json-with-jq",
        "title": "Parsing AWS JSON with 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": 1594995646,
                "post_id": 62955547,
                "comment_id": 111330552,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "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": 1594996243,
                "post_id": 62955547,
                "comment_id": 111330827,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1594999311,
                "post_id": 62955547,
                "comment_id": 111332559,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "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": 1594999792,
                "post_id": 62955547,
                "comment_id": 111332818,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595002706,
                "post_id": 62955547,
                "comment_id": 111334173,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595002794,
                "post_id": 62955547,
                "comment_id": 111334217,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595003143,
                "post_id": 62955547,
                "comment_id": 111334383,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595004078,
                "post_id": 62955547,
                "comment_id": 111334854,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13075955,
                    "reputation": 24990,
                    "user_id": 9448090,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/600951510246447/picture?type=large",
                    "display_name": "Jack Fleeting",
                    "link": "https://stackoverflow.com/users/9448090/jack-fleeting"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1595004278,
                "post_id": 62955547,
                "comment_id": 111334959,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1595069170,
                "last_edit_date": 1595069170,
                "creation_date": 1594998171,
                "answer_id": 62956694,
                "question_id": 62955547,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As far as I&#39;m concerned JQ still doesn&#39;t have a built-in for that. However, if a path in `.[1][&quot;name&quot;]` format is also acceptable, that&#39;s pretty easy:\r\n* get paths in array form using `path` built-in,\r\n* enclose each path component of type string in double quotes; `tojson` can be used for that,\r\n* join all components by `][`,\r\n* and put the result between `.[` and `]`.\r\n```\r\npath(recurse | select(.==&quot;XML&quot;)) | &quot;.[\\(map(tojson) | join(&quot;][&quot;))]&quot;\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/iz1og1bn9_)&lt;/sup&gt;",
                "title": "Is there a way to get the path to a specific element within the JSON value?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1595094417,
                "last_edit_date": 1595094417,
                "creation_date": 1595000629,
                "answer_id": 62957404,
                "question_id": 62955547,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n\r\nTo get the JSON representation of the path(s) of interest, you could write:\r\n\r\n    paths as $p\r\n    | select(getpath($p) == &quot;XML&quot;)\r\n    | $p\r\n\r\nThis form is normally the most useful, but it’s easy to transform it into another form if need be, as shown in @OguzIsmail&#39;s answer (see also below).\r\n\r\nIf only the path of the first occurrence is desired, you can simply use `first(...)`, but of course there are different possible conceptions of “first”.\r\n\r\n## Producing jq-style path expressions\r\n\r\nAs pointed out by @OguzIsmail, `tojson` can be used to produce jq-style path expressions (i.e., jq expressions that can be used to fetch a value directly, without `getpath`), e.g. by adding the following to the above pipeline :\r\n```\r\n&quot;.[&quot; + (map(tojson)|join(&quot;][&quot;)) + &quot;]&quot;\r\n```\r\n\r\n\r\n",
                "title": "Is there a way to get the path to a specific element within the JSON value?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1595094417,
        "creation_date": 1594994270,
        "last_edit_date": 1595011029,
        "question_id": 62955547,
        "body_markdown": "Given this simple example from the jq manual:\r\n\r\n    [    \r\n        {\r\n            &quot;name&quot;:&quot;JSON&quot;,\r\n            &quot;good&quot;:true        \r\n        },\r\n        {\r\n            &quot;name&quot;:&quot;XML&quot;,\r\n            &quot;good&quot;:false        \r\n        }\r\n    ]\r\n\r\nusing this expression:\r\n\r\n    .[1].name\r\n\r\nI get `&quot;XML&quot;` as output.\r\n\r\nAnd the question: in xpath, for example, there are ways to do the reverse: given an element, an xpath function will return the xpath to the element within the document. Is there a way to do that with jq? That is, given `&quot;XML&quot;`, is there a way to get \r\n\r\n    .[1].name\r\n\r\nas the output?\r\n\r\nI am aware of the `getpath(PATHS)` function, but unless I&#39;m missing something, that&#39;s not it.",
        "link": "https://stackoverflow.com/questions/62955547/is-there-a-way-to-get-the-path-to-a-specific-element-within-the-json-value",
        "title": "Is there a way to get the path to a specific element within the JSON value?"
    },
    {
        "tags": [
            "json",
            "select",
            "command-line-interface",
            "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": 2,
                "creation_date": 1595032533,
                "post_id": 62961988,
                "comment_id": 111344004,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595204808,
                "post_id": 62961988,
                "comment_id": 111384816,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1595032928,
                "last_edit_date": 1595032928,
                "creation_date": 1595030871,
                "answer_id": 62963249,
                "question_id": 62961988,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input, the following jq filter produces the output shown below:\r\n```\r\n. as $in\r\n| paths as $p \r\n| $p\r\n| select($p[-1] == &quot;x&quot;)\r\n| $in\r\n| getpath($p[:-2])[]\r\n```\r\n### Output\r\n```\r\n&quot;y&quot;\r\n&quot;F&quot;\r\n&quot;U&quot;\r\n```\r\n\r\n\r\n",
                "title": "How do I print all contents after finding path to key using jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1598910532,
                "creation_date": 1598910532,
                "answer_id": 63678633,
                "question_id": 62961988,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Shameless (non-commercial) plug.\r\n\r\nFor unknown files  \r\nI have an approach that generates   \r\n*all* distinct `jq` query paths in a `.json` file\r\nand presents them in `jq`&#39;s format\r\n\r\nperfect for exploring &amp; pasting back into your queries\r\n\r\nhttps://github.com/TomConlin/json_to_paths",
                "title": "How do I print all contents after finding path to key using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1598910532,
        "creation_date": 1595021347,
        "question_id": 62961988,
        "body_markdown": "    {\r\n      &quot;A&quot;: &quot;B&quot;,\r\n      &quot;?&quot;: {\r\n        &quot;x&quot; : &quot;y&quot;,\r\n        &quot;D&quot; : &quot;F&quot;,\r\n        &quot;G&quot; : &quot;U&quot;\r\n      }\r\n    }\r\n\r\nSince I don&#39;t know the key (?), I&#39;m able to use this jq command \r\n\r\njq &#39;.. | .x? | select(.)&#39;\r\n\r\nto locate .x &amp; print its contents , but what do I do if I want to print all contents inside ?? ",
        "link": "https://stackoverflow.com/questions/62961988/how-do-i-print-all-contents-after-finding-path-to-key-using-jq",
        "title": "How do I print all contents after finding path to key using jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "sed",
            "grep",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8440460,
                    "reputation": 17498,
                    "user_id": 6849682,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://i.sstatic.net/dVNqQ.png?s=256",
                    "display_name": "bigbounty",
                    "link": "https://stackoverflow.com/users/6849682/bigbounty"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1595037084,
                "post_id": 62963768,
                "comment_id": 111344751,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19103419,
                    "reputation": 5,
                    "user_id": 13951152,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bd26d12a164cc18278006335b50d13f0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "malhaut",
                    "link": "https://stackoverflow.com/users/13951152/malhaut"
                },
                "reply_to_user": {
                    "account_id": 8440460,
                    "reputation": 17498,
                    "user_id": 6849682,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://i.sstatic.net/dVNqQ.png?s=256",
                    "display_name": "bigbounty",
                    "link": "https://stackoverflow.com/users/6849682/bigbounty"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595038253,
                "post_id": 62963768,
                "comment_id": 111344926,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 447475,
                    "reputation": 1,
                    "user_id": 841108,
                    "user_type": "registered",
                    "accept_rate": 61,
                    "profile_image": "https://i.sstatic.net/Fm52y.png?s=256",
                    "display_name": "Basile Starynkevitch",
                    "link": "https://stackoverflow.com/users/841108/basile-starynkevitch"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595039060,
                "post_id": 62963768,
                "comment_id": 111345058,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1595039928,
                "last_edit_date": 1595039928,
                "creation_date": 1595038936,
                "answer_id": 62963982,
                "question_id": 62963768,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `jq` command. This is just example parsing.\r\n\r\n```\r\nfor k in $(jq -c &#39;.[]&#39; a.txt); do\r\n    echo &quot;hello-&quot; $k\r\ndone\r\n```\r\n\r\nOutput:\r\n```\r\nhello- {&quot;foo&quot;:&quot;bar:baz:foo*&quot;,&quot;bar*&quot;:&quot;baz*&quot;,&quot;etc&quot;:&quot;etc&quot;}\r\nhello- {&quot;foo2&quot;:&quot;bar2:baz2:foo2*&quot;,&quot;bar2*&quot;:&quot;baz2*&quot;,&quot;etc&quot;:&quot;etc&quot;}\r\nhello- {&quot;foo3&quot;:&quot;bar3:baz3:foo3*&quot;,&quot;bar3*&quot;:&quot;baz3*&quot;,&quot;etc&quot;:&quot;etc&quot;}\r\nhello- {&quot;foo4&quot;:&quot;bar4:baz4:foo4*&quot;,&quot;bar4*&quot;:&quot;baz4*&quot;,&quot;etc&quot;:&quot;etc&quot;}\r\n```\r\n\r\nYou can use the `$k` anywhere inside the loop you want.\r\n\r\n```\r\nfor k in $(jq -c &#39;.[]&#39; a.txt); do\r\n    curl -d &quot;$k&quot; &lt;url&gt;\r\ndone\r\n```",
                "title": "Get specific string line from file bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1595107528,
                "last_edit_date": 1595107528,
                "creation_date": 1595039067,
                "answer_id": 62963998,
                "question_id": 62963768,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I suggest that you can use `jq` to process your json file.  `jq` is capable of reading json, and formatting output.  Here&#39;s an example `jq` script to process your json file (which I unimaginatively call &#39;jsonfile&#39;):\r\n\r\n    jq -r &#39;.[] | &quot;curl -d &#39;\\&#39;&#39; \\(.) &#39;\\&#39;&#39;  http://restful.com/api &quot; &#39; jsonfile\r\n\r\nHere&#39;s the output:\r\n\r\n    curl -d &#39; {&quot;foo&quot;:&quot;bar:baz:foo*&quot;,&quot;bar*&quot;:&quot;baz*&quot;,&quot;etc&quot;:&quot;etc&quot;} &#39;  http://restful.com/api \r\n    curl -d &#39; {&quot;foo2&quot;:&quot;bar2:baz2:foo2*&quot;,&quot;bar2*&quot;:&quot;baz2*&quot;,&quot;etc&quot;:&quot;etc&quot;} &#39;  http://restful.com/api \r\n    curl -d &#39; {&quot;foo3&quot;:&quot;bar3:baz3:foo3*&quot;,&quot;bar3*&quot;:&quot;baz3*&quot;,&quot;etc&quot;:&quot;etc&quot;} &#39;  http://restful.com/api \r\n    curl -d &#39; {&quot;foo4&quot;:&quot;bar4:baz4:foo4*&quot;,&quot;bar4*&quot;:&quot;baz4*&quot;,&quot;etc&quot;:&quot;etc&quot;} &#39;  http://restful.com/api \r\n\r\nHere&#39;s what&#39;s going on:\r\n\r\nWe pass three arguments to the `jq` program:  jq -r &amp;lt;script&gt; &amp;lt;inputfile&gt;.  \r\nThe `-r` tells jq to output the results in raw format (that is, please don&#39;t escape quotes and stuff).\r\nThe script looks like this:\r\n\r\n    .[] | &quot;some string \\(.)&quot; \r\n\r\nThe first `.` means take the whole json structure and the `[]` means iterate through each array element in the structure.  The `|` is a filter that processes each element in the array.  The filter is to output a string. We are using `\\(.)` to interpolate the whole element passed into the `|` filter.  \r\n\r\nWow... I&#39;ve never really explained a `jq` script before (and it shows).  But the crux of it is, we are using jq to find each element in the json array and insert it into a string.  Our string is this:\r\n\r\n    curl -d &#39;&lt;the json dictionary array element&gt;&#39; http://restful.com/api\r\n\r\nOk.  And you see the output.  It works.  But wait a second, we only have output.  Let&#39;s tell the shell to run each line like this:\r\n\r\n    jq -r &#39;.[] | &quot;curl -d &#39;\\&#39;&#39; \\(.) &#39;\\&#39;&#39;  http://restful.com/api &quot; &#39; jsonfile | bash\r\n\r\nBy piping the output to bash, we execute each line that we output.  Essentially, we are writing a bash script with jq to curl http://restful.com/api passing the json element as the `-d` data parameter to POST the json element.\r\n\r\n## Revisiting for single quote issue ##\r\n\r\n@oguz ismail pointed out that bash will explode if there is a single quote in the json input file.  This is  true.   We can avoid the quote by escaping, but we gain more complexity - making this a non-ideal approach.  \r\n\r\nHere&#39;s the problem input (I just inserted a single quote):\r\n\r\n    [{&quot;foo&quot;:&quot;bar:&#39;baz:foo*&quot;,&quot;bar*&quot;:&quot;baz*&quot;,&quot;etc&quot;:&quot;etc&quot;},\r\n    {&quot;foo2&quot;:&quot;bar2:baz2:foo2*&quot;,&quot;bar2*&quot;:&quot;baz2*&quot;,&quot;etc&quot;:&quot;etc&quot;},\r\n    {&quot;foo3&quot;:&quot;bar3:baz3:foo3*&quot;,&quot;bar3*&quot;:&quot;baz3*&quot;,&quot;etc&quot;:&quot;etc&quot;},\r\n    {&quot;foo4&quot;:&quot;bar4:baz4:foo4*&quot;,&quot;bar4*&quot;:&quot;baz4*&quot;,&quot;etc&quot;:&quot;etc&quot;}]\r\n\r\nNotice above that `baz` is now `&#39;baz`.  The problem is that a single single quote makes the bash shell complain about unmatched quotes:\r\n\r\n    $ jq -r &#39;.[] | &quot;curl -d &#39;\\&#39;&#39; \\(.) &#39;\\&#39;&#39;  http://restful.com/api &quot; &#39; jsonfile | bash\r\n    bash: line 4: unexpected EOF while looking for matching `&quot;&#39;\r\n    bash: line 5: syntax error: unexpected end of file\r\n\r\n\r\n\r\nHere&#39;s the solution:\r\n\r\n    $ jq -r  $&#39;.[] |    &quot;\\(.)&quot;  | gsub( &quot;\\&#39;&quot; ; &quot;\\\\\\\\\\&#39;&quot; )  | &quot;echo $\\&#39;\\(.)\\&#39;&quot; &#39; jsonfile     | bash\r\n    {&quot;foo&quot;:&quot;bar&#39;baz:foo*&quot;,&quot;bar*&quot;:&quot;baz*&quot;,&quot;etc&quot;:&quot;etc&quot;}\r\n    {&quot;foo2&quot;:&quot;bar2:baz2:foo2*&quot;,&quot;bar2*&quot;:&quot;baz2*&quot;,&quot;etc&quot;:&quot;etc&quot;}\r\n    {&quot;foo3&quot;:&quot;bar3:baz3:foo3*&quot;,&quot;bar3*&quot;:&quot;baz3*&quot;,&quot;etc&quot;:&quot;etc&quot;}\r\n    {&quot;foo4&quot;:&quot;bar4:baz4:foo4*&quot;,&quot;bar4*&quot;:&quot;baz4*&quot;,&quot;etc&quot;:&quot;etc&quot;}\r\n\r\nAbove I am using $&#39;&#39; to quote the jq script.  This allows me to escape single quotes using \\&#39;.   I&#39;ve also changed the `curl` command to `echo` so I can test the bash script without bothering the folks at `http://restful.com/api`.  \r\n\r\nThe &#39;trick&#39; is to make sure that the bash script we generate also escapes all single quotes with a backslash \\.  So, we have to change `&#39;` to `\\&#39;`.  That&#39;s what gsub is doing.\r\n\r\n    gsub( &quot;\\&#39;&quot; ; &quot;\\\\\\\\\\&#39;&quot; ) \r\n\r\nAfter making that substitution ( `&#39;` --&gt; `\\&#39;` ) we pipe the entire string to this:\r\n\r\n    &quot;echo $\\&#39;\\(.)\\&#39;&quot; \r\n\r\nwhich surrounds the output of gsub with `echo $&#39;&#39;`.  Now we are using $&#39; again so the `\\&#39;` is properly understood by bash.  \r\n\r\nSo we wind up with this when we put the curl back in:\r\n\r\n    jq -r  $&#39;.[] |    &quot;\\(.)&quot;  | gsub( &quot;\\&#39;&quot; ; &quot;\\\\\\\\\\&#39;&quot; )  | &quot;curl -d $\\&#39;\\(.)\\&#39; http://restful.com/api &quot; &#39; jsonfile     | bash\r\n\r\n\r\n\r\n \r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "Get specific string line from file bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -3,
        "last_activity_date": 1595107528,
        "creation_date": 1595036572,
        "last_edit_date": 1595051912,
        "question_id": 62963768,
        "body_markdown": "I have a file with this kind of text with pattern\r\n\r\n    [{&quot;foo&quot;:&quot;bar:baz:foo*&quot;,&quot;bar*&quot;:&quot;baz*&quot;,&quot;etc&quot;:&quot;etc&quot;},\r\n    {&quot;foo2&quot;:&quot;bar2:baz2:foo2*&quot;,&quot;bar2*&quot;:&quot;baz2*&quot;,&quot;etc&quot;:&quot;etc&quot;},\r\n    {&quot;foo3&quot;:&quot;bar3:baz3:foo3*&quot;,&quot;bar3*&quot;:&quot;baz3*&quot;,&quot;etc&quot;:&quot;etc&quot;},\r\n    {&quot;foo4&quot;:&quot;bar4:baz4:foo4*&quot;,&quot;bar4*&quot;:&quot;baz4*&quot;,&quot;etc&quot;:&quot;etc&quot;}]\r\n\r\nI  need to take every string like this\r\n```{&quot;foo&quot;:&quot;bar:baz:foo*&quot;,&quot;bar*&quot;:&quot;baz*&quot;,&quot;etc&quot;:&quot;etc&quot;}``` and send each of them to some url via curl\r\n\r\n\r\n    for i in text.txt\r\n    do (awk,sed,grep etc)\r\n    then curl $string\r\n\r\nI can&#39;t figure out how to get the desired lines properly from the file without unnecessary symbols\r\n\r\n",
        "link": "https://stackoverflow.com/questions/62963768/get-specific-string-line-from-file-bash",
        "title": "Get specific string line from file bash"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1595123392,
                "creation_date": 1595123392,
                "answer_id": 62975500,
                "question_id": 62973375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re dealing with just two properties from an object, just select the objects to put into an array, then put into an array.\r\n\r\n    [\r\n      .element1, .element2     # select properties element1 then element2\r\n    ]                          # wrapped in [] creates the array\r\n\r\nIn general, you could use this to gather all values of an object. This should keep the objects in document order.\r\n\r\n    [\r\n      .[]    # select all property values of object (in document order)\r\n    ]        # wrapped in [] creates the array\r\n\r\n",
                "title": "how to create an array from json object using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1595123392,
        "creation_date": 1595103351,
        "question_id": 62973375,
        "body_markdown": "i have a json show below. i using linux with bash and jq. I want this output only using jq.\r\n\r\ninput json(test.json)\r\n\r\n    {\r\n      &quot;element1&quot;:{\r\n       &quot;param1&quot;: &quot;element1.value1&quot;,\r\n       &quot;param2&quot;: &quot;element1.value2&quot;\r\n      },\r\n    \r\n      &quot;element2&quot;:{\r\n       &quot;param1&quot;: &quot;element2.value1&quot;,\r\n       &quot;param2&quot;: &quot;element2.value2&quot;\r\n     }\r\n    }\r\n\r\ni want an expected output like this\r\n\r\nExpected output\r\n\r\n    [\r\n    {\r\n      &quot;param1&quot;: &quot;element1.value1&quot;,\r\n      &quot;param2&quot;: &quot;element1.value2&quot;\r\n    },\r\n    {\r\n      &quot;param1&quot;: &quot;element2.value1&quot;,\r\n      &quot;param2&quot;: &quot;element2.value2&quot;\r\n    }\r\n    ]\r\n\r\nI tried with jq in bash\r\n\r\n    &lt;test.json|jq &#39;.element1,.element2|[{param1:.param1,param2:.param2}]&#39;\r\n\r\nBut it is producing output like this.I mean array is added for every element.\r\n\r\n    [\r\n      {\r\n        &quot;param1&quot;: &quot;element1.value1&quot;,\r\n        &quot;param2&quot;: &quot;element1.value2&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;param1&quot;: &quot;element2.value1&quot;,\r\n        &quot;param2&quot;: &quot;element2.value2&quot;\r\n      }\r\n    ]\r\n\r\nHow to produce the output shown in expected output?\r\n",
        "link": "https://stackoverflow.com/questions/62973375/how-to-create-an-array-from-json-object-using-jq",
        "title": "how to create an array from json object using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1595107410,
                "creation_date": 1595107410,
                "answer_id": 62973933,
                "question_id": 62973410,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following:\r\n\r\n`.[] | {unicode,&quot;label&quot;: .label}`\r\n\r\nproduces:\r\n```\r\n{&quot;unicode&quot;:&quot;f26e&quot;,&quot;label&quot;:&quot;pink&quot;}\r\n{&quot;unicode&quot;:&quot;b1e3&quot;,&quot;label&quot;:&quot;red&quot;}\r\n{&quot;unicode&quot;:&quot;11a2&quot;,&quot;label&quot;:&quot;blue&quot;}\r\n```\r\n\r\nThe &quot;gotcha&quot; here is that &quot;label&quot; is a keyword, and so one cannot write `{label}` as an abbreviation for `{&quot;label&quot;:.label}`.\r\n",
                "title": "Parsing JSON: Stuck in a seemingly easy jq task"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1595107410,
        "creation_date": 1595103631,
        "question_id": 62973410,
        "body_markdown": "I have a JSON of this sort:\r\n```\r\n{\r\n  &quot;key1&quot;: {\r\n      &quot;unicode&quot;: &quot;f26e&quot;,\r\n      &quot;label&quot;: &quot;pink&quot;,\r\n      &quot;free&quot;: false\r\n  },\r\n  &quot;key2&quot;: {\r\n      &quot;unicode&quot;: &quot;b1e3&quot;,\r\n      &quot;label&quot;: &quot;red&quot;,\r\n      &quot;free&quot;: true\r\n  },\r\n  &quot;key3&quot;: {\r\n      &quot;unicode&quot;: &quot;11a2&quot;,\r\n      &quot;label&quot;: &quot;blue&quot;,\r\n      &quot;free&quot;: false\r\n  }\r\n  ...\r\n}\r\n```\r\n\r\nAnd I want to extract the pair label/unicode from each inner object. So far I only could get the list of all keys with:\r\n\r\n```\r\njp &#39;. | keys&#39; icons.json\r\n```\r\n\r\nDo I have to start drilling from there?",
        "link": "https://stackoverflow.com/questions/62973410/parsing-json-stuck-in-a-seemingly-easy-jq-task",
        "title": "Parsing JSON: Stuck in a seemingly easy jq task"
    },
    {
        "tags": [
            "json",
            "jq",
            "confluence-rest-api"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17773243,
                    "reputation": 1773,
                    "user_id": 12906246,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ZzaJb.png?s=256",
                    "display_name": "rootkonda",
                    "link": "https://stackoverflow.com/users/12906246/rootkonda"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595242232,
                "post_id": 62993611,
                "comment_id": 111396609,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19082082,
                    "reputation": 23,
                    "user_id": 13934088,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7b04ff80a2c8c0ca3f574e31e940ed95?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "sheerak",
                    "link": "https://stackoverflow.com/users/13934088/sheerak"
                },
                "reply_to_user": {
                    "account_id": 17773243,
                    "reputation": 1773,
                    "user_id": 12906246,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ZzaJb.png?s=256",
                    "display_name": "rootkonda",
                    "link": "https://stackoverflow.com/users/12906246/rootkonda"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595243292,
                "post_id": 62993611,
                "comment_id": 111397106,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17773243,
                    "reputation": 1773,
                    "user_id": 12906246,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ZzaJb.png?s=256",
                    "display_name": "rootkonda",
                    "link": "https://stackoverflow.com/users/12906246/rootkonda"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595245820,
                "post_id": 62993611,
                "comment_id": 111398252,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19082082,
                    "reputation": 23,
                    "user_id": 13934088,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7b04ff80a2c8c0ca3f574e31e940ed95?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "sheerak",
                    "link": "https://stackoverflow.com/users/13934088/sheerak"
                },
                "reply_to_user": {
                    "account_id": 17773243,
                    "reputation": 1773,
                    "user_id": 12906246,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ZzaJb.png?s=256",
                    "display_name": "rootkonda",
                    "link": "https://stackoverflow.com/users/12906246/rootkonda"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595249278,
                "post_id": 62993611,
                "comment_id": 111400043,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1595271177,
                "creation_date": 1595271177,
                "answer_id": 63002038,
                "question_id": 62993611,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your file, the following invocation produces the output shown below:\r\n```\r\njq -r --arg prefix &quot;SPACEKEY : GROUPNAME : &quot; &#39;\r\n   $prefix + (.results | map(.username) | join(&quot;,&quot;))\r\n&#39; GroupList.json\r\n```\r\n\r\n### Output\r\n```\r\nSPACEKEY : GROUPNAME : USERID1,USERID2\r\n```\r\n",
                "title": "Append string and special character in the output of jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1595271177,
        "creation_date": 1595241566,
        "last_edit_date": 1595270878,
        "question_id": 62993611,
        "body_markdown": "I have a json file GroupList.json:\r\n\r\n```\r\n{\r\n  &quot;results&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;known&quot;,\r\n      &quot;username&quot;: &quot;USERID1&quot;,\r\n      &quot;displayName&quot;: &quot;DISPLAYNAME1&quot;,\r\n      &quot;_links&quot;: {\r\n        &quot;self&quot;: &quot;https://confluence.com/rest/api/user?key=123&quot;\r\n      },\r\n      &quot;_expandable&quot;: {\r\n        &quot;status&quot;: &quot;&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;known&quot;,\r\n      &quot;username&quot;: &quot;USERID2&quot;,\r\n      &quot;displayName&quot;: &quot;DISPLAYNAME2&quot;,\r\n      &quot;_links&quot;: {\r\n        &quot;self&quot;: &quot;https://confluence.com/rest/api/user?key=1234&quot;\r\n      },\r\n      &quot;_expandable&quot;: {\r\n        &quot;status&quot;: &quot;&quot;\r\n      }\r\n    }\r\n  ],\r\n  &quot;start&quot;: 0,\r\n  &quot;limit&quot;: 50000,\r\n  &quot;size&quot;: 2,\r\n  &quot;_links&quot;: {\r\n    &quot;self&quot;: &quot;https://confluence.com/rest/api/group/GROUPNAME/member&quot;,\r\n    &quot;base&quot;: &quot;https://confluence.com&quot;\r\n  }\r\n}\r\n```\r\n\r\nI&#39;m fetching the username using the below command:\r\n***jq -r &#39;.results | map(.username) | join(&quot;,&quot;)&#39; GroupList.json &gt; UserNameList.txt***\r\n\r\nOutput in UserNameList.txt is:\r\n***USERID1,USERID2***\r\n\r\nI want to modify the output to be:\r\n\r\n***SPACEKEY : GROUPNAME : USERID1,USERID2***\r\n\r\nSPACEKEY &amp; GROUPNAME are 2 variables whose value changes in every iteration.\r\n",
        "link": "https://stackoverflow.com/questions/62993611/append-string-and-special-character-in-the-output-of-jq-command",
        "title": "Append string and special character in the output of jq command"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1595283230,
                "post_id": 63004420,
                "comment_id": 111415848,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1595283381,
                "creation_date": 1595283381,
                "answer_id": 63004593,
                "question_id": 63004420,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `bash` and `zsh`:\r\n\r\n    child_name=&quot;child2&quot;\r\n    fruits=&#39;[&quot;orange&quot;,&quot;potato&quot;,&quot;watermelon&quot;]&#39;\r\n\r\n    added_string=$(printf &#39;.main_object += {%s: %s}&#39; &quot;$child_name&quot; &quot;$fruits&quot;)\r\n    cat file | jq &quot;$added_string&quot;  # quotes are important\r\n\r\nOutput:\r\n&lt;pre&gt;\r\n{\r\n  &quot;main_object&quot;: {\r\n    &quot;child1&quot;: [\r\n      &quot;banana&quot;,\r\n      &quot;apple&quot;,\r\n      &quot;orange&quot;\r\n    ],\r\n    &quot;child2&quot;: [\r\n      &quot;orange&quot;,\r\n      &quot;potato&quot;,\r\n      &quot;watermelon&quot;\r\n    ]\r\n  }\r\n}\r\n&lt;/pre&gt;",
                "title": "jq bash Adding a json field to a json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1595283381,
        "creation_date": 1595282368,
        "last_edit_date": 1595282923,
        "question_id": 63004420,
        "body_markdown": "i&#39;m stuck on jq input problem. I have a json file that looks like this:\r\n\r\n    {\r\n        &quot;main_object&quot;: {\r\n            &quot;child1&quot;: [&quot;banana&quot;, &quot;apple&quot;, &quot;orange&quot;]\r\n        }\r\n    }\r\n\r\nI need to add another child object and rewrite this file, the problem is that this child object needs to be generated dynamically. so i&#39;m doing this:\r\n\r\n    added_string=$(printf &#39;.main_object += {%s: %s}&#39; &quot;$child_name&quot; &quot;$fruits&quot;)\r\n\r\nThen I wrote this line, which worked well on my mac shell:\r\n\r\n    edited_json=$(cat $json_variable_file | jq $added_string)\r\n\r\nWhen i tried to run all of this from a bash script i got this error:\r\n\r\njq: error: Could not open file +=: No such file or directory\\\r\njq: error: Could not open file {&quot;child2&quot;:: No such file or directory\\\r\njq: error: Could not open file [&quot;orange&quot;,&quot;potato&quot;,&quot;watermelon&quot;]}: No such file or directory\r\n\r\nSo I tried many things so far, most of them still give me the same error, also tried doing this:\r\n\r\n    edited_json=$(cat $json_variable_file | jq &lt;&lt;&lt; $added_string)\r\n\r\nThe error i got is this:\r\nparse error: Invalid numeric literal at line 1, column 23\r\n\r\nReally appreciate your time, the weird thing here is that it works completely fine, generating the needed json on my zsh but it does not work on bash. ",
        "link": "https://stackoverflow.com/questions/63004420/jq-bash-adding-a-json-field-to-a-json-file",
        "title": "jq bash Adding a json field to a json file"
    },
    {
        "tags": [
            "json",
            "integer",
            "jq",
            "bigint",
            "arbitrary-precision"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1595349697,
                "post_id": 63018852,
                "comment_id": 111441572,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1595364180,
                "last_edit_date": 1595364180,
                "creation_date": 1595363872,
                "answer_id": 63022741,
                "question_id": 63018852,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As of right now, the best jq has to offer with respect to JSON numbers is the &quot;master&quot; version, which preserves the external numerical value very well.  The updates were made on or about 22 Oct 2019, and the &quot;master&quot; version of jq seems to be as safe to use as the most recent release (jq 1.6).\r\n\r\nExamples using a recent &quot;master&quot; version:\r\n```\r\n    jqMaster -n -M &#39;\r\n    [0000,\r\n     10000000000000000000000000000000000000012, \r\n     1.0000000000000000000000000000000000000012, \r\n     1000000000000000000000000000000000000001210000000000000000000000000000000000000012,\r\n     0.1e123456]&#39;\r\n```\r\n### Output\r\n```\r\n[\r\n  0,\r\n  10000000000000000000000000000000000000012,\r\n  1.0000000000000000000000000000000000000012,\r\n  1000000000000000000000000000000000000001210000000000000000000000000000000000000012,\r\n  1E+123455\r\n]\r\n```\r\n",
                "title": "How do I get jq to preserve bigint values?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1626102536,
                "creation_date": 1626102536,
                "answer_id": 68349736,
                "question_id": 63018852,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another option would be to use “gojq”, the Go implementation of jq that uses unbounded-precision representation of integer literals.\r\n\r\nIn fact, except for one bug that has only been fixed in the “master” version of gojq as of this writing, gojq supports unbounded-precision integer arithmetic. The bug fix: https://github.com/itchyny/gojq/commit/7a1840289029c9c038d61274ceac9b8d307c0358\r\n\r\n\r\n  ",
                "title": "How do I get jq to preserve bigint values?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1684523750,
                "creation_date": 1684523750,
                "answer_id": 76291890,
                "question_id": 63018852,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not the most elegant solution, but one that should allow you to avoid installing any external packages/libraries would be to use Python in the command line to parse the bigint the following way:\r\n\r\n    JSON_DATA=&#39;{&quot;id&quot;: 8532687839421703901}&#39;\r\n    ID=$(echo &quot;$JSON_DATA&quot; | python3 -c &#39;import json,sys;obj=json.load(sys.stdin);print(obj[&quot;id&quot;]);&#39;)\r\n    echo $ID\r\n\r\nOutputs the original bigint value:\r\n\r\n    8532687839421703901\r\n\r\nHere is the python script not in a one-liner for readability:\r\n\r\n```\r\nimport json\r\nimport sys\r\n\r\n\r\nobj = json.load(sys.stdin)\r\nprint(obj[&quot;id&quot;])\r\n```",
                "title": "How do I get jq to preserve bigint values?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 6,
        "last_activity_date": 1684523750,
        "creation_date": 1595348692,
        "last_edit_date": 1626103135,
        "question_id": 63018852,
        "body_markdown": "I have a large JSON file that contains bigints with their full values--not rounded like JavaScript loves to do by default.\r\nWe have a workaround to deal with the bigints in Node.js, but I&#39;m trying to use jq (the command-line tool) to clean up our data.\r\nHowever, when I ran jq on our JSON file, it rounded all of our bigints.\r\n\r\nIs there a way to use jq so that it doesn&#39;t round the bigints or is there perhaps another command-line tool that works on a Mac that I may use instead?\r\n",
        "link": "https://stackoverflow.com/questions/63018852/how-do-i-get-jq-to-preserve-bigint-values",
        "title": "How do I get jq to preserve bigint values?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1595382901,
                "creation_date": 1595382901,
                "answer_id": 63025618,
                "question_id": 63023754,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A straightforward and efficient approach would be:\r\n```\r\nreduce .[] as $o ({};\r\n  reduce ($o|keys_unsorted[]) as $k (.;\r\n    .[$k] += [$o[$k]]))\r\n```",
                "title": "Combine lists by object key in JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1595409446,
                "creation_date": 1595409446,
                "answer_id": 63030878,
                "question_id": 63023754,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is another approach using [reduce](https://stedolan.github.io/jq/manual/#Reduce) and [to_entries](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries):\r\n```\r\nreduce ( .[] | to_entries[] ) as {$key,$value} ({}; .[$key] += [$value]) \r\n```\r\n[Try it online!](https://tio.run/##yyr8/78oNaU0OVVBQ0EvOlahRqEkPz41r6QoM7UYyNVUSCxWqFbJTq3UUSlLzClNrVXQqK61BioFicUqaNsqREMkYjUV/v@P5lJQqFZKVLJSMNRRUEoC0ka1OnAxY6iYSS1X7L/8gpLM/Lzi/7rJAA &quot;jq – Try It Online&quot;)",
                "title": "Combine lists by object key in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1595409446,
        "creation_date": 1595368916,
        "question_id": 63023754,
        "body_markdown": "I&#39;d like to aggregate a list of objects like this:\r\n\r\n```json\r\n[\r\n  {&quot;a&quot;: 1, &quot;b&quot;: 2},\r\n  {&quot;a&quot;: 3, &quot;b&quot;: 4}\r\n]\r\n```\r\n\r\nTo a single object with list values:\r\n\r\n```json\r\n{\r\n  &quot;a&quot;: [1,3],\r\n  &quot;b&quot;: [2,4]\r\n}\r\n```\r\nI&#39;ve scoured the docs but I think I just don&#39;t know the term for what I&#39;m trying to do. Any ideas?",
        "link": "https://stackoverflow.com/questions/63023754/combine-lists-by-object-key-in-jq",
        "title": "Combine lists by object key in JQ"
    },
    {
        "tags": [
            "json",
            "recursion",
            "tree",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1595408231,
                "last_edit_date": 1595408231,
                "creation_date": 1595397219,
                "answer_id": 63027771,
                "question_id": 63027032,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following recursive function seems to meet the requirements, or at least the filter `.metaModel | transform` transforms the sample input in accordance with the sample output:\r\n```\r\ndef transform:\r\n  if type == &quot;object&quot; and has(&quot;clazz&quot;)\r\n  then  {clazz, code} + (if has(&quot;children&quot;) then {children: (.children|transform)} else null end)\r\n  elif type == &quot;array&quot; then map(transform)\r\n  else .\r\n  end;\r\n```\r\n\r\n## Footnote\r\nIf you don&#39;t like the redundancy of the expression\r\n```\r\n{children: (.children|transform)}\r\n```\r\n\r\nyou could write:\r\n```\r\n{children} | map_values(transform)\r\n```",
                "title": "How to transform json tree recursively with jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1595408688,
                "creation_date": 1595408688,
                "answer_id": 63030648,
                "question_id": 63027032,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an approach that uses [tostream](https://stedolan.github.io/jq/manual/#tostream), [setpath](https://stedolan.github.io/jq/manual/#setpath\\(PATHS;VALUE\\)) and [reduce](https://stedolan.github.io/jq/manual/#Reduce):\r\n```\r\nreduce (tostream|select(.[0][-1]|.==&quot;clazz&quot; or .==&quot;code&quot; or .==&quot;children&quot;)) as [$p,$v] (\r\n  {}; setpath($p;$v)\r\n)\r\n```\r\n[Try it online!](https://tio.run/##lZKxboMwEIZ3nuJkMYCURsXdiDJUmfsEyIMLVyWVU4h9MCTh2SnEUcCQkJYBdPf/9vdj3/ehaTRmZYoQUG5Io9yfDSpMKVgmryJ5icR5uV6zVMnjkUGu4VLlGfbFdqcyjT8sDEEaSPxi4VcCAg/gVK/AIBWStoFfrPwq9MKmgfY5ed2b7ZHkR7uZYjEk1@ZFsLwY2DuR3n2WhBsljYnYYuDpUsT26wgZfslSUadVUpWueIvrEueofLB@QubRWB3jW8fNUPfev7GjWTZ/yp5mf/z//8kxyfJ21zHOc981zCQcuXaqXuv7tnc91@cTxB9NEJ@bIG5v0FKFV/8C &quot;jq – Try It Online&quot;)\r\n\r\ntostream converts your input to &quot;streaming&quot; [path,value] form: \r\n```\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,0,&quot;clazz&quot;],&quot;AttributeClass2&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,0,&quot;code&quot;],&quot;code21&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,0,&quot;default&quot;],&quot;value21&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,0,&quot;default&quot;]]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,1,&quot;children&quot;,0,&quot;children&quot;],[]]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,1,&quot;children&quot;,0,&quot;clazz&quot;],&quot;AttributeClass1&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,1,&quot;children&quot;,0,&quot;code&quot;],&quot;code31&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,1,&quot;children&quot;,0,&quot;default&quot;],&quot;value31&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,1,&quot;children&quot;,0,&quot;default&quot;]]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,1,&quot;children&quot;,0]]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,1,&quot;clazz&quot;],&quot;AttributeClass1&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,1,&quot;code&quot;],&quot;code22&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,1,&quot;default&quot;],&quot;value22&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,1,&quot;default&quot;]]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,1]]\r\n[[&quot;metaModel&quot;,0,&quot;clazz&quot;],&quot;AttributeClass1&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;code&quot;],&quot;code1&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;default&quot;],&quot;value1&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;default&quot;]]\r\n[[&quot;metaModel&quot;,1,&quot;clazz&quot;],&quot;AttributeClass2&quot;]\r\n[[&quot;metaModel&quot;,1,&quot;code&quot;],&quot;code2&quot;]\r\n[[&quot;metaModel&quot;,1,&quot;default&quot;],&quot;value2&quot;]\r\n[[&quot;metaModel&quot;,1,&quot;default&quot;]]\r\n[[&quot;metaModel&quot;,1]]\r\n[[&quot;metaModel&quot;]]\r\n```\r\nselect filters out all paths not ending in &quot;clazz&quot;, &quot;code&quot; or &quot;children&quot;:\r\n```\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,0,&quot;clazz&quot;],&quot;AttributeClass2&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,0,&quot;code&quot;],&quot;code21&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,1,&quot;children&quot;,0,&quot;children&quot;],[]]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,1,&quot;children&quot;,0,&quot;clazz&quot;],&quot;AttributeClass1&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,1,&quot;children&quot;,0,&quot;code&quot;],&quot;code31&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,1,&quot;clazz&quot;],&quot;AttributeClass1&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;children&quot;,1,&quot;code&quot;],&quot;code22&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;clazz&quot;],&quot;AttributeClass1&quot;]\r\n[[&quot;metaModel&quot;,0,&quot;code&quot;],&quot;code1&quot;]\r\n[[&quot;metaModel&quot;,1,&quot;clazz&quot;],&quot;AttributeClass2&quot;]\r\n[[&quot;metaModel&quot;,1,&quot;code&quot;],&quot;code2&quot;]\r\n```\r\nreduce and setpath reconstruct the final result:\r\n```\r\n{\r\n  &quot;metaModel&quot;: [\r\n    {\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;clazz&quot;: &quot;AttributeClass2&quot;,\r\n          &quot;code&quot;: &quot;code21&quot;\r\n        },\r\n        {\r\n          &quot;children&quot;: [\r\n            {\r\n              &quot;children&quot;: [],\r\n              &quot;clazz&quot;: &quot;AttributeClass1&quot;,\r\n              &quot;code&quot;: &quot;code31&quot;\r\n            }\r\n          ],\r\n          &quot;clazz&quot;: &quot;AttributeClass1&quot;,\r\n          &quot;code&quot;: &quot;code22&quot;\r\n        }\r\n      ],\r\n      &quot;clazz&quot;: &quot;AttributeClass1&quot;,\r\n      &quot;code&quot;: &quot;code1&quot;\r\n    },\r\n    {\r\n      &quot;clazz&quot;: &quot;AttributeClass2&quot;,\r\n      &quot;code&quot;: &quot;code2&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "How to transform json tree recursively with jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1595488676,
                "last_edit_date": 1595488676,
                "creation_date": 1595459286,
                "answer_id": 63044437,
                "question_id": 63027032,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `walk/1`:\r\n```\r\n.metaModel\r\n| walk( if type == &quot;object&quot; and has(&quot;clazz&quot;)\r\n        then {clazz, code} + (if .children then { children } else null end )\r\n        else .\r\n        end )\r\n```",
                "title": "How to transform json tree recursively with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1595488676,
        "creation_date": 1595393026,
        "last_edit_date": 1595397305,
        "question_id": 63027032,
        "body_markdown": "I have the following JSON that I need to transform with jq. The main task is to leave only specified attributes in the tree. The number of levels in the tree may be different. \r\n\r\n        {\r\n        &quot;metaModel&quot;: [ {\r\n            &quot;clazz&quot;: &quot;AttributeClass1&quot;,\r\n            &quot;code&quot;: &quot;code1&quot;,\r\n            &quot;default&quot;: &quot;value1&quot;,\r\n            &quot;children&quot;: [ {\r\n                &quot;clazz&quot;: &quot;AttributeClass2&quot;,\r\n                &quot;code&quot;: &quot;code21&quot;,\r\n                &quot;default&quot;: &quot;value21&quot;\r\n            },\r\n            {\r\n                &quot;clazz&quot;: &quot;AttributeClass1&quot;,\r\n                &quot;code&quot;: &quot;code22&quot;,\r\n                &quot;default&quot;: &quot;value22&quot;,\r\n                &quot;children&quot;: [ {\r\n                    &quot;clazz&quot;: &quot;AttributeClass1&quot;,\r\n                    &quot;code&quot;: &quot;code31&quot;,\r\n                    &quot;default&quot;: &quot;value31&quot;,\r\n                    &quot;children&quot;: []\r\n                }\r\n                ]\r\n            }\r\n            ]\r\n        },\r\n        {\r\n            &quot;clazz&quot;: &quot;AttributeClass2&quot;,\r\n            &quot;code&quot;: &quot;code2&quot;,\r\n            &quot;default&quot;: &quot;value2&quot;\r\n        }\r\n        ]\r\n    }\r\n\r\nIs it possible to get the output like the following (leave only clazz, code, children)?\r\n\r\n        {\r\n            &quot;clazz&quot;: &quot;AttributeClass1&quot;,\r\n            &quot;code&quot;: &quot;code1&quot;,\r\n            &quot;children&quot;: [ {\r\n                &quot;clazz&quot;: &quot;AttributeClass2&quot;,\r\n                &quot;code&quot;: &quot;code21&quot;\r\n            },\r\n            {\r\n                &quot;clazz&quot;: &quot;AttributeClass1&quot;,\r\n                &quot;code&quot;: &quot;code22&quot;,\r\n                &quot;children&quot;: [ {\r\n                    &quot;clazz&quot;: &quot;AttributeClass1&quot;,\r\n                    &quot;code&quot;: &quot;code31&quot;,\r\n                    &quot;children&quot;: []\r\n                }\r\n                ]\r\n            }\r\n            ]\r\n        },\r\n        {\r\n            &quot;clazz&quot;: &quot;AttributeClass2&quot;,\r\n            &quot;code&quot;: &quot;code2&quot;\r\n        }\r\n\r\n&#39;metaModel&#39; may be left in the output too.",
        "link": "https://stackoverflow.com/questions/63027032/how-to-transform-json-tree-recursively-with-jq",
        "title": "How to transform json tree recursively with jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1595420738,
                "post_id": 63033862,
                "comment_id": 111467321,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1595420855,
                "post_id": 63033862,
                "comment_id": 111467375,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19009996,
                    "reputation": 67,
                    "user_id": 13876061,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ff96eaf38ab650e10ef004d019b65d65?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jabra",
                    "link": "https://stackoverflow.com/users/13876061/jabra"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595427956,
                "post_id": 63033862,
                "comment_id": 111471602,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1595444961,
                "creation_date": 1595444961,
                "answer_id": 63041519,
                "question_id": 63033862,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get a stream of the dates for just &quot;england-and-wales&quot; efficiently:\r\n\r\n    .[&quot;england-and-wales&quot;] | .events[] | .date\r\n\r\nIf you wanted these sorted and &quot;uniquified&quot;, simply delay the itemization (`[]`):\r\n\r\n    .[&quot;england-and-wales&quot;] | .events | map(.date) | unique[]",
                "title": "Getting all nested values from a particular key in a given JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1595444961,
        "creation_date": 1595419711,
        "last_edit_date": 1595430410,
        "question_id": 63033862,
        "body_markdown": "I am trying to get all the date values in a json array for the dates inside the england-and-wales value.The array that like this (except it has a lot more values) the json array is here : https://www.gov.uk/bank-holidays.json\r\n\r\n```\r\n{&quot;england-and-wales&quot;:{&quot;division&quot;:&quot;england-and-wales&quot;,&quot;events&quot;:[{&quot;title&quot;:&quot;New Year’s Day&quot;,&quot;date&quot;:&quot;2015-01-01&quot;,&quot;notes&quot;:&quot;&quot;,&quot;bunting&quot;:true}},{&quot;title&quot;:&quot;Good Friday&quot;,&quot;date&quot;:&quot;2015-04-03&quot;,&quot;notes&quot;:&quot;&quot;,&quot;bunting&quot;:false}]},&quot;scotland&quot;:{&quot;division&quot;:&quot;scotla\r\nnd&quot;,&quot;events&quot;:[{&quot;title&quot;:&quot;New Year’s Day&quot;,&quot;date&quot;:&quot;2015-01-01&quot;,&quot;notes&quot;:&quot;&quot;,&quot;bunting&quot;:true},{&quot;title&quot;:&quot;2nd January&quot;,&quot;date&quot;:&quot;2015-01-02&quot;,&quot;notes&quot;:&quot;&quot;,&quot;bunting&quot;:true},{&quot;title&quot;:&quot;Good Friday&quot;,&quot;date&quot;:&quot;2\r\n015-04-03&quot;,&quot;notes&quot;:&quot;&quot;,&quot;bunting&quot;:false},{&quot;title&quot;:&quot;Early May bank holiday&quot;,&quot;date&quot;:&quot;2015-05-04&quot;,&quot;notes&quot;:&quot;&quot;,&quot;bunting&quot;:true}\r\n```\r\n\r\nAs commented below the following will pick out all dates:\r\n```\r\ncurl -s https://www.gov.uk/bank-holidays.json | jq &#39;.. | .date? // empty&#39;\r\n```\r\n\r\nIm not sure how to only pick dates inside the england-and-wales array?",
        "link": "https://stackoverflow.com/questions/63033862/getting-all-nested-values-from-a-particular-key-in-a-given-json",
        "title": "Getting all nested values from a particular key in a given JSON"
    },
    {
        "tags": [
            "select",
            "filter",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595423006,
                "post_id": 63034513,
                "comment_id": 111468572,
                "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": 1595475309,
                "post_id": 63034513,
                "comment_id": 111489151,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8420642,
                    "reputation": 577,
                    "user_id": 6319555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c980bfdff56e5504ecc6b23d3227f384?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Invisible999",
                    "link": "https://stackoverflow.com/users/6319555/invisible999"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595524009,
                "post_id": 63034513,
                "comment_id": 111512255,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8420642,
                    "reputation": 577,
                    "user_id": 6319555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c980bfdff56e5504ecc6b23d3227f384?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Invisible999",
                    "link": "https://stackoverflow.com/users/6319555/invisible999"
                },
                "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": 1595524080,
                "post_id": 63034513,
                "comment_id": 111512290,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595524822,
                "post_id": 63034513,
                "comment_id": 111512652,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1595442683,
                "last_edit_date": 1595442683,
                "creation_date": 1595437330,
                "answer_id": 63039506,
                "question_id": 63034513,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use this filter to achieve the result\r\n\r\n\r\n    [ &quot;Business Overview&quot;, &quot;Load Test&quot;, &quot;Performance Monitoring&quot; ] as $bl | \r\n    map( select( [ [.db[].name] | unique[] | IN( $bl[] ) ] |\r\n      map( select( . == true ) ) |\r\n        length == ($bl|length) | not ) \r\n      )\r\n\r\n&lt;sup&gt;[jqplay - Online demo][1]&lt;/sup&gt;\r\n\r\nThe filter works by selecting number of times, unique instances of `.name` field of the object matches one of the entries in the blacklist array. If the count matches the  number of items in blacklist, we exclude that from being printed.\r\n\r\nYou can also customize the blacklist from the command line by including the array in the `--argjson` field as below and exclude the first line in the above pipeline.\r\n\r\n    --argjson bl &#39;[&quot;Business Overview&quot;, &quot;Load Test&quot;, &quot;Performance Monitoring&quot;]&#39;\r\n\r\n  [1]: https://jqplay.org/s/SOaYKaCjNg",
                "title": "jq - select entry if any of several keys is NOT present"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1595458932,
                "last_edit_date": 1595458932,
                "creation_date": 1595441724,
                "answer_id": 63040705,
                "question_id": 63034513,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `contains` filter seems suited for your task.\r\n\r\n&gt; The filter `contains(b)` will produce true if b is completely contained within the input. … An array B is contained in an array A if all elements in B are contained in any element in A. ([jq 1.6 manual](https://stedolan.github.io/jq/manual/v1.6/#Builtinoperatorsandfunctions))\r\n\r\nMy solution puts the values of &quot;name&quot; in each object into an array. It uses `contains` to see if the array of the values you listed are all in that array.\r\n\r\n    jq &#39;map( select( [.db[].name]\r\n       | contains( [&quot;Business Overview&quot;, &quot;Performance Monitoring&quot;, &quot;Load Test&quot;] )\r\n       | not ) )&#39;\r\n\r\n**Note**\r\n\r\nInian points out that `contains` can be tricky. For example, this returns &quot;true.&quot;\r\n\r\n    jq &#39;contains([&quot;A&quot;])&#39; &lt;&lt;&lt; &#39;[&quot;A B&quot;]&#39;\r\n\r\nThat could lead to the wrong result if the value of &quot;name&quot; is &quot;Business Overview B&quot; and so on.",
                "title": "jq - select entry if any of several keys is NOT present"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1595447890,
                "creation_date": 1595447890,
                "answer_id": 63042235,
                "question_id": 63034513,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an approach that uses [index](https://stedolan.github.io/jq/manual/#index\\(s\\),rindex\\(s\\)) and [any/2](https://stedolan.github.io/jq/manual/#any,any\\(condition\\),any\\(generator;condition\\)) (the two argument form of any) along with map and select in a manner similar to the other answers given here.\r\n```\r\n  [ &quot;Performance Monitoring&quot;, &quot;Business Overview&quot;, &quot;Load Test&quot; ] as $required\r\n| map( select( [.db[].name] | any(index($required[]); . == null) ) )\r\n```\r\n[Try it online!](https://tio.run/##tZJNb9swDIbv@RWEsEMKRAFlyXayoYdtGLDDvrBmuxg@yBZTeEjk1naydmt/e0Y3dnaYg7ZDS8EQTErvC/LRj8vdDiAB8YWqZVmtrc8JPpa@aMqq8OdiAuLNpi481TV83lK1Lehnm/xQWgcLqhsBKdgaXlR0uSkqcqMbWNuLMdS0orwZQzJ1WZJOvV1TCjdg/fW48I6uxocbSXryCqZwegp@s1qdAK/dLhkB/OYPQLzzTXUtXna/nFiQt77hjHj7Wi7MXAdi0tfOGntObemicuIuebuvCZdxOunO9VqcL1x7/KoNRFQSLVqJGWYSc8xlHIVGm4MBX2hbaa/8O5fuzO3kmEvGMWQSZdEsxmjI5QiX/7ZaRioyUThk9Zdpr97t6ahzup/Ip@/ya6C0HiDiaPsYInkb3EHUdRBj/AxEqjbYhbWXuJQ4Q713CUnNtFbPjcShk87oeRg/EMlR9V8crG4kEhILO9f6kCSaacRB9fcl7wOsDy738/62kGc8qHCAd930M3kY8CznhagDBpDn0qBBqZxyUgfRPNBPDtzqzEgVaNwDR1IBGvOUwG1muSFz96L4bbnc9ki0ih@LZJT@AQ &quot;jq – Try It Online&quot;)",
                "title": "jq - select entry if any of several keys is NOT present"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1595474665,
                "creation_date": 1595474665,
                "answer_id": 63046376,
                "question_id": 63034513,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here are two solutions which avoid `contains` (which has complex semantics, as noted elsewhere on this page) and `index/1` (which currently is not implemented as efficiently as one would hope).  In both cases, it is assumed that\r\n`$required` has somehow been set to the list of required values, e.g. by:\r\n\r\n```\r\n[&quot;Business Overview&quot;, &quot;Load Test&quot;, &quot;Performance Monitoring&quot;] as $required\r\n```\r\n\r\n## Simple\r\n    map(select( $required - [.db[].name] != []))\r\n\r\n## Efficient\r\n```\r\nmap(select( .db as $db\r\n            | all( $required[]; . as $req | any($db[].name; . == $req) )\r\n            | not))\r\n\r\n```\r\n",
                "title": "jq - select entry if any of several keys is NOT present"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1595475125,
        "creation_date": 1595421914,
        "last_edit_date": 1595475125,
        "question_id": 63034513,
        "body_markdown": "I have the JSON file as shown below. What I want - using jq select and display as a new array all the individual Entries where db[].name \r\nis missing any of &quot;Business Overview&quot;, &quot;Load Test&quot; or &quot;Performance Monitoring&quot;. In other words, any Entry where all three of them are present in db.[] should be dropped and left only these where any of them is missing.\r\n\r\nSo, the result of applying such a filter would be displaying the very last Entry with &quot;Tenant&quot;: &quot;UT-S1835&quot;, where db[].name is missing &quot;Load Test&quot;.\r\n\r\nI can&#39;t seem to make it work. You probably know better, would be glad to know how.\r\n\r\nThanks\r\n\r\n```\r\n[\r\n  {\r\n    &quot;Entry&quot;: {\r\n      &quot;Tenant&quot;: &quot;CA-T4932&quot;,\r\n      &quot;Stage&quot;: &quot;prd&quot;\r\n    },\r\n    &quot;db&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;xxxxx0001-0a0a-0b0b-0c0c-765434&quot;,\r\n        &quot;name&quot;: &quot;Business Overview&quot;,\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;bbbb0001-0a0a-0b0b-0c0c-6b68706&quot;,\r\n        &quot;name&quot;: &quot;Performance Monitoring&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;bbbb0001-0a0a-0b0b-0c0c-f616465&quot;,\r\n        &quot;name&quot;: &quot;Load Test&quot;\r\n      }\r\n\t  ]\r\n  },\r\n  {\r\n    &quot;Entry&quot;: {\r\n      &quot;Tenant&quot;: &quot;NV-R2133&quot;,\r\n      &quot;Stage&quot;: &quot;dev&quot;\r\n    },\r\n    &quot;db&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;ccccc0006-0a0a-0707-0c0c-765434&quot;,\r\n        &quot;name&quot;: &quot;Business Overview&quot;,\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;rrrrr0007-0f0f-0803-0c0c-5e18331&quot;,\r\n        &quot;name&quot;: &quot;Performance Monitoring&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;bbbb0001-0a0a-0b0b-0d0d-d439575&quot;,\r\n        &quot;name&quot;: &quot;Load Test&quot;\r\n      },\r\n\t  {\r\n        &quot;id&quot;: &quot;zzzz0004-0e0e-0ddd-0a0e-ee83005&quot;,\r\n        &quot;name&quot;: &quot;Home&quot;\r\n      }\r\n\t  ]\r\n   },\r\n     {\r\n    &quot;Entry&quot;: {\r\n      &quot;Tenant&quot;: &quot;UT-S1835&quot;,\r\n      &quot;Stage&quot;: &quot;stg&quot;\r\n     },\r\n    &quot;db&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;bcbcb0032-0ccc-4040-1d1d-326923&quot;,\r\n        &quot;name&quot;: &quot;Business Overview&quot;,\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;rrrrr0007-a3b4-1230-0c0c-0e12044&quot;,\r\n        &quot;name&quot;: &quot;Performance Monitoring&quot;\r\n      },\r\n\t  {\r\n        &quot;id&quot;: &quot;abab0043-0c0f-0dca-0a0e-ee31705&quot;,\r\n        &quot;name&quot;: &quot;Home&quot;\r\n      }\r\n\t  ]\r\n   }\r\n]\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/63034513/jq-select-entry-if-any-of-several-keys-is-not-present",
        "title": "jq - select entry if any of several keys is NOT present"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595491388,
                "post_id": 63046989,
                "comment_id": 111494474,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17760454,
                    "reputation": 1,
                    "user_id": 12896555,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/uQqKc.jpg?s=256",
                    "display_name": "Nadeem Taj",
                    "link": "https://stackoverflow.com/users/12896555/nadeem-taj"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595492370,
                "post_id": 63046989,
                "comment_id": 111494951,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1595502882,
                "last_edit_date": 1595502882,
                "creation_date": 1595501886,
                "answer_id": 63052660,
                "question_id": 63046989,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "While waiting a jq&#39;s solution, let me address the question &quot;... or any tool?&quot;\r\n\r\nDifferent people mean different things by &quot;merging&quot;, thus assuming here a plain recursive JSON merging, then with `jtc` (another tool) the solution would be like this (for an arbitrary number of files):\r\n- read all the JSONs into one super JSON array\r\n- merge into the 1st child (the first read JSON) the rest of read JSONs\r\n- output the resulting 1st JSON child in the array \r\n\r\n```\r\njtc -J / -w[0] -mi[1:] / -w[0] *.json \r\n```\r\nto illustrate the solution, here&#39;s how it works with couple arbitrary JSON files:\r\n```\r\nbash $ jtc -tc file1.json \r\n{\r\n   &quot;days&quot;: {\r\n      &quot;2020-05-18&quot;: { &quot;seconds&quot;: 60 },\r\n      &quot;2020-05-19&quot;: { &quot;seconds&quot;: 30 },\r\n      &quot;2020-05-20&quot;: { &quot;seconds&quot;: 1400 }\r\n   },\r\n   &quot;total&quot;: { &quot;seconds&quot;: 1490 }\r\n}\r\nbash $ jtc -tc file2.json \r\n{\r\n   &quot;days&quot;: {\r\n      &quot;2020-05-20&quot;: { &quot;seconds&quot;: 95 },\r\n      &quot;2020-05-21&quot;: { &quot;seconds&quot;: 80 },\r\n      &quot;2020-05-22&quot;: { &quot;seconds&quot;: 120 }\r\n   },\r\n   &quot;total&quot;: { &quot;seconds&quot;: 295 }\r\n}\r\nbash $ jtc -J / -w[0] -mi[1:] / -w[0] -tc file*.json\r\n{\r\n   &quot;days&quot;: {\r\n      &quot;2020-05-18&quot;: { &quot;seconds&quot;: 60 },\r\n      &quot;2020-05-19&quot;: { &quot;seconds&quot;: 30 },\r\n      &quot;2020-05-20&quot;: {\r\n         &quot;seconds&quot;: [ 1400, 95 ]\r\n      },\r\n      &quot;2020-05-21&quot;: { &quot;seconds&quot;: 80 },\r\n      &quot;2020-05-22&quot;: { &quot;seconds&quot;: 120 }\r\n   },\r\n   &quot;total&quot;: {\r\n      &quot;seconds&quot;: [ 1490, 295 ]\r\n   }\r\n}\r\nbash $ \r\n```\r\n&gt; `-tc` flag is used only to display JSONs here in a compact format\r\n\r\n\r\nPS. It so happens that I&#39;m the creator of `jtc` tool - unix JSON processing utility.\r\n\r\n",
                "title": "How to merge multiple json files in a directory with jq or any tool?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1626216333,
                "last_edit_date": 1626216333,
                "creation_date": 1626214387,
                "answer_id": 68369869,
                "question_id": 63046989,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**The answer**\r\nHere is the `jq` answer... for more see the explanation below:\r\n\r\n    s=&quot;*.json&quot;; jq -s &quot;`x=-1; n=$(ls $s | wc -l); while [ $((x++)) -lt $(($n-2)) ]; do printf &quot;.[$x] * &quot; ; done; printf &quot;.[$(($n-1))]&quot;;`&quot; $s\r\n\r\n**Step by step explanation**\r\n\r\nTo merge two json files using `jq` use this command:\r\n\r\n    jq -s &quot;.[0] * .[1]&quot; file1.json file2.json\r\n\r\nNow to merge three json files:\r\n\r\n    jq -s &quot;.[0] * .[1] * .[2]&quot; file1.json file2.json file3.json\r\n\r\nLet&#39;s follow the same logic and generalise for n files using wildcards. The difficult part is to generate the string `.[0] * .[1] ... .[n-1]`. \r\n\r\nFirst let&#39;s find n. n is the number of json files in the folder. so:\r\n\r\n    ls *.json | wc -l\r\n\r\nnow let&#39;s write a loop that will build the string &quot;.[1] * .. * .[a] * .[a+1] * .. * .[n-2] *&quot;. The kernel of this string is `.[a] *` so:\r\n\r\n    x=-1; n=$(ls *.json | wc -l); while [ $((x++)) -lt $(($n-2)) ]; do printf &quot;.[$x] * &quot; ; done;\r\n\r\nok and now let&#39;s add the last part `.[n-1]`:\r\n\r\n    x=-1; n=$(ls *.json | wc -l); while [ $((x++)) -lt $(($n-2)) ]; do printf &quot;.[$x] * &quot; ; done; printf &quot;.[$(($n-1))]&quot;;\r\n\r\nnow let&#39;s pass that string to the jq command... and let&#39;s parameterise *.json so that we can replace it with whatever we want with ease:\r\n\r\n    s=&quot;*.json&quot;; jq -s &quot;`x=-1; n=$(ls $s | wc -l); while [ $((x++)) -lt $(($n-2)) ]; do printf &quot;.[$x] * &quot; ; done; printf &quot;.[$(($n-1))]&quot;;`&quot; $s\r\n\r\net voil&#224;!",
                "title": "How to merge multiple json files in a directory with jq or any tool?"
            },
            {
                "up_vote_count": 11,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1652290514,
                "creation_date": 1652290514,
                "answer_id": 72205326,
                "question_id": 63046989,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this:\r\n```\r\njq -s add *.json &gt; merged.json\r\n```",
                "title": "How to merge multiple json files in a directory with jq or any tool?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1713423089,
                "creation_date": 1713423089,
                "answer_id": 78345395,
                "question_id": 63046989,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "My JSON files contain JSON object. `jq -s add *.json` did not work, but the following works\r\n\r\n```\r\njq -s &#39;.&#39; *.json &gt; merged.json\r\n```",
                "title": "How to merge multiple json files in a directory with jq or any tool?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1725464140,
                "creation_date": 1725464140,
                "answer_id": 78949466,
                "question_id": 63046989,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From what I&#39;ve seen, `jq -s add *.json` merges objects only at the top level (i.e. not recursively), and `jq -s &#39;.&#39; *.json` creates an array with each element being one of the JSON files.\r\n\r\nThe command Ouss wrote just hung for me, so I don&#39;t know about that.\r\n\r\nI ended up using the following, which simple enough and worked for me to perform a recursive merge of multiple JSON files:\r\n\r\n```bash\r\njq -s &#39;reduce .[] as $obj ({}; . * $obj)&#39; *.json\r\n```\r\n",
                "title": "How to merge multiple json files in a directory with jq or any tool?"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 7,
        "last_activity_date": 1725464140,
        "creation_date": 1595479116,
        "last_edit_date": 1595491368,
        "question_id": 63046989,
        "body_markdown": "I am trying to merge all json files in a directory (can be many).\r\n\r\nI know that if there are only 2 files, I can use `jq -s . file1.json file2.json`. But when I tried to use the a wild card like `jq -s . file*.json`, it fails. Any idea?\r\n",
        "link": "https://stackoverflow.com/questions/63046989/how-to-merge-multiple-json-files-in-a-directory-with-jq-or-any-tool",
        "title": "How to merge multiple json files in a directory with jq or any tool?"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "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": 1595501114,
                "post_id": 63052020,
                "comment_id": 111499561,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11001122,
                    "reputation": 183,
                    "user_id": 9014551,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e7859ef064e6a26d3e8e826587a3ec46?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Mayur Kadam",
                    "link": "https://stackoverflow.com/users/9014551/mayur-kadam"
                },
                "reply_to_user": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595504263,
                "post_id": 63052020,
                "comment_id": 111501112,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1595505198,
                "creation_date": 1595505198,
                "answer_id": 63053636,
                "question_id": 63052020,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you just want the `results` array of objects:\r\n\r\n    jq -r &#39;([&quot;id&quot;,&quot;ph_no&quot;,&quot;status&quot;], (.results[] | [.id, .ph_no, .status])) | @csv&#39; temp.json",
                "title": "Convert JSON Array to CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1595505541,
        "creation_date": 1595499742,
        "last_edit_date": 1595501054,
        "question_id": 63052020,
        "body_markdown": "Trying to convert a JSON array into a CSV file using `jq` but not able to succeed. Following is my JSON output from `curl` command:\r\n\r\n    {\r\n      &quot;requestID&quot;: &quot;463aeb25-f4c3-40ba-a031-e62d698afc6e&quot;,\r\n      &quot;signature&quot;: {\r\n        &quot;id&quot;: &quot;json&quot;,\r\n        &quot;ph_no&quot;: &quot;json&quot;,\r\n        &quot;status&quot;: &quot;json&quot;\r\n      },\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;9f34-66758813073c&quot;,\r\n          &quot;ph_no&quot;: &quot;343434325&quot;,\r\n          &quot;status&quot;: &quot;active&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;b1a2-30a14a68c576&quot;,\r\n          &quot;ph_no&quot;: &quot;6767666764&quot;,\r\n          &quot;status&quot;: &quot;active&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;9af4-5b231f05ce37&quot;,\r\n          &quot;ph_no&quot;: &quot;546745435&quot;,\r\n          &quot;status&quot;: &quot;active&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;99bd-ed67fd139074&quot;,\r\n          &quot;ph_no&quot;: &quot;323246566&quot;,\r\n          &quot;status&quot;: &quot;active&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;9ecc-8277c3ffa274&quot;,\r\n          &quot;ph_no&quot;: &quot;6753643554&quot;,\r\n          &quot;status&quot;: &quot;active&quot;\r\n        }\r\n      ],\r\n      &quot;status&quot;: &quot;success&quot;,\r\n      &quot;metrics&quot;: {\r\n        &quot;elapsedTime&quot;: &quot;29.461027ms&quot;,\r\n        &quot;executionTime&quot;: &quot;29.364961ms&quot;,\r\n        &quot;resultCount&quot;: 146,\r\n        &quot;resultSize&quot;: 13856\r\n      }\r\n    }\r\n\r\nI have tried using following referring to some solutions online but not working.\r\n\r\n    jq  -r &#39;[&quot;id&quot;,&quot;ph_no&quot;,&quot;status&quot;],(to_entries|.[]|[.key,.value.id,.value.ph_no,.value.status)|@csv&#39;  temp.json\r\n\r\nHow should i modify the `jq` command to convert JSON to CSV ?\r\n",
        "link": "https://stackoverflow.com/questions/63052020/convert-json-array-to-csv",
        "title": "Convert JSON Array to CSV"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4719941,
                    "reputation": 33452,
                    "user_id": 4518341,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XRndu.png?s=256",
                    "display_name": "wjandrea",
                    "link": "https://stackoverflow.com/users/4518341/wjandrea"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1595525373,
                "post_id": 63059832,
                "comment_id": 111512879,
                "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": 5,
                "creation_date": 1595525421,
                "post_id": 63059832,
                "comment_id": 111512892,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1595525447,
                "post_id": 63059832,
                "comment_id": 111512905,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18925838,
                    "reputation": 10183,
                    "user_id": 13809001,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14Gjyemx6zXG9xxFSU3QnY6douwouRvKC87a1c6A=k-s256",
                    "display_name": "M. Nejat Aydin",
                    "link": "https://stackoverflow.com/users/13809001/m-nejat-aydin"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1595525483,
                "post_id": 63059832,
                "comment_id": 111512920,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595525588,
                "post_id": 63059832,
                "comment_id": 111512985,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10275035,
                    "reputation": 121775,
                    "user_id": 7582247,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KPNHoVDG.png?s=256",
                    "display_name": "Ted Lyngmo",
                    "link": "https://stackoverflow.com/users/7582247/ted-lyngmo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1595525623,
                "post_id": 63059832,
                "comment_id": 111513001,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10275035,
                    "reputation": 121775,
                    "user_id": 7582247,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KPNHoVDG.png?s=256",
                    "display_name": "Ted Lyngmo",
                    "link": "https://stackoverflow.com/users/7582247/ted-lyngmo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595526152,
                "post_id": 63059832,
                "comment_id": 111513229,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12637594,
                    "reputation": 45,
                    "user_id": 9186277,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/decfb3261d8f637218cdab94b4df5ea8?s=256&d=identicon&r=PG",
                    "display_name": "user9186277",
                    "link": "https://stackoverflow.com/users/9186277/user9186277"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595526324,
                "post_id": 63059832,
                "comment_id": 111513307,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10275035,
                    "reputation": 121775,
                    "user_id": 7582247,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KPNHoVDG.png?s=256",
                    "display_name": "Ted Lyngmo",
                    "link": "https://stackoverflow.com/users/7582247/ted-lyngmo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595526497,
                "post_id": 63059832,
                "comment_id": 111513391,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10275035,
                    "reputation": 121775,
                    "user_id": 7582247,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KPNHoVDG.png?s=256",
                    "display_name": "Ted Lyngmo",
                    "link": "https://stackoverflow.com/users/7582247/ted-lyngmo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595526682,
                "post_id": 63059832,
                "comment_id": 111513482,
                "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": 1595526891,
                "post_id": 63059832,
                "comment_id": 111513593,
                "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": 1595527328,
                "post_id": 63059832,
                "comment_id": 111513795,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10275035,
                    "reputation": 121775,
                    "user_id": 7582247,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KPNHoVDG.png?s=256",
                    "display_name": "Ted Lyngmo",
                    "link": "https://stackoverflow.com/users/7582247/ted-lyngmo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595527384,
                "post_id": 63059832,
                "comment_id": 111513817,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1595605411,
                "creation_date": 1595605411,
                "answer_id": 63076942,
                "question_id": 63059832,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. The provided &quot;JSON&quot; is invalid as JSON.  Please fix it.\r\n\r\n2. When using jq at the bash command line, it&#39;s almost always best to enclose the jq program in single-quotation marks; bash shell variables can be passed in using --arg or --argjson.  Consider for example the following snippet that assume `commandGetEvents&#39; is valid JSON along the lines suggested in the Q:\r\n```\r\nindex=0\r\ncurrentEventId=$(jq --argjson index $index &#39;.[$index].eventId&#39; &lt;&lt;&lt; ${commandGetEvents})\r\necho index=$index\r\necho currentEventId=$currentEventId\r\n```\r\n3. The part of the question involving `eventCounter` is somewhat obscure, but it looks like the example given immediately above will serve as a guide.\r\n\r\n4. Rather than using bash constructs to iterate through the JSON array, it would almost certainly be better to use jq&#39;s support for iteration and selection. For example:\r\n\r\n    jq &#39;.[] | select(.eventId == 22)&#39; &lt;&lt;&lt; ${commandGetEvents}\r\n\r\nyields:\r\n```\r\n{\r\n  &quot;eventId&quot;: 22,\r\n  &quot;Name&quot;: &quot;Bob&quot;,\r\n  &quot;Activity&quot;: &quot;Eat Food&quot;,\r\n  &quot;startedEventId&quot;: 15\r\n}\r\n```\r\n\r\nSo if you just want the startedEventId value (or values) corresponding to .eventId == 22, you could write:\r\n\r\n    jq &#39;.[] | select(.eventId == 22) | .startedEventId&#39; &lt;&lt;&lt; ${commandGetEvents}",
                "title": "Bash number comparision error: line 90: [[: 22: syntax error: operand expected (error token is &quot;22&quot;)"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1595605411,
        "creation_date": 1595525021,
        "last_edit_date": 1595526224,
        "question_id": 63059832,
        "body_markdown": "Let&#39;s assume `$commandGetEvents` is an array of json objects. I use the following command to extract the event Id, which is a number from 1 - 65 and store it in `currentEventId`. Now let&#39;s assume I have another variable called `startedEventId` which holds the value I&#39;m looking for, which is 22.\r\n\r\nHere&#39;s an example of the data $commandGetEvents contains.\r\n\r\n```\r\n[   \r\n  {\r\n        &quot;eventId&quot;: 22,\r\n        &quot;Name&quot; : &quot;Bob&quot;\r\n        &quot;Activity&quot; : &quot;Eat Food&quot;\r\n        &quot;startedEventId&quot; : 15\r\n    },\r\n    {\r\n        &quot;eventId&quot;: 21,\r\n        &quot;Name&quot; : &quot;Smith&quot;\r\n        &quot;Activity&quot; : &quot;Ride a bike&quot;\r\n        &quot;startedEventId&quot; : 13\r\n    },\r\n    {\r\n        &quot;eventId&quot;: 20,\r\n        &quot;Name&quot; : &quot;Tony&quot;\r\n        &quot;Activity&quot;: &quot;Print paper&quot;\r\n        &quot;startedEventId&quot; : 10\r\n    },\r\n]\r\n```\r\neventId is the unique identifier of the json object. &amp; startedEventId is the identifier of json object that caused the current one to take place. \r\n\r\n```\r\ncurrentEventId=$(jq &quot;.[$index].eventId&quot; &lt;&lt;&lt; ${commandGetEvents})\r\nstartedEventid=$(jq &quot;.[${eventCounter}].startedEventId&quot; &lt;&lt;&lt; $commandGetEvents)\r\n```\r\n\r\nWhen i echo both statements in a while loop, I get the following output. \r\n\r\n```\r\ncurrentEventId = 1\r\nstartedEventId = 22\r\n\r\ncurrentEventId = 2\r\nstartedEventId = 22\r\n\r\ncurrentEventId = 3\r\nstartedEventId = 22\r\n```\r\n\r\nThe while loop continues until all elements of `currentEventId` are exhausted. \r\n\r\nMy problem is when I compare both statements like this: \r\n\r\n```\r\nif [[ ${startedId} -eq ${currentEventId} ]] ;\r\n   then\r\n   echo &quot;Equal&quot;\r\nfi\r\n```\r\n\r\nI get the following error message: \r\n\r\n```none\r\nline 90: [[: 22: syntax error: operand expected (error token is &quot;22&quot;)\r\n```",
        "link": "https://stackoverflow.com/questions/63059832/bash-number-comparision-error-line-90-22-syntax-error-operand-expected",
        "title": "Bash number comparision error: line 90: [[: 22: syntax error: operand expected (error token is &quot;22&quot;)"
    },
    {
        "tags": [
            "json",
            "select",
            "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": 1595605795,
                "post_id": 63076675,
                "comment_id": 111542659,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1595681820,
                "last_edit_date": 1595681820,
                "creation_date": 1595604647,
                "answer_id": 63076743,
                "question_id": 63076675,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Got it, posting because this took a few minutes and there were some red-herrings in the first few threads I followed:\r\n\r\n```\r\ncat foo.jsonl | jq &#39;. | select( .&quot;arbitrary.key&quot; | match(&quot;^f&quot;))&#39;\r\n```",
                "title": "JQ: filter and select rows from JSONL input?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1595681820,
        "creation_date": 1595604413,
        "last_edit_date": 1595681810,
        "question_id": 63076675,
        "body_markdown": "Suppose I have a JSONL file: \r\n\r\n```\r\n# foo.jsonl\r\n\r\n{ &quot;arbitrary.key&quot;:&quot;foo&quot; }\r\n{ &quot;arbitrary.key&quot;:&quot;foobar&quot; }\r\n{ &quot;arbitrary.key&quot;:&quot;bar&quot; }\r\n```\r\n\r\nAnd I would like to filter the rows of this file: \r\n\r\n```\r\n# in pseudo code\r\ncat foo.jsonl | jq &#39;. | where(.&quot;arbitrary.key&quot; | is_match(&quot;^foo&quot;))&#39;\r\n``` \r\n\r\nIs this possible in `jq`? ",
        "link": "https://stackoverflow.com/questions/63076675/jq-filter-and-select-rows-from-jsonl-input",
        "title": "JQ: filter and select rows from JSONL input?"
    },
    {
        "tags": [
            "python",
            "json",
            "bash",
            "sed",
            "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": 1,
                "creation_date": 1595616145,
                "post_id": 63078109,
                "comment_id": 111547091,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1595616215,
                "post_id": 63078109,
                "comment_id": 111547119,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2982365,
                    "reputation": 663,
                    "user_id": 2532068,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/7a0c7ccb271de9a8fcd0641a3d0cc752?s=256&d=identicon&r=PG",
                    "display_name": "Byron Mansfield",
                    "link": "https://stackoverflow.com/users/2532068/byron-mansfield"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595616490,
                "post_id": 63078109,
                "comment_id": 111547238,
                "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": 3,
                "creation_date": 1595616651,
                "post_id": 63078109,
                "comment_id": 111547305,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2982365,
                    "reputation": 663,
                    "user_id": 2532068,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/7a0c7ccb271de9a8fcd0641a3d0cc752?s=256&d=identicon&r=PG",
                    "display_name": "Byron Mansfield",
                    "link": "https://stackoverflow.com/users/2532068/byron-mansfield"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595617442,
                "post_id": 63078109,
                "comment_id": 111547662,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1595615184,
                "last_edit_date": 1595615184,
                "creation_date": 1595612622,
                "answer_id": 63078833,
                "question_id": 63078109,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So first to add results into new file create a json file with &quot;[]&quot; an empty array as its content, this is to make sure the file we load is valid json.\r\nNext run the following command for each file as input\r\n```\r\njq --argjson results &quot;$(&lt;new.json)&quot; &#39;.result | . += $results  &#39;  orig.json &gt; new.json\r\n```\r\nIssue with your query was .result[] this return all the elements individually not as a json object in format\r\n```\r\n{}\r\n{}\r\n```\r\ninstead of \r\n```\r\n[\r\n{},\r\n{}\r\n]\r\n```\r\n",
                "title": "How to add json objects from file to another json array of objects in another file"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1595620422,
                "creation_date": 1595620422,
                "answer_id": 63080588,
                "question_id": 63078109,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can turn the invalid JSON from the API response into a valid array by wrapping it in `[...]`. The resulting array can be imported and added directly to the `result` array.\r\n\r\n&lt;pre&gt;&lt;code&gt;jq --argjson results &quot;&lt;b&gt;[&lt;/b&gt;$(&amp;lt;new.json)&lt;b&gt;]&lt;/b&gt;&quot; &#39;.result += &lt;b&gt;$results&lt;/b&gt;&#39; original.json&lt;/code&gt;&lt;/pre&gt;",
                "title": "How to add json objects from file to another json array of objects in another file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1595621441,
                "creation_date": 1595621441,
                "answer_id": 63080790,
                "question_id": 63078109,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Based on the given new.json and its description, you seem to have comma-separated JSON objects with the JSON-separating commas on separate lines matching the regex &#39;^}, *$&#39;\r\n\r\nIf that&#39;s the case, the good news is you can achieve the result you want by simply removing the superfluous commas with:\r\n\r\n    sed &#39;s/^}, *$/}/&#39; new.txt\r\n\r\nThis produces a stream of objects, which can then be processed in any one of several well-known ways (e.g. by &quot;slurping&quot; it using the -s option).\r\n\r\n### &quot;XY problem&quot;?\r\n\r\nIn a side-comment, you wrote:\r\n\r\n&gt; I did fix this with sed to add the commas, which are included in the question.\r\n\r\nSo it is beginning to sound as if the Q as posted is really a so-called [&quot;XY&quot; problem][1].  Anyway, if you were starting with a stream of JSON objects, then of course there would be need to add the commas and deal with the consequences.   \r\n\r\n\r\n  [1]: https://meta.stackexchange.com/questions/66377/what-is-the-xy-problem",
                "title": "How to add json objects from file to another json array of objects in another file"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1595621441,
        "creation_date": 1595609711,
        "question_id": 63078109,
        "body_markdown": "In *nix environment. I&#39;m seeking a solution on how to add some (not quite so valid) json in a file, to another (valid) json file. Let me elaborate and also cover some failed attempts I&#39;ve tried so far.\r\n\r\nThis will run in a shell script in a loop which will grow quite large. It&#39;s making an api call which can only return 1000 at a time. However, there are 70,000,000+ total records. So, I will have to make this api call 70,000 times in order to get all of the desired records. The original json file I want to keep, it includes information outside of the actual data I want, such as result info and success messages, etc. Each time I iterate and call the next set, I&#39;m trying to strip out that information and just append the main data records to the main data records of the first set.\r\n\r\nI&#39;m already 99% there. I&#39;m attempting this using `jq` `sed` and `python`. The body of the data records is not technically valid json. So `jq` is complaining because it can only append if valid data. My attempt looks like this `jq --argjson results &quot;$(&lt;new.json)&quot; &#39;.result[] += [$results]&#39; original.json`. But if it would, then it would be valid json.\r\n\r\nI&#39;ve already used `grep -n` to abstract the line number of where I want to start appending the new sets of records to the first set of records. So I&#39;ve been trying to use `sed` but can not figure out the right syntax. Though I feel I&#39;m close. I&#39;ve been trying something like `sed -i -e $linenumber &#39;&lt;a few sed things here&gt; new.json&#39; original.json`. But no success yet.\r\n\r\nI&#39;ve now tried to write a `python` script to do this. But I had never tried anything like this before. Just some string matching on readlines and string replacements. I didn&#39;t realize that there isn&#39;t a built in method for jumping to a specific line. I guess I could do some find statements to jump to that line in `python` but I&#39;ve already done this in the bash script. Also, I realize I could read each line to memory in `python` but I fear that with this many records, it might get to be too much and become very slow.\r\n\r\nI had some passing thoughts on trying some kind of `head` and `tail` and write in between since I know the exact line number. Any thoughts or solutions with any tools/languages are welcome. This is a devops project that is just to diagnose some logs, so I&#39;m trying to not make this a full project, as once I produce the logs, I&#39;ll shift all my focus and efforts to running commands against this final produced json file and not really use this script ever again.\r\n\r\nExample of `original.json`\r\n\r\n```\r\n{\r\n  &quot;result&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;5b5915f4cdb39c7b&quot;,\r\n      &quot;kind&quot;: &quot;foo&quot;,\r\n      &quot;source&quot;: &quot;bar&quot;,\r\n      &quot;action&quot;: &quot;baz&quot;,\r\n      &quot;matches&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;b298ee91704b489b8119c1d604a8308d&quot;,\r\n          &quot;source&quot;: &quot;blah&quot;,\r\n          &quot;action&quot;: &quot;buzz&quot;\r\n        }\r\n      ],\r\n      &quot;occurred_at&quot;: &quot;date&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;5b5915f4cdb39c7b&quot;,\r\n      &quot;kind&quot;: &quot;foo&quot;,\r\n      &quot;source&quot;: &quot;bar&quot;,\r\n      &quot;action&quot;: &quot;baz&quot;,\r\n      &quot;matches&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;b298ee91704b489b8119c1d604a8308d&quot;,\r\n          &quot;source&quot;: &quot;blah&quot;,\r\n          &quot;action&quot;: &quot;buzz&quot;\r\n        }\r\n      ],\r\n      &quot;occurred_at&quot;: &quot;date&quot;\r\n    }\r\n],\r\n  &quot;result_info&quot;: {\r\n    &quot;cursors&quot;: {\r\n      &quot;after&quot;: &quot;dlipU4c&quot;,\r\n      &quot;before&quot;: &quot;iLjx06u&quot;\r\n    },\r\n    &quot;scanned_range&quot;: {\r\n      &quot;since&quot;: &quot;date&quot;,\r\n      &quot;until&quot;: &quot;date&quot;\r\n    }\r\n  },\r\n  &quot;success&quot;: true,\r\n  &quot;errors&quot;: [],\r\n  &quot;messages&quot;: []\r\n}\r\n```\r\nExample of new.json\r\n```\r\n{\r\n  &quot;id&quot;: &quot;5b5915f4cdb39c7b&quot;,\r\n  &quot;kind&quot;: &quot;foo&quot;,\r\n  &quot;source&quot;: &quot;bar&quot;,\r\n  &quot;action&quot;: &quot;baz&quot;,\r\n  &quot;matches&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;b298ee91704b489b8119c1d604a8308d&quot;,\r\n      &quot;source&quot;: &quot;blah&quot;,\r\n      &quot;action&quot;: &quot;buzz&quot;\r\n    }\r\n  ],\r\n  &quot;occurred_at&quot;: &quot;date&quot;\r\n},\r\n{\r\n  &quot;id&quot;: &quot;5b5915f4cdb39c7b&quot;,\r\n  &quot;kind&quot;: &quot;foo&quot;,\r\n  &quot;source&quot;: &quot;bar&quot;,\r\n  &quot;action&quot;: &quot;baz&quot;,\r\n  &quot;matches&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;b298ee91704b489b8119c1d604a8308d&quot;,\r\n      &quot;source&quot;: &quot;blah&quot;,\r\n      &quot;action&quot;: &quot;buzz&quot;\r\n    }\r\n  ],\r\n  &quot;occurred_at&quot;: &quot;date&quot;\r\n}\r\n```\r\nDon&#39;t worry about the indentation or missing trailing commas, I already have that figured out and confirmed working. ",
        "link": "https://stackoverflow.com/questions/63078109/how-to-add-json-objects-from-file-to-another-json-array-of-objects-in-another-fi",
        "title": "How to add json objects from file to another json array of objects in another file"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595632358,
                "post_id": 63082535,
                "comment_id": 111552263,
                "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": 1595632856,
                "post_id": 63082535,
                "comment_id": 111552363,
                "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": 1595632979,
                "post_id": 63082535,
                "comment_id": 111552387,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1595632750,
                "creation_date": 1595632750,
                "answer_id": 63082623,
                "question_id": 63082535,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `--arg` prevents your data from being incorrectly parsed as syntax. Usually, a shell variable you&#39;re passing into `jq` contains literal data, so this is the correct thing.\r\n\r\nIn this case, your variable contains syntax, not literal data: The `.` isn&#39;t part of the string you want to do a lookup by, but is instead an instruction to jq to do two separate lookups one after the other.\r\n\r\nSo, in this case, you should do the more obvious thing, *instead of* using `--arg`:\r\n\r\n```\r\njq -e &quot;.$KEY&quot;\r\n```",
                "title": "Passing a path (&quot;key1.key2&quot;) from a bash variable to jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1595659153,
        "creation_date": 1595632067,
        "last_edit_date": 1595659153,
        "question_id": 63082535,
        "body_markdown": "I am having trouble accessing bash variable inside &#39;jq&#39;.\r\nThe snippet below shows my bash loop to check for missing keys in a Json file.\r\n\r\n    #!/bin/sh\r\n    for key in &quot;key1&quot; &quot;key2.key3&quot;; do\r\n      echo &quot;$key&quot;\r\n      if ! cat ${JSON_FILE} | jq --arg KEY &quot;$key&quot; -e &#39;.[$KEY]&#39;; then\r\n        missingKeys+=${key}\r\n      fi\r\n    done\r\n\r\nJSON_FILE:\r\n\r\n    {\r\n      &quot;key1&quot;: &quot;val1&quot;,\r\n      &quot;key2&quot;: {\r\n        &quot;key3&quot;: &quot;val3&quot;\r\n      }\r\n    }\r\n\r\nThe script works correctly for top level keys such as &quot;key1&quot;. But it does not work correctly (returns null) for &quot;key2.key3&quot;.\r\n\r\n&#39;jq&#39; on the command line does return the correct value\r\n\r\n    cat input.json | jq &#39;.key2.key3&#39;\r\n    &quot;val3&quot;\r\n\r\nI followed answers from other posts to come to this solution. However can&#39;t seem to figure out why it does not work for nested json keys.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63082535/passing-a-path-key1-key2-from-a-bash-variable-to-jq",
        "title": "Passing a path (&quot;key1.key2&quot;) from a bash variable to jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8244357,
                    "reputation": 47,
                    "user_id": 6201006,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/10209214821191725/picture?type=large",
                    "display_name": "Fernando F. Freire",
                    "link": "https://stackoverflow.com/users/6201006/fernando-f-freire"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595697280,
                "post_id": 63091111,
                "comment_id": 111566978,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8244357,
                    "reputation": 47,
                    "user_id": 6201006,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/10209214821191725/picture?type=large",
                    "display_name": "Fernando F. Freire",
                    "link": "https://stackoverflow.com/users/6201006/fernando-f-freire"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595697527,
                "post_id": 63091111,
                "comment_id": 111567043,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1595733293,
                "last_edit_date": 1595733293,
                "creation_date": 1595699720,
                "answer_id": 63091666,
                "question_id": 63091111,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the `next` key is either nonexistent in the response or its value is a string forming a valid URL when prepended to `http://example.com`:\r\n```\r\n#!/bin/bash -\r\nnext=/\r\nwhile resp=$(curl -sS &quot;http://example.com$next&quot;); do\r\n  if ! next=$(jq -er &#39;.next&#39; &lt;&lt;&lt; &quot;$resp&quot;); then\r\n    # `resp&#39; is the final response here\r\n    # , do whatever you want with it\r\n    break\r\n  fi\r\ndone\r\n```",
                "title": "Follow links in cURL responses using a loop"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1666590356,
        "creation_date": 1595696667,
        "last_edit_date": 1666590356,
        "question_id": 63091111,
        "body_markdown": "```\r\ncurl -H &quot;Accept: application/json&quot; &#39;http://example.com&#39;\r\n```\r\nthe response I get is \r\n```\r\n{&quot;next&quot;:&quot;/gibberish&quot;}\r\n```\r\nSo I perform another request:\r\n```\r\ncurl -H &quot;Accept: application/json&quot; &#39;http://example.com/gibberish&#39;\r\n```\r\nthe response I get is \r\n```\r\n{&quot;next&quot;:&quot;/anotherGibberish&quot;}\r\n```\r\n\r\nI want to be able to do the curl request, get the `next` information and loop in to the next request. \r\n\r\nDo you guys have any idea how to perform this in bash? \r\n\r\n**EDIT:** Any help using jq would also be great.\r\nThe last response is a JSON response with an authentication failure - that&#39;s where I should stop the loop. \r\n\r\n```\r\n{&quot;unauthorized&quot;:&quot;Authenticate with username and password&quot;}\r\n```",
        "link": "https://stackoverflow.com/questions/63091111/follow-links-in-curl-responses-using-a-loop",
        "title": "Follow links in cURL responses using a loop"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595710650,
                "post_id": 63093336,
                "comment_id": 111570717,
                "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": 0,
                "creation_date": 1595710751,
                "post_id": 63093336,
                "comment_id": 111570754,
                "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": 0,
                "creation_date": 1595710785,
                "post_id": 63093336,
                "comment_id": 111570764,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10283711,
                    "reputation": 318,
                    "user_id": 8274517,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/59a7422b05e69d553afea3bfb241942b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Firmin Martin",
                    "link": "https://stackoverflow.com/users/8274517/firmin-martin"
                },
                "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": 1595710834,
                "post_id": 63093336,
                "comment_id": 111570776,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1595716924,
                "creation_date": 1595716924,
                "answer_id": 63094310,
                "question_id": 63093336,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Depending on how you want to handle `null`/`empty` values you could try these:\r\n\r\n    map(.b |= (. // [] | join(&quot;, &quot;)))\r\n\r\n    map(if .b then .b |= join(&quot;, &quot;) else . end)",
                "title": "jq: join string array whether it is empty or not"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1595716924,
        "creation_date": 1595709518,
        "last_edit_date": 1595710866,
        "question_id": 63093336,
        "body_markdown": "I have a JSON `test.json` as follows:\r\n```json\r\n[\r\n  {\r\n    &quot;a&quot;: &quot;a&quot;,\r\n    &quot;b&quot;: [\r\n      &quot;a&quot;,\r\n      &quot;b&quot;,\r\n      &quot;c&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;a&quot;: &quot;a&quot;\r\n  }\r\n]\r\n```\r\nAnd I would want to join the field `b` of each entry and handle the case of its\r\nemptiness:\r\n\r\n```json\r\n{  &quot;a&quot;: &quot;a&quot;,\r\n  &quot;b&quot;: &quot;a, b, c&quot;\r\n},\r\n{\r\n  &quot;a&quot;: &quot;a&quot;,\r\n  &quot;b&quot;: null\r\n}\r\n```\r\nThe following command works...\r\n```bash\r\ncat test.json | \r\n      jq &#39;.[] | .b as $t | if $t then {a: .a, b: $t | join(&quot;, &quot;)} else {a: .a, b: $t} end&#39;\r\n```\r\n... but it&#39;s too long as I have to write almost the same constructor two times.\r\n\r\nI have tried to move the `if-then-else` conditional or even the `//` operator in the `{}` construction, but they result to a syntax error.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63093336/jq-join-string-array-whether-it-is-empty-or-not",
        "title": "jq: join string array whether it is empty or not"
    },
    {
        "tags": [
            "json",
            "jq",
            "key-value",
            "del"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595758291,
                "post_id": 63097014,
                "comment_id": 111579237,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1595790587,
                "last_edit_date": 1595790587,
                "creation_date": 1595750927,
                "answer_id": 63097659,
                "question_id": 63097014,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not easy, finding *elements* which have a `tags` key somewhere whose value is either the string `internal`, or an array of which an element is the string `internal` in a reliable way is only possible with a complex boolean expression as below.\r\n\r\nOnce found, deleting them can be done using the `del` built-in.\r\n```\r\ndel(.[] | first(select(recurse\r\n  | objects\r\n  | has(&quot;tags&quot;) and (.tags\r\n    | . == &quot;internal&quot; or (\r\n      type == &quot;array&quot; and index(&quot;internal&quot;)\r\n    )\r\n  )\r\n)))\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/r6ukB-Ol17)&lt;/sup&gt;",
                "title": "Remove parent elements with certain key-value pairs using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1691495824,
                "last_edit_date": 1691495824,
                "creation_date": 1595753985,
                "answer_id": 63098128,
                "question_id": 63097014,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following solution is written with a helper function for clarity.  The helper function uses `any` for efficiency and is defined so as to add a dash of generality.\r\n\r\nTo understand the solution, it will be helpful to know about [`with_entries`][1] and the infix [``//``][2] operator, both of which are explained in the jq manual.  \r\n\r\n```\r\n# Does the incoming JSON value contain an object which has a .tags\r\n# value that is equal to $value or to an array containing $value ?\r\ndef hasTag($value):\r\n  any(.. | select(type==&quot;object&quot;) | .tags;\r\n      . == $value or (type == &quot;array&quot; and index($value)));\r\n```\r\nAssuming the top-level JSON entity is a JSON object, we can now simply write:\r\n```\r\nwith_entries( select( .value | hasTag(&quot;internal&quot;) | not) )\r\n```\r\n\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/v1.6/#to_entries-from_entries-with_entries\r\n  [2]: https://jqlang.github.io/jq/manual/v1.6/#alternative-operator",
                "title": "Remove parent elements with certain key-value pairs using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1595795408,
                "creation_date": 1595795408,
                "answer_id": 63105379,
                "question_id": 63097014,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think I figured out how to also solve the more complex case. I am now running:\r\n````\r\nwalk(if type == &quot;object&quot; and has(&quot;tags&quot;) and (.tags  | . == &quot;internal&quot; or (type == &quot;array&quot; and index(&quot;internal&quot;))) then del(.) else . end) | delpaths([paths as $path | select(getpath($path) == null) | $path])\r\n````\r\nThis will remove all elements that contain &#39;internal&#39; as &#39;tag&#39;.",
                "title": "Remove parent elements with certain key-value pairs using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1691495824,
        "creation_date": 1595746205,
        "last_edit_date": 1595822048,
        "question_id": 63097014,
        "body_markdown": "I need to remove elements from a json file based on certain key values. Here is the file I am trying to process.\r\n\r\n````\r\n{\r\n  &quot;element1&quot;: &quot;Test Element 1&quot;,\r\n  &quot;element2&quot;: {\r\n    &quot;tags&quot;: &quot;internal&quot;,\r\n    &quot;data&quot;: {\r\n      &quot;data1&quot;: &quot;Test Data 1&quot;,\r\n      &quot;data2&quot;: &quot;Test Data 2&quot;\r\n    }\r\n  },\r\n  &quot;element3&quot;: {\r\n    &quot;function1&quot;: {\r\n      &quot;tags&quot;: [\r\n        &quot;new&quot;,\r\n        &quot;internal&quot;\r\n      ]\r\n    },\r\n    &quot;data3&quot;: &quot;Test Data 3&quot;,\r\n    &quot;data4&quot;: &quot;Test Data 4&quot;\r\n  },\r\n  &quot;element4&quot;: {\r\n    &quot;function2&quot;: {\r\n      &quot;tags&quot;: &quot;new&quot;\r\n    },\r\n    &quot;data5&quot;: &quot;Test Data 5&quot;\r\n  }\r\n}\r\n````\r\nI want to remove all elements that have a &quot;tag&quot; with value &quot;internal&quot;. So the result should look like this:\r\n````\r\n{\r\n  &quot;element1&quot;: &quot;Test Element 1&quot;,\r\n  &quot;element4&quot;: {\r\n    &quot;function2&quot;: {\r\n      &quot;tags&quot;: &quot;new&quot;\r\n    },\r\n    &quot;data5&quot;: &quot;Test Data 5&quot;\r\n  }\r\n}\r\n````\r\nI tried various approaches but I just don&#39;t get it done using jq. Any ideas? Thanks.\r\n\r\nJust to add some more complexity. Let&#39;s assume the json is:\r\n````\r\n{\r\n  &quot;element1&quot;: &quot;Test Element 1&quot;,\r\n  &quot;element2&quot;: {\r\n    &quot;tags&quot;: &quot;internal&quot;,\r\n    &quot;data&quot;: {\r\n      &quot;data1&quot;: &quot;Test Data 1&quot;,\r\n      &quot;data2&quot;: &quot;Test Data 2&quot;\r\n    }\r\n  },\r\n  &quot;element3&quot;: {\r\n    &quot;function1&quot;: {\r\n      &quot;tags&quot;: [\r\n        &quot;new&quot;,\r\n        &quot;internal&quot;\r\n      ]\r\n    },\r\n    &quot;data3&quot;: &quot;Test Data 3&quot;,\r\n    &quot;data4&quot;: &quot;Test Data 4&quot;\r\n  },\r\n  &quot;element4&quot;: {\r\n    &quot;function2&quot;: {\r\n      &quot;tags&quot;: &quot;new&quot;\r\n    },\r\n    &quot;data5&quot;: &quot;Test Data 5&quot;\r\n  },\r\n  &quot;structure1&quot; : {\r\n    &quot;substructure1&quot;: {\r\n      &quot;element5&quot;: &quot;Test Element 5&quot;,\r\n      &quot;element6&quot;: {\r\n        &quot;tags&quot;: &quot;internal&quot;,\r\n        &quot;data6&quot;: &quot;Test Data 6&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n````\r\nand I want to get\r\n````\r\n{\r\n  &quot;element1&quot;: &quot;Test Element 1&quot;,\r\n  &quot;element4&quot;: {\r\n    &quot;function2&quot;: {\r\n      &quot;tags&quot;: &quot;new&quot;\r\n    },\r\n    &quot;data5&quot;: &quot;Test Data 5&quot;\r\n  },\r\n  &quot;structure1&quot; : {\r\n    &quot;substructure1&quot;: {\r\n      &quot;element5&quot;: &quot;Test Element 5&quot;,\r\n    }\r\n  }\r\n}\r\n````",
        "link": "https://stackoverflow.com/questions/63097014/remove-parent-elements-with-certain-key-value-pairs-using-jq",
        "title": "Remove parent elements with certain key-value pairs using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "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": 1595752884,
                "post_id": 63097905,
                "comment_id": 111577935,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13211984,
                    "reputation": 237,
                    "user_id": 9541890,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e7d8e9f46dfa066f99bd4a7ab7f373f2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "papi",
                    "link": "https://stackoverflow.com/users/9541890/papi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595753256,
                "post_id": 63097905,
                "comment_id": 111578017,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1924671,
                    "reputation": 96232,
                    "user_id": 1735406,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://i.sstatic.net/IF9uS.png?s=256",
                    "display_name": "Maroun",
                    "link": "https://stackoverflow.com/users/1735406/maroun"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595753338,
                "post_id": 63097905,
                "comment_id": 111578047,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13211984,
                    "reputation": 237,
                    "user_id": 9541890,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e7d8e9f46dfa066f99bd4a7ab7f373f2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "papi",
                    "link": "https://stackoverflow.com/users/9541890/papi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595754232,
                "post_id": 63097905,
                "comment_id": 111578273,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1595754654,
                "post_id": 63097905,
                "comment_id": 111578400,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3201485,
                    "reputation": 3470,
                    "user_id": 2703456,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1f3b76d7aea8eda16387053e6767a618?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Reino",
                    "link": "https://stackoverflow.com/users/2703456/reino"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1595757531,
                "post_id": 63097905,
                "comment_id": 111579044,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1595780707,
                "creation_date": 1595780707,
                "answer_id": 63102755,
                "question_id": 63097905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one possibility:\r\n\r\n    any(.[]; .id == &quot;13&quot;)",
                "title": "check if specific string is in Json file via bash"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1595795651,
                "creation_date": 1595795651,
                "answer_id": 63105416,
                "question_id": 63097905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**Note**: when the question was closed, I added this answer to the question in an effort to get the question reopened:\r\n\r\n```bash\r\n(( $(jq &lt; file.json &#39;[.[].id | select(. == &quot;13&quot;)] | length&#39;) &gt; 0))\r\n```\r\n\r\nThe OP said it was inefficient. I do not know why. Here is what it does:\r\n\r\n1. It passes the JSON through the `jq` program, which is a JSON parser. The bash shell has no native understanding of JSON, so any solution is going to make use of an external program. Other programs will treat JSON as text, and may work in some or most cases, but it is best to use a program like `jq` that follows the formal JSON specification to parse the data.\r\n\r\n1. It creates an array to capture the output of...\r\n\r\n   1. It loops through the array, picking out all the `id` fields\r\n\r\n   1. It outputs the value of the `id` field if the value is &quot;13&quot;\r\n\r\n1. It counts the length of the array, which is the number of the `id` fields whose value is &quot;13&quot;\r\n\r\n1. Using native `bash`, it converts that output into a number and evaluates to true if the number is greater than 0 and false otherwise.\r\n\r\nI do not think you will find something significantly more efficient that formally follows the JSON spec.\r\n\r\n- This only runs 1 program, `jq`, which is the *de facto* standard JSON processor. It is not part of the POSIX standard (which predates JSON) but it is the most likely JSON processor to be installed on a system.\r\n- This uses native `bash` constructs to interpret the output and to the test.\r\n- There is not going to be a solution that is more efficient because it runs zero programs (bash cannot do it alone) and there is not going to be a better program to use than `jq`. \r\n- There is not going to be a significantly better `jq` filter, because it is going to process the entire input (that is just how it works) and the `select` filter stops the processing of objects that fail the test, which is all or almost all of them. \r\n\r\nThe alternative &quot;peak&quot; suggests is more compact and more elegant (good things) but not significantly more (or less) efficient. It looks better in the post because a lot is left out. The full test would be\r\n\r\n```bash\r\n[[ $(jq &lt; file.json &#39;any(.[]; .id == &quot;13&quot;)&#39;) == &quot;true&quot; ]]\r\n```\r\n\r\nActually, the `.[];` generator is unnecessary, so the even more compact answer would be \r\n\r\n```bash\r\n[[ $(jq &lt; file.json &#39;any(.id == &quot;13&quot;)&#39;) == &quot;true&quot; ]]\r\n```",
                "title": "check if specific string is in Json file via bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1595807499,
                "creation_date": 1595807499,
                "answer_id": 63106988,
                "question_id": 63097905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one simple way to to determine if a given &quot;id&quot; value is present using `perl`:\r\n\r\n    echo &#39;[ { &quot;id&quot;:&quot;45&quot; }, { &quot;id&quot;:&quot;56&quot; }, { &quot;id&quot;:&quot;13&quot; }, { &quot;id&quot;:&quot;5&quot; } ]&#39; | perl -00 -lne &#39;if (/&quot;id&quot;:&quot;13&quot;/) {print &quot;true&quot;} else {print &quot;false&quot;}&#39;\r\n    true\r\n\r\n    echo &#39;[ { &quot;id&quot;:&quot;45&quot; }, { &quot;id&quot;:&quot;56&quot; }, { &quot;id&quot;:&quot;13&quot; }, { &quot;id&quot;:&quot;5&quot; } ]&#39; | perl -00 -lne &#39;if (/&quot;id&quot;:&quot;33&quot;/) {print &quot;true&quot;} else {print &quot;false&quot;}&#39;\r\n    false\r\n\r\n",
                "title": "check if specific string is in Json file via bash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1595807499,
        "creation_date": 1595752473,
        "last_edit_date": 1595793625,
        "question_id": 63097905,
        "body_markdown": "Lets say this is my json file content:\r\n\r\n    [ { &quot;id&quot;:&quot;45&quot; }, { &quot;id&quot;:&quot;56&quot; }, { &quot;id&quot;:&quot;13&quot; }, { &quot;id&quot;:&quot;5&quot; } ]\r\n\r\nand I want to find out if id &quot;13&quot; is in the json file. \r\nIs there an way to do this in `bash`?\r\n\r\nI tried to run the command with jq and all sorts of different variations of it (with contain and without for example) and nothing answers this query for me.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63097905/check-if-specific-string-is-in-json-file-via-bash",
        "title": "check if specific string is in Json file via bash"
    },
    {
        "tags": [
            "json",
            "awk",
            "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": 5,
                "creation_date": 1595794756,
                "post_id": 63105247,
                "comment_id": 111590781,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15827931,
                    "reputation": 15,
                    "user_id": 11420222,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c6d4c99147a58c24d9fb0fc97b37fd94?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "DavidBoe",
                    "link": "https://stackoverflow.com/users/11420222/davidboe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595795545,
                "post_id": 63105247,
                "comment_id": 111591008,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15827931,
                    "reputation": 15,
                    "user_id": 11420222,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c6d4c99147a58c24d9fb0fc97b37fd94?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "DavidBoe",
                    "link": "https://stackoverflow.com/users/11420222/davidboe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1595796246,
                "post_id": 63105247,
                "comment_id": 111591184,
                "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": 1595800050,
                "post_id": 63105247,
                "comment_id": 111592201,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1595805158,
                "last_edit_date": 1595805158,
                "creation_date": 1595798958,
                "answer_id": 63105891,
                "question_id": 63105247,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s doable in `jq` with some string interpolation:\r\n\r\n```\r\n$ find . -name &quot;*.json&quot; -exec jq -r \\\r\n  &#39;(input_filename | gsub(&quot;^\\\\./|\\\\.json$&quot;;&quot;&quot;)) as $fname |\r\n   (map(.gender.value) | unique | join(&quot;,&quot;)) as $genders |\r\n   (map(.age|floor|tostring) | join(&quot;,&quot;)) as $ages |\r\n   (map(.age_group) | unique | join(&quot;,&quot;)) as $age_groups |\r\n   &quot;\\($fname) &amp; \\($genders) &amp; \\($ages) &amp; \\($age_groups)&quot;&#39; &#39;{}&#39; +\r\n1000 &amp; Female,Male &amp; 38,26 &amp; adult\r\n2000 &amp; Male &amp; 63,11 &amp; adult,child\r\n```\r\n\r\nThe `input_filename` command returns the obvious, and for the other parts, just grab the needed fields from `.` as an array and join them into CSV strings (Using `join` instead of `@csv` to avoid added quotes).\r\n\r\n---\r\n\r\nThe `find` stuff is to avoid the possibility of just `jq -r &#39;...&#39; *.json` being too long a command line, since you said you have more than 5000 files. It runs `jq` potentially multiple times, with as many filenames as possible each time (The trailing `+` instead of `;` makes `-exec` work a lot like `xargs`), instead of running it once per file, for the sake of efficiency.",
                "title": "Get json values using awk or jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1595903995,
        "creation_date": 1595794557,
        "last_edit_date": 1595903995,
        "question_id": 63105247,
        "body_markdown": "My json files looks like this.\r\n\r\n\r\ni have more than 5000 files :\r\nfilename : **xxxx.json**\r\n\r\nexample file **1000.json**\r\n```\r\n[\r\n  {\r\n    &quot;gender&quot;: {\r\n      &quot;value&quot;: &quot;Female&quot;\r\n    },\r\n    &quot;age&quot;: 38.58685,\r\n    &quot;age_group&quot;: &quot;adult&quot;\r\n  },\r\n  {\r\n    &quot;gender&quot;: {\r\n      &quot;value&quot;: &quot;Male&quot;\r\n    },\r\n    &quot;age&quot;: 26.64953,\r\n    &quot;age_group&quot;: &quot;adult&quot;\r\n  }\r\n]\r\n```\r\n\r\nexample file **2000.json**\r\n```\r\n[\r\n  {\r\n    &quot;gender&quot;: {\r\n      &quot;value&quot;: &quot;Male&quot;\r\n    },\r\n    &quot;age&quot;: 63.8272,\r\n    &quot;age_group&quot;: &quot;adult&quot;\r\n  },\r\n  {\r\n    &quot;gender&quot;: {\r\n      &quot;value&quot;: &quot;Male&quot;\r\n    },\r\n    &quot;age&quot;: 11.8287,\r\n    &quot;age_group&quot;: &quot;child&quot;\r\n  }\r\n]\r\n```\r\n\r\nDesired Output in one file **output.txt**\r\n\r\n```1000 &amp; Female,Male &amp; 38,26 &amp; adult,adult``` &lt;br/&gt; ```2000 &amp; Male,Male &amp; 63,11 &amp; adult,child```",
        "link": "https://stackoverflow.com/questions/63105247/get-json-values-using-awk-or-jq",
        "title": "Get json values using awk or jq"
    },
    {
        "tags": [
            "json",
            "apache-kafka",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1595864797,
                "last_edit_date": 1595864797,
                "creation_date": 1595830248,
                "answer_id": 63109564,
                "question_id": 63108807,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To pair corresponding elements of two arrays and construct an object out of them, we use the `transpose` built-in in conjunction with `add`.\r\n\r\nAnd slurping raw input into a huge single JSON script is often unnecessary, not to mention how bad a practice it is.\r\n\r\nGiven `--null-input` and `--raw-input` options on the command line, this JQ program produces your expected output:\r\n```\r\n[ input | splits(&quot; +&quot;) ] as $header | [\r\n  inputs\r\n  | [ splits(&quot; +&quot;) ]\r\n  | select(. != $header)\r\n  | [ $header, . ]\r\n  | [ transpose[] | { (.[0]): .[1] } ]\r\n  | add\r\n]\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/LEuZ-EoYRo)&lt;/sup&gt;",
                "title": "Convert table to JSON omitting repeated header lines"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1595864797,
        "creation_date": 1595824863,
        "last_edit_date": 1595833769,
        "question_id": 63108807,
        "body_markdown": "I have a Kafka command which will give you an output in below format. \r\n\r\n    GROUP                         TOPIC           PARTITION  CURRENT-OFFSET  LOG-END-OFFSET  LAG             CONSUMER-ID                                                                     HOST            CLIENT-ID\r\n    connect-mm-leads-mapture-map DEV.mmvm.V2 0          9               9               0               connector-consumer-mm-leads-mapture-map-0-296b0e23-0995-4220-b493-fb006f41760a /10.00.000.00   connector-consumer-mm-leads-mapture-map-0\r\n    connect-mm-leads-mapture-map DEV.mmLeads.V1 1          7               7               0               connector-consumer-mm-leads-mapture-map-0-296b0e23-0995-4220-b493-fb006f41760a /10.01.01.01   connector-consumer-mm-leads-mapture-map-0\r\n    GROUP             TOPIC                          PARTITION  CURRENT-OFFSET  LOG-END-OFFSET  LAG             CONSUMER-ID                                                         HOST            CLIENT-ID\r\n    connect-ccc-7562w DEV3.MMAutoshipTemplates.V1    0          594013          594021          8               connector-consumer-kkk-34ff-0-dfsfdsf-dsfd-1 /10.01.01.02   connector-consumer-ccc-7562w-0\r\n    connect-ccc-7562w DEV3.MMProducts.V1             0          4884            4885            1               connector-consumer-kkk-234f-2444vf-2-s-dsffdd-11 /10.01.01.03   connector-consumer-ccc-7562w-0\r\n    connect-kkk-7562w DEV3.mmLeads.V1\r\n    GROUP                              TOPIC              PARTITION  CURRENT-OFFSET  LOG-END-OFFSET  LAG             CONSUMER-ID                                                                                                                          HOST            CLIENT-ID\r\n    _company-centerpart-0-command _company-command 0          20              20              0               _company-centerpart-0-command-0d76f6e2-7ff3-47fa-a63c-0f36aedda046-StreamThread-1-consumer-66e0cc27-469e-4735-80cf-c930f27f6e5e /10.01.01.04   _company-centerpart-0-command-0d76f6e2-7ff3-47fa-a63c-0f36aedda046-StreamThread-1-consumer\r\n\r\nBut I want the output in Json format and the content should come as below. \r\n\r\nDesired Output should be :\r\n\r\n    [\r\n     {\r\n       &quot;GROUP&quot;: &quot;connect-mm-leads-mapture-map&quot;,\r\n       &quot;TOPIC&quot;: &quot;DEV.mmvm.V2&quot;,\r\n       &quot;PARTITION&quot;: &quot;0&quot;,\r\n       &quot;CURRENT-OFFSET&quot;: &quot;9&quot;,\r\n       &quot;LOG-END-OFFSET&quot;: &quot;9&quot;,\r\n       &quot;LAG&quot;: &quot;0&quot;,\r\n       &quot;CONSUMER-ID&quot;: &quot;connector-consumer-mm-leads-mapture-map-0-296b0e23-0995-4220-b493-fb006f41760a&quot;,\r\n       &quot;HOST&quot;: &quot;/10.00.000.00&quot;,\r\n       &quot;CLIENT-ID&quot;: &quot;connector-consumer-mm-leads-mapture-map-0&quot;\r\n     },\r\n     {\r\n       &quot;GROUP&quot;: &quot;connect-mm-leads-mapture-map&quot;,\r\n       &quot;TOPIC&quot;: &quot;DEV.mmLeads.V1&quot;,\r\n       &quot;PARTITION&quot;: &quot;1&quot;,\r\n       &quot;CURRENT-OFFSET&quot;: &quot;7&quot;,\r\n       &quot;LOG-END-OFFSET&quot;: &quot;7&quot;,\r\n       &quot;LAG&quot;: &quot;0&quot;,\r\n       &quot;CONSUMER-ID&quot;: &quot;connector-consumer-mm-leads-mapture-map-0-296b0e23-0995-4220-b493-fb006f41760a&quot;,\r\n       &quot;HOST&quot;: &quot;/10.01.01.01&quot;,\r\n       &quot;CLIENT-ID&quot;: &quot;connector-consumer-mm-leads-mapture-map-0&quot;\r\n     },\r\n     {\r\n       &quot;GROUP&quot;: &quot;connect-ccc-7562w&quot;,\r\n       &quot;TOPIC&quot;: &quot;DEV3.MMAutoshipTemplates.V1&quot;,\r\n       &quot;PARTITION&quot;: &quot;0&quot;,\r\n       &quot;CURRENT-OFFSET&quot;: &quot;594013&quot;,\r\n       &quot;LOG-END-OFFSET&quot;: &quot;594021&quot;,\r\n       &quot;LAG&quot;: &quot;8&quot;,\r\n       &quot;CONSUMER-ID&quot;: &quot;connector-consumer-kkk-34ff-0-dfsfdsf-dsfd-1&quot;,\r\n       &quot;HOST&quot;: &quot;/10.01.01.02&quot;,\r\n       &quot;CLIENT-ID&quot;: &quot;connector-consumer-ccc-7562w-0&quot;\r\n     },\r\n     {\r\n       &quot;GROUP&quot;: &quot;connect-ccc-7562w&quot;,\r\n       &quot;TOPIC&quot;: &quot;DEV3.MMProducts.V1&quot;,\r\n       &quot;PARTITION&quot;: &quot;0&quot;,\r\n       &quot;CURRENT-OFFSET&quot;: &quot;4884&quot;,\r\n       &quot;LOG-END-OFFSET&quot;: &quot;4885&quot;,\r\n       &quot;LAG&quot;: &quot;1&quot;,\r\n       &quot;CONSUMER-ID&quot;: &quot;connector-consumer-kkk-234f-2444vf-2-s-dsffdd-11&quot;,\r\n       &quot;HOST&quot;: &quot;/10.01.01.03&quot;,\r\n       &quot;CLIENT-ID&quot;: &quot;connector-consumer-ccc-7562w-0&quot;\r\n     },\r\n     {\r\n       &quot;GROUP&quot;: &quot;connect-kkk-7562w&quot;,\r\n       &quot;TOPIC&quot;: &quot;DEV3.mmLeads.V1&quot;,\r\n       &quot;PARTITION&quot;: &quot;&quot;,\r\n       &quot;CURRENT-OFFSET&quot;: &quot;&quot;,\r\n       &quot;LOG-END-OFFSET&quot;: &quot;&quot;,\r\n       &quot;LAG&quot;: &quot;&quot;,\r\n       &quot;CONSUMER-ID&quot;: &quot;&quot;,\r\n       &quot;HOST&quot;: &quot;&quot;,\r\n       &quot;CLIENT-ID&quot;: &quot;&quot;\r\n     },\r\n    \r\n     {\r\n       &quot;GROUP&quot;: &quot;_company-centerpart-0-command&quot;,\r\n       &quot;TOPIC&quot;: &quot;_company-command&quot;,\r\n       &quot;PARTITION&quot;: &quot;0&quot;,\r\n       &quot;CURRENT-OFFSET&quot;: &quot;20&quot;,\r\n       &quot;LOG-END-OFFSET&quot;: &quot;20&quot;,\r\n       &quot;LAG&quot;: &quot;0&quot;,\r\n       &quot;CONSUMER-ID&quot;: &quot;_company-centerpart-0-command-0d76f6e2-7ff3-47fa-a63c-0f36aedda046-StreamThread-1-consumer-66e0cc27-469e-4735-80cf-c930f27f6e5e&quot;,\r\n       &quot;HOST&quot;: &quot;/10.01.01.04&quot;,\r\n       &quot;CLIENT-ID&quot;: &quot;_company-centerpart-0-command-0d76f6e2-7ff3-47fa-a63c-0f36aedda046-StreamThread-1-consumer&quot;\r\n     }\r\n    ]\r\n\r\nI am using below command and able to convert into expected json with some additional meaning less data.\r\n\r\nCommand :\r\n```\r\n./kafka-consumer-groups.sh --bootstrap-server &quot;xxxxxxx:9092&quot; --command-config /root/config.properties --describe --all-groups| jq -sR &#39;[sub(&quot;\\n$&quot;;&quot;&quot;) | splits(&quot;\\n&quot;) | sub(&quot;^ +&quot;;&quot;&quot;) | [splits(&quot; +&quot;)]] | .[1] as $header | .[2:] | [.[] | [. as $x | range($header | length) | {&quot;key&quot;: $header[.], &quot;value&quot;: $x[.]}] | from_entries]&#39;\r\n```\r\nCommand output :\r\n\r\n    [\r\n     {\r\n       &quot;GROUP&quot;: &quot;connect-mm-leads-mapture-map&quot;,\r\n       &quot;TOPIC&quot;: &quot;DEV.mmvm.V2&quot;,\r\n       &quot;PARTITION&quot;: &quot;0&quot;,\r\n       &quot;CURRENT-OFFSET&quot;: &quot;9&quot;,\r\n       &quot;LOG-END-OFFSET&quot;: &quot;9&quot;,\r\n       &quot;LAG&quot;: &quot;0&quot;,\r\n       &quot;CONSUMER-ID&quot;: &quot;connector-consumer-mm-leads-mapture-map-0-296b0e23-0995-4220-b493-fb006f41760a&quot;,\r\n       &quot;HOST&quot;: &quot;/10.00.000.00&quot;,\r\n       &quot;CLIENT-ID&quot;: &quot;connector-consumer-mm-leads-mapture-map-0&quot;\r\n     },\r\n     {\r\n       &quot;GROUP&quot;: &quot;connect-mm-leads-mapture-map&quot;,\r\n       &quot;TOPIC&quot;: &quot;DEV.mmLeads.V1&quot;,\r\n       &quot;PARTITION&quot;: &quot;1&quot;,\r\n       &quot;CURRENT-OFFSET&quot;: &quot;7&quot;,\r\n       &quot;LOG-END-OFFSET&quot;: &quot;7&quot;,\r\n       &quot;LAG&quot;: &quot;0&quot;,\r\n       &quot;CONSUMER-ID&quot;: &quot;connector-consumer-mm-leads-mapture-map-0-296b0e23-0995-4220-b493-fb006f41760a&quot;,\r\n       &quot;HOST&quot;: &quot;/10.01.01.01&quot;,\r\n       &quot;CLIENT-ID&quot;: &quot;connector-consumer-mm-leads-mapture-map-0&quot;\r\n     },\r\n     {\r\n       &quot;GROUP&quot;: &quot;GROUP&quot;,\r\n       &quot;TOPIC&quot;: &quot;TOPIC&quot;,\r\n       &quot;PARTITION&quot;: &quot;PARTITION&quot;,\r\n       &quot;CURRENT-OFFSET&quot;: &quot;CURRENT-OFFSET&quot;,\r\n       &quot;LOG-END-OFFSET&quot;: &quot;LOG-END-OFFSET&quot;,\r\n       &quot;LAG&quot;: &quot;LAG&quot;,\r\n       &quot;CONSUMER-ID&quot;: &quot;CONSUMER-ID&quot;,\r\n       &quot;HOST&quot;: &quot;HOST&quot;,\r\n       &quot;CLIENT-ID&quot;: &quot;CLIENT-ID&quot;\r\n     },\r\n     {\r\n       &quot;GROUP&quot;: &quot;connect-ccc-7562w&quot;,\r\n       &quot;TOPIC&quot;: &quot;DEV3.MMAutoshipTemplates.V1&quot;,\r\n       &quot;PARTITION&quot;: &quot;0&quot;,\r\n       &quot;CURRENT-OFFSET&quot;: &quot;594013&quot;,\r\n       &quot;LOG-END-OFFSET&quot;: &quot;594021&quot;,\r\n       &quot;LAG&quot;: &quot;8&quot;,\r\n       &quot;CONSUMER-ID&quot;: &quot;connector-consumer-kkk-34ff-0-dfsfdsf-dsfd-1&quot;,\r\n       &quot;HOST&quot;: &quot;/10.01.01.02&quot;,\r\n       &quot;CLIENT-ID&quot;: &quot;connector-consumer-ccc-7562w-0&quot;\r\n     },\r\n     {\r\n       &quot;GROUP&quot;: &quot;connect-ccc-7562w&quot;,\r\n       &quot;TOPIC&quot;: &quot;DEV3.MMProducts.V1&quot;,\r\n       &quot;PARTITION&quot;: &quot;0&quot;,\r\n       &quot;CURRENT-OFFSET&quot;: &quot;4884&quot;,\r\n       &quot;LOG-END-OFFSET&quot;: &quot;4885&quot;,\r\n       &quot;LAG&quot;: &quot;1&quot;,\r\n       &quot;CONSUMER-ID&quot;: &quot;connector-consumer-kkk-234f-2444vf-2-s-dsffdd-11&quot;,\r\n       &quot;HOST&quot;: &quot;/10.01.01.03&quot;,\r\n       &quot;CLIENT-ID&quot;: &quot;connector-consumer-ccc-7562w-0&quot;\r\n     },\r\n     {\r\n       &quot;GROUP&quot;: &quot;connect-kkk-7562w&quot;,\r\n       &quot;TOPIC&quot;: &quot;DEV3.mmLeads.V1&quot;,\r\n       &quot;PARTITION&quot;: &quot;&quot;,\r\n       &quot;CURRENT-OFFSET&quot;: &quot;&quot;,\r\n       &quot;LOG-END-OFFSET&quot;: &quot;&quot;,\r\n       &quot;LAG&quot;: &quot;&quot;,\r\n       &quot;CONSUMER-ID&quot;: &quot;&quot;,\r\n       &quot;HOST&quot;: &quot;&quot;,\r\n       &quot;CLIENT-ID&quot;: &quot;&quot;\r\n     },\r\n     {\r\n       &quot;GROUP&quot;: &quot;GROUP&quot;,\r\n       &quot;TOPIC&quot;: &quot;TOPIC&quot;,\r\n       &quot;PARTITION&quot;: &quot;PARTITION&quot;,\r\n       &quot;CURRENT-OFFSET&quot;: &quot;CURRENT-OFFSET&quot;,\r\n       &quot;LOG-END-OFFSET&quot;: &quot;LOG-END-OFFSET&quot;,\r\n       &quot;LAG&quot;: &quot;LAG&quot;,\r\n       &quot;CONSUMER-ID&quot;: &quot;CONSUMER-ID&quot;,\r\n       &quot;HOST&quot;: &quot;HOST&quot;,\r\n       &quot;CLIENT-ID&quot;: &quot;CLIENT-ID&quot;\r\n     },\r\n     {\r\n       &quot;GROUP&quot;: &quot;_company-centerpart-0-command&quot;,\r\n       &quot;TOPIC&quot;: &quot;_company-command&quot;,\r\n       &quot;PARTITION&quot;: &quot;0&quot;,\r\n       &quot;CURRENT-OFFSET&quot;: &quot;20&quot;,\r\n       &quot;LOG-END-OFFSET&quot;: &quot;20&quot;,\r\n       &quot;LAG&quot;: &quot;0&quot;,\r\n       &quot;CONSUMER-ID&quot;: &quot;_company-centerpart-0-command-0d76f6e2-7ff3-47fa-a63c-0f36aedda046-StreamThread-1-consumer-66e0cc27-469e-4735-80cf-c930f27f6e5e&quot;,\r\n       &quot;HOST&quot;: &quot;/10.01.01.04&quot;,\r\n       &quot;CLIENT-ID&quot;: &quot;_company-centerpart-0-command-0d76f6e2-7ff3-47fa-a63c-0f36aedda046-StreamThread-1-consumer&quot;\r\n     }\r\n    ]\r\n\r\nSeeing below meaning less (unwanted) output which should be removed :\r\n\r\n    {\r\n       &quot;GROUP&quot;: &quot;GROUP&quot;,\r\n       &quot;TOPIC&quot;: &quot;TOPIC&quot;,\r\n       &quot;PARTITION&quot;: &quot;PARTITION&quot;,\r\n       &quot;CURRENT-OFFSET&quot;: &quot;CURRENT-OFFSET&quot;,\r\n       &quot;LOG-END-OFFSET&quot;: &quot;LOG-END-OFFSET&quot;,\r\n       &quot;LAG&quot;: &quot;LAG&quot;,\r\n       &quot;CONSUMER-ID&quot;: &quot;CONSUMER-ID&quot;,\r\n       &quot;HOST&quot;: &quot;HOST&quot;,\r\n       &quot;CLIENT-ID&quot;: &quot;CLIENT-ID&quot;\r\n     },\r\n\r\nNote : Command output may have many lines.\r\n\r\nThanks.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63108807/convert-table-to-json-omitting-repeated-header-lines",
        "title": "Convert table to JSON omitting repeated header lines"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1595850984,
                "last_edit_date": 1595850984,
                "creation_date": 1595850361,
                "answer_id": 63114662,
                "question_id": 63113661,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Building strings is a good trick. You can also build intermediate objects to put things in an easier to understand form if it helps. e.g.\r\n\r\n    $ cat stuff.jq\r\n    .members[]\r\n       | select(.serverModel == &quot;Proliant DL380 Gen10&quot;)\r\n       | {\r\n           name: .serverName,\r\n           rom: ( .components[] | select(.componentName == &quot;System ROM&quot;) | .componentVersion )\r\n           }\r\n       | &quot;The ROM version for \\(.name) is \\(.rom)&quot;\r\n\r\nThis gives the following as output:\r\n   \r\n\r\n    $ jq -rf stuff.jq firmware.json \r\n    The ROM version for bb-r2-n12-ilo is U30 v1.46 (10/02/2018)\r\n    The ROM version for bb-r5-n10-ilo is U30 v1.36 (02/15/2018)\r\n    $\r\n\r\n",
                "title": "How to print multiple results with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1595850984,
        "creation_date": 1595846592,
        "last_edit_date": 1595846788,
        "question_id": 63113661,
        "body_markdown": "I have a JSON output from HPE OneView.  A short example is:\r\n\r\n ```\r\n{\r\n    &quot;uri&quot;: &quot;/rest/server-hardware/*/firmware?start=0&amp;count=32&quot;,\r\n    &quot;total&quot;: 102,\r\n    &quot;start&quot;: 0,\r\n    &quot;prevPageUri&quot;: null,\r\n    &quot;type&quot;: &quot;sever-firmwareinventory-list-1&quot;,\r\n    &quot;category&quot;: &quot;server-hardware&quot;,\r\n    &quot;count&quot;: 32,\r\n    &quot;members&quot;: [\r\n      {\r\n          &quot;uri&quot;: &quot;/rest/server-hardware/37383638-5A43-3338-313356585742/firmware&quot;,\r\n          &quot;type&quot;: &quot;server-hardware-firmware-1&quot;,\r\n          &quot;category&quot;: &quot;server-hardware&quot;,\r\n          &quot;serverHardwareUri&quot;: &quot;/rest/server-hardware/37383638-5A43-3338-313356585742&quot;,\r\n          &quot;serverName&quot;: &quot;bb-r2-n12-ilo&quot;,\r\n          &quot;serverModel&quot;: &quot;Proliant DL380 Gen10&quot;,\r\n          &quot;components&quot;: [\r\n            {\r\n                &quot;componentVersion&quot;: &quot;4.0.4.288&quot;,\r\n                &quot;componentLocation&quot;: &quot;System Board&quot;,\r\n                &quot;componentName&quot;: &quot;Server Platform Services (SPS) Firmware&quot;,\r\n                &quot;componentKey&quot;: &quot;b34e5677-21dc-45d3-872b-42f76fee9053&quot;\r\n            },\r\n            {\r\n                &quot;componentVersion&quot;: &quot;U30 v1.46 (10/02/2018)&quot;,\r\n                &quot;componentLocation&quot;: &quot;System Board&quot;,\r\n                &quot;componentName&quot;: &quot;System ROM&quot;,\r\n                &quot;componentKey&quot;: &quot;aa148d2e-6e09-453e-bc6f-62baa5f5ccc4&quot;\r\n                \r\n            }\r\n        ],\r\n        &quot;created&quot;: &quot;2020-07-26T22:01:54.679Z&quot;\r\n      },\r\n      {\r\n          &quot;uri&quot;: &quot;/rest/server-hardware/37383638-5A43-3338-313052304C4A/firmware&quot;,\r\n          &quot;type&quot;: &quot;server-hardware-firmware-1&quot;,\r\n          &quot;category&quot;: &quot;server-hardware&quot;,\r\n          &quot;serverHardwareUri&quot;: &quot;/rest/server-hardware/37383638-5A43-3338-313052304C4A&quot;,\r\n          &quot;serverName&quot;: &quot;bb-r5-n10-ilo&quot;,\r\n          &quot;serverModel&quot;: &quot;Proliant DL380 Gen10&quot;,\r\n          &quot;components&quot;: [\r\n            {\r\n                &quot;componentVersion&quot;: &quot;4.1.4.296&quot;,\r\n                &quot;componentLocation&quot;: &quot;System Board&quot;,\r\n                &quot;componentName&quot;: &quot;Server Platform Services (SPS) Firmware&quot;,\r\n                &quot;componentKey&quot;: &quot;b34e5677-21dc-45d3-872b-42f76fee9053&quot;\r\n            },\r\n            {\r\n                &quot;componentVersion&quot;: &quot;U30 v1.36 (02/15/2018)&quot;,\r\n                &quot;componentLocation&quot;: &quot;System Board&quot;,\r\n                &quot;componentName&quot;: &quot;System ROM&quot;,\r\n                &quot;componentKey&quot;: null\r\n                \r\n            }\r\n        ],\r\n        &quot;created&quot;: &quot;2020-07-26T22:01:54.679Z&quot;\r\n      },\r\n      {\r\n          &quot;uri&quot;: &quot;/rest/server-hardware/37313438-3033-5A43-3338-30384D533730/firmware&quot;,\r\n          &quot;type&quot;: &quot;server-hardware-firmware-1&quot;,\r\n          &quot;category&quot;: &quot;server-hardware&quot;,\r\n          &quot;serverHardwareUri&quot;: &quot;/rest/server-hardware/37313438-3033-5A43-3338-30384D533730&quot;,\r\n          &quot;serverName&quot;: &quot;bb-r3-n1-ilo&quot;,\r\n          &quot;serverModel&quot;: &quot;Proliant DL560 Gen10&quot;,\r\n          &quot;components&quot;: [\r\n            {\r\n                &quot;componentVersion&quot;: &quot;4.1.4.296&quot;,\r\n                &quot;componentLocation&quot;: &quot;System Board&quot;,\r\n                &quot;componentName&quot;: &quot;Server Platform Services (SPS) Firmware&quot;,\r\n                &quot;componentKey&quot;: &quot;b34e5677-21dc-45d3-872b-42f76fee9053&quot;\r\n            },\r\n            {\r\n                &quot;componentVersion&quot;: &quot;U34 v2.10 (05/21/2019)&quot;,\r\n                &quot;componentLocation&quot;: &quot;System Board&quot;,\r\n                &quot;componentName&quot;: &quot;System ROM&quot;,\r\n                &quot;componentKey&quot;: &quot;aa148d2e-6e08-453e-bc6f-63baa5f5ccc4&quot;\r\n                \r\n            }\r\n        ],\r\n        &quot;created&quot;: &quot;2020-07-26T22:01:54.679Z&quot;\r\n      }\r\n    ],\r\n    &quot;modified&quot;: &quot;2020-07-27T09:30:55.882Z&quot;,\r\n    &quot;nextPageUri&quot;: null\r\n}\r\n\r\n```\r\n\r\nI know I can retrieve the System ROM version for DL380 Gen 10s with: `jq -r &#39;.members[]  | select(.serverModel == &quot;Proliant DL380 Gen10&quot;) |  .components[] | select(.componentName == &quot;System ROM&quot;) |.componentVersion&#39; firmware`, but I also wanted to print the serverName along with the system ROM version.  Everything I am trying just gives an error.  Does anyone know how to do that?",
        "link": "https://stackoverflow.com/questions/63113661/how-to-print-multiple-results-with-jq",
        "title": "How to print multiple results with jq"
    },
    {
        "tags": [
            "json",
            "sorting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1595912608,
                "last_edit_date": 1595912608,
                "creation_date": 1595910325,
                "answer_id": 63127009,
                "question_id": 63126834,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The built-in [`sort_by`](https://stedolan.github.io/jq/manual/#sort,sort_by(path_expression)) accepts an array as input, not a stream of objects. You need to do:\r\n```\r\njq &#39;.pullRequests | sort_by(.key)&#39;\r\n```",
                "title": "sort_by on array elements gives error &#39;Cannot index string with string &quot;key&quot;&#39;"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1595989108,
                "last_edit_date": 1595989108,
                "creation_date": 1595939235,
                "answer_id": 63134126,
                "question_id": 63126834,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If, as indicated in the comments, the actual goal is essentially to find the maximum value by .key, then it would be better to use `max_by` rather than `sort_by`.  Based on the comments, the following would suffice:\r\n\r\n    .pullRequests\r\n    | max_by(.key).status.qualityGateStatus",
                "title": "sort_by on array elements gives error &#39;Cannot index string with string &quot;key&quot;&#39;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 7,
        "last_activity_date": 1595989108,
        "creation_date": 1595908916,
        "last_edit_date": 1595912496,
        "question_id": 63126834,
        "body_markdown": "I&#39;m trying to get the status of a code scan by the pull request ID and I&#39;m having trouble getting the value of the status.\r\nThe json file looks similar to below.\r\n\r\n    {\r\n    &quot;pullRequests&quot;: [\r\n    {\r\n      &quot;key&quot;: &quot;11346&quot;,\r\n      &quot;title&quot;: &quot;feature/XXX-Validation&quot;,\r\n      &quot;branch&quot;: &quot;feature/XXX-Validation&quot;,\r\n      &quot;base&quot;: &quot;develop&quot;,\r\n      &quot;status&quot;: {\r\n        &quot;qualityGateStatus&quot;: &quot;OK&quot;,\r\n        &quot;bugs&quot;: 0,\r\n        &quot;vulnerabilities&quot;: 0,\r\n        &quot;codeSmells&quot;: 1\r\n      },\r\n      &quot;analysisDate&quot;: &quot;2020-07-27T14:22:36+0000&quot;,\r\n      &quot;url&quot;: &quot;https://abc/org/_git/repo/pullrequest/11346&quot;,\r\n      &quot;target&quot;: &quot;develop&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;11151&quot;,\r\n      &quot;title&quot;: &quot;feature/xxx-data&quot;,\r\n      &quot;branch&quot;: &quot;feature/xxx-data&quot;,\r\n      &quot;base&quot;: &quot;develop&quot;,\r\n      &quot;status&quot;: {\r\n        &quot;qualityGateStatus&quot;: &quot;OK&quot;,\r\n        &quot;bugs&quot;: 0,\r\n        &quot;vulnerabilities&quot;: 0,\r\n        &quot;codeSmells&quot;: 0\r\n      },\r\n      &quot;analysisDate&quot;: &quot;2020-07-22T11:11:11+0000&quot;,\r\n      &quot;url&quot;: &quot;https://abc/org/_git/repo/pullrequest/11151&quot;,\r\n      &quot;target&quot;: &quot;develop&quot;\r\n    }\r\n    ]\r\n    }\r\nI need to sort this json by the key value (as this is the easiest way - earlier I had tried sorting by analysisDate) and get the value of qualityGateStatus for that key.\r\n\r\nI tried this command to first sort by the key or analysisDate and then tried using key, but I keep getting the error. I thought maybe the value is not a string, so tried to map the key tonumber, but still doesn&#39;t work.\r\n\r\n    jq: error (at &lt;stdin&gt;:0): Cannot index string with string\r\n\r\nCommands tried:\r\n\r\n    jq &#39;.pullRequests[] |sort_by(.analysisDate)[-1].key&#39;\r\n    jq &#39;.pullRequests[] | sort_by(.key|tonumber)&#39;\r\n\r\n&gt; Error:\r\n&gt;\r\n&gt; jq: error (at &lt;stdin&gt;:0): Cannot index string with string &quot;key&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63126834/sort-by-on-array-elements-gives-error-cannot-index-string-with-string-key",
        "title": "sort_by on array elements gives error &#39;Cannot index string with string &quot;key&quot;&#39;"
    },
    {
        "tags": [
            "json",
            "cmd",
            "jq",
            "windows-10-desktop"
        ],
        "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": 5,
                "creation_date": 1595937397,
                "post_id": 63133465,
                "comment_id": 111640635,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1595939754,
                "creation_date": 1595939754,
                "answer_id": 63134285,
                "question_id": 63133465,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you can somehow extract the data component of the JavaScript, you can use a tool such as [tag:hjson] to convert the JSON-like data to JSON, and then use jq.\r\n\r\nFor example:\r\n```\r\n#!/bin/bash\r\n\r\nfunction data {\r\n  cat&lt;&lt;EOF\r\n{\r\n  header: {\r\n    rui: {\r\n      iframeUri: &quot;header/header.html&quot;,\r\n      divId: &quot;&quot;,\r\n      initFnName: &quot;&quot;\r\n    }\r\n  }\r\n}\r\nEOF\r\n}\r\n\r\ndata | hjson -j | jq .header.rui.iframeUri\r\n```\r\nyields\r\n\r\n```\r\n&quot;header/header.html&quot;\r\n```",
                "title": "jq: parse error: Invalid numeric literal at line 1, column 14"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1595945296,
                "creation_date": 1595945296,
                "answer_id": 63136044,
                "question_id": 63133465,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could perhaps use `JSON.stringify` to create a valid JSON string for subsequent processing by jq.\r\n\r\nFor example, suppose my.js contains the following javascript code:\r\n\r\n```\r\nwindow={};\r\n\r\nwindow.someConfig = {\r\n  header: {\r\n    rui: {\r\n      iframeUri: &quot;header/header.html&quot;,\r\n      divId: &quot;&quot;,\r\n      initFnName: &quot;&quot;\r\n    }\r\n  }\r\n};\r\n\r\nprint(JSON.stringify(window));\r\n```\r\n\r\nThen using spidermonkey&#39;s js:\r\n\r\n    js my.js | jq .someConfig.header.rui.iframeUri\r\n\r\nyields:\r\n\r\n    &quot;header/header.html&quot;\r\n\r\n",
                "title": "jq: parse error: Invalid numeric literal at line 1, column 14"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -3,
        "last_activity_date": 1595945296,
        "creation_date": 1595936947,
        "question_id": 63133465,
        "body_markdown": "I am unable to access any field in the following json file (someconfig.js) which starts with\r\n\r\n    window.table = {\r\n      config: getBootstrapConfig()\r\n    };\r\n    \r\n    window.someConfig = {\r\n      header: {\r\n        rui: {\r\n          iframeUri: &quot;header/header.html&quot;,\r\n          divId: &quot;&quot;,\r\n          initFnName: &quot;&quot;\r\n        }\r\n      },\r\n    ....\r\n    ...\r\n    ....\r\nWhat did I try?\r\n\r\n    jq .header someconfig.js\r\n    parse error: Invalid numeric literal at line 1, column 14\r\n    \r\n    jq .window.someConfig someconfig.js\r\n    \r\n    parse error: Invalid numeric literal at line 2, column 0\r\n    \r\nI am new to jq and have also tried \r\n\r\n    jq .[&#39;header&#39;] someconfig.js\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .[&#39;header&#39;]\r\n    jq: 1 compile error\r\n\r\nHowever I am not able to understand how to fetch fields ex: divId, I want to see &quot;&quot;. I also want to know what command would substitute divId =&quot;&quot; to divId = &quot;abcd&quot;",
        "link": "https://stackoverflow.com/questions/63133465/jq-parse-error-invalid-numeric-literal-at-line-1-column-14",
        "title": "jq: parse error: Invalid numeric literal at line 1, column 14"
    },
    {
        "tags": [
            "windows",
            "powershell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1595944511,
                "creation_date": 1595944511,
                "answer_id": 63135801,
                "question_id": 63135630,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In Powershell, you have to backslash the double quotes for jq:\r\n\r\n```\r\nPS C:\\Users\\Administrator&gt; &#39;[{&quot;name&quot;:&quot;joe&quot;}]&#39; | jq &#39;.[] | select (.name==\\&quot;joe\\&quot;)&#39;\r\n\r\n{\r\n  &quot;name&quot;: &quot;joe&quot;\r\n}\r\n```\r\n",
                "title": "jq command in windows not working as expected"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1595944511,
        "creation_date": 1595944014,
        "question_id": 63135630,
        "body_markdown": "I am trying to execute a simple jq command in windows but it is not working as expected\r\n\r\n```\r\nC:\\Users\\Administrator&gt; aws ec2 describe-instances --instance-ids $instanceId --query &quot;Reservations[0].Instances[0].Tags&quot; | jq &#39;.[] | select (.Key==&quot;Name&quot;)&#39;\r\n```\r\n\r\nError:\r\n```\r\njq: error: Name/0 is not defined at &lt;top-level&gt;, line 1:\r\n.[] | select (.Key==Name)\r\njq: 1 compile error\r\n```\r\n\r\nCould someone help me with this?",
        "link": "https://stackoverflow.com/questions/63135630/jq-command-in-windows-not-working-as-expected",
        "title": "jq command in windows not working as expected"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1595946829,
                "post_id": 63136507,
                "comment_id": 111646281,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1595956195,
                "last_edit_date": 1595956195,
                "creation_date": 1595947590,
                "answer_id": 63136850,
                "question_id": 63136507,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To manipulate the object key-name as you desire, you can apply the filter operation inside `(..)`. Any operation done inside it, the result is preserved &quot;literally&quot;.\r\n\r\nYour case demands the `DBInstanceIdentifier` to be split by `-` and using the first element in the resultant array. \r\n\r\nWith that and few other trivial modifications, you need\r\n\r\n    .DBInstances |\r\n    map\r\n    (\r\n      {\r\n        ( .DBInstanceIdentifier | split(&quot;-&quot;)[0] ): {\r\n             DBInstanceClass,\r\n             DBInstanceIdentifier,\r\n             DBName,\r\n             DBParameterGroupName:.DBParameterGroups[].DBParameterGroupName,\r\n             DBSubnetGroupName: .DBSubnetGroup.DBSubnetGroupName,\r\n             KmsKeyId,\r\n             OptionGroupName: .OptionGroupMemberships[].OptionGroupName,\r\n             VpcSecurityGroupIds: [.VpcSecurityGroups[] | .VpcSecurityGroupId ]\r\n          }\r\n      }\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/BWJ47aO63X",
                "title": "How to build a parent key based on a sub-string of another value using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1596055808,
                "creation_date": 1596055808,
                "answer_id": 63162219,
                "question_id": 63136507,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I took the long path and since I couldn&#39;t resolve it on the same filter I did another one that takes the output of the first one and thus achieved the desired result. But it is awful compared with the answer selected as the solution.\r\n\r\nBased on [Inian][1] [answer][2], I did a small modification since my real *DBInstanceIdentifier* values have the following format:\r\n`&lt;name&gt;-db-&lt;environment&gt;` and I need *DBInstancePrefix* becomes `&lt;name&gt;-db`.\r\n\r\nSo, my final filter is:\r\n```\r\n.DBInstances |\r\nmap\r\n(      \r\n  {        \r\n    ( .DBInstanceIdentifier|split(&quot;-&quot;)[0:2] | join(&quot;-&quot;) ): {\r\n      DBInstanceClass,\r\n      DBInstanceIdentifier,\r\n      DBName,\r\n      DBParameterGroupName:.DBParameterGroups[].DBParameterGroupName,\r\n      DBSubnetGroupName: .DBSubnetGroup.DBSubnetGroupName,\r\n      KmsKeyId,\r\n      OptionGroupName: .OptionGroupMemberships[].OptionGroupName,\r\n      VpcSecurityGroupIds: [.VpcSecurityGroups[] | .VpcSecurityGroupId ]        \r\n      }     \r\n  } \r\n)\r\n```\r\n\r\n\r\n\r\n\r\n\r\n  [1]: https://stackoverflow.com/users/5291015/inian\r\n  [2]: https://stackoverflow.com/a/63136850/7820212",
                "title": "How to build a parent key based on a sub-string of another value using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1596092709,
        "creation_date": 1595946613,
        "last_edit_date": 1596092709,
        "question_id": 63136507,
        "body_markdown": "I&#39;m re-shaping a JSON file which base content is the output of an AWS API call. From the raw output, I&#39;m currently extracting the fields that I&#39;m interested in the format I want except for a small detail that motivated this question.\r\n\r\nSpecifically, my input comes from the output of `aws rds describe-db-instances` command and contains the info of multiple RDS instances. Taking an example with 2 instances, this is how it looks:\r\n\r\n    {\r\n    &quot;DBInstances&quot;: [\r\n        {\r\n            &quot;DBInstanceIdentifier&quot;: &quot;db1-name&quot;,\r\n            &quot;DBInstanceClass&quot;: &quot;db.m5.xlarge&quot;,\r\n            &quot;Engine&quot;: &quot;oracle-ee&quot;,\r\n            &quot;DBInstanceStatus&quot;: &quot;available&quot;,\r\n            &quot;MasterUsername&quot;: &quot;user&quot;,\r\n            &quot;DBName&quot;: &quot;RANDOM&quot;,\r\n            &quot;Endpoint&quot;: {\r\n                &quot;Address&quot;: &quot;some-endpoint.rds.amazonaws.com&quot;,\r\n                &quot;Port&quot;: 5698,\r\n                &quot;HostedZoneId&quot;: &quot;GHDSFHFSDHSDH&quot;\r\n            },\r\n            &quot;AllocatedStorage&quot;: 4000,\r\n            &quot;InstanceCreateTime&quot;: &quot;2018-07-23T23:21:42.361000+00:00&quot;,\r\n            &quot;PreferredBackupWindow&quot;: &quot;09:30-07:00&quot;,\r\n            &quot;BackupRetentionPeriod&quot;: 14,\r\n            &quot;DBSecurityGroups&quot;: [],\r\n            &quot;VpcSecurityGroups&quot;: [\r\n                {\r\n                    &quot;VpcSecurityGroupId&quot;: &quot;sg-xxxxxxxxxxxxxxxxx&quot;,\r\n                    &quot;Status&quot;: &quot;active&quot;\r\n                },\r\n                {\r\n                    &quot;VpcSecurityGroupId&quot;: &quot;sg-xxxxxxxxxxxxxxxxx&quot;,\r\n                    &quot;Status&quot;: &quot;active&quot;\r\n                }\r\n            ],\r\n            &quot;DBParameterGroups&quot;: [\r\n                {\r\n                    &quot;DBParameterGroupName&quot;: &quot;DB1-parameter&quot;,\r\n                    &quot;ParameterApplyStatus&quot;: &quot;in-sync&quot;\r\n                }\r\n            ],\r\n            &quot;AvailabilityZone&quot;: &quot;ZONE1&quot;,\r\n            &quot;DBSubnetGroup&quot;: {\r\n                &quot;DBSubnetGroupName&quot;: &quot;dbsubnetgroup-1&quot;,\r\n                &quot;DBSubnetGroupDescription&quot;: &quot;dbsubnetgroup-1&quot;,\r\n                &quot;VpcId&quot;: &quot;vpc-xxxxxxxxxxxxxxxxx&quot;,\r\n                &quot;SubnetGroupStatus&quot;: &quot;Complete&quot;,\r\n                &quot;Subnets&quot;: [\r\n                    {\r\n                        &quot;SubnetIdentifier&quot;: &quot;subnet-xxxxxxxxxxxxxxxxx&quot;,\r\n                        &quot;SubnetAvailabilityZone&quot;: {\r\n                            &quot;Name&quot;: &quot;az1&quot;\r\n                        },\r\n                        &quot;SubnetStatus&quot;: &quot;Active&quot;\r\n                    },\r\n                    {\r\n                        &quot;SubnetIdentifier&quot;: &quot;subnet-xxxxxxxxxxxxxxxxx&quot;,\r\n                        &quot;SubnetAvailabilityZone&quot;: {\r\n                            &quot;Name&quot;: &quot;az2&quot;\r\n                        },\r\n                        &quot;SubnetStatus&quot;: &quot;Active&quot;\r\n                    }\r\n                ]\r\n            },\r\n            &quot;PreferredMaintenanceWindow&quot;: &quot;sat:07:00-sat:07:30&quot;,\r\n            &quot;PendingModifiedValues&quot;: {},\r\n            &quot;LatestRestorableTime&quot;: &quot;2020-03-27T18:54:25+00:00&quot;,\r\n            &quot;MultiAZ&quot;: false,\r\n            &quot;EngineVersion&quot;: &quot;X.X.X&quot;,\r\n            &quot;AutoMinorVersionUpgrade&quot;: false,\r\n            &quot;ReadReplicaDBInstanceIdentifiers&quot;: [],\r\n            &quot;LicenseModel&quot;: &quot;bring-your-own-license&quot;,\r\n            &quot;Iops&quot;: 5000,\r\n            &quot;OptionGroupMemberships&quot;: [\r\n                {\r\n                    &quot;OptionGroupName&quot;: &quot;optiongroupName&quot;,\r\n                    &quot;Status&quot;: &quot;in-sync&quot;\r\n                }\r\n            ],\r\n            &quot;CharacterSetName&quot;: &quot;WE8ISO8859P15&quot;,\r\n            &quot;PubliclyAccessible&quot;: false,\r\n            &quot;StorageType&quot;: &quot;io1&quot;,\r\n            &quot;DbInstancePort&quot;: 0,\r\n            &quot;StorageEncrypted&quot;: true,\r\n            &quot;KmsKeyId&quot;: &quot;someKey&quot;,\r\n            &quot;DbiResourceId&quot;: &quot;db-xxxxxxxxxxxxxxxxxxxxxxxxx&quot;,\r\n            &quot;CACertificateIdentifier&quot;: &quot;rds-ca-2019&quot;,\r\n            &quot;DomainMemberships&quot;: [],\r\n            &quot;CopyTagsToSnapshot&quot;: true,\r\n            &quot;MonitoringInterval&quot;: 0,\r\n            &quot;DBInstanceArn&quot;: &quot;someARN&quot;,\r\n            &quot;IAMDatabaseAuthenticationEnabled&quot;: false,\r\n            &quot;PerformanceInsightsEnabled&quot;: false,\r\n            &quot;DeletionProtection&quot;: false,\r\n            &quot;AssociatedRoles&quot;: []\r\n        },\r\n        {\r\n            &quot;DBInstanceIdentifier&quot;: &quot;db2-name&quot;,\r\n            &quot;DBInstanceClass&quot;: &quot;db.m5.large&quot;,\r\n            &quot;Engine&quot;: &quot;oracle-ee&quot;,\r\n            &quot;DBInstanceStatus&quot;: &quot;available&quot;,\r\n            &quot;MasterUsername&quot;: &quot;user2&quot;,\r\n            &quot;DBName&quot;: &quot;XXXX&quot;,\r\n            &quot;Endpoint&quot;: {\r\n                &quot;Address&quot;: &quot;endpoint2.rds.amazonaws.com&quot;,\r\n                &quot;Port&quot;: 8974,\r\n                &quot;HostedZoneId&quot;: &quot;FASDFDS54FSA&quot;\r\n            },\r\n            &quot;AllocatedStorage&quot;: 100,\r\n            &quot;InstanceCreateTime&quot;: &quot;2020-04-23T21:38:53.023000+00:00&quot;,\r\n            &quot;PreferredBackupWindow&quot;: &quot;01:00-05:30&quot;,\r\n            &quot;BackupRetentionPeriod&quot;: 35,\r\n            &quot;DBSecurityGroups&quot;: [],\r\n            &quot;VpcSecurityGroups&quot;: [\r\n                {\r\n                    &quot;VpcSecurityGroupId&quot;: &quot;sg-xxxxxxxxxxxxxxxxx&quot;,\r\n                    &quot;Status&quot;: &quot;active&quot;\r\n                }\r\n            ],\r\n            &quot;DBParameterGroups&quot;: [\r\n                {\r\n                    &quot;DBParameterGroupName&quot;: &quot;default&quot;,\r\n                    &quot;ParameterApplyStatus&quot;: &quot;in-sync&quot;\r\n                }\r\n            ],\r\n            &quot;AvailabilityZone&quot;: &quot;AZ-2&quot;,\r\n            &quot;DBSubnetGroup&quot;: {\r\n                &quot;DBSubnetGroupName&quot;: &quot;subnet-group&quot;,\r\n                &quot;DBSubnetGroupDescription&quot;: &quot;&quot;,\r\n                &quot;VpcId&quot;: &quot;vpc-xxxxxxxxxxxxxxxxx&quot;,\r\n                &quot;SubnetGroupStatus&quot;: &quot;Complete&quot;,\r\n                &quot;Subnets&quot;: [\r\n                    {\r\n                        &quot;SubnetIdentifier&quot;: &quot;subnet-xxxxxxxxxxxxxxxxx&quot;,\r\n                        &quot;SubnetAvailabilityZone&quot;: {\r\n                            &quot;Name&quot;: &quot;AZ-1&quot;\r\n                        },\r\n                        &quot;SubnetStatus&quot;: &quot;Active&quot;\r\n                    },\r\n                    {\r\n                        &quot;SubnetIdentifier&quot;: &quot;subnet-xxxxxxxxxxxxxxxxx&quot;,\r\n                        &quot;SubnetAvailabilityZone&quot;: {\r\n                            &quot;Name&quot;: &quot;AZ-2&quot;\r\n                        },\r\n                        &quot;SubnetStatus&quot;: &quot;Active&quot;\r\n                    },\r\n                    {\r\n                        &quot;SubnetIdentifier&quot;: &quot;subnet-xxxxxxxxxxxxxxxxx&quot;,\r\n                        &quot;SubnetAvailabilityZone&quot;: {\r\n                            &quot;Name&quot;: &quot;AZ-3&quot;\r\n                        },\r\n                        &quot;SubnetStatus&quot;: &quot;Active&quot;\r\n                    }\r\n                ]\r\n            },\r\n            &quot;PreferredMaintenanceWindow&quot;: &quot;sun:08:39-sun:09:09&quot;,\r\n            &quot;PendingModifiedValues&quot;: {},\r\n            &quot;LatestRestorableTime&quot;: &quot;2020-07-27T18:53:18+00:00&quot;,\r\n            &quot;MultiAZ&quot;: false,\r\n            &quot;EngineVersion&quot;: &quot;X.X.X&quot;,\r\n            &quot;AutoMinorVersionUpgrade&quot;: false,\r\n            &quot;ReadReplicaDBInstanceIdentifiers&quot;: [],\r\n            &quot;LicenseModel&quot;: &quot;bring-your-own-license&quot;,\r\n            &quot;Iops&quot;: 2000,\r\n            &quot;OptionGroupMemberships&quot;: [\r\n                {\r\n                    &quot;OptionGroupName&quot;: &quot;optiongroup-name&quot;,\r\n                    &quot;Status&quot;: &quot;in-sync&quot;\r\n                }\r\n            ],\r\n            &quot;CharacterSetName&quot;: &quot;AL32UTF8&quot;,\r\n            &quot;PubliclyAccessible&quot;: false,\r\n            &quot;StorageType&quot;: &quot;io1&quot;,\r\n            &quot;DbInstancePort&quot;: 0,\r\n            &quot;StorageEncrypted&quot;: true,\r\n            &quot;KmsKeyId&quot;: &quot;someARN&quot;,\r\n            &quot;DbiResourceId&quot;: &quot;db-xxxxxxxxxxxxxxxxx&quot;,\r\n            &quot;CACertificateIdentifier&quot;: &quot;rds-ca-2019&quot;,\r\n            &quot;DomainMemberships&quot;: [],\r\n            &quot;CopyTagsToSnapshot&quot;: false,\r\n            &quot;MonitoringInterval&quot;: 0,\r\n            &quot;DBInstanceArn&quot;: &quot;someARN&quot;,\r\n            &quot;IAMDatabaseAuthenticationEnabled&quot;: false,\r\n            &quot;PerformanceInsightsEnabled&quot;: false,\r\n            &quot;DeletionProtection&quot;: false,\r\n            &quot;AssociatedRoles&quot;: []\r\n        }\r\n    ]\r\n}\r\n\r\nThis is my current output:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;DBInstancePrefix&quot;: {\r\n      &quot;DBInstanceClass&quot;: &quot;db.m5.xlarge&quot;,\r\n      &quot;DBInstanceIdentifier&quot;: &quot;db1-name&quot;,\r\n      &quot;DBName&quot;: &quot;RANDOM&quot;,\r\n      &quot;DBParameterGroupName&quot;: &quot;DB1-parameter&quot;,\r\n      &quot;DBSubnetGroupName&quot;: &quot;dbsubnetgroup-1&quot;,\r\n      &quot;KmsKeyId&quot;: &quot;someKey&quot;,\r\n      &quot;OptionGroupName&quot;: &quot;optiongroupName&quot;,\r\n      &quot;VpcSecurityGroupIds&quot;: [\r\n        &quot;sg-xxxxxxxxxxxxxxxxx&quot;,\r\n        &quot;sg-xxxxxxxxxxxxxxxxx&quot;\r\n      ]\r\n    }\r\n  },\r\n  {\r\n    &quot;DBInstancePrefix&quot;: {\r\n      &quot;DBInstanceClass&quot;: &quot;db.m5.large&quot;,\r\n      &quot;DBInstanceIdentifier&quot;: &quot;db2-name&quot;,\r\n      &quot;DBName&quot;: &quot;XXXX&quot;,\r\n      &quot;DBParameterGroupName&quot;: &quot;default&quot;,\r\n      &quot;DBSubnetGroupName&quot;: &quot;subnet-group&quot;,\r\n      &quot;KmsKeyId&quot;: &quot;someARN&quot;,\r\n      &quot;OptionGroupName&quot;: &quot;optiongroup-name&quot;,\r\n      &quot;VpcSecurityGroupIds&quot;: [\r\n        &quot;sg-xxxxxxxxxxxxxxxxx&quot;\r\n      ]\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nThis is my current JQ filter:\r\n\r\n    . | [.[] | map(.) | .[] | {DBInstancePrefix: {DBInstanceClass: .DBInstanceClass, DBInstanceIdentifier: .DBInstanceIdentifier, DBName: .DBName, DBParameterGroupName:.DBParameterGroups[].DBParameterGroupName, DBSubnetGroupName: .DBSubnetGroup.DBSubnetGroupName, KmsKeyId:.KmsKeyId, OptionGroupName: .OptionGroupMemberships[].OptionGroupName, VpcSecurityGroupIds: [.VpcSecurityGroups | .[] | .VpcSecurityGroupId] }}] \r\n\r\nYou can verify it on this snippet on [jqplay.org][1].\r\n\r\n**What I need is to turn the parent key &quot;DBInstancePrefix&quot; dynamic based on a substring from &quot;DBInstanceIdentifier&quot; key**. So for the example names I wrote would be:\r\n\r\n&gt; &quot;db1-name&quot; &gt;&gt;&gt; &quot;db1&quot; \r\n\r\n&gt; &quot;db2-name&quot; &gt;&gt;&gt; &quot;db2&quot;\r\n\r\nSo, my desired output would be:\r\n```\r\n[\r\n  {\r\n    &quot;db1&quot;: {\r\n      &quot;DBInstanceClass&quot;: &quot;db.m5.xlarge&quot;,\r\n      &quot;DBInstanceIdentifier&quot;: &quot;db1-name&quot;,\r\n      &quot;DBName&quot;: &quot;RANDOM&quot;,\r\n      &quot;DBParameterGroupName&quot;: &quot;DB1-parameter&quot;,\r\n      &quot;DBSubnetGroupName&quot;: &quot;dbsubnetgroup-1&quot;,\r\n      &quot;KmsKeyId&quot;: &quot;someKey&quot;,\r\n      &quot;OptionGroupName&quot;: &quot;optiongroupName&quot;,\r\n      &quot;VpcSecurityGroupIds&quot;: [\r\n        &quot;sg-xxxxxxxxxxxxxxxxx&quot;,\r\n        &quot;sg-xxxxxxxxxxxxxxxxx&quot;\r\n      ]\r\n    }\r\n  },\r\n  {\r\n    &quot;db2&quot;: {\r\n      &quot;DBInstanceClass&quot;: &quot;db.m5.large&quot;,\r\n      &quot;DBInstanceIdentifier&quot;: &quot;db2-name&quot;,\r\n      &quot;DBName&quot;: &quot;XXXX&quot;,\r\n      &quot;DBParameterGroupName&quot;: &quot;default&quot;,\r\n      &quot;DBSubnetGroupName&quot;: &quot;subnet-group&quot;,\r\n      &quot;KmsKeyId&quot;: &quot;someARN&quot;,\r\n      &quot;OptionGroupName&quot;: &quot;optiongroup-name&quot;,\r\n      &quot;VpcSecurityGroupIds&quot;: [\r\n        &quot;sg-xxxxxxxxxxxxxxxxx&quot;\r\n      ]\r\n    }\r\n  }\r\n]\r\n```\r\nAny ideas or suggestions? Thanks for reading.\r\n\r\n  [1]: https://jqplay.org/s/zQqEfm9yN_",
        "link": "https://stackoverflow.com/questions/63136507/how-to-build-a-parent-key-based-on-a-sub-string-of-another-value-using-jq",
        "title": "How to build a parent key based on a sub-string of another value using jq?"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1595957300,
                "creation_date": 1595957300,
                "answer_id": 63139655,
                "question_id": 63139542,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### Summary\r\n\r\nFollowing your link to the jq FAQ, we find the exact quote:\r\n\r\n&gt; [...] Thus you may be able to use `jq -n -f FILENAME` to convert nearly-valid JSON to JSON.\r\n\r\n_That&#39;s exactly the case here._\r\n\r\n---\r\n\r\n### Explanation\r\n\r\nA file that&#39;s almost JSON, but has `#` comments, *is going to be valid `jq` code*. Thus, if you have an input file created by the shell command:\r\n\r\n```\r\ncat &gt;input.notjson &lt;&lt;&#39;EOF&#39;\r\n{\r\n  &quot;This is a key&quot;: &quot;This is a value&quot; # this is a comment, which is why this is not JSON\r\n}\r\nEOF\r\n```\r\n\r\n...you can run it as a jq program:\r\n\r\n```\r\njq -nf input.notjson\r\n```\r\n\r\n...to get as output:\r\n\r\n```\r\n{\r\n  &quot;This is a key&quot;: &quot;This is a value&quot;\r\n}\r\n```\r\n\r\n...which can thereafter be fed as input to another, arbitrary jq program (or other consumer of JSON).",
                "title": "Removing &quot;#&quot; comments with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1595957300,
        "creation_date": 1595956847,
        "question_id": 63139542,
        "body_markdown": "In the [FAQ for jq][1], it says:\r\n\r\n&gt; As noted in the previous Q, jq itself can be used to transform nearly-valid JSON to JSON in many instances. **For example, &quot;#&quot; comments can be removed using jq.**\r\n\r\nHowever, I cannot seem to find any documentation on how to actually do this with jq. What&#39;s the proper way to read a JSON file that has &quot;#&quot; comments?\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ#processing-not-quite-valid-json",
        "link": "https://stackoverflow.com/questions/63139542/removing-comments-with-jq",
        "title": "Removing &quot;#&quot; comments with JQ"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1595959330,
                "post_id": 63140165,
                "comment_id": 111652844,
                "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": 1595959396,
                "post_id": 63140165,
                "comment_id": 111652880,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1595959483,
                "creation_date": 1595959483,
                "answer_id": 63140237,
                "question_id": 63140165,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The &quot;null string&quot; is an empty string -- a zero-byte string, that is, a string with no characters contained within it. `s=&quot;&quot;` assigns a null string to the variable `s`, just as `s=` or `s=&#39;&#39;` do.\r\n\r\n`s=null`, or `s=&#39;null&#39;`, or `s=&quot;null&quot;`, by contrast, assign a string with the four-byte string `null` (and then terminated by a literal NUL character, as all C strings are). These strings are not &quot;null strings&quot; or &quot;empty strings&quot; in the sense that `test -z &quot;$s&quot;` or `[ -z &quot;$s&quot; ]` check for: It doesn&#39;t have zero characters; instead, it has four (those being `n`, `u`, `l` and `l`).\r\n\r\nTo detect *either* an empty string or the non-empty string `&quot;null&quot;`, use instead:\r\n\r\n```\r\nif [ -z &quot;$someId&quot; ] || [ &quot;$someId&quot; = null ]; then\r\n  echo &quot;Order Placement failed; unable to parse someId from the response&quot;\r\n  exit 1\r\nfi\r\n```",
                "title": "Bash script not checking for null correctly"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1595967320,
                "last_edit_date": 1595967320,
                "creation_date": 1595959772,
                "answer_id": 63140315,
                "question_id": 63140165,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `--exit-status` option, which makes `jq` have a non-zero exit status if the last output value is `false` or `null`.\r\n\r\n    #! /bin/bash\r\n    \r\n    \r\n    if ! someId=$(curl -sk -H -X POST -d &quot;fizzbuzz&quot; &quot;https://someapi.example.com/v1/orders/fire&quot; | jq -r --exit-status &#39;.someId&#39;); then\r\n      echo &quot;Order Placement failed; unable to parse someId from the response&quot;\r\n      exit 1\r\n    fi\r\n    \r\n    echo &quot;...order $someId placed&quot;",
                "title": "Bash script not checking for null correctly"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1595967320,
        "creation_date": 1595959194,
        "last_edit_date": 1595960250,
        "question_id": 63140165,
        "body_markdown": "I have a bash script:\r\n\r\n```\r\n#! /bin/bash\r\n\r\nsomeId=$(curl -sk -H -X POST -d &quot;fizzbuzz&quot; &quot;https://someapi.example.com/v1/orders/fire&quot; | jq &#39;.someId&#39;)\r\n\r\nif [ -z &quot;$someId&quot; ]; then\r\n  echo &quot;Order Placement failed; unable to parse someId from the response&quot;\r\n  exit 1\r\nfi\r\n\r\necho &quot;...order $someId placed&quot;\r\n```\r\n\r\nWhen I run this I get the following output:\r\n\r\n```\r\n...order null placed\r\n```\r\n\r\nSo somehow `$someId` is `null` but then...shouldn&#39;t I be seeing the `&quot;Order Placement failed; unable to parse someId from the response&quot;` echo instead?\r\n\r\n**How can I modify the `if [ -z &quot;$someId&quot; ]; then` conditional to execute if `$someId` is null?**",
        "link": "https://stackoverflow.com/questions/63140165/bash-script-not-checking-for-null-correctly",
        "title": "Bash script not checking for null correctly"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3201485,
                    "reputation": 3470,
                    "user_id": 2703456,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1f3b76d7aea8eda16387053e6767a618?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Reino",
                    "link": "https://stackoverflow.com/users/2703456/reino"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596062018,
                "post_id": 63154459,
                "comment_id": 111693565,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1596050368,
                "creation_date": 1596050368,
                "answer_id": 63160967,
                "question_id": 63154459,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The jq filter you want can be written as follows:\r\n\r\n```\r\n(input_filename | gsub(&quot;^\\\\./|\\\\.json$&quot;;&quot;&quot;)) as $fname\r\n| ( [ .result.tags[] | [.tag.en, (.confidence | floor)] | join(&quot;:&quot;) ]\r\n    | join(&quot;,&quot;) ) as $tags\r\n| &quot;\\($fname)&amp;\\($tags)&quot;\r\n```",
                "title": "Parsing json values using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1596050368,
        "creation_date": 1596028454,
        "last_edit_date": 1596028834,
        "question_id": 63154459,
        "body_markdown": "I am trying to get values &quot;**en**&quot; of a JSON structure using jq on the linux command line.\r\n\r\n    find . -name &quot;*.json&quot; -exec jq -r \\ &#39;(input_filename | gsub(&quot;^\\\\./|\\\\.json$&quot;;&quot;&quot;)) as $fname (map(.tags) | .[] | .[] | .tag.en ) as $tags | &quot;\\($fname)&amp;\\($tags)&quot;&#39; &#39;{}&#39; + \r\n\r\n\r\ni have more than 5000 files, start from **0001.json 0002.json .. 5000.json**\r\n\r\nThis is a simple file **0001.json**\r\n\r\n    {\r\n    &quot;result&quot;: {\r\n        &quot;tags&quot;: [\r\n            { &quot;confidence&quot;: 100, &quot;tag&quot;: { &quot;en&quot;: &quot;turbine&quot; } },\r\n            { &quot;confidence&quot;: 64.8014373779297, &quot;tag&quot;: { &quot;en&quot;: &quot;wind&quot; } },\r\n            { &quot;confidence&quot;: 63.3033409118652, &quot;tag&quot;: { &quot;en&quot;: &quot;generator&quot; } },\r\n            { &quot;confidence&quot;: 7.27894926071167, &quot;tag&quot;: { &quot;en&quot;: &quot;device&quot; } },\r\n            { &quot;confidence&quot;: 7.01708889007568, &quot;tag&quot;: { &quot;en&quot;: &quot;line&quot; } }\r\n        ]\r\n    },\r\n    &quot;status&quot;: { &quot;text&quot;: &quot;&quot;, &quot;type&quot;: &quot;success&quot; }\r\n    }\r\n\r\n\r\n\r\ni get this result :\r\n\r\n    0001&amp;turbine\r\n    0001&amp;wind\r\n    0001&amp;generator\r\n    0001&amp;device\r\n    0001&amp;line\r\n    jq: error (at ./0001.json:0): Cannot iterate over null (null)\r\n    Ouptut..\r\n    jq: error (at ./0002.json:0): Cannot iterate over null (null)\r\n    Output..\r\n    jq: error (at ./0003.json:0): Cannot iterate over null (null)\r\n\r\n\r\nMy Desired Output in one file from all json files results.\r\n\r\n**filename&amp;enValue:confidenceValue**\r\n\r\n    0001&amp;turbine:100,wind:64,generator:63,device:7,line:7\r\n    0002&amp;...\r\n    0003&amp;...\r\n    0004&amp;...\r\n",
        "link": "https://stackoverflow.com/questions/63154459/parsing-json-values-using-jq",
        "title": "Parsing json values using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1596087648,
                "post_id": 63162686,
                "comment_id": 111699297,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1596293914,
                "last_edit_date": 1596293914,
                "creation_date": 1596058082,
                "answer_id": 63162687,
                "question_id": 63162686,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the [select](https://til.hashrocket.com/posts/uv0bjiokwk-use-jq-to-filter-objects-list-with-regex) function you can extract an attribute using a regex.\r\n\r\n```\r\n# the solution\r\ncat json_file | jq -r &#39;select(.name|test(&quot;^tmp_[0-9a-zA-z]*&quot;)) | .images|.[]|.digest&#39;\r\n\r\n# output:\r\nsha256:44815925453c50637a53d4d8fb7903d0880fa76bdc37a76b127f68410bc39a35\r\n```",
                "title": "Select objects based on value of other nested attributes using regex with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1596293914,
        "creation_date": 1596058082,
        "last_edit_date": 1596206158,
        "question_id": 63162686,
        "body_markdown": "I have the following json file:\r\n```\r\n{\r\n  &quot;images&quot;: [\r\n    {\r\n      &quot;digest&quot;: &quot;sha256:ab5e999ae06daefd488f3b44a54e75cc1f2e13920cbdece9b28271e4b9d69500&quot;\r\n    }\r\n  ],\r\n  &quot;name&quot;: &quot;latest&quot;\r\n}\r\n{\r\n  &quot;images&quot;: [\r\n    {\r\n      &quot;digest&quot;: &quot;sha256:44815925453c50637a53d4d8fb7903d0880fa76bdc37a76b127f68410bc39a35&quot;\r\n    }\r\n  ],\r\n  &quot;name&quot;: &quot;tmp_118a872e760bfe4275b489b17ddf2cfbf692ff55&quot;\r\n}\r\n{\r\n  &quot;images&quot;: [\r\n    {\r\n      &quot;digest&quot;: &quot;sha256:ab5e999ae06daefd488f3b44a54e75cc1f2e13920cbdece9b28271e4b9d69500&quot;\r\n    }\r\n  ],\r\n  &quot;name&quot;: &quot;0.1.0&quot;\r\n}\r\n```\r\n\r\nI am using jq and want to get the &quot;digest&quot; elements of the objects where &quot;name&quot; follows the regular expression &quot;^tmp_[0-9a-zA-z]*&quot;\r\n\r\nWhat i know:\r\n```\r\n# how to get all the names\r\ncat json_file | jq &#39;.name&#39;\r\n\r\nOutputs:\r\n&quot;latest&quot;\r\n&quot;tmp_118a872e760bfe4275b489b17ddf2cfbf692ff55&quot;\r\n&quot;0.1.0&quot;\r\n\r\n\r\n# how to get all the digest values\r\ncat json_file | jq -r &#39;.images|.[]|.digest&#39;\r\n\r\nOutputs:\r\nsha256:ab5e999ae06daefd488f3b44a54e75cc1f2e13920cbdece9b28271e4b9d69500\r\nsha256:44815925453c50637a53d4d8fb7903d0880fa76bdc37a76b127f68410bc39a35\r\nsha256:ab5e999ae06daefd488f3b44a54e75cc1f2e13920cbdece9b28271e4b9d69500\r\n```",
        "link": "https://stackoverflow.com/questions/63162686/select-objects-based-on-value-of-other-nested-attributes-using-regex-with-jq",
        "title": "Select objects based on value of other nested attributes using regex with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1596076254,
                "last_edit_date": 1596076254,
                "creation_date": 1596074830,
                "answer_id": 63165090,
                "question_id": 63163909,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, there is no need to call jq more than once.\r\n\r\nSecond, because the main object does not have distinct key names, you would have to use the --stream command-line option.\r\n\r\nThird, you could use `test` to select the hostnames of interest, especially if as seems to be the case, the criterion can most easily be expressed as a regex.\r\n\r\nSo here in a nutshell is a solution:\r\n\r\n## Invocation\r\n    jq -n --stream -c -f program.jq input.json\r\n\r\n## program.jq\r\n```\r\n{instances:\r\n [inputs\r\n | select(length==2 and (.[0][-2:] == [&quot;ciAttributes&quot;, &quot;entries&quot;]))\r\n | .[-1]\r\n | fromjson\r\n | keys_unsorted[]\r\n | select(test(&quot;cdc.[.]&quot;))]}\r\n```",
                "title": "Trying to filter an array output with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1596076254,
        "creation_date": 1596064942,
        "question_id": 63163909,
        "body_markdown": "I have the given input as such:\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    [{\r\n      &quot;ciAttributes&quot;: {\r\n        &quot;entries&quot;: &quot;{\\&quot;hostname-cdc1.website.com\\&quot;:[\\&quot;127.0.0.1\\&quot;],\\&quot;hostname-cdc1-extension.website.com\\&quot;:[\\&quot;127.0.0.1\\&quot;]}&quot;\r\n      },\r\n      &quot;ciAttributes&quot;: {\r\n        &quot;entries&quot;: &quot;{\\&quot;hostname-dfw1.website.com\\&quot;:[\\&quot;127.0.0.1\\&quot;],\\&quot;hostname-dfw1-extension.website.com\\&quot;:[\\&quot;127.0.0.1\\&quot;]}&quot;\r\n      },\r\n      &quot;ciAttributes&quot;: {\r\n        &quot;entries&quot;: &quot;{\\&quot;hostname-cdc2.website.com\\&quot;:[\\&quot;127.0.0.1\\&quot;],\\&quot;hostname-cdc2-extension.website.com\\&quot;:[\\&quot;127.0.0.1\\&quot;]}&quot;\r\n      },\r\n      &quot;ciAttributes&quot;: {\r\n        &quot;entries&quot;: &quot;{\\&quot;hostname-dfw2.website.com\\&quot;:[\\&quot;127.0.0.1\\&quot;],\\&quot;hostname-dfw2-extension.website.com\\&quot;:[\\&quot;127.0.0.1\\&quot;]}&quot;\r\n      },\r\n    }]\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n...and when I execute my jq with the following command (manipulating existing json):\r\n\r\n    jq &#39;.[].ciAttributes.entries | fromjson | keys | [ { hostname: .[0] }] | add&#39; | jq -s &#39;{ instances: . }&#39;\r\n\r\n...I get this output:\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    {\r\n      &quot;instances&quot;: [\r\n        {\r\n          &quot;hostname&quot;: &quot;hostname-cdc1.website.com&quot;\r\n        },\r\n        {\r\n          &quot;hostname&quot;: &quot;hostname-dfw1.website.com&quot;\r\n        },\r\n        {\r\n          &quot;hostname&quot;: &quot;hostname-cdc2.website.com&quot;\r\n        },\r\n        {\r\n          &quot;hostname&quot;: &quot;hostname-dfw2.website.com&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n**My end goal is to only extract &quot;hostnames&quot; that contain &quot;cdc.&quot; I&#39;ve tried playing with the json select expression but I get a syntax error so I&#39;m sure I&#39;m doing something wrong.**",
        "link": "https://stackoverflow.com/questions/63163909/trying-to-filter-an-array-output-with-jq",
        "title": "Trying to filter an array output with jq"
    },
    {
        "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": 1596183151,
                "post_id": 63188008,
                "comment_id": 111736136,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5616703,
                    "reputation": 8281,
                    "user_id": 4452265,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/08344f2696c085e78dfd375b0a3462ab?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jetchisel",
                    "link": "https://stackoverflow.com/users/4452265/jetchisel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596184766,
                "post_id": 63188008,
                "comment_id": 111736901,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1596182449,
        "creation_date": 1596182449,
        "question_id": 63188008,
        "body_markdown": "I want to parse below json array and store property of object in array of shell script variable.\r\n```\r\n{\r\n   &quot;student_profile&quot;:[\r\n      {\r\n         &quot;fname&quot;:&quot;abc&quot;,\r\n         &quot;lname&quot;:&quot;xyz&quot;\r\n      },\r\n      {\r\n         &quot;fname&quot;:&quot;def&quot;,\r\n         &quot;lname&quot;:&quot;pqr&quot;\r\n      }\r\n   ]\r\n}\r\n\r\n```\r\nBelow is my sh file. \r\n\r\n```\r\nmyfile.sh\r\n\r\n#!/bin/bash\r\n\r\ndeclare -a names=()\r\n\r\n###### Acess and parse json file here and store fname inside the name array\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/63188008/how-to-parse-json-in-shell-script-using-jq-add-store-into-array-in-shell-script",
        "title": "How to parse json in shell script using jq add store into array in shell script"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1596209095,
                "creation_date": 1596209095,
                "answer_id": 63194734,
                "question_id": 63194295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With a simple recursive function:\r\n```\r\ndef f: .name as $parent | .children[] | {$parent, displayName: .name}, f;\r\n[ {name: &quot;&quot;, children: .} | f ]\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/3PlEhGQkex)&lt;/sup&gt;",
                "title": "Flatten a hierarchical JSON array using JQ"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1596225709,
                "last_edit_date": 1596225709,
                "creation_date": 1596220208,
                "answer_id": 63197278,
                "question_id": 63194295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward solution that does not involve a helper function and actually solves a more general problem.  It is based on the idea of beginning by adding a &quot;parent&quot; key to each child, and then using `..` to collect all the name/parent pairs.\r\n\r\nSo first consider:\r\n```\r\n[ walk(if type==&quot;object&quot; and has(&quot;children&quot;)\r\n       then .name as $n | .children |= map(.parent = $n)\r\n       else . end)\r\n  | ..\r\n  | select(type==&quot;object&quot; and has(&quot;name&quot;))\r\n  | {displayName: .name, parent}\r\n]\r\n```\r\nThis meets the requirements except that for the top-level (parentless) object, it produces a .parent value of `null`.  That would generally be more JSON-esque than &quot;&quot;, but if the empty string is really required, one has simply to replace the last non-trivial line above by:\r\n\r\n    | {displayName: .name, parent: (.parent // &quot;&quot;)}\r\n\r\n\r\n",
                "title": "Flatten a hierarchical JSON array using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1596225709,
        "creation_date": 1596207470,
        "last_edit_date": 1596209416,
        "question_id": 63194295,
        "body_markdown": "Can anyone help me get the correct jq command to flatten the below example?  I&#39;ve seen a few other posts and I&#39;m hacking away at it but can&#39;t seem to get it.  I&#39;d greatly appreciate any help.\r\n\r\nInput:\r\n\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;level1&quot;,\r\n            &quot;children&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;level2&quot;,\r\n                    &quot;children&quot;: [\r\n                        {\r\n                            &quot;name&quot;: &quot;level3-1&quot;,\r\n                            &quot;children&quot;: []\r\n                        },\r\n                        {\r\n                            &quot;name&quot;: &quot;level3-2&quot;,\r\n                            &quot;children&quot;: []\r\n                        }\r\n                    ]\r\n                }\r\n            ]\r\n        }\r\n    ]\r\nOutput:\r\n\r\n    [\r\n        {\r\n            &quot;displayName&quot;: &quot;level1&quot;,\r\n            &quot;parent&quot;: &quot;&quot;\r\n        },\r\n        {\r\n            &quot;displayName&quot;: &quot;level2&quot;,\r\n            &quot;parent&quot;: &quot;level1&quot;\r\n        },\r\n        {\r\n            &quot;displayName&quot;: &quot;level3-1&quot;,\r\n            &quot;parent&quot;: &quot;level2&quot;\r\n        },\r\n        {\r\n            &quot;displayName&quot;: &quot;level3-2&quot;,\r\n            &quot;parent&quot;: &quot;level2&quot;\r\n        }\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63194295/flatten-a-hierarchical-json-array-using-jq",
        "title": "Flatten a hierarchical JSON array using JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1596219738,
                "creation_date": 1596219738,
                "answer_id": 63197162,
                "question_id": 63197081,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Missing the dot in last command\r\n\r\n```\r\njq &#39;.[]|keys&#39; data.json\r\n[\r\n  &quot;key-user&quot;,\r\n  &quot;oidc-cid&quot;\r\n]\r\n```\r\n",
                "title": "Read Keys from JSON output using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1596219738,
        "creation_date": 1596219351,
        "question_id": 63197081,
        "body_markdown": "Have a JSON output as below. Trying to extract only key names like &quot;key-user&quot; and &quot;oidc-cid&quot; using JQ\r\n\r\n```\r\n[\r\n  {\r\n    &quot;key-user&quot;: {\r\n      &quot;contentType&quot;: &quot;&quot;,\r\n      &quot;enabled&quot;: true,\r\n      &quot;isSecret&quot;: true,\r\n      &quot;value&quot;: null\r\n    },\r\n    &quot;oidc-cid&quot;: {\r\n      &quot;contentType&quot;: &quot;&quot;,\r\n      &quot;enabled&quot;: true,\r\n      &quot;isSecret&quot;: true,\r\n      &quot;value&quot;: null\r\n    }\r\n  }\r\n]\r\n```\r\nTried the following command \r\n```\r\njq &#39;keys&#39; and jq &#39;keys[]&#39; and jq &#39;[] | keys&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/63197081/read-keys-from-json-output-using-jq",
        "title": "Read Keys from JSON output using jq"
    },
    {
        "tags": [
            "json",
            "group-by",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1596236272,
                "post_id": 63199503,
                "comment_id": 111757917,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19203285,
                    "reputation": 13,
                    "user_id": 14030767,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b6fb506872aee142665f712872e57300?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "crayboy",
                    "link": "https://stackoverflow.com/users/14030767/crayboy"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596469279,
                "post_id": 63199503,
                "comment_id": 111814041,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1596246477,
                "creation_date": 1596246477,
                "answer_id": 63201001,
                "question_id": 63199503,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a jq solution that avoids the built-in `group_by` filter for the reasons explained in the comments below.\r\n\r\n```\r\n# This stream-oriented variant of the built-in `group_by` emits a stream of arrays,\r\n# each array representing a group. The main advantages over `group_by` are\r\n# that no sorting is required, and the ordering of items within a group is preserved.\r\n# There are no restrictions on f or the items in the stream;\r\n# in particular, f may evaluate to any number of values,\r\n# but if f evaluates to empty at any item in the stream, then that item will in effect be discarded.\r\n# Example:\r\n#  GROUPS_BY( 4,3,2,1; . % 2 ) =&gt; [4,2] [3,1]\r\n\r\ndef GROUPS_BY(stream; f): \r\n  reduce stream as $x ({};\r\n    reduce [$x|f][] as $s (.;\r\n        ($s|type) as $t\r\n        | (if $t == &quot;string&quot; then $s\r\n           else ($s|tojson) end) as $y\r\n        | .[$t][$y] += [$x] ) ) \r\n  | .[][] ;\r\n```\r\n\r\nUsing the -n command-line option, we can avoid &quot;slurping&quot; the input by writing the solution as follows:\r\n\r\n```\r\nGROUPS_BY(inputs; .dataCenter)\r\n| {dataCenter: .[0].dataCenter, hosts: map(.hostname) }\r\n```",
                "title": "reformat json with jq - collect results in array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1596250592,
        "creation_date": 1596232111,
        "last_edit_date": 1596250592,
        "question_id": 63199503,
        "body_markdown": "I have a query that returns json like this:\r\n```\r\n{\r\n  &quot;hostname&quot;: &quot;seapr1pgdb032&quot;,\r\n  &quot;ip&quot;: &quot;10.215.0.6&quot;,\r\n  &quot;dataCenter&quot;: &quot;seapr1&quot;\r\n}\r\n{\r\n  &quot;hostname&quot;: &quot;seapr1cpndb001&quot;,\r\n  &quot;ip&quot;: &quot;10.203.0.41&quot;,\r\n  &quot;dataCenter&quot;: &quot;seapr1&quot;\r\n}\r\n{\r\n  &quot;hostname&quot;: &quot;seapr1dhcp01&quot;,\r\n  &quot;ip&quot;: &quot;10.205.3.212&quot;,\r\n  &quot;dataCenter&quot;: &quot;seapr1&quot;\r\n}\r\n```\r\nThe dataCenter can vary, I would like to collect all the hosts for each dataCenter into a single object like this:\r\n```\r\n{\r\n &quot;dataCenter&quot;: &quot;seapr1&quot;,\r\n &quot;hosts&quot;: [\r\n    &quot;seapr1pgdb032&quot;,\r\n    &quot;seapr1cpndb001&quot;,\r\n    &quot;seapr1dhcp01&quot;\r\n  ] \r\n}\r\n```\r\nWorking from [Reshaping JSON with jq][1] I thought this would do it:\r\n```\r\n{dataCenter: .dataCenter, hosts: [.hostname] } \r\n```\r\nbut I get three dataCenter objects, not the single consolidated one I expected:\r\n```\r\n{\r\n  &quot;dataCenter&quot;: &quot;seapr1&quot;,\r\n  &quot;hosts&quot;: [\r\n    &quot;seapr1pgdb032&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;dataCenter&quot;: &quot;seapr1&quot;,\r\n  &quot;hosts&quot;: [\r\n    &quot;seapr1cpndb001&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;dataCenter&quot;: &quot;seapr1&quot;,\r\n  &quot;hosts&quot;: [\r\n    &quot;seapr1dhcp01&quot;\r\n  ]\r\n}\r\n```\r\n\r\n\r\n\r\n  [1]: https://programminghistorian.org/en/lessons/json-and-jq",
        "link": "https://stackoverflow.com/questions/63199503/reformat-json-with-jq-collect-results-in-array",
        "title": "reformat json with jq - collect results in array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1596309523,
                "creation_date": 1596309523,
                "answer_id": 63209165,
                "question_id": 63207815,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a very conservative approach:\r\n```\r\n.data\r\n| to_entries[]\r\n| [.key]\r\n  + (.value[]\r\n     | (.statistics | [.wins, .battles])\r\n       + [.mark_of_mastery, .tank_id])\r\n```\r\n",
                "title": "I need assistance in parsing a JSON file to a .csv file using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1596362538,
        "creation_date": 1596301137,
        "last_edit_date": 1596362538,
        "question_id": 63207815,
        "body_markdown": "OK, so this is the fairly simple JSON source file which needs to be parsed...\r\n```\r\n{\r\n  &quot;status&quot;: &quot;ok&quot;,\r\n  &quot;meta&quot;: {\r\n    &quot;count&quot;: 10\r\n  },\r\n  &quot;data&quot;: {\r\n    &quot;1040918564&quot;: [\r\n      {\r\n        &quot;statistics&quot;: {\r\n          &quot;wins&quot;: 166,\r\n          &quot;battles&quot;: 441\r\n        },\r\n        &quot;mark_of_mastery&quot;: 1,\r\n        &quot;tank_id&quot;: 9505\r\n      },\r\n      {\r\n        &quot;statistics&quot;: {\r\n          &quot;wins&quot;: 154,\r\n          &quot;battles&quot;: 325\r\n        },\r\n        &quot;mark_of_mastery&quot;: 1,\r\n        &quot;tank_id&quot;: 47105\r\n      }\r\n    ],\r\n    &quot;1040836357&quot;: [\r\n      {\r\n        &quot;statistics&quot;: {\r\n          &quot;wins&quot;: 216,\r\n          &quot;battles&quot;: 490\r\n        },\r\n        &quot;mark_of_mastery&quot;: 1,\r\n        &quot;tank_id&quot;: 47105\r\n      },\r\n      {\r\n        &quot;statistics&quot;: {\r\n          &quot;wins&quot;: 114,\r\n          &quot;battles&quot;: 254\r\n        },\r\n        &quot;mark_of_mastery&quot;: 2,\r\n        &quot;tank_id&quot;: 7969\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nI would like to end up with the following output which can then be piped to @csv and output to my .csv file....\r\n```\r\n[\r\n  1040918564,\r\n  166,\r\n  441,\r\n  1,\r\n  9505\r\n]\r\n[\r\n  1040918564,\r\n  154,\r\n  325,\r\n  1,\r\n  47105\r\n]\r\n[\r\n  1040836357,\r\n  216,\r\n  490,\r\n  1,\r\n  47105\r\n]\r\n[\r\n  1040836357,\r\n  114,\r\n  254,\r\n  2,\r\n  7969\r\n]\r\n```\r\n\r\nMy first step is `.data | to_entries[]` which parses as follows....\r\n```\r\n{\r\n  &quot;key&quot;: &quot;1040918564&quot;,\r\n  &quot;value&quot;: [\r\n    {\r\n      &quot;statistics&quot;: {\r\n        &quot;wins&quot;: 166,\r\n        &quot;battles&quot;: 441\r\n      },\r\n      &quot;mark_of_mastery&quot;: 1,\r\n      &quot;tank_id&quot;: 9505\r\n    },\r\n    {\r\n      &quot;statistics&quot;: {\r\n        &quot;wins&quot;: 154,\r\n        &quot;battles&quot;: 325\r\n      },\r\n      &quot;mark_of_mastery&quot;: 1,\r\n      &quot;tank_id&quot;: 47105\r\n    }\r\n  ]\r\n*** snip ***\r\n```\r\n\r\nThis is where I&#39;m stuck. How do I include the &quot;key&quot; value into each element of the &quot;value&quot; array to achieve my desired output. \r\n\r\nIf I ignore &quot;key&quot; and use &#39;to_entries&#39; on the &quot;value&quot; array, it almost does the job, but not quite...\r\n\r\n`.data | to_entries[] | {id: .key, value} | .value | to_entries [] | .value | [.statistics.wins, .statistics.battles, .mark_of_mastery, .tank_id]`\r\ngives....\r\n```\r\n[\r\n  166,\r\n  441,\r\n  1,\r\n  9505\r\n]\r\n[\r\n  154,\r\n  325,\r\n  1,\r\n  47105\r\n]\r\n[\r\n  216,\r\n  490,\r\n  1,\r\n  47105\r\n]\r\n[\r\n  114,\r\n  254,\r\n  2,\r\n  7969\r\n]\r\n```\r\nwhich is as close as I have been able to get.\r\n\r\nI&#39;m getting too old for this and would really appreciate some help.    :)\r\n",
        "link": "https://stackoverflow.com/questions/63207815/i-need-assistance-in-parsing-a-json-file-to-a-csv-file-using-jq",
        "title": "I need assistance in parsing a JSON file to a .csv file using jq"
    },
    {
        "tags": [
            "json",
            "aws-cloudformation",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1912742,
                    "reputation": 16377,
                    "user_id": 1726083,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/757452f7cd7ba2347c667ef9298ceadb?s=256&d=identicon&r=PG",
                    "display_name": "erik258",
                    "link": "https://stackoverflow.com/users/1726083/erik258"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596307259,
                "post_id": 63208694,
                "comment_id": 111772644,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1596311362,
                "last_edit_date": 1596311362,
                "creation_date": 1596308778,
                "answer_id": 63209055,
                "question_id": 63208694,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Select each entry with a key starting with `NUMBER::` and update it to remove that prefix and convert the value to a number.\r\n```\r\nwith_entries(\r\n  select(.key | startswith(&quot;NUMBER::&quot;)) |= (\r\n    (.key   |= ltrimstr(&quot;NUMBER::&quot;)) |\r\n    (.value |= tonumber)\r\n  )\r\n)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/DC-TCdr9M8)&lt;/sup&gt;",
                "title": "How do you conditionally change a string value to a number in JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1596427393,
        "creation_date": 1596306542,
        "last_edit_date": 1596427393,
        "question_id": 63208694,
        "body_markdown": "I am pulling a secret from **SecretsManager** in **AWS** and using the resulting JSON to build a parameters JSON file that can pass this on to the cloud formation engine. Unfortunately, SecretsManager stores all values as strings, so when I try to pass these values to my cloud formation template it will fail because it is passing a string instead of a number and some cloud formation parameters need to be numbers (e.g. not a string). \r\n\r\nIn the example below, I want to tell JQ that &quot;**HEALTH_CHECK_UNHEALTHY_THRESHOLD_COUNT**&quot; and &quot;**AUTOSCALING_MAX_CAPACITY**&quot; are numbers.  So, I prefix the key with &quot;NUMBER::&quot;.\r\n\r\nThis serves two purposes.  First, it tells the person viewing this secret that it will be converted to a number, second, it will tell JQ to convert the string value of &quot;2&quot; to 2.  This needs to scale so that I can have 1..n keys that need to be converted in the JSON.\r\n\r\nConsider this JSON:\r\n```\r\n{\r\n  &quot;NUMBER::AUTOSCALING_MAX_CAPACITY&quot;: &quot;12&quot;,\r\n  &quot;SERVICE_PLATFORM_VERSION&quot;: &quot;1.3.0&quot;,\r\n  &quot;HEALTH_CHECK_PROTOCOL&quot;: &quot;HTTPS&quot;,\r\n  &quot;NUMBER::HEALTH_CHECK_UNHEALTHY_THRESHOLD_COUNT&quot;: &quot;2&quot;\r\n}\r\n```\r\n\r\nHere is what I&#39;d like to do with JQ:\r\n1. JQ will copy over the key/value pairs for the majority of elements in the JSON &quot;as is&quot;.  If there is no &quot;NUMBER::&quot; prefix, they are copied over &quot;as is&quot;.\r\n2. However, if a key is prefixed with &quot;NUMBER::&quot; I&#39;d like the following to happen:\r\n\r\n   a. JQ will remove the &quot;NUMBER::&quot; prefix from the key name.\r\n\r\n   b. JQ will convert the value from a string to a number.\r\n\r\nThe end result is a JSON that looks like this:\r\n\r\n```\r\n{\r\n  &quot;AUTOSCALING_MAX_CAPACITY&quot;: 12,\r\n  &quot;SERVICE_PLATFORM_VERSION&quot;: &quot;1.3.0&quot;,\r\n  &quot;HEALTH_CHECK_PROTOCOL&quot;: &quot;HTTPS&quot;,\r\n  &quot;HEALTH_CHECK_UNHEALTHY_THRESHOLD_COUNT&quot;: 2\r\n}\r\n```\r\n\r\n**What I&#39;ve tried**\r\n\r\nI have tried using Map to do this with limited success.  In this example I am looking for a specific field mainly as a test.  I don&#39;t want to have to call out specific keys by name, but rather just use any key that begins with &quot;NUMBER::&quot; to do the conversions.\r\n\r\n**NOTE: The SECRET_STRING variable in the examples below contains the source JSON.**\r\n\r\n```\r\n echo $SECRET_STRING | jq &#39;to_entries | map(if .key == &quot;NUMBER::AUTOSCALING_MAX_CAPACITY&quot;  then . + {&quot;value&quot;:.value}  else . end ) | from_entries&#39;**\r\n\r\n```\r\n\r\nI&#39;ve also tried to use &quot;tonumber&quot; across the entire JSON.  JQ will examine all the values and see if it can convert them to numbers.  The problem is it fails when it hits the &quot;SERVICE_PLATFORM_VERSION&quot; key as it detects &quot;1.3.0&quot; as a number and it tries for make that a number, which of course is bogus.\r\n\r\n```\r\nExample: echo $SECRET_STRING | jq -r &#39;.[] | tonumber&#39;\r\n```\r\n\r\n**Recap**\r\nI&#39;d like to use JQ to convert JSON string values to number by use a prefix of &quot;NUMBER::&quot; in the key name.\r\n\r\n**Note**: This problem does not exist when attempting to pull entries from the **Systems Manager Parameter Store** because AWS allows you use &quot;resolve&quot; entries as strings or numbers.  The same feature does not exist in SecretsManager. I&#39;d also like to use the SecretsManager to provide a list of some 30 or more configuration items to set up my stack.  With the Parameter store you have to set up each config item as a separate entry, which we be a maintenance nightmare.\r\n",
        "link": "https://stackoverflow.com/questions/63208694/how-do-you-conditionally-change-a-string-value-to-a-number-in-jq",
        "title": "How do you conditionally change a string value to a number in JQ?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1596330991,
                "last_edit_date": 1596330991,
                "creation_date": 1596321990,
                "answer_id": 63210762,
                "question_id": 63210290,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Well, I found a solution. It&#39;s ugly, but it works.\r\nWould be grateful if someone could write a more elegant version.\r\n```\r\n.config\r\n| (\r\n  .endpoints\r\n  | map(.extra[&quot;namespace_auth.com&quot;] | select(.scope) | .[])\r\n  | unique\r\n) as $s\r\n| .extra[&quot;auth_namespace.com&quot;] | select(.name)\r\n| {name, id, scopes: $s}\r\n```",
                "title": "Create a composite object from a complex json object using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1596335690,
                "creation_date": 1596335690,
                "answer_id": 63211838,
                "question_id": 63210290,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Perhaps the following is closer to what you&#39;re looking for:\r\n\r\n```\r\n.config\r\n| (.extra.&quot;auth_namespace.com&quot; | {id, name}) \r\n  + {scopes: .endpoints\r\n             | map( select(has(&quot;extra&quot;))\r\n                    | .extra.&quot;namespace_auth.com&quot;\r\n                    | select(has(&quot;scope&quot;))\r\n                    | .scope )\r\n             | unique }\r\n```",
                "title": "Create a composite object from a complex json object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1596335690,
        "creation_date": 1596317696,
        "last_edit_date": 1596321435,
        "question_id": 63210290,
        "body_markdown": "I have complex configuration file in JSON:\r\n```\r\n{\r\n    &quot;config&quot;: {\r\n        ...,\r\n        &quot;extra&quot;: {\r\n            ...\r\n            &quot;auth_namespace.com&quot;: {\r\n                ...\r\n                &quot;name&quot;: &quot;some_name&quot;,\r\n                &quot;id&quot;: 1,\r\n                ...\r\n            }\r\n        },\r\n        ...,\r\n        &quot;endpoints&quot;: [\r\n            {   ...,\r\n                &quot;extra&quot;: {\r\n                    &quot;namespace_1.com&quot;: {...},\r\n                    &quot;namespace_auth.com&quot;: { &quot;scope&quot;: &quot;scope1&quot; }\r\n            }},\r\n            {   ...\r\n                # object without &quot;extra&quot; property\r\n                ...\r\n            },\r\n            ...,\r\n            {   ...\r\n                &quot;extra&quot;: {\r\n                    &quot;namespace_1.com&quot;: {...},\r\n                    &quot;namespace_auth.com&quot;: { &quot;scope&quot;: &quot;scope2&quot; }\r\n            }},\r\n            {   ...\r\n                &quot;extra&quot;: {\r\n                    # scopes may repeat\r\n                    &quot;namespace_auth.com&quot;: { &quot;scope&quot;: &quot;scope2&quot; }\r\n            }}\r\n        ]\r\n    }\r\n}\r\n```\r\n\r\nAnd I want to get the output object with properties **&quot;name&quot;**, **&quot;id&quot;**, **&quot;scopes&quot;**. Where &quot;scopes&quot; is an array of unique values.\r\nSomething like this:\r\n```\r\n{\r\n    &quot;name&quot;: &quot;some_name&quot;,\r\n    &quot;id&quot;: 1,\r\n    &quot;scopes&quot;: [&quot;scope1&quot;, &quot;scope2&quot; ... &quot;scopeN&quot;]\r\n}\r\n```\r\n\r\nI can get these properties separately. But I don&#39;t know how to combine them together.\r\n```\r\n[\r\n    .config |\r\n    (\r\n        .extra[&quot;auth_namespace.com&quot;] |\r\n        select(.name) |\r\n        {name, id}\r\n    ) as $name_id |\r\n\r\n    .endpoints[] |\r\n    .extra[&quot;namespace_auth.com&quot;].scope |\r\n    select(.)\r\n] | unique | {scopes: .}\r\n```",
        "link": "https://stackoverflow.com/questions/63210290/create-a-composite-object-from-a-complex-json-object-using-jq",
        "title": "Create a composite object from a complex json object using jq"
    },
    {
        "tags": [
            "jq",
            "exit-code"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596320716,
                "post_id": 63210383,
                "comment_id": 111776013,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596320766,
                "post_id": 63210383,
                "comment_id": 111776028,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1596323743,
                "last_edit_date": 1596323743,
                "creation_date": 1596322843,
                "answer_id": 63210844,
                "question_id": 63210383,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This answer is based on current `jq` 1.6 source code from https://github.com/stedolan/jq\r\n\r\nWith `--exit-status` (`-e`), there are 6 possible exit codes:\r\n\r\n- 0: jq output something and last line was neither false nor null\r\n- 1: last line output was false or null\r\n- 2: usage problem or system error\r\n- 3: jq program compile error\r\n- 4: jq didn&#39;t ouput anything at all\r\n- 5: unknown (unexpected) error: any error other than 2 and 3\r\n\r\nWithout `--exit-status` (`-e`), 0 just means that `jq` ran successfully. Additionally, exit status 1 and 4 disappear and 0 is returned instead. \r\n\r\nHere is (Unix Bourne shell) some ways to get 1 as an exit value:\r\n\r\n    $ echo false | jq -e .\r\n    false\r\n    $ echo &#39;{ &quot;foo&quot;: false }&#39; | jq -e .foo\r\n    false\r\n\r\n    $ echo null | jq -e .\r\n    null\r\n    $ echo &#39;{ &quot;foo&quot;: null }&#39; | jq -e .foo\r\n    null\r\n    $ echo &#39;{ }&#39; | jq -e .foo\r\n    null\r\n    $ echo &#39;{ &quot;foo&quot;: false }&#39; | jq -e &#39;.bar?&#39;\r\n    null\r\n\r\nHere is how to get 4:\r\n\r\n    $ echo &#39;false&#39; | jq -e &#39;.foo?&#39;\r\n\r\nAnd (I&#39;m sure you want to know) here is one way to get 5:\r\n\r\n    $ echo false | jq .foo\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index boolean with string &quot;foo&quot;",
                "title": "What exit code 1 of linux jq means"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1596575416,
                "last_edit_date": 1596575416,
                "creation_date": 1596341301,
                "answer_id": 63212296,
                "question_id": 63210383,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following is intended to supplement the information given about the -e option elsewhere on this page.\r\n\r\nAssuming -e has NOT been specified, the return code is:\r\n\r\n* 5 if a call to `error/1` or `halt_error/0` causes program termination\r\n* an integral value (*) depending on N if `halt_error(N)` causes program termination, where N is a number; in particular, if N is non-negative, then the status is set to (N%256).\r\n\r\nOtherwise, but still assuming -e has NOT been specified, the return code is:\r\n\r\n* 2 if a parsing error reading input causes program termination\r\n* 3 or 4 if a syntax error in the jq program causes program termination\r\n* 0 on normal termination.\r\n\r\n---\r\n(*) Specifically: \r\n\r\n`N % 256 | if . &lt; 0 then 256+. else . end`\r\n&lt;/super&gt;",
                "title": "What exit code 1 of linux jq means"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1596575416,
        "creation_date": 1596318536,
        "last_edit_date": 1596344219,
        "question_id": 63210383,
        "body_markdown": "As the tile says, I wonder when jq exits with code 1. In its manual, it says -e sets the exit status of jq to 0 if the last output values was neither false nor null, 1 if the last output value was either false or null. Not clear what it means by the last output values of false or null? what if I don&#39;t use -e?",
        "link": "https://stackoverflow.com/questions/63210383/what-exit-code-1-of-linux-jq-means",
        "title": "What exit code 1 of linux jq means"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596449588,
                "post_id": 63227372,
                "comment_id": 111805020,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12216649,
                    "reputation": 241,
                    "user_id": 8916876,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2f123a28dddfcdff46b45cf7ab1e8ee9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Bibelo",
                    "link": "https://stackoverflow.com/users/8916876/bibelo"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596451482,
                "post_id": 63227372,
                "comment_id": 111805745,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1596455130,
                "last_edit_date": 1596455130,
                "creation_date": 1596449962,
                "answer_id": 63227621,
                "question_id": 63227372,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem with your attempt is neither of `.` or `.[]` lets you access object keys nested at the level `.name` key is present. Also you have a missing close `)` for all the invocations of `select` function.\r\n\r\nThere are multiple ways to get this done. One way is map the path leading up to the `name` key and get the value of that path\r\n\r\n    (paths | select( .[-1] == &quot;name&quot;)) as $path | getpath($path)\r\n\r\n&lt;sup&gt;[jqplay Demo](https://jqplay.org/s/sIPGPDgxq5)&lt;/sup&gt;\r\n\r\nor as noted in the comments, just use the recursive descent builtin `recurse` and select objects with fields containing `.name` key\r\n\r\n    recurse | select(has(&quot;name&quot;)?).name\r\n\r\n\r\n\r\n",
                "title": "Select all keys in sub-sub objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1596479084,
        "creation_date": 1596448912,
        "last_edit_date": 1596479084,
        "question_id": 63227372,
        "body_markdown": "I don&#39;t get how jq works. I&#39;m trying hard but I just don&#39;t get it. See below how I now create a jq query.\r\n\r\nSo this is my JSON, and I just want to extract the **name** keys in all the sub-objects\r\n\r\n```\r\n{\r\n  &quot;checkpassword&quot;: {\r\n    &quot;checkpassword&quot;: {\r\n      &quot;containers&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;checkpassword&quot;,\r\n          &quot;exists&quot;: &quot;true&quot;,\r\n          &quot;running&quot;: &quot;true&quot;\r\n        }\r\n      ],\r\n      &quot;projectdir&quot;: &quot;true&quot;,\r\n      &quot;nginxdef&quot;: &quot;true&quot;\r\n    }\r\n  },\r\n  &quot;reverse_proxy&quot;: {\r\n    &quot;reverse_proxy&quot;: {\r\n      &quot;containers&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;reverse_proxy&quot;,\r\n          &quot;exists&quot;: &quot;true&quot;,\r\n          &quot;running&quot;: &quot;true&quot;\r\n        }\r\n      ],\r\n      &quot;projectdir&quot;: &quot;true&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI gave up trying by myself, I&#39;m wasting time on it.\r\nI feel lots of users are in the same situation.\r\n\r\nPlease any help is appreciated.\r\n\r\n\r\n\r\n.\r\n\r\nNB: this is how I develop my queries:\r\n\r\n```\r\nroot@priv  …/newProject   master  san_listProjects | jq -r &#39;.[] | select( any(.name)&#39;\r\njq: error: syntax error, unexpected $end, expecting &#39;;&#39; or &#39;)&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.[] | select( any(.name)\r\njq: 1 compile error\r\n root@priv  …/newProject   master  san_listProjects | jq -r &#39;.[] | select( any(&quot;.name&quot;)&#39;\r\njq: error: syntax error, unexpected $end, expecting &#39;;&#39; or &#39;)&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.[] | select( any(&quot;.name&quot;)\r\njq: 1 compile error\r\n root@priv  …/newProject   master  san_listProjects | jq -r &#39;.[] | select( any(&quot;name&quot;)&#39;\r\njq: error: syntax error, unexpected $end, expecting &#39;;&#39; or &#39;)&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.[] | select( any(&quot;name&quot;)\r\njq: 1 compile error\r\n root@priv  …/newProject   master  san_listProjects | jq -r &#39;.[] | select(any(&quot;name&quot;)&#39;\r\njq: error: syntax error, unexpected $end, expecting &#39;;&#39; or &#39;)&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.[] | select(any(&quot;name&quot;)\r\njq: 1 compile error\r\n root@priv  …/newProject   master  san_listProjects | jq -r &#39;. | select(any(&quot;name&quot;)&#39;\r\njq: error: syntax error, unexpected $end, expecting &#39;;&#39; or &#39;)&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n. | select(any(&quot;name&quot;)\r\njq: 1 compile error\r\n root@priv  …/newProject   master  san_listProjects | jq -r &#39;. | select(any(&quot;.name&quot;)&#39;\r\njq: error: syntax error, unexpected $end, expecting &#39;;&#39; or &#39;)&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n. | select(any(&quot;.name&quot;)\r\njq: 1 compile error\r\n root@priv  …/newProject   master  san_listProjects | jq -r &#39;. | select(any(.name)&#39;\r\njq: error: syntax error, unexpected $end, expecting &#39;;&#39; or &#39;)&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n. | select(any(.name)\r\njq: 1 compile error\r\n```\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63227372/select-all-keys-in-sub-sub-objects",
        "title": "Select all keys in sub-sub objects"
    },
    {
        "tags": [
            "json",
            "export-to-csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1596474737,
                "post_id": 63228971,
                "comment_id": 111816489,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1596485661,
                "last_edit_date": 1596485661,
                "creation_date": 1596475815,
                "answer_id": 63234251,
                "question_id": 63228971,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your jq solution can be slightly simplified in a way which also enhances its efficiency:\r\n```\r\n.countries[]\r\n| .countryName as $country\r\n| .cities[]\r\n| .cityName as $city\r\n| .streets[]\r\n| [$country, $city, .streetName]\r\n| @csv\r\n```\r\nIn conjunction with the -r command-line options, this will of course produce valid CSV, but your Q indicates a preference that (unnecessary?) quotation marks be removed. In the case of the sample data shown, you could get away with replacing `@csv` by `join(&quot;,&quot;)` but in general, one has to watch for commas and other characters that are special to CSV.\r\n\r\n## General case\r\nThe following seems to handle the general case but relies on sed to handle the CSV conventions regarding quotation marks and embedded newlines, and has not been thoroughly tested:\r\n```\r\n&lt; sampleData.json jq -r &#39;\r\ndef q:\r\n  if type == &quot;string&quot; and test(&quot;[,\\n\\&quot;]&quot;)\r\n  then tojson \r\n  else . end;\r\n  \r\n.countries[]\r\n| .countryName as $country\r\n| .cities[]\r\n| .cityName as $city\r\n| .streets[]\r\n| [$country, $city, .streetName]\r\n| map(q)\r\n| join(&quot;,&quot;)\r\n&#39; | sed -e &#39;s/\\\\\\&quot;/&quot;&quot;/g&#39; -e &#39;s/\\\\n/\\\r\n/g&#39;\r\n\r\n",
                "title": "generating &quot;table&quot; from json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1596485661,
        "creation_date": 1596455740,
        "last_edit_date": 1596484024,
        "question_id": 63228971,
        "body_markdown": "Bringing back one of my sample data from previous question:\r\n\r\n    {\r\n      &quot;countries&quot;: [\r\n        {\r\n          &quot;countryName&quot;: &quot;CZ&quot;,\r\n          &quot;cities&quot;: [\r\n            {\r\n              &quot;cityName&quot;: &quot;Prague&quot;,\r\n              &quot;streets&quot;: [\r\n                {\r\n                  &quot;streetName&quot;: &quot;Norsk&#225;&quot;\r\n                },\r\n                {\r\n                  &quot;streetName&quot;: &quot;Slovensk&#225;&quot;\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;countryName&quot;: &quot;FR&quot;,\r\n          &quot;cities&quot;: [\r\n            {\r\n              &quot;cityName&quot;: &quot;Paris&quot;,\r\n              &quot;streets&quot;: [\r\n                {\r\n                  &quot;streetName&quot;: &quot;rue piat&quot;\r\n                },\r\n                {\r\n                  &quot;streetName&quot;: &quot;rue lesage&quot;\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nI&#39;d like to use jq to generate plaintext/asciidoc/markdown table from this data, but I miss some basic idea how to do that. The duplication in given column is what I don&#39;t get.\r\n\r\nSo the expected output could look like:\r\n\r\n    CZ Prague Norsk&#225;\r\n    CZ Prague Slovensk&#225;\r\n    FR Paris rue piat\r\n    FR Paris rue lesage\r\n\r\nie. how to iterate over top level array `countries`, pick field `countryName` from it, and iterate over  field `cities` contained in `countries` array elements and pick `cityName` from it, etc. to have resultant array of triplets, which can be then processed into desired output text.\r\n\r\n\r\nEDIT: \r\n\r\n- updated json to be in sync with expected output data.\r\n- meanwhile I was kinda lucky with expression:\r\n\r\n    jq &#39;.countries[] | .countryName as $country| .cities[] | .cityName as $city | .streets[] | $country+&quot; &quot;+$city+&quot; &quot;+.streetName &#39; &lt; /tmp/sampleData.json\r\n\r\nbut following one using @csv did not work for me for some reason.\r\n\r\n    jq &#39;[(.countries[] | .countryName as $country| .cities[] | .cityName as $city | .streets[] | [$country,$city,.streetName])] | @csv&#39; &lt; /tmp/sampleData.json\r\n\r\nI&#39;d be thankful for any suggestion for improvements.\r\n\r\nEDIT2: for @csv to work, the it must be fed with array(which it is) but not array of arrays. Misconception of imperative programming style. Anyways, this one is correct:\r\n\r\n    jq &#39;[(.countries[] | .countryName as $country| .cities[] | .cityName as $city | .streets[] | [$country,$city,.streetName])] | .[] | @csv&#39; &lt; /tmp/sampleData.json \r\n\r\n",
        "link": "https://stackoverflow.com/questions/63228971/generating-table-from-json-using-jq",
        "title": "generating &quot;table&quot; from json using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1596524837,
                "last_edit_date": 1596524837,
                "creation_date": 1596473760,
                "answer_id": 63233722,
                "question_id": 63233442,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The variable `acc` is assigned the entire output of JQ, there&#39;s no loop there. And you don&#39;t need one either.\r\n```\r\n$ jq -r &#39;&quot;\\(.accounts[]) test&quot;&#39; file\r\nbob.doe test\r\njoe.gomez test\r\nbill.murr test\r\n```",
                "title": "Expand array elements appending a string to each in a loop"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1596532751,
                "creation_date": 1596532751,
                "answer_id": 63243764,
                "question_id": 63233442,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "thanks this got me on the right path!\r\n\r\n    sa=$(cat $file |  jq -r  &#39;&quot;\\\\n \\&quot;\\(.service_accounts[])\\&quot; = [\\&quot;\\(.namespace)\\&quot;]&quot;&#39;)",
                "title": "Expand array elements appending a string to each in a loop"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1596532751,
        "creation_date": 1596472686,
        "last_edit_date": 1596524663,
        "question_id": 63233442,
        "body_markdown": "Hopefully someone could point me in the right direction!\r\n\r\nMy input:\r\n``` json\r\n{\r\n  &quot;accounts&quot;: [\r\n    &quot;bob.doe&quot;,\r\n    &quot;joe.gomez&quot;,\r\n    &quot;bill.murr&quot;\r\n  ]\r\n}\r\n```\r\nMy attempt:\r\n``` bash\r\nacc=$(cat $file |  jq -r  &#39;.accounts[]&#39; )\r\necho &quot;$acc test&quot;\r\n```\r\nOutput:\r\n``` none\r\nbob.doe\r\njoe.gomez\r\nbill.murr test\r\n```\r\nIt seems to treat all the values in JSON as one array object.\r\n\r\nDesired output:\r\n``` none\r\nbob.doe test\r\njoe.gomez test\r\nbill.murr test\r\n```\r\nAny suggestions?",
        "link": "https://stackoverflow.com/questions/63233442/expand-array-elements-appending-a-string-to-each-in-a-loop",
        "title": "Expand array elements appending a string to each in a loop"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1596483224,
                "creation_date": 1596483224,
                "answer_id": 63235839,
                "question_id": 63235633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re actually not too far off, except\r\n\r\n1. You want to use `map` so that the final result stays an array.\r\n2. You want to use a `|=` instead of an `=` to alter a subpath of `.` while still returning `.`.\r\n3. You don&#39;t actually need a regex to grab two characters off of the beginning of a string.\r\n\r\nSo this ought to work:\r\n\r\n    jq &#39;map((.id + .id[0:2]) as $newid | .data[].something |= $newid)`",
                "title": "update part of JSON using capture function in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1597474455,
                "creation_date": 1597474455,
                "answer_id": 63423424,
                "question_id": 63235633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks a lot for @hobbs, who provided a lot help to solve this.\r\n\r\nregarding the updated question, which asked about using capture, the solution looks like this:\r\n\r\n    jq &#39;.arr |= map(.a.id as $id | .a.b.c[].data[].something |= ($id | capture(&quot;(?&lt;a&gt;[a-zA-z]*)(?&lt;b&gt;.*)&quot;) | (.a+.b+.a)  ) ) &#39; &lt; a.json &gt; c.json\r\n\r\nso what I was missing, and what was required to move from hobbs answer to using `capture` function was just a pair or `()`. Let me try to explain this(I&#39;m nowhere near hobbs knowledge, but lets try).\r\n\r\nyou identify array you want to update, in this case `.arr`. You have to update it, otherwise you won&#39;t get original data in result. You update `arr` array using `map`, which  in this case applies some transformation and return new array; in this example there are just 2 things: variable assignment, which does not change context, and another `|=` operator, so the first `|=` updates `.arr` with updated self. About transformation within `map`: first we declare `$id` variable, which does not change the context. Then we say, that within current context, we would like to update `.a.b.c[].data[].something` with new value. That new value can be literal, or something, which does not change context, and since capture does that, we just need to use brackets `()`. So here within brackets we expand variable `$id`, capture regex, and from new context produced by `capture`, we produce new value for `something` using string concatenation `(.a+.b+.a)`.\r\n\r\n(disclaimer: I&#39;m jq learner, so some terminology in explanation might be shaky, but provided command should work)",
                "title": "update part of JSON using capture function in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1597474455,
        "creation_date": 1596482309,
        "last_edit_date": 1596530281,
        "question_id": 63235633,
        "body_markdown": "Say that I have JSON, which contains missing data, which can be calculated from data already present using regex.\r\n\r\nSample data:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;a100&quot;,\r\n        &quot;data&quot;: [\r\n          {\r\n            &quot;something&quot;: null\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;a101&quot;,\r\n        &quot;data&quot;: [\r\n          {\r\n            &quot;something&quot;: null\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;b100&quot;,\r\n        &quot;data&quot;: [\r\n          {\r\n            &quot;something&quot;: null\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nAssumption: for simplicity/brewity of this example I&#39;m using array as top-level element. Imagine wildly bigger JSON with bigger nesting of data residing in this array, ie. it cannot be solved by adding array creation.\r\n\r\nSay, that we need to calculate `something` from `id`, where `something` should be `id` with its first two chars added to the end:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;a100&quot;,\r\n        &quot;data&quot;: [\r\n          {\r\n            &quot;something&quot;: &quot;a100a1&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;a101&quot;,\r\n        &quot;data&quot;: [\r\n          {\r\n            &quot;something&quot;: &quot;a101a1&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;b100&quot;,\r\n        &quot;data&quot;: [\r\n          {\r\n            &quot;something&quot;: &quot;b100b1&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nI was able to come up with:\r\n\r\n    jq &#39;.[] \r\n    | . as $env \r\n    | .data[].something=($env.id | capture(&quot;(?&lt;cid&gt;[a-z0-9]{2})(?&lt;rest&gt;.*)&quot;) | .cid+.rest+.cid)&#39; &lt; test.json\r\n\r\nbut this &quot;solution&quot; omits everything up from the declared variable, which in this simplified example is top-level array. So the question: as we go deeper in json structure, how to store some values along the node path, so that we can use this variables to update some part of structure while keeping the rest untouched?\r\n\r\n\r\nEDIT: The example above was incorrect because it can be easily solved without using `capture` function I was asking about. I will present another example. The problem is, that I don&#39;t know how to use `|=` to update part of json, if `capture` returns `json-data` where I will lose the data needed for the update, not understanding sufficiently, why declaring variable blocks me from using `|=` sometimes  etc etc. Ie. I have no idea how to use it, despite of many attempts and googling.\r\n\r\n    {\r\n      &quot;arr&quot;: [\r\n        {\r\n          &quot;a&quot;: {\r\n            &quot;id&quot;: &quot;a100&quot;,\r\n            &quot;b&quot;: {\r\n              &quot;c&quot;: [\r\n                {\r\n                  &quot;data&quot;: [\r\n                    {\r\n                      &quot;something&quot;: null\r\n                    }\r\n                  ]\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        },\r\n        {\r\n          &quot;a&quot;: {\r\n            &quot;id&quot;: &quot;bPleaseUseRegex100&quot;,\r\n            &quot;b&quot;: {\r\n              &quot;c&quot;: [\r\n                {\r\n                  &quot;data&quot;: [\r\n                    {\r\n                      &quot;something&quot;: null\r\n                    }\r\n                  ]\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nto produce:\r\n\r\n    {\r\n      &quot;arr&quot;: [\r\n        {\r\n          &quot;a&quot;: {\r\n            &quot;id&quot;: &quot;a100&quot;,\r\n            &quot;b&quot;: {\r\n              &quot;c&quot;: [\r\n                {\r\n                  &quot;data&quot;: [\r\n                    {\r\n                      &quot;something&quot;: &quot;a100a&quot;\r\n                    }\r\n                  ]\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        },\r\n        {\r\n          &quot;a&quot;: {\r\n            &quot;id&quot;: &quot;bPleaseUseRegex100&quot;,\r\n            &quot;b&quot;: {\r\n              &quot;c&quot;: [\r\n                {\r\n                  &quot;data&quot;: [\r\n                    {\r\n                      &quot;something&quot;: &quot;bPleaseUseRegex100bPleaseUseRegex&quot;\r\n                    }\r\n                  ]\r\n                }\r\n              ]\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nabout regex rule: everything from start of `id` until first decimal has to be  appended to the `id` to produce `something`. Tbh I don&#39;t care if you use `.*` instead, just please use `capture` function to see how it works.\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63235633/update-part-of-json-using-capture-function-in-jq",
        "title": "update part of JSON using capture function in jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596492511,
                "post_id": 63237346,
                "comment_id": 111823334,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1596500913,
                "creation_date": 1596500913,
                "answer_id": 63238661,
                "question_id": 63237346,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following script should work for you.\r\n\r\n    jq -n &#39;{ &quot;master-key&quot;: input | add | map_values(. + input) }&#39; file1.json file2.json\r\n\r\nThe [`-n` (`--null-input`)](https://stedolan.github.io/jq/manual/#Invokingjq) option disables the automatic read of input streams so that you can manually deal with each object (using functions like [`input` or `inputs`](https://stedolan.github.io/jq/manual/#IO)). The first `input` call loads the array from your primary file and `add` converts this array to an object. Then `map_values` merges each sub-object with a new object loaded from the input stream (now on the secondary file) by subsequent `input` calls.",
                "title": "JQ: Combine array with a list of objects from another file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1596500913,
        "creation_date": 1596490953,
        "question_id": 63237346,
        "body_markdown": "I need to append content in my primary file with information from a secondary file.\r\n\r\nThe primary file looks like this one:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;dynamic-parent-key-1&quot;: {\r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;,\r\n      &quot;array1&quot;: [\r\n        &quot;array-value-1&quot;,\r\n        &quot;array-value-2&quot;\r\n      ]\r\n    }\r\n  },\r\n  {\r\n    &quot;dynamic-parent-key-2&quot;: {\r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;,\r\n      &quot;array1&quot;: [\r\n        &quot;array-value-1&quot;\r\n      ]\r\n    }\r\n  }\r\n]\r\n```\r\nAnd the secondary file looks like this one:\r\n\r\n```\r\n{\r\n  &quot;fixedKey&quot;: [\r\n    {\r\n      &quot;Key&quot;: &quot;A&quot;,\r\n      &quot;Value&quot;: &quot;abc&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;B&quot;,\r\n      &quot;Value&quot;: &quot;xyz&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;C&quot;,\r\n      &quot;Value&quot;: &quot;asd&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;fixedKey&quot;: [\r\n    {\r\n      &quot;Key&quot;: &quot;A&quot;,\r\n      &quot;Value&quot;: &quot;aaa&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;B&quot;,\r\n      &quot;Value&quot;: &quot;bbb&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;C&quot;,\r\n      &quot;Value&quot;: &quot;ccc&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThe elements order is related. The first object &quot;fixedKey&quot; corresponds to &quot;dynamic-parent-key-1&quot; and so on. The first file is JSON compliant and the second is not, it is just a list of JSON objects saved on a common file. \r\n\r\nI need an output file (or just update the first one) so it looks ideally like this:\r\n\r\n```\r\n{\r\n  &quot;master-key&quot;: {\r\n    &quot;dynamic-parent-key-1&quot;: {\r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;,\r\n      &quot;array1&quot;: [\r\n        &quot;array-value-1&quot;,\r\n        &quot;array-value-2&quot;\r\n      ],\r\n      &quot;fixedKey&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;A&quot;,\r\n          &quot;Value&quot;: &quot;abc&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;B&quot;,\r\n          &quot;Value&quot;: &quot;xyz&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;C&quot;,\r\n          &quot;Value&quot;: &quot;asd&quot;\r\n        }\r\n      ]\r\n    },\r\n    &quot;dynamic-parent-key-2&quot;: {\r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;,\r\n      &quot;array1&quot;: [\r\n        &quot;array-value-1&quot;\r\n      ],\r\n      &quot;fixedKey&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;A&quot;,\r\n          &quot;Value&quot;: &quot;aaa&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;B&quot;,\r\n          &quot;Value&quot;: &quot;bbb&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;C&quot;,\r\n          &quot;Value&quot;: &quot;ccc&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nBut if that is not possible or too complicated, I could stick to first file structure and obtain something like this:\r\n```\r\n[\r\n  {\r\n    &quot;dynamic-parent-key-1&quot;: {\r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;,\r\n      &quot;array1&quot;: [\r\n        &quot;array-value-1&quot;,\r\n        &quot;array-value-2&quot;\r\n      ],\r\n      &quot;fixedKey&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;A&quot;,\r\n          &quot;Value&quot;: &quot;abc&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;B&quot;,\r\n          &quot;Value&quot;: &quot;xyz&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;C&quot;,\r\n          &quot;Value&quot;: &quot;asd&quot;\r\n        }\r\n      ]\r\n    }\r\n  },\r\n  {\r\n    &quot;dynamic-parent-key-2&quot;: {\r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;,\r\n      &quot;array1&quot;: [\r\n        &quot;array-value-1&quot;\r\n      ],\r\n      &quot;fixedKey&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;A&quot;,\r\n          &quot;Value&quot;: &quot;aaa&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;B&quot;,\r\n          &quot;Value&quot;: &quot;bbb&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;C&quot;,\r\n          &quot;Value&quot;: &quot;ccc&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n]\r\n```\r\nHow can I achieve this? I&#39;ve been trying with map(), |=, + but I can&#39;t make it.\r\nShould I first prepare my secondary file to be JSON compliant or it is not necessary? ",
        "link": "https://stackoverflow.com/questions/63237346/jq-combine-array-with-a-list-of-objects-from-another-file",
        "title": "JQ: Combine array with a list of objects from another file"
    },
    {
        "tags": [
            "bash",
            "shell",
            "unix",
            "filter",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1596502391,
                "post_id": 63238759,
                "comment_id": 111825427,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1596505253,
                "creation_date": 1596505253,
                "answer_id": 63239101,
                "question_id": 63238759,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re pretty close to there! In your case, the `join` function may help:\r\n```bash\r\njq -r &#39;[.[]|select(.property==&quot;ENABLED&quot;)|.name]|join(&quot; &quot;)&#39; input.json\r\n```\r\nBy wrapping all names in an array, the `join` function works like that in python. From the doc:\r\n\r\n&gt; join(str)\r\n&gt;\r\n&gt; Joins the array of elements given as input, using the argument as separator. It is the inverse of split: that  is,  running\r\n&gt; split(&quot;foo&quot;) | join(&quot;foo&quot;) over any input string returns said input string.\r\n&gt; \r\n&gt;     jq &#180;join(&quot;, &quot;)&#180;\r\n&gt;        [&quot;a&quot;,&quot;b,c,d&quot;,&quot;e&quot;]\r\n&gt;     =&gt; &quot;a, b,c,d, e&quot;\r\n\r\n",
                "title": "Replace \\n with space in jq query/command output without tr and sed commands"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1750128269,
        "creation_date": 1596501973,
        "last_edit_date": 1750128269,
        "question_id": 63238759,
        "body_markdown": "With `input.json`:\r\n\r\n    {\r\n      &quot;server1&quot;: {\r\n        &quot;name&quot;: &quot;server1&quot;,\r\n        &quot;property&quot;: &quot;ENABLED&quot;\r\n      },\r\n      &quot;server2&quot;: {\r\n        &quot;name&quot;: &quot;server2&quot;,\r\n        &quot;property&quot;: &quot;ENABLED&quot;\r\n      },\r\n      &quot;server3&quot;: {\r\n        &quot;name&quot;: &quot;server3&quot;,\r\n        &quot;property&quot;: &quot;ENABLED&quot;\r\n      },\r\n    }\r\n\r\nThe following `jq` query:\r\n\r\n    jq -r &#39;.[] | select(.property == &quot;ENABLED&quot;) |.name&#39; input.json\r\n\r\noutputs:\r\n\r\n    server1\r\n    server2\r\n    server3\r\n\r\nI want my output to be without any new line and as below, separated by space and no space after the last word (server3 in this case)\r\n\r\n    server1 server2 server3\r\n\r\nI don&#39;t want to do pipe after jq command and obtain the output with sed and tr commands. I want to achieve this with jq command only.",
        "link": "https://stackoverflow.com/questions/63238759/replace-n-with-space-in-jq-query-command-output-without-tr-and-sed-commands",
        "title": "Replace \\n with space in jq query/command output without tr and sed commands"
    },
    {
        "tags": [
            "json",
            "nested",
            "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": 1596505827,
                "post_id": 63239004,
                "comment_id": 111826067,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1596505786,
                "creation_date": 1596505786,
                "answer_id": 63239146,
                "question_id": 63239004,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A jq query for retrieving the .bodyText values as a stream is:\r\n\r\n    .response.results[] | .fields.bodyText\r\n",
                "title": "Trouble accessing a nested JSON value with PYJQ"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1596565037,
        "creation_date": 1596504510,
        "last_edit_date": 1596565037,
        "question_id": 63239004,
        "body_markdown": "    {\r\n    &quot;response&quot;: {\r\n        &quot;status&quot;: &quot;ok&quot;,\r\n        &quot;userTier&quot;: &quot;developer&quot;,\r\n        &quot;total&quot;: 18398,\r\n        &quot;startIndex&quot;: 1,\r\n        &quot;pageSize&quot;: 10,\r\n        &quot;currentPage&quot;: 1,\r\n        &quot;pages&quot;: 1840,\r\n        &quot;orderBy&quot;: &quot;relevance&quot;,\r\n        &quot;results&quot;: [\r\n            {\r\n                &quot;id&quot;: &quot;world/2020/jul/03/coronavirus-the-week-explained&quot;,\r\n                &quot;type&quot;: &quot;article&quot;,\r\n                &quot;sectionId&quot;: &quot;world&quot;,\r\n                &quot;sectionName&quot;: &quot;World news&quot;,\r\n                &quot;webPublicationDate&quot;: &quot;2020-07-03T11:03:46Z&quot;,\r\n                &quot;webTitle&quot;: &quot;Coronavirus: the week explained&quot;,\r\n                &quot;webUrl&quot;: &quot;https://www.theguardian.com/world/2020/jul/03/coronavirus-the-week-explained&quot;,\r\n                &quot;apiUrl&quot;: &quot;https://content.guardianapis.com/world/2020/jul/03/coronavirus-the-week-explained&quot;,\r\n                &quot;fields&quot;: {\r\n                    &quot;bodyText&quot;: &quot;words&quot;\r\n                },\r\n                &quot;isHosted&quot;: false,\r\n                &quot;pillarId&quot;: &quot;pillar/news&quot;,\r\n                &quot;pillarName&quot;: &quot;News&quot;\r\n            },\r\n            {\r\n                &quot;id&quot;: &quot;music/2020/jun/10/saving-classical-music-from-coronavirus&quot;,\r\n                &quot;type&quot;: &quot;article&quot;,\r\n                &quot;sectionId&quot;: &quot;music&quot;,\r\n                &quot;sectionName&quot;: &quot;Music&quot;,\r\n                &quot;webPublicationDate&quot;: &quot;2020-06-10T17:38:03Z&quot;,\r\n                &quot;webTitle&quot;: &quot;Saving classical music from coronavirus | Letters&quot;,\r\n                &quot;webUrl&quot;: &quot;https://www.theguardian.com/music/2020/jun/10/saving-classical-music-from-coronavirus&quot;,\r\n                &quot;apiUrl&quot;: &quot;https://content.guardianapis.com/music/2020/jun/10/saving-classical-music-from-coronavirus&quot;,\r\n                &quot;fields&quot;: {\r\n                    &quot;bodyText&quot;: &quot;more words&quot;\r\n                },\r\n                &quot;isHosted&quot;: false,\r\n                &quot;pillarId&quot;: &quot;pillar/arts&quot;,\r\n                &quot;pillarName&quot;: &quot;Arts&quot;\r\n            }  \r\n        }\r\n\r\n\r\n\r\n\r\n\r\n\r\nThe code I use can access WebUrl and webPublicationDate, however I am interested in the bodyText value. To access these values I am using pyjq.\r\n\r\n\r\ndata = response.json()&lt;br/&gt; \r\nquery=f&#39;.response .results [] | {{web_url: .webUrl, pub_date: .webPublicationDate}}&#39;&lt;br/&gt; \r\n\r\noutput=pyjq.all(query,data)&lt;br/&gt; \r\n\r\n\r\n^This code will extract the webUrl, and PublicationDate. However I want to extract the bodyText. How would I write a query in the same format to grab the bodyText? \r\n\r\n",
        "link": "https://stackoverflow.com/questions/63239004/trouble-accessing-a-nested-json-value-with-pyjq",
        "title": "Trouble accessing a nested JSON value with PYJQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1596550183,
                "creation_date": 1596550183,
                "answer_id": 63248716,
                "question_id": 63248435,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just.. `select` them?\r\n```\r\n.[][] |= select(has(&quot;prop_3&quot;))\r\n```",
                "title": "filter based on presence of entry in sub-object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1596550285,
        "creation_date": 1596549261,
        "last_edit_date": 1596550285,
        "question_id": 63248435,
        "body_markdown": "For this:\r\n\r\n```\r\n{\r\n    &quot;item-1&quot;: {\r\n        &quot;sub-item-1&quot;: {\r\n            &quot;prop_1&quot;: 0,\r\n            &quot;prop_2&quot;: &quot;bar&quot;\r\n        },\r\n        &quot;sub-item-2&quot;: {\r\n            &quot;prop_1&quot;: 0,\r\n            &quot;prop_2&quot;: &quot;bar&quot;,\r\n            &quot;prop_3&quot;: &quot;OK&quot;\r\n        }\r\n    },\r\n    &quot;item-2&quot;: {\r\n        &quot;sub-item-1&quot;: {\r\n            &quot;prop_3&quot;: &quot;OK&quot;\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nI want a jq filter that gives me the same structure, but only the sub-objects that have the &quot;prop_3&quot; entry:\r\n\r\n```\r\n{\r\n    &quot;item-1&quot;: {\r\n        &quot;sub-item-2&quot;: {\r\n            &quot;prop_1&quot;: 0,\r\n            &quot;prop_2&quot;: &quot;bar&quot;,\r\n            &quot;prop_3&quot;: &quot;OK&quot;\r\n        }\r\n    },\r\n    &quot;item-2&quot;: {\r\n        &quot;sub-item-1&quot;: {\r\n            &quot;prop_3&quot;: &quot;OK&quot;\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nI can filter the top level using the following:\r\n\r\n```\r\njq &#39;with_entries(select([.key] | inside(&quot;item-1&quot;, &quot;item-2&quot;)))\r\n```\r\n\r\nBut can&#39;t figure out how to extend this further down the hierarchy.",
        "link": "https://stackoverflow.com/questions/63248435/filter-based-on-presence-of-entry-in-sub-object",
        "title": "filter based on presence of entry in sub-object"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1596551951,
                "creation_date": 1596551951,
                "answer_id": 63249233,
                "question_id": 63249171,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The shell will try to execute the contents of `$data`.  Try this:\r\n\r\n    result=$(echo $data | jq --arg Name &quot;$1&quot; -r &#39;.items[] | select(.app==$Name) | .name&#39;)\r\n\r\nOr my preference:\r\n\r\n    result=$( curl -sb -H $url |  jq --arg Name &quot;$1&quot; -r &#39;.items[] | select(.app==$Name) | .name&#39;)\r\n\r\n\r\n\r\n",
                "title": "Failing to store result in variable after jq filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1596552013,
        "creation_date": 1596551710,
        "last_edit_date": 1596552013,
        "question_id": 63249171,
        "body_markdown": "    url=&quot;http://something.com&quot;\r\n    data=`curl -sb -H  $url`\r\n    result=$($data | jq --arg Name &quot;$1&quot; -r &#39;.items[] | select(.app==$Name) | .name&#39;)\r\n    echo $result\r\n\r\nI am not able to store result \r\n",
        "link": "https://stackoverflow.com/questions/63249171/failing-to-store-result-in-variable-after-jq-filter",
        "title": "Failing to store result in variable after jq filter"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596568913,
                "post_id": 63253610,
                "comment_id": 111851775,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4778665,
                    "reputation": 31,
                    "user_id": 3861098,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/02d811e5b4a4b23106c4c5f000eae832?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Faro",
                    "link": "https://stackoverflow.com/users/3861098/faro"
                },
                "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": 1596593080,
                "post_id": 63253610,
                "comment_id": 111858504,
                "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": 1596609504,
                "post_id": 63253610,
                "comment_id": 111862487,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1596568758,
                "creation_date": 1596568758,
                "answer_id": 63253719,
                "question_id": 63253610,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try\r\n\r\n    curl --silent &quot;https://api.nordvpn.com/v1/servers?limit=16384&quot; |\\\r\n        jq --raw-output &#39;map(select(.locations[].country.city.name == &quot;Bangkok&quot;))| sort_by(.load)[] | &quot;  Server: \\(.name)\\nHostname: \\(.hostname)\\n      IP: \\(.station)\\n Country: \\(.locations[0].country.name)\\n    City: \\(.locations[0].country.city.name)\\n    Load: \\(.load)\\n&quot;&#39;\r\n",
                "title": "How can I sort jq result by load?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1596609269,
                "last_edit_date": 1596609269,
                "creation_date": 1596584296,
                "answer_id": 63256466,
                "question_id": 63253610,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To avoid the messiness, one could define a helper function:\r\n```\r\n  def format: \r\n    (keys_unsorted | max_by(length) | length) as $mx\r\n    | keys_unsorted[] as $k \r\n    | (($mx - ($k|length)) * &quot; &quot;) + $k + &quot; : &quot; + &quot;\\(.[$k])&quot;;\r\n```\r\nThe main program can then be written as follows:\r\n```\r\n  map( select(.locations[].country.city.name == &quot;Bangkok&quot;) )\r\n  | sort_by(.load)[]\r\n  | {&quot;Server&quot;: .name, \r\n     &quot;Hostname&quot;: .hostname, \r\n     &quot;IP&quot;: .station,\r\n     &quot;Country&quot;: .locations[0].country.name,\r\n     &quot;City&quot;: .locations[0].country.city.name,\r\n     &quot;Load&quot;: .load \r\n    } \r\n  | format, &quot;&quot;&#39;\r\n```\r\n\r\n## Output\r\n\r\nWith the given input, the first two segments are:\r\n\r\n```\r\n  Server : Thailand #8\r\nHostname : th8.nordvpn.com\r\n      IP : 122.155.174.70\r\n Country : Thailand\r\n    City : Bangkok\r\n    Load : 10\r\n\r\n  Server : Thailand #6\r\nHostname : th6.nordvpn.com\r\n      IP : 122.155.174.66\r\n Country : Thailand\r\n    City : Bangkok\r\n    Load : 12\r\n\r\n```",
                "title": "How can I sort jq result by load?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1596609269,
        "creation_date": 1596568272,
        "last_edit_date": 1596608933,
        "question_id": 63253610,
        "body_markdown": "I have script:\r\n\r\n    curl --silent &quot;https://api.nordvpn.com/v1/servers?limit=16384&quot;  | jq --raw-output &#39;.[] | select(.locations[].country.city.name == &quot;Bangkok&quot;) | &quot;  Server: \\(.name)\\nHostname: \\(.hostname)\\n      IP: \\(.station)\\n Country: \\(.locations[0].country.name)\\n    City: \\(.locations[0].country.city.name)\\n    Load: \\(.load)\\n&quot;&#39;\r\n\r\n\r\n\r\nResult is:\r\n```\r\n   Server: Thailand #5\r\nHostname: th5.nordvpn.com\r\n      IP: 122.155.174.64\r\n Country: Thailand\r\n    City: Bangkok\r\n    Load: 17\r\n\r\n  Server: Thailand #6\r\nHostname: th6.nordvpn.com\r\n      IP: 122.155.174.66\r\n Country: Thailand\r\n    City: Bangkok\r\n    Load: 10\r\n\r\n  Server: Thailand #7\r\nHostname: th7.nordvpn.com\r\n      IP: 122.155.174.68\r\n Country: Thailand\r\n    City: Bangkok\r\n    Load: 27\r\n```\r\nI need help to sort it out by load.\r\nThank you in advance",
        "link": "https://stackoverflow.com/questions/63253610/how-can-i-sort-jq-result-by-load",
        "title": "How can I sort jq result by load?"
    },
    {
        "tags": [
            "json",
            "jq",
            "dicom",
            "dcmtk"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1596578105,
                "creation_date": 1596578105,
                "answer_id": 63255633,
                "question_id": 63255413,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When selecting key-value pairs, `with_entries` is often the tool of choice:\r\n\r\n    with_entries( select(.value | has(&quot;InlineBinary&quot;) | not) )",
                "title": "How to filter out elements with a particular property (or keep elements without that property)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1596578105,
        "creation_date": 1596577008,
        "question_id": 63255413,
        "body_markdown": "I&#39;m processing the output from [dcm2json][1], which converts the metadata from medical imaging data in the DICOM format to JSON. The values for this metadata is mostly strings, integers, floats, and similar, but it also includes inline binary values in the form of base64-encoded strings. We don&#39;t need those binaries and they can get pretty large, so I need to filter out all metadata elements that have an InlineBinary property. Below is a (very simple small) sample of the JSON output from dcm2json:\r\n\r\n```json\r\n{\r\n    &quot;00080005&quot;: {\r\n        &quot;vr&quot;: &quot;CS&quot;,\r\n        &quot;Value&quot;: [&quot;ISO_IR 192&quot;]\r\n    },\r\n    &quot;00291010&quot;: {\r\n        &quot;vr&quot;: &quot;OB&quot;,\r\n        &quot;InlineBinary&quot;: &quot;Zm9vYmFyCg==&quot;\r\n    }\r\n}\r\n```\r\n\r\nI want to transform this to:\r\n\r\n```json\r\n{\r\n    &quot;00080005&quot;: {\r\n        &quot;vr&quot;: &quot;CS&quot;,\r\n        &quot;Value&quot;: [&quot;ISO_IR 192&quot;]\r\n    }\r\n}\r\n```\r\n\r\nI tried a few different things that didn&#39;t work but finally ended up using this:\r\n\r\n```bash\r\n$ dcm2json file.dcm | jq &#39;[to_entries | .[] | select(.value.Value)] | from_entries&#39;\r\n```\r\n\r\nI kept playing with it though because I don&#39;t like having that expression embedded in the array (i.e. `[to_entries ...]`). I came up with something a bit more elegant, but I&#39;m totally stumped as to why it works the way it does:\r\n\r\n```\r\njq &#39;to_entries | . - map(select(.value | has(&quot;InlineBinary&quot;) == true)) | from_entries&#39; | less\r\n```\r\n\r\nWhat&#39;s confusing is the `has(&quot;InlineBinary&quot;) == true` bit. I first ran this comparing it to `false` because what I wanted was those elements that *don&#39;t* have the `InlineBinary` property. Why does it work seemingly opposite what I think I&#39;m requesting? Given that I really don&#39;t understand what&#39;s happening with the `. - map(...)` structure in there (I totally swiped it from another post where someone asked a similar question), I&#39;m not surprised it does something I don&#39;t understand but I&#39;d like to understand why that is :)\r\n\r\nThe other thing I&#39;m confused about is `to_entries/from_entries/with_entries`. The [manual says about these][2]:\r\n\r\n&gt; with_entries(foo) is a shorthand for to_entries | map(foo) | from_entries\r\n\r\nCool! So that would be:\r\n\r\n```bash\r\njq &#39;with_entries(map( . - map(select(.value | has(&quot;InlineBinary&quot;) == true))))&#39;\r\n```\r\n\r\nBut that doesn&#39;t work:\r\n\r\n```bash\r\n$ cat 1.json | jq &#39;with_entries(map(. - map(select(.value | has(&quot;InlineBinary&quot;) == true))))&#39;\r\njq: error (at &lt;stdin&gt;:848): Cannot iterate over string (&quot;00080005&quot;)\r\n```\r\n\r\nGiven that this statement is supposed to be functionally equivalent, I&#39;m not sure why this wouldn&#39;t work.\r\n\r\nThanks for any info you can provide!\r\n\r\n  [1]: https://support.dcmtk.org/docs/dcm2json.html\r\n  [2]: https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries",
        "link": "https://stackoverflow.com/questions/63255413/how-to-filter-out-elements-with-a-particular-property-or-keep-elements-without",
        "title": "How to filter out elements with a particular property (or keep elements without that property)"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4085219,
                    "reputation": 1117,
                    "user_id": 3354661,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/61eff7ba5dd58bd633b714e727ae0385?s=256&d=identicon&r=PG",
                    "display_name": "luciole75w",
                    "link": "https://stackoverflow.com/users/3354661/luciole75w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596618666,
                "post_id": 63259559,
                "comment_id": 111866523,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9935159,
                    "reputation": 149,
                    "user_id": 7353736,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/1614366361947946/picture?type=large",
                    "display_name": "Abhra Ray",
                    "link": "https://stackoverflow.com/users/7353736/abhra-ray"
                },
                "reply_to_user": {
                    "account_id": 4085219,
                    "reputation": 1117,
                    "user_id": 3354661,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/61eff7ba5dd58bd633b714e727ae0385?s=256&d=identicon&r=PG",
                    "display_name": "luciole75w",
                    "link": "https://stackoverflow.com/users/3354661/luciole75w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596625813,
                "post_id": 63259559,
                "comment_id": 111870032,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1596611626,
                "last_edit_date": 1596611626,
                "creation_date": 1596611068,
                "answer_id": 63260023,
                "question_id": 63259559,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need to use the whole path of `subnetId` again. You&#39;ve already selected that node from the pipeline before. Just use the `+=` append operator to suffix the required string\r\n\r\n    ( .parameters.batchPools.value[] | \r\n      select(.networkConfiguration.subnetId | contains(&quot;batch&quot;) | not) | \r\n      .networkConfiguration.subnetId ) += &quot;-batch&quot;\r\n\r\n&lt;sup&gt;[jqplay - Online demo][1]&lt;/sup&gt;\r\n\r\n\r\n  [1]: https://jqplay.org/s/1AxpZWUAcV",
                "title": "Using jq to suffix a string to a field in an object not containing it"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1596611626,
        "creation_date": 1596608752,
        "last_edit_date": 1596611321,
        "question_id": 63259559,
        "body_markdown": "I have a json as follows:\r\n\r\n    {\r\n      &quot;$schema&quot;: &quot;http://schema.management.azure.com/schemas/2015-01-01/deploymentParameters.json#&quot;,\r\n      &quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n      &quot;parameters&quot;: {\r\n        &quot;batchPools&quot;: {\r\n          &quot;value&quot;: [\r\n            {\r\n              &quot;networkConfiguration&quot;: {\r\n                &quot;subnetId&quot;: &quot;/subscriptions/xxxx/resourceGroups/xxx/providers/Microsoft.Network/virtualNetworks/xxxxx/subnets/sample-name-batch&quot;,\r\n                &quot;subnetAddressPrefix&quot;: &quot;&quot;\r\n              }\r\n            },\r\n            {\r\n              &quot;networkConfiguration&quot;: {\r\n                &quot;subnetId&quot;: &quot;/subscriptions/xxxx/resourceGroups/xxx/providers/Microsoft.Network/virtualNetworks/xxxxx/subnets/sample-name&quot;,\r\n                &quot;subnetAddressPrefix&quot;: &quot;&quot;\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\nI need to check if any of the `networkConfiguration.subnetID` under the array `value` contains the string `batch`. If yes then nothing needs to be done. Else, append `-batch` to the existing value. In this case, only the second `networkConfiguration.subnetID` of the array should be updated.\r\n\r\nI tried the following:\r\n\r\n`(.parameters.batchPools.value[] | select(.networkConfiguration.subnetId | contains(&quot;-batch&quot;) | not) | .networkConfiguration.subnetId) |= (.networkConfiguration.subnetId+&quot;-batch&quot;)`\r\n\r\nI get the following error: \r\n`jq: error (at &lt;stdin&gt;:38): Cannot index string with string &quot;networkConfiguration&quot;\r\nexit status 5`\r\n\r\nI tried this: \r\n\r\n`(.parameters.batchPools.value[] | select(.networkConfiguration.subnetId | contains(&quot;batch&quot;) | not) | .networkConfiguration.subnetId) |= &quot;someValue&quot;`\r\n\r\nThis worked fine and replaced the entire `subnetId` with `someValue`. I am not able to figure out why the previous command is not working out. Please help.",
        "link": "https://stackoverflow.com/questions/63259559/using-jq-to-suffix-a-string-to-a-field-in-an-object-not-containing-it",
        "title": "Using jq to suffix a string to a field in an object not containing it"
    },
    {
        "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": 1596634421,
                "post_id": 63264954,
                "comment_id": 111874203,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3839012,
                    "reputation": 123,
                    "user_id": 3182644,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a8bee8c7e079055203b18c14dd7fb2dc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "moogly81",
                    "link": "https://stackoverflow.com/users/3182644/moogly81"
                },
                "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": 1597048084,
                "post_id": 63264954,
                "comment_id": 111996381,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1647254972,
                "last_edit_date": 1647254972,
                "creation_date": 1596641156,
                "answer_id": 63268435,
                "question_id": 63264954,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try the following code. This can handle any number of files. All inputs are assumed to be json objects with all values inside as arrays. All such arrays are aggregated after grouping by keys. It outputs an object which has keys associated with corresponding aggregated arrays.\r\n\r\n    jq -s &#39;map(to_entries)|add|group_by(.key)|\r\n        map( { &quot;key&quot;: (.[0].key), &quot;value&quot;: (map(.value)|add)})|\r\n        from_entries&#39; file1.json file2.json\r\n\r\nFor your sample input this gives:\r\n\r\n    {\r\n      &quot;shapes&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;1&quot;,\r\n          &quot;name&quot;: &quot;circle&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;2&quot;,\r\n          &quot;name&quot;: &quot;square&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;3&quot;,\r\n          &quot;name&quot;: &quot;triangle&quot;\r\n        }\r\n      ]\r\n    }",
                "title": "Aggregate json arrays from multiple files using jq, grouping by key"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1596655552,
                "creation_date": 1596655552,
                "answer_id": 63272256,
                "question_id": 63264954,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution that also solves a more general problem: first, it handles arbitrarily many input files; and second, it forms the &quot;sum&quot; by key, for every key, on the assumption that every top-level key is array-valued.\r\n\r\nThe generic function:\r\n```\r\n  # the values at each key are assumed to be arrays\r\n  def aggregate(stream): \r\n    reduce stream as $o ({}; \r\n      reduce ($o|keys_unsorted[]) as $k (.; \r\n        .[$k] += $o[$k] ));\r\n```\r\nTo avoid &quot;slurping&quot;, we will use `inputs`:\r\n\r\n    aggregate(inputs)\r\n\r\nThe invocation must therefore use the -n command-line option:\r\n\r\n    jq -n -f program.jq *.json\r\n",
                "title": "Aggregate json arrays from multiple files using jq, grouping by key"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1597144300,
                "last_edit_date": 1597144300,
                "creation_date": 1597067953,
                "answer_id": 63341693,
                "question_id": 63264954,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution that’s suitable when each top-level object has only one key, and that is both efficient and conceptually simple.  It assumes jq is invoked with the -n option.\r\n```\r\nreduce inputs as $in (null;\r\n   ($in|keys_unsorted[0]) as $k | { ($k): (.[$k] + $in[$k]) })\r\n```\r\nor slightly more compactly:\r\n```\r\nreduce inputs as $in (null; ($in|keys_unsorted[0]) as $k | .[$k] += $in[$k] )\r\n```",
                "title": "Aggregate json arrays from multiple files using jq, grouping by key"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1647254972,
        "creation_date": 1596629572,
        "last_edit_date": 1596637932,
        "question_id": 63264954,
        "body_markdown": "I would like to aggregate two or more files into a single json, and aggregate arrays under a same key. \r\n\r\n\r\nfile1.json\r\n```\r\n{\r\n  &quot;shapes&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;1&quot;,\r\n      &quot;name&quot;: &quot;circle&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;2&quot;,\r\n      &quot;name&quot;: &quot;square&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nfile2.json\r\n```\r\n{\r\n  &quot;shapes&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;3&quot;,\r\n      &quot;name&quot;: &quot;triangle&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nExpected result : \r\n```\r\n{\r\n  &quot;shapes&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;1&quot;,\r\n      &quot;name&quot;: &quot;circle&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;2&quot;,\r\n      &quot;name&quot;: &quot;square&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;3&quot;,\r\n      &quot;name&quot;: &quot;triangle&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\n\r\nI can do this with the following jq command : \r\n```\r\njq -s &#39;{shapes: map(.shapes)|add }&#39; file*.json\r\n```\r\n\r\nBut this requires me to know the **shapes** attribute and hardcode it. Is there a simple way I can get the same result without ever using the key name explicitly?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63264954/aggregate-json-arrays-from-multiple-files-using-jq-grouping-by-key",
        "title": "Aggregate json arrays from multiple files using jq, grouping by key"
    },
    {
        "tags": [
            "gitlab",
            "gitlab-ci",
            "jq",
            "yq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1596634703,
                "creation_date": 1596634703,
                "answer_id": 63266448,
                "question_id": 63266261,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your `jq` installation is not quite correct. Your version information `jq==1.0.2` indicates that you have installed the python package `jq` - https://pypi.org/project/jq/ which is not the same as the executable binary `jq` that gets installed. You need the executable to be installed, before invoking the `yq` tool.\r\n\r\nSince `yq` looks in `PATH` for availability of the `jq` binary, but doesn&#39;t find it, you get the runtime error indicating the absence. The fix will be setup your CI to download the `jq` binary from one of the steps mentioned in https://stedolan.github.io/jq/download/\r\n\r\n",
                "title": "Is jq installed and available on PATH?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1636392182,
                "creation_date": 1636392182,
                "answer_id": 69887485,
                "question_id": 63266261,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Run `sudo apt-get install jq` not `pip3 install jq`.",
                "title": "Is jq installed and available on PATH?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 8,
        "last_activity_date": 1636392182,
        "creation_date": 1596634113,
        "question_id": 63266261,
        "body_markdown": "I am trying to read a yaml file in gitlab CI. I installed `jq==1.0.2` and `yq==2.10.1` using `pip` in my CI job and I use python:3.7 image. When I tried to read the yaml file, it has the error \r\n```\r\nyq: Error starting jq: FileNotFoundError: [Errno 2] No such file or directory: &#39;jq&#39;: &#39;jq&#39;. Is jq installed and available on PATH?\r\n```\r\nMy yaml file is not call jq and I do have this yaml file in my commit. I am able to do `which yq`, when I do `which jq`, the CI job failed. Anyone has any idea?\r\n",
        "link": "https://stackoverflow.com/questions/63266261/is-jq-installed-and-available-on-path",
        "title": "Is jq installed and available on PATH?"
    },
    {
        "tags": [
            "json",
            "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": 1,
                "creation_date": 1596726091,
                "post_id": 63286182,
                "comment_id": 111909133,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11402297,
                    "reputation": 2348,
                    "user_id": 8358881,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/uhm8s.jpg?s=256",
                    "display_name": "PatientOtter",
                    "link": "https://stackoverflow.com/users/8358881/patientotter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596726259,
                "post_id": 63286182,
                "comment_id": 111909238,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17995250,
                    "reputation": 41,
                    "user_id": 13078452,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2e5c1062276ad7155bc67ac1eb3ab11e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Dam",
                    "link": "https://stackoverflow.com/users/13078452/dam"
                },
                "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": 1596726465,
                "post_id": 63286182,
                "comment_id": 111909352,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17995250,
                    "reputation": 41,
                    "user_id": 13078452,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2e5c1062276ad7155bc67ac1eb3ab11e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Dam",
                    "link": "https://stackoverflow.com/users/13078452/dam"
                },
                "reply_to_user": {
                    "account_id": 11402297,
                    "reputation": 2348,
                    "user_id": 8358881,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/uhm8s.jpg?s=256",
                    "display_name": "PatientOtter",
                    "link": "https://stackoverflow.com/users/8358881/patientotter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596726518,
                "post_id": 63286182,
                "comment_id": 111909376,
                "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": 3,
                "creation_date": 1596726562,
                "post_id": 63286182,
                "comment_id": 111909402,
                "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": 1596728536,
                "post_id": 63286182,
                "comment_id": 111910455,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1596726480,
                "creation_date": 1596726480,
                "answer_id": 63286526,
                "question_id": 63286182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `has` function does the job:\r\n```bash\r\njq &#39;.results|map(has(&quot;uri&quot;))|.[]&#39;\r\n```\r\n`map` the `has` function on `.results`.",
                "title": "How to use jq to give true or false when uri field is present in my output json"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1596884865,
                "last_edit_date": 1596884865,
                "creation_date": 1596727370,
                "answer_id": 63286777,
                "question_id": 63286182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you use `jq`, it means you are working within a shell script context.\r\n\r\nIf the boolean result is to be handled by the shell script, you can make `jq` set its `EXIT_CODE` depending on the JSON request success or failure status, with `jq -e`\r\n\r\nExample shell script using the `EXIT_CODE` from `jq`:\r\n\r\n```sh\r\nif uri=$(jq -je &#39;.results[].uri&#39;) &lt;&lt;&lt;&quot;$search_query_response&quot;\r\nthen\r\n  printf &#39;Search results contains an URI: %s.\\n&#39; &quot;$uri&quot;\r\nelse\r\n  echo &#39;No URI in search results.&#39;\r\nfi\r\n```\r\n\r\n&lt;hr&gt;\r\nSee &lt;code&gt;man jq&lt;/code&gt;:\r\n&lt;blockquote&gt;\r\n&lt;ul&gt;\r\n&lt;li&gt;&lt;dl&gt;&lt;dt&gt;&lt;code&gt;-e&lt;/code&gt; / &lt;code&gt;--exit-status&lt;/code&gt;:&lt;/dt&gt;\r\n&lt;dd&gt;Sets the exit status of &lt;code&gt;jq&lt;/code&gt; to &lt;code&gt;0&lt;/code&gt; if the last output values was neither &lt;code&gt;false&lt;/code&gt; nor &lt;code&gt;null&lt;/code&gt;, &lt;code&gt;1&lt;/code&gt; if the last output value was either &lt;code&gt;false&lt;/code&gt; or &lt;code&gt;null&lt;/code&gt;, or &lt;code&gt;4&lt;/code&gt; if no valid result was ever produced. Normally &lt;code&gt;jq&lt;/code&gt; exits with &lt;code&gt;2&lt;/code&gt; if there was any usage problem or system error, &lt;code&gt;3&lt;/code&gt; if there was a &lt;code&gt;jq&lt;/code&gt; program compile error, or &lt;code&gt;0&lt;/code&gt; if the &lt;code&gt;jq&lt;/code&gt; program ran.&lt;/dd&gt;\r\n\r\n&lt;dd&gt;Another way to set the exit status is with the &lt;code&gt;halt_error&lt;/code&gt; builtin function.&lt;/dd&gt;\r\n&lt;/dl&gt;  &lt;/li&gt;&lt;/ul&gt;&lt;/blockquote&gt;\r\n\r\n",
                "title": "How to use jq to give true or false when uri field is present in my output json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1596884865,
        "creation_date": 1596725327,
        "last_edit_date": 1596828289,
        "question_id": 63286182,
        "body_markdown": "I have a JSON which goes like this:\r\n\r\n    {\r\n       &quot;results&quot;:[\r\n          {\r\n             &quot;uri&quot;:&quot;www.xxx.com&quot;\r\n          }\r\n       ]\r\n    }\r\n**EDIT**\r\nWhen uri is not present, JSON looks like this:\r\n\r\n    {\r\n    &quot;results&quot;:[\r\n  \r\n    ]\r\n    }\r\n\r\nIn some cases, uri is present and in some cases, it is not.\r\nNow, I want to use jq to return boolean value if uri is present or not.\r\n\r\nThis is what I wrote so far but despite uri being present, it gives null.\r\n${search_query_response} contains the JSON\r\n   \r\n\r\n    file_status=$(jq -r &#39;.uri&#39; &lt;&lt;&lt; ${search_query_response})\r\n\r\nCan anyone guide me?",
        "link": "https://stackoverflow.com/questions/63286182/how-to-use-jq-to-give-true-or-false-when-uri-field-is-present-in-my-output-json",
        "title": "How to use jq to give true or false when uri field is present in my output json"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596803754,
                "post_id": 63301629,
                "comment_id": 111935859,
                "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": 1596859477,
                "post_id": 63301629,
                "comment_id": 111953043,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1596803005,
                "creation_date": 1596803005,
                "answer_id": 63301811,
                "question_id": 63301629,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Get the path to the entry whose `first_name` is `Jan` as an array, and extract the country name from it.\r\n```\r\npath(.[][] | select(.first_name == &quot;Jan&quot;))[0]\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/n7_6B4D4Vq)&lt;/sup&gt;",
                "title": "Find parent key based on child value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1596825724,
                "creation_date": 1596825724,
                "answer_id": 63307563,
                "question_id": 63301629,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following prevents the production of repetitions when &quot;Jan&quot; is the first name of several individuals, and is also more efficient than alternatives that unconditionally scan through all &quot;first_name&quot; values:\r\n```\r\nto_entries[] | select( any(.value[]; .first_name==&quot;Jan&quot;)).key\r\n```",
                "title": "Find parent key based on child value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1596825724,
        "creation_date": 1596802411,
        "last_edit_date": 1596808483,
        "question_id": 63301629,
        "body_markdown": "I have the following JSON. I want to know from which country &quot;Jan&quot; is (Belgium).\r\n\r\n```\r\n{\r\n    &quot;Belgium&quot;: [\r\n        {\r\n            &quot;first_name&quot;: &quot;Jan&quot;,\r\n            &quot;last_name&quot;: &quot;Molenaar&quot;\r\n        },\r\n        {\r\n            &quot;first_name&quot;: &quot;Piet&quot;,\r\n            &quot;last_name&quot;: &quot;Hoogenboom&quot;\r\n        }\r\n    ],\r\n    &quot;Germany&quot;: [\r\n        {\r\n            &quot;first_name&quot;: &quot;Herman&quot;,\r\n            &quot;last_name&quot;: &quot;Bret&quot;\r\n        },\r\n        {\r\n            &quot;first_name&quot;: &quot;Sanne&quot;,\r\n            &quot;last_name&quot;: &quot;Klepper&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI found and tried different queries, such as:\r\n```\r\ncat data.json |jq &#39;. as $parent | select(.first_name == &quot;Jan&quot;) | $parent&#39;\r\n```\r\n\r\nBut unfortunately, I am unable to find the correct query.",
        "link": "https://stackoverflow.com/questions/63301629/find-parent-key-based-on-child-value",
        "title": "Find parent key based on child value"
    },
    {
        "tags": [
            "json",
            "nested",
            "jq",
            "key-value"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6759085,
                    "reputation": 3560,
                    "user_id": 5223223,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-QFGa11QGfIg/AAAAAAAAAAI/AAAAAAAAAB0/1HgxEcgjlSg/s256-rj/photo.jpg",
                    "display_name": "dibery",
                    "link": "https://stackoverflow.com/users/5223223/dibery"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596816217,
                "post_id": 63303863,
                "comment_id": 111941771,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16155946,
                    "reputation": 27,
                    "user_id": 11663164,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-CQcs-XW7vws/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rck2mbsW2WpOVRE4mtnSH2yaw3quA/mo/s256-rj/photo.jpg",
                    "display_name": "Philip Lewis",
                    "link": "https://stackoverflow.com/users/11663164/philip-lewis"
                },
                "reply_to_user": {
                    "account_id": 6759085,
                    "reputation": 3560,
                    "user_id": 5223223,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-QFGa11QGfIg/AAAAAAAAAAI/AAAAAAAAAB0/1HgxEcgjlSg/s256-rj/photo.jpg",
                    "display_name": "dibery",
                    "link": "https://stackoverflow.com/users/5223223/dibery"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596816652,
                "post_id": 63303863,
                "comment_id": 111941980,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1596820164,
                "creation_date": 1596820164,
                "answer_id": 63306369,
                "question_id": 63303863,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In `act.jq`:\r\n\r\n    def f:\r\n     if .value|type==&quot;object&quot; then\r\n      &quot;nfs-0_\\(.key)={\\([.value|to_entries|.[]|&quot;\\(.key)=\\&quot;\\(.value)\\&quot;&quot;]|join(&quot;,&quot;))}&quot;\r\n     else\r\n      &quot;nfs-0_\\(.key)=\\&quot;\\(.value)\\&quot;&quot;\r\n     end;\r\n    \r\n    to_entries|.[]|f\r\n\r\nInvocation:\r\n```\r\njq -rf act.jq file.json\r\n```\r\nUse `type` to check if we should go down. If the type of `.value` is `object` then we split it again and then collect the result; otherwise we just interpolate it. You can also write `f` function inline (i.e., after `to_entries|.[]`).",
                "title": "Using jq and map to convert JSON objects with nested objects to Name=Value format"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1596832219,
                "last_edit_date": 1596832219,
                "creation_date": 1596826672,
                "answer_id": 63307732,
                "question_id": 63303863,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution that allows arbitrarily deep nesting and illustrates the use of recursive inner functions:\r\n```\r\ndef pairs:\r\n  def q:\r\n    if type == &quot;string&quot; then tojson\r\n    elif type == &quot;number&quot; then &quot;\\&quot;\\(.)\\&quot;&quot;\r\n    else . end;\r\n  def ip:\r\n    if type == &quot;object&quot;\r\n    then &quot;{&quot; + (to_entries | map(&quot;\\(.key)=\\(.value|ip)&quot;) | join(&quot;,&quot;)) + &quot;}&quot;\r\n    else q end;\r\n  if type == &quot;object&quot;\r\n  then to_entries[] | (&quot;\\(.key)=\\(.value | ip)&quot;)\r\n  else . end;\r\n\r\npairs\r\n```  ",
                "title": "Using jq and map to convert JSON objects with nested objects to Name=Value format"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1596900082,
        "creation_date": 1596810648,
        "last_edit_date": 1596900082,
        "question_id": 63303863,
        "body_markdown": "Completely stuck with this one.\r\n\r\nI&#39;ve got JSON Like this:\r\n\r\n```\r\n{\r\n  &quot;create_option&quot;: &quot;Restore&quot;,\r\n  &quot;disk_iops_read_write&quot;: 120,\r\n  &quot;disk_mbps_read_write&quot;: 25,\r\n  &quot;tags&quot;: {\r\n    &quot;Monitor&quot;: &quot;No&quot;,\r\n    &quot;RSVaultBackup&quot;: &quot;2dc504bd&quot;\r\n  }\r\n}\r\n```\r\nand with the following jq\r\n```\r\n.|to_entries|map(&quot;nfs-0_\\(.key)=\\&quot;\\(.value)\\&quot;&quot;)|.[]\r\n```\r\nI&#39;ve got to this\r\n```\r\nnfs-0_create_option=&quot;Restore&quot;\r\nnfs-0_disk_iops_read_write=&quot;120&quot;\r\nnfs-0_disk_mbps_read_write=&quot;25&quot;\r\nnfs-0_tags=&quot;{&quot;Monitor&quot;:&quot;No&quot;,&quot;RSVaultBackup&quot;:&quot;2dc504bd&quot;}&quot;\r\n```\r\nbut the nfs-0_tags line section also needs to be in name=value format. What I want to end up with is this\r\n```\r\nnfs-0_create_option=&quot;Restore&quot;\r\nnfs-0_disk_iops_read_write=&quot;120&quot;\r\nnfs-0_disk_mbps_read_write=&quot;25&quot;\r\nnfs-0_tags={Monitor=&quot;No&quot;, VaultBackup=&quot;2dc504bd&quot;}\r\n```\r\n\r\n I feel I should be able to recursively apply the map but for the life of me I can&#39;t figure out how that might be achieved.\r\n\r\nAny ideas?\r\n\r\nThanks :)\r\n\r\nEDIT:\r\n\r\nOkay I think I&#39;m getting a bit closer now with this \r\n```\r\n.|.tags |= (to_entries | map(&quot;\\(.key) = \\(.value)&quot;))|to_entries|map (&quot;\\(.key) = \\(.value)&quot;)|.[]\r\n```\r\nI&#39;m now getting\r\n```\r\ncreate_option = Restore\r\ndisk_iops_read_write = 120\r\ndisk_mbps_read_write = 25\r\ntags = [&quot;Monitor = No&quot;,&quot;RSVaultBackup = 2dc504bd&quot;]\r\n```\r\nBut I need the tags line in curly braces {} with the key unquoted and the value quoted. Like this\r\n```\r\nnfs-0_tags={Monitor=&quot;No&quot;, VaultBackup=&quot;2dc504bd&quot;}\r\n```\r\nEDIT:\r\n\r\nI still want the output to look like this \r\n```\r\nnfs-0_create_option=&quot;Restore&quot;\r\nnfs-0_disk_iops_read_write=&quot;120&quot;\r\nnfs-0_disk_mbps_read_write=&quot;25&quot;\r\nnfs-0_tags={Monitor=&quot;No&quot;, VaultBackup=&quot;2dc504bd&quot;}\r\n```\r\nafter the jq runs\r\n",
        "link": "https://stackoverflow.com/questions/63303863/using-jq-and-map-to-convert-json-objects-with-nested-objects-to-name-value-forma",
        "title": "Using jq and map to convert JSON objects with nested objects to Name=Value format"
    },
    {
        "tags": [
            "linux",
            "unix",
            "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": 2,
                "creation_date": 1596918600,
                "post_id": 63319824,
                "comment_id": 111967451,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9089347,
                    "reputation": 107,
                    "user_id": 9639041,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d48783135a5817a8c92625c2e6dd2892?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "artemisia480",
                    "link": "https://stackoverflow.com/users/9639041/artemisia480"
                },
                "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": 1596918744,
                "post_id": 63319824,
                "comment_id": 111967490,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9089347,
                    "reputation": 107,
                    "user_id": 9639041,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d48783135a5817a8c92625c2e6dd2892?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "artemisia480",
                    "link": "https://stackoverflow.com/users/9639041/artemisia480"
                },
                "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": 1,
                "creation_date": 1596920332,
                "post_id": 63319824,
                "comment_id": 111967879,
                "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": 2,
                "creation_date": 1596920375,
                "post_id": 63319824,
                "comment_id": 111967894,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9089347,
                    "reputation": 107,
                    "user_id": 9639041,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d48783135a5817a8c92625c2e6dd2892?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "artemisia480",
                    "link": "https://stackoverflow.com/users/9639041/artemisia480"
                },
                "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": 1596921376,
                "post_id": 63319824,
                "comment_id": 111968125,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9089347,
                    "reputation": 107,
                    "user_id": 9639041,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d48783135a5817a8c92625c2e6dd2892?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "artemisia480",
                    "link": "https://stackoverflow.com/users/9639041/artemisia480"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596922200,
                "post_id": 63319824,
                "comment_id": 111968298,
                "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": 1596925350,
                "post_id": 63319824,
                "comment_id": 111968890,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9089347,
                    "reputation": 107,
                    "user_id": 9639041,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d48783135a5817a8c92625c2e6dd2892?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "artemisia480",
                    "link": "https://stackoverflow.com/users/9639041/artemisia480"
                },
                "reply_to_user": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596925406,
                "post_id": 63319824,
                "comment_id": 111968898,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9089347,
                    "reputation": 107,
                    "user_id": 9639041,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d48783135a5817a8c92625c2e6dd2892?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "artemisia480",
                    "link": "https://stackoverflow.com/users/9639041/artemisia480"
                },
                "reply_to_user": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1596925817,
                "post_id": 63319824,
                "comment_id": 111968970,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 12,
                "is_accepted": true,
                "score": 12,
                "last_activity_date": 1596925902,
                "creation_date": 1596925902,
                "answer_id": 63320808,
                "question_id": 63319824,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s easier to filter before converting the object to an array for `@csv`:\r\n\r\n```sh\r\n$ (echo &quot;column1,column2,column3&quot;;\r\n   jq -r &#39;select(.column3 | startswith(&quot;ab&quot;))\r\n          | [.column1, .column2, .column3]\r\n          | @csv&#39; data.json) &gt; test.csv\r\n$ cat test.csv\r\ncolumn1,column2,column3\r\n&quot;hello&quot;,&quot;bye&quot;,&quot;abc&quot;\r\n```\r\n\r\nBut if you do want to convert to an array first, you then have to `select` using the appropriate array index:\r\n\r\n```\r\njq -r &#39;[.column1, .column2, .column3]\r\n       | select(.[2] | startswith(&quot;ab&quot;))\r\n       | @csv&#39; data.json\r\n```\r\n\r\n---\r\n\r\nNote how I enclosed the `echo` and `jq` in a set of parenthesis so they both run in the same subshell, and the output redirection outside of it, instead of having to redirect the output of both commands. Also gets rid of the Useless Use Of Cat; `jq` takes input filenames as arguments. Even if it didn&#39;t, input redirection is better than `cat`.",
                "title": "How to add contains or startswith in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 7,
        "last_activity_date": 1596926385,
        "creation_date": 1596917586,
        "last_edit_date": 1596926385,
        "question_id": 63319824,
        "body_markdown": "I have the following command:\r\n\r\n```sh\r\necho &quot;column1, column2, column3&quot; &gt; test.csv &amp;&amp;\r\ncat data.json | jq -r &#39;. | [.[&quot;column1&quot;], .[&quot;column2&quot;], .[&quot;column3&quot;]] | @csv’ &gt;&gt; test.csv\r\n```\r\n\r\nIt creates a column headings and the data from `data.json`.\r\n\r\nI am trying to also add it where for example it only would pull data that contains the words (`&quot;abc&quot;`) from `column3`.  \r\n\r\nI added `|select(.column3| startswith (&#39;ab&#39;))` so the full command is:\r\n\r\n```sh\r\necho &quot;column1, column2, column3&quot; &gt; test.csv &amp;&amp;\r\ncat data.json | jq -r &#39;. | [.[&quot;column1&quot;], .[&quot;column2&quot;], .[&quot;column3&quot;]] |select(.column3| startswith (&#39;ab&#39;)) | @csv’ &gt;&gt; test.csv\r\n```\r\n\r\nbut I get the following error:\r\n\r\n```\r\n-bash: syntax error near unexpected token `(&#39;\r\n```\r\n\r\nmy json.data looks like this:\r\n \r\n```javascript\r\n{\r\n      &quot;column1&quot;: &quot;hello&quot;,\r\n      &quot;column2&quot;: &quot;bye&quot;,\r\n      &quot;column3&quot;: &quot;abc&quot;\r\n}\r\n```\r\n\r\nHow do I parse `column3`? Not sure what I am doing wrong.\r\n",
        "link": "https://stackoverflow.com/questions/63319824/how-to-add-contains-or-startswith-in-jq",
        "title": "How to add contains or startswith in jq"
    },
    {
        "tags": [
            "bash",
            "zsh",
            "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": 1597089972,
                "post_id": 63347170,
                "comment_id": 112015126,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6382514,
                    "reputation": 543,
                    "user_id": 4951413,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/1bae1f91a6ba201577fe08775c283743?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/4951413/aaron"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1597090043,
                "post_id": 63347170,
                "comment_id": 112015159,
                "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": 1597108516,
                "post_id": 63347170,
                "comment_id": 112020264,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1597091024,
                "creation_date": 1597091024,
                "answer_id": 63347503,
                "question_id": 63347170,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Is this what you were expecting ?\r\n\r\n```\r\n$ var=&quot;$(jq &quot;[.folder]&quot; test.json)&quot;\r\n$ echo &quot;$var&quot;\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Desktop&quot;,\r\n    &quot;path&quot;: &quot;Users/user/Desktop&quot;,\r\n    &quot;executable&quot;: false\r\n  }\r\n]\r\n```",
                "title": "Using jq to read in json as an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1597091024,
        "creation_date": 1597089488,
        "last_edit_date": 1597090422,
        "question_id": 63347170,
        "body_markdown": "I have this example `test.json` file:\r\n```\r\n{\r\n    &quot;folder&quot;: {\r\n\t&quot;name&quot;: &quot;Desktop&quot;,\r\n\t&quot;path&quot;: &quot;Users/user/Desktop&quot;,\r\n\t&quot;executable&quot;: false\r\n    }\r\n}\r\n```\r\nI am trying to read the object contained in &#39;folder&#39; into a variable `$var` as an array. Desired output - `$var` contains the following:\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Desktop&quot;,\r\n    &quot;path&quot;: &quot;Users/user/Desktop&quot;,\r\n    &quot;executable&quot;: false\r\n  }\r\n]\r\n```\r\n\r\nIt seemed relatively straightforward. `jq &#39;.folder&#39; test.json` to read in the folder value, and then pipe the output using the `-s` flag to get it enclosed in an array. This command executes just fine:\r\n```\r\njq &#39;.folder&#39; test.json | jq -s\r\n```\r\nHowever, when I try to save the result to a variable, it throws an error displaying the `jq` usage statement. What am I missing? Is there a different way to accomplish this?\r\n```\r\nvar=$(jq &#39;.folder&#39; test.json | jq -s)\r\necho $var\r\n```\r\n\r\nI also found out that this works fine in `zsh` but throws an error in `bash`. Not sure if that&#39;s relevant and whether it has to do with different versions of `jq`",
        "link": "https://stackoverflow.com/questions/63347170/using-jq-to-read-in-json-as-an-array",
        "title": "Using jq to read in json as an array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "if-statement",
            "search",
            "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": 1597127062,
                "post_id": 63352438,
                "comment_id": 112024300,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1597128092,
                "post_id": 63352438,
                "comment_id": 112024690,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8420642,
                    "reputation": 577,
                    "user_id": 6319555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c980bfdff56e5504ecc6b23d3227f384?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Invisible999",
                    "link": "https://stackoverflow.com/users/6319555/invisible999"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1597154871,
                "post_id": 63352438,
                "comment_id": 112037460,
                "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": 1597159740,
                "post_id": 63352438,
                "comment_id": 112040196,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1597138496,
                "creation_date": 1597138496,
                "answer_id": 63355494,
                "question_id": 63352438,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a filter to get you started.  With the following in **merge.jq** and the other files you&#39;ve specified\r\n```\r\ndef key: [.Person, .City] ;\r\n[\r\n      reduce .[][] as $e ({}; setpath($e|key; getpath($e|key) + $e)) \r\n    | .[][]\r\n    | select(.Landline != null)\r\n]\r\n```\r\nThe command \r\n```\r\njq -Ms -f merge.jq landline.json mobile.json \r\n```\r\nproduces\r\n```\r\n[\r\n  {\r\n    &quot;City&quot;: &quot;San Francisco&quot;,\r\n    &quot;Person&quot;: &quot;John Doe&quot;,\r\n    &quot;Landline&quot;: false,\r\n    &quot;Mobile&quot;: false\r\n  },\r\n  {\r\n    &quot;City&quot;: &quot;Los Angeles&quot;,\r\n    &quot;Person&quot;: &quot;Steve Smith&quot;,\r\n    &quot;Landline&quot;: false\r\n  }\r\n]\r\n```\r\n\r\nTo understand what is going on here, observe how this filter\r\n```\r\ndef key: [.Person, .City] ;\r\nreduce .[][] as $e ({}; setpath($e|key; getpath($e|key) + $e)) \r\n```\r\nconstructs a temporary nested object whose keys are Person and City from the inputs\r\n```\r\n{\r\n  &quot;John Doe&quot;: {\r\n    &quot;San Francisco&quot;: {\r\n      &quot;City&quot;: &quot;San Francisco&quot;,\r\n      &quot;Person&quot;: &quot;John Doe&quot;,\r\n      &quot;Landline&quot;: false,\r\n      &quot;Mobile&quot;: false\r\n    }\r\n  },\r\n  &quot;Steve Smith&quot;: {\r\n    &quot;Los Angeles&quot;: {\r\n      &quot;City&quot;: &quot;Los Angeles&quot;,\r\n      &quot;Person&quot;: &quot;Steve Smith&quot;,\r\n      &quot;Landline&quot;: false\r\n    }\r\n  },\r\n  &quot;Jenny Miller&quot;: {\r\n    &quot;Los Angeles&quot;: {\r\n      &quot;City&quot;: &quot;Los Angeles&quot;,\r\n      &quot;Person&quot;: &quot;Jenny Miller&quot;,\r\n      &quot;Mobile&quot;: false\r\n    }\r\n  }\r\n}\r\n```\r\nfrom this object iteration and select are used to convert back to the desired form keeping only objects with non-null Landline.",
                "title": "Jq - add a key/value to one JSON file if such key/value exists in another JSON file"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1597181868,
                "creation_date": 1597181868,
                "answer_id": 63366740,
                "question_id": 63352438,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For this type of problem, a &quot;dictionary lookup&quot; is easy to understand, and given jq&#39;s `INDEX` function, also easy to implement. Consider for example:\r\n```\r\njq -n &#39; \r\n  def key: {City,Person};\r\n  (input | INDEX(.[]; key) | map_values( {Mobile} ) ) as $mobile\r\n  | input | map( . + $mobile[key|tostring] )\r\n&#39; mobile.json landline.json\r\n```\r\n",
                "title": "Jq - add a key/value to one JSON file if such key/value exists in another JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1597181868,
        "creation_date": 1597126213,
        "question_id": 63352438,
        "body_markdown": "There is one JSON file - **landline.json**\r\n```\r\n[\r\n    {\r\n        &quot;City&quot;: &quot;San Francisco&quot;,\r\n        &quot;Person&quot;: &quot;John Doe&quot;,\r\n        &quot;Landline&quot;: false\r\n    },\r\n    {\r\n        &quot;City&quot;: &quot;Los Angeles&quot;,\r\n        &quot;Person&quot;: &quot;Steve Smith&quot;,\r\n        &quot;Landline&quot;: false\r\n    }\r\n]\r\n```\r\n\r\n\r\nAnd there is another JSON file - **mobile.json**\r\n```\r\n[\r\n    {\r\n        &quot;City&quot;: &quot;San Francisco&quot;,\r\n        &quot;Person&quot;: &quot;John Doe&quot;,\r\n        &quot;Mobile&quot;: false\r\n    },\r\n    {\r\n        &quot;City&quot;: &quot;Los Angeles&quot;,\r\n        &quot;Person&quot;: &quot;Jenny Miller&quot;,\r\n        &quot;Mobile&quot;: false\r\n    }\r\n]\r\n```\r\nQuestion is how using **jq**&#39;s filters and condition statement create a new file/array adding after the `&quot;Landline&quot;: false` `&quot;Mobile&quot;: false` for `John Doe`? So the resulting array should look like the following:\r\n\r\n```\r\n[\r\n    {\r\n        &quot;City&quot;: &quot;San Francisco&quot;,\r\n        &quot;Person&quot;: &quot;John Doe&quot;,\r\n        &quot;Landline&quot;: false,\r\n        &quot;Mobile&quot;: false\r\n    },\r\n    {\r\n        &quot;City&quot;: &quot;Los Angeles&quot;,\r\n        &quot;Person&quot;: &quot;Steve Smith&quot;,\r\n        &quot;Landline&quot;: false\r\n    }\r\n]\r\n```\r\nSo the algorithm should be following -  if in the `mobile.json` there is `&quot;Person&quot;: &quot;John Doe&quot;` entry and in the same block there is `&quot;Mobile&quot;: false` entry, then add `&quot;Mobile&quot;: false` entry after `&quot;Landline&quot;: false` for `&quot;Person&quot;: &quot;John Doe&quot;` in `landline.json`.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63352438/jq-add-a-key-value-to-one-json-file-if-such-key-value-exists-in-another-json-f",
        "title": "Jq - add a key/value to one JSON file if such key/value exists in another JSON file"
    },
    {
        "tags": [
            "bash",
            "amazon-web-services",
            "awk",
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1597244390,
                "last_edit_date": 1597244390,
                "creation_date": 1597231048,
                "answer_id": 63375388,
                "question_id": 63369021,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using multiple escaping is a source of error, almost impossible to maintain, and prone to break anytime; when an in-between-generated outputs escapes and injects unattended syntax.\r\n\r\nI&#39;d recommend instead you either process the loop with bash:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\nwhile read -r arn; do\r\n  aws acm describe-certificate --certificate-arn &quot;$arn&quot; |\r\n    jq &#39;.Certificate | select( (.InUseBy | length) &gt; 0) | .InUseBy, .Type&#39;\r\ndone&lt; &lt;(\r\n  aws acm list-certificates |\r\n    jq -r &#39;.CertificateSummaryList[].CertificateArn&#39;\r\n)\r\n```\r\n\r\nOr use `xargs` rather than a bash loop:\r\n\r\n```sh\r\naws acm list-certificates |\r\n  jq -r &#39;.CertificateSummaryList[].CertificateArn&#39; |\r\n    xargs -l aws acm describe-certificate --certificate-arn |\r\n      jq &#39;.Certificate | select( (.InUseBy | length) &gt; 0) | .InUseBy, .Type&#39;\r\n```\r\n",
                "title": "jq with select + awk"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1613959319,
        "creation_date": 1597200339,
        "last_edit_date": 1613959319,
        "question_id": 63369021,
        "body_markdown": "I&#39;m trying to take a JSON array returned from AWS&#39; cli and loop through each item and call another AWS command to get more details about the resource.  I&#39;m open to another approach, this is how I&#39;m approaching it right now.\r\n\r\nI&#39;m making a call to AWS to get the initial list and passing it into `jq` to be able to extract one property from each of the objects in the JSON list piping the output into `awk` to generate a new generate a new command to execute for each of the items in the first list.  I&#39;m able to accomplish this with the following:\r\n\r\n**Working without select**\r\n\r\n```\r\naws acm list-certificates |\r\njq &#39;.CertificateSummaryList[].CertificateArn&#39; |\r\nawk &#39;{ c=system(&quot;aws acm describe-certificate --certificate-arn &quot;$1 &quot; | jq &#39;&#39;&#39;.Certificate.InUseBy,.Certificate.DomainName,.Certificate.CertificateArn&#39;&#39;&#39;&quot;); }&#39;\r\n```\r\n\r\nHowever I need to filter the response from each of those commands to only output the properties if a certain condition is valid and this is where I&#39;m encountering an issue.  The updated command that I&#39;m using: \r\n\r\n**Failure when I add select**\r\n\r\n```sh\r\naws acm list-certificates |\r\njq &#39;.CertificateSummaryList[].CertificateArn&#39; |\r\nawk &#39;{ c=system(&quot;aws acm describe-certificate --certificate-arn &quot;$1 &quot; | jq &#39;&#39;&#39;.Certificate |\r\nselect( .InUseBy != null)&#39;&#39;&#39; &quot;);}&#39;\r\n```\r\nThrows the following error:\r\n\r\n```none\r\nno matches found: select( .InUseBy != null) &quot;); }\r\nawk: non-terminated string  | jq .Cer... at source line 1\r\n context is\r\n\t &gt;&gt;&gt;  &lt;&lt;&lt;\r\nawk: giving up\r\n source line number 2\r\n➜  ~\r\n[1]    5484 done         aws acm list-certificates |\r\n       5485 broken pipe  jq &#39;.CertificateSummaryList[].CertificateArn&#39; |\r\n       5486 exit 2       awk\r\n\r\n```\r\n\r\nI&#39;ve tried escaping the `|`, `(` and `)` without any success.  The command below is an example of a similar approach just short circuiting the first part and taking just one item from the list then doing the check to see if the length of one of the properties is greater than zero.  \r\n\r\n**Short-circuited to test the select portion**\r\n\r\n```\r\naws acm list-certificates |\r\njq &#39;.CertificateSummaryList[] | select (.CertificateArn==&quot;arn:aws:acm:us-east-1:000000000000:certificate/00000000-0000-0000-0000-000000000000&quot;).CertificateArn&#39; |\r\nxargs aws acm describe-certificate --certificate-arn |\r\njq &#39;.Certificate | select( (.InUseBy | length) &gt; 0) | .InUseBy, .Type&#39;\r\n```\r\n\r\nSo I&#39;m pretty confident in the syntax of the second jq statement however I&#39;m not sure what is causing the syntax error when I add the `select` portion to the statement.\r\n\r\n&lt;hr&gt;\r\n\r\n[EDITED]\r\n\r\nSample `aws acm list-certificates` from [list-certificates &amp;mdash; AWS CLI 1.18.117 Command Reference](https://docs.aws.amazon.com/cli/latest/reference/acm/list-certificates.html#examples):\r\n\r\n```json\r\n{\r\n    &quot;CertificateSummaryList&quot;: [\r\n        {\r\n            &quot;CertificateArn&quot;: &quot;arn:aws:acm:us-east-1:123456789012:certificate/12345678-1234-1234-1234-123456789012&quot;,\r\n            &quot;DomainName&quot;: &quot;www.example.com&quot;\r\n        },\r\n        {\r\n            &quot;CertificateArn&quot;: &quot;arn:aws:acm:us-east-1:493619779192:certificate/87654321-4321-4321-4321-210987654321&quot;,\r\n            &quot;DomainName&quot;: &quot;www.example.net&quot;\r\n        }\r\n    ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/63369021/jq-with-select-awk",
        "title": "jq with select + awk"
    },
    {
        "tags": [
            "json",
            "key",
            "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": 1597226864,
                "post_id": 63374014,
                "comment_id": 112061967,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1597227918,
                "creation_date": 1597227918,
                "answer_id": 63374580,
                "question_id": 63374014,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "https://jqplay.org/s/n1kf-19yFT\r\n\r\nWith the input\r\n\r\n```\r\n{\r\n   &quot;error&quot;: 0,\r\n   &quot;descErr&quot;: &quot;Ok&quot;,\r\n   &quot;seqNumber&quot;: 0,\r\n   &quot;data&quot;: {\r\n      &quot;events&quot;: [],\r\n      &quot;devices&quot;: {\r\n         &quot;aaa1234a&quot;: {\r\n            &quot;deviceType&quot;: &quot;aaa&quot;,\r\n            &quot;ip&quot;: &quot;192.168.1.4&quot;,\r\n            &quot;otherInformation&quot;: &quot;blabla4&quot;\r\n            },\r\n         &quot;aaa1235a&quot;: {\r\n            &quot;deviceType&quot;: &quot;aaa&quot;,\r\n            &quot;ip&quot;: &quot;192.168.1.5&quot;,\r\n            &quot;otherInformation&quot;: &quot;blabla5&quot;\r\n            },\r\n        &quot;aaa1236a&quot;: {\r\n            &quot;deviceType&quot;: &quot;aaa&quot;,\r\n            &quot;ip&quot;: &quot;192.168.1.6&quot;,\r\n            &quot;otherInformation&quot;: &quot;blabla6&quot;\r\n            }\r\n         }\r\n    }\r\n}\r\n```\r\n\r\nWhen I execute the query \r\n\r\n```.data.devices | to_entries | map({key, value: {ip: .value.ip, otherInformation: .value.otherInformation}}) | from_entries```\r\n\r\nI&#39;ve got the output \r\n\r\n```\r\n{\r\n  &quot;aaa1234a&quot;: {\r\n    &quot;ip&quot;: &quot;192.168.1.4&quot;,\r\n    &quot;otherInformation&quot;: &quot;blabla4&quot;\r\n  },\r\n  &quot;aaa1235a&quot;: {\r\n    &quot;ip&quot;: &quot;192.168.1.5&quot;,\r\n    &quot;otherInformation&quot;: &quot;blabla5&quot;\r\n  },\r\n  &quot;aaa1236a&quot;: {\r\n    &quot;ip&quot;: &quot;192.168.1.6&quot;,\r\n    &quot;otherInformation&quot;: &quot;blabla6&quot;\r\n  }\r\n}\r\n```\r\n\r\nIs this what you&#39;re expecting?",
                "title": "How to filter json with jq, if keys has dynamic value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1597232156,
                "creation_date": 1597232156,
                "answer_id": 63375677,
                "question_id": 63374014,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To select the keys matching the regex pattern &quot;^aaa.*a$&quot;, you could write:\r\n```\r\n.devices | with_entries(select(.key|test(&quot;^aaa.*a$&quot;)))\r\n```\r\n\r\nSimilarly, if you wanted to retain the original structure:\r\n```\r\n.data.devices |= with_entries(select(.key|test(&quot;^aaa.*a$&quot;)))\r\n```\r\n",
                "title": "How to filter json with jq, if keys has dynamic value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1597232156,
        "creation_date": 1597225804,
        "last_edit_date": 1597229641,
        "question_id": 63374014,
        "body_markdown": "i have json:\r\n```\r\n    {\r\n   &quot;error&quot;: 0,\r\n   &quot;descErr&quot;: &quot;Ok&quot;,\r\n   &quot;seqNumber&quot;: 0,\r\n   &quot;data&quot;: {\r\n      &quot;events&quot;: [],\r\n      &quot;devices&quot;: {\r\n         &quot;aaa1234a&quot;: {\r\n            &quot;deviceType&quot;: &quot;aaa&quot;,\r\n            &quot;ip&quot;: &quot;192.168.1.4&quot;,\r\n\t\t\t&quot;otherInformation&quot;: &quot;blabla4&quot;\r\n            },\r\n         &quot;aaa1235a&quot;: {\r\n            &quot;deviceType&quot;: &quot;aaa&quot;,\r\n            &quot;ip&quot;: &quot;192.168.1.5&quot;,\r\n\t\t\t&quot;otherInformation&quot;: &quot;blabla5&quot;\r\n            },\r\n\t\t&quot;aaa1236a&quot;: {\r\n            &quot;deviceType&quot;: &quot;aaa&quot;,\r\n            &quot;ip&quot;: &quot;192.168.1.6&quot;,\r\n\t\t\t&quot;otherInformation&quot;: &quot;blabla6&quot;\r\n            }\r\n         }\r\n\t}\r\n}\r\n```\r\nand want to get only device name (into json look like aaa1234a), ``ip`` and ``otherInformation`` with **jq**.\r\ni need a result:\r\n```\r\n&quot;aaa1234a&quot;: {\r\n            &quot;ip&quot;: &quot;192.168.1.4&quot;,\r\n            &quot;otherInformation&quot;: &quot;blabla4&quot;\r\n            },\r\n&quot;aaa1235a&quot;: {\r\n            &quot;ip&quot;: &quot;192.168.1.5&quot;,\r\n            &quot;otherInformation&quot;: &quot;blabla5&quot;\r\n            },\r\n&quot;aaa1236a&quot;: {\r\n            &quot;ip&quot;: &quot;192.168.1.6&quot;,\r\n            &quot;otherInformation&quot;: &quot;blabla6&quot;\r\n            }\r\n```\r\nHow is filtering this json with jq, if device name i do not know, but look like &quot;aaa1234a&quot;, where aaa - type device and last &quot;a&quot; - model device - 1234 - dynamic name",
        "link": "https://stackoverflow.com/questions/63374014/how-to-filter-json-with-jq-if-keys-has-dynamic-value",
        "title": "How to filter json with jq, if keys has dynamic value"
    },
    {
        "tags": [
            "json",
            "object",
            "null",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1597226918,
                "last_edit_date": 1597226918,
                "creation_date": 1597226617,
                "answer_id": 63374232,
                "question_id": 63374134,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes, there is. The [`has`](https://stedolan.github.io/jq/manual/v1.6/#has(key)) built-in returns a boolean value representing whether its argument exists in its input as a key (or index, if the input is an array).\r\n```\r\n$ echo &#39;{&quot;foo&quot;: null}&#39; | jq &#39;has(&quot;foo&quot;)&#39;\r\ntrue\r\n$ echo &#39;{&quot;foo&quot;: null}&#39; | jq &#39;has(&quot;bar&quot;)&#39;\r\nfalse\r\n$ echo &#39;[null]&#39; | jq &#39;has(0)&#39;\r\ntrue\r\n$ echo &#39;[null]&#39; | jq &#39;has(1)&#39;\r\nfalse\r\n```",
                "title": "Is there a way to differentiate between a null value and the absence of a key?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1597229502,
        "creation_date": 1597226233,
        "last_edit_date": 1597229502,
        "question_id": 63374134,
        "body_markdown": "If I execute\r\n```\r\necho &#39;{&quot;foo&quot;: &quot;bar&quot;, &quot;baz&quot;: null}&#39; | jq &#39;.baz&#39;\r\n```\r\nI receive `null` as result.\r\n\r\nBut if I execute\r\n```\r\necho &#39;{&quot;foo&quot;: &quot;bar&quot;, &quot;baz&quot;: null}&#39; | jq &#39;.hello&#39;\r\n```\r\nI also receive `null` as result.\r\n\r\nIn the first case, the value is `null`, in the second it does not exist (can&#39;t be resolved). Is there any way to tell the two cases apart?",
        "link": "https://stackoverflow.com/questions/63374134/is-there-a-way-to-differentiate-between-a-null-value-and-the-absence-of-a-key",
        "title": "Is there a way to differentiate between a null value and the absence of a key?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1597250473,
                "creation_date": 1597250473,
                "answer_id": 63381098,
                "question_id": 63380882,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use a variable to do so:\r\n\r\n    jq &#39;.data.id as $id | .data.details[] | [$id, .vid, .long, .lat]&#39; file.json\r\n",
                "title": "add value from an object into each element of an array"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1597257303,
                "last_edit_date": 1597257303,
                "creation_date": 1597251271,
                "answer_id": 63381300,
                "question_id": 63380882,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Or without a variable:\r\n\r\n    jq -r &#39;.data | [.id] + (.details[] | [.vid, .long, .lat]) | @csv&#39; file.json\r\n\r\nIf you really want all the values to be quoted, simply add `map(tostring)` to the pipeline before the final `@csv`.",
                "title": "add value from an object into each element of an array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1597257303,
        "creation_date": 1597249667,
        "last_edit_date": 1597251762,
        "question_id": 63380882,
        "body_markdown": "I have a json object that looks like this:\r\n\r\n    {\r\n        &quot;data&quot;: {\r\n            &quot;id&quot; : 1234,\r\n            &quot;details&quot;: [\r\n                {\r\n                    &quot;vid&quot;: &quot;332&quot;,\r\n                    &quot;long&quot;: -79,\r\n                    &quot;lat&quot;: 45\r\n                },\r\n                {\r\n                    &quot;vid&quot;: &quot;33&quot;,\r\n                    &quot;long&quot;: -77,\r\n                    &quot;lat&quot;: 32\r\n                }\r\n            ]\r\n        }\r\n    }\r\n\r\nI would like output a csv file from this data that looks like this:\r\n\r\n    &quot;1234&quot;,&quot;332&quot;,&quot;-79&quot;, &quot;45&quot;\r\n    &quot;1234&quot;, &quot;33&quot;, &quot;-77&quot;, &quot;32&quot;\r\n\r\nE.g. I want to add something from a node in each of another node&#39;s array&#39;s objects, essentially de-normalize the data.\r\n\r\nIs there a way to access a value from somewhere else in the json data?\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63380882/add-value-from-an-object-into-each-element-of-an-array",
        "title": "add value from an object into each element of an array"
    },
    {
        "tags": [
            "json",
            "shell",
            "grep",
            "jq",
            "tmux"
        ],
        "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": 2,
                "creation_date": 1597270428,
                "post_id": 63385068,
                "comment_id": 112081700,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16607861,
                    "reputation": 60,
                    "user_id": 12001758,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/RY2Gt.png?s=256",
                    "display_name": "I&#39;m a TI calculator",
                    "link": "https://stackoverflow.com/users/12001758/im-a-ti-calculator"
                },
                "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": 1597298879,
                "post_id": 63385068,
                "comment_id": 112087958,
                "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": 1597304585,
                "post_id": 63385068,
                "comment_id": 112090301,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1597307069,
                "last_edit_date": 1597307069,
                "creation_date": 1597301551,
                "answer_id": 63389638,
                "question_id": 63385068,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To show how jq can be used to solve the problem without any hackery, let&#39;s first suppose that the blacklist is somehow available as a text file, say blacklist.txt:\r\n```\r\nalpha\r\nomega\r\nkappa\r\n```\r\n\r\nThen you could use an invocation of jq along the following lines:\r\n```\r\n&lt; blacklist.txt jq --argjson curl &quot;$(curl https://myapi.call)&quot; -Rn &#39;\r\n  [inputs] as $blacklist\r\n  | [ $curl\r\n      | .online_terms[]\r\n      | select( .term | IN($blacklist[]) | not) ]&#39;\r\n```\r\n\r\nHere, the output of the curl command has been provided to jq using the `--argjson` option.\r\n\r\nThis solution can readily be modified to handle other sources of the black list.\r\n\r\n### An alternative\r\nYou could also provide the output of the curl command to jq via STDIN, but then you&#39;d first have to convert the textual blacklist into JSON. This could be done by invoking jq once more:\r\n\r\n```\r\ncurl https://myapi.call | \r\n  jq --argjson blacklist &quot;$(jq -Rn &#39;[inputs]&#39; blacklist.txt)&quot; &#39;\r\n    [.online_terms[]\r\n     | select( .term | IN($blacklist[]) | not)]&#39;\r\n\r\n```\r\nNot pretty, but it serves to highlight the fact that things would be somewhat simpler if your black list generator could provide the black list as JSON.\r\n\r\n\r\n",
                "title": "Parse and return proper JSON with JQ after inverse GREP"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1597304343,
                "creation_date": 1597304343,
                "answer_id": 63390337,
                "question_id": 63385068,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following solution is offered mainly because it is similar to the one proposed by the OP, though it uses `comm` rather than `grep`, and assumes the blacklist is in a text file, blacklist.txt:\r\n```\r\ncurl https://myapi.call |\r\n jq -r &#39;[.online_terms[].term] | sort[]&#39; |\r\n comm -23 - &lt;(sort blacklist.txt) |\r\n jq -Rn &#39;[{term: inputs}]&#39; \r\n```\r\n\r\nThis has the disadvantage of requiring a second invocation of jq to reconstruct a JSON entity; it also requires two sorting operations, which might not be desirable, though of course the sorting of the blacklist could be skipped if it is already sorted.",
                "title": "Parse and return proper JSON with JQ after inverse GREP"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1597351562,
        "creation_date": 1597268460,
        "last_edit_date": 1597351562,
        "question_id": 63385068,
        "body_markdown": "I&#39;ve been struggling way too much with something that seems to simple to struggle with.\r\n\r\nRoutinely throughout the day I use iOs shortcuts to monitor one of my servers, and the shortcuts app is very finicky when it comes to dealing with JSON objects.\r\n\r\nI need to return a perfectly formatted (without nesting) array; i.e :\r\n\r\n    {\r\n      {\r\n        &quot;term&quot;: &quot;alpha&quot;\r\n      },\r\n      {\r\n        &quot;term&quot;: &quot;beta&quot;\r\n      },\r\n      {\r\n        &quot;term&quot;: &quot;gamma&quot;\r\n      },\r\n    }\r\n\r\nThe data is being fetched from an internal API call, of which I need to filter out values from already existing terms.\r\nI want to know which objects are returned from the API that are **NOT currently** a running tmux of same name.\r\n\r\nHere&#39;s a non-formatted return from API call :\r\n\r\n    {\r\n      &quot;online_terms&quot;: [\r\n        {\r\n          &quot;term&quot;: &quot;alpha&quot;\r\n        },\r\n        {\r\n          &quot;term&quot;: &quot;beta&quot;\r\n        },\r\n        {\r\n          &quot;term&quot;: &quot;gamma&quot;\r\n        }\r\n      ],\r\n      &quot;total&quot;: 3,\r\n    }\r\n\r\n\r\nHere&#39;s the one-liner used currently : \r\n\r\n    list=$(tmux list-sessions -F \\#S); curl https://myapi.call| jq -r &#39;.online_terms[] | .term&#39; | grep -v $list\r\n\r\nThe $list will contain multiple line LS style names of current running tmux sessions. i.e :\r\n\r\n    alpha\r\n    omega\r\n    kappa\r\n\r\nThat&#39;s what I&#39;ve been using so far, but it&#39;s wacky at best. To clarify, declared all my tmux sessions into the **$list** variable, then do the API call, parse out the nested values i need, inverse grep against the **$list** ... not ideal !\r\n\r\nAnd it only returns *single line names*, i.e (filtered out alpha):\r\n\r\n    beta\r\n    gamma\r\n\r\nI&#39;ve not been able to parse it into the type of object explained above despite many attempts to slurp back the raw data into JQ.\r\n\r\nI&#39;m welcome to any suggestions as to how to inverse grep the **tmux ls** values more cleanly, or parse into a proper JSON object, thank you in advance for any help !\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63385068/parse-and-return-proper-json-with-jq-after-inverse-grep",
        "title": "Parse and return proper JSON with JQ after inverse GREP"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1597315371,
                "post_id": 63393366,
                "comment_id": 112095467,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1597317440,
                "post_id": 63393366,
                "comment_id": 112096475,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1597317658,
                "post_id": 63393366,
                "comment_id": 112096577,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1934235,
                    "reputation": 2182,
                    "user_id": 2367867,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/GeHG3.jpg?s=256",
                    "display_name": "Pieter",
                    "link": "https://stackoverflow.com/users/2367867/pieter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1597317758,
                "post_id": 63393366,
                "comment_id": 112096620,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1632306658,
                "last_edit_date": 1632306658,
                "creation_date": 1597317608,
                "answer_id": 63394051,
                "question_id": 63393366,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "i hacked a fix using awk, there must me a way to do it with jq.\r\n\r\n    | awk &#39;NR==1{print}NR&gt;1{sub(/^]/,&quot;&quot;);sub(/^\\[/,&quot;,&quot;);print}END{print &quot;]&quot;}&#39; \\\r\n\r\nWhat it does, \r\n1. skip first line &quot;[&quot; (leave it in place)\r\n2. remove all &quot;^]&quot; at start of lines\r\n3. replace &quot;[&quot; at start of line with &quot;,&quot; new list starting\r\n4. at the end close it all with &quot;]&quot;",
                "title": "merge multiple lists with jq into single list"
            },
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1622673467,
                "creation_date": 1622673467,
                "answer_id": 67813335,
                "question_id": 63393366,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you have jq 1.5, the solution posted here:\r\n\r\nhttps://stackoverflow.com/questions/51491317/jq-how-to-merge-multiple-objects-into-one\r\n\r\nprovides the basic technique of using `jq -n` with the `inputs` operator.\r\n\r\n    cat FILE | jq -n &#39;[inputs|.[]]&#39;\r\n\r\ndoes the trick.  `[inputs]` glues the multiple results into a single list and the &#39;.[]&#39; strips the extra level of list that was added.",
                "title": "merge multiple lists with jq into single list"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1648101145,
        "creation_date": 1597315274,
        "last_edit_date": 1597317186,
        "question_id": 63393366,
        "body_markdown": "I have a aws cli bash loop generating multiple json lists, containing dictionaries.\r\nI can&#39;t get jq to merge the lists into one large list with all the dictionaries.\r\n\r\ne.g.\r\n\r\n    [  { &quot;key1&quot;: &quot;value1&quot;, &quot;key2&quot;: &quot;value2&quot; },\r\n       { &quot;key1&quot;: &quot;value3&quot;, &quot;key2&quot;: &quot;value4&quot; }\r\n    ]\r\n    [  { &quot;key1&quot;: &quot;value5&quot;, &quot;key2&quot;: &quot;value6&quot; }\r\n    ]\r\n    [  { &quot;key1&quot;: &quot;value7&quot; }\r\n    ]\r\n\r\nthis gets piped to jq and i would like it to be merged to\r\n\r\n    [ { &quot;key1&quot;: &quot;value1&quot;, &quot;key2&quot;: &quot;value2&quot; },\r\n      { &quot;key1&quot;: &quot;value3&quot;, &quot;key2&quot;: &quot;value4&quot; },\r\n      { &quot;key1&quot;: &quot;value5&quot;, &quot;key2&quot;: &quot;value6&quot; },\r\n      { &quot;key1&quot;: &quot;value7&quot; }\r\n    ]\r\n\r\n\r\n\r\n  ",
        "link": "https://stackoverflow.com/questions/63393366/merge-multiple-lists-with-jq-into-single-list",
        "title": "merge multiple lists with jq into single list"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1597397575,
                "last_edit_date": 1597397575,
                "creation_date": 1597392469,
                "answer_id": 63408922,
                "question_id": 63407632,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Below program produces the expected output by inserting `mode: &quot;NULLABLE&quot;` pair between `type` and `name` keys of each object that doesn&#39;t have a `mode` key.\r\n```\r\nmap(select(has(&quot;mode&quot;) | not) |= {type, mode: &quot;NULLABLE&quot;, name})\r\n```\r\n\r\nBut, if the aim here is to convert the input JSON to CSV, I don&#39;t think an intermediate structure is necessary. Assuming `mode` is either non-existent or a non-null value, the alternate operator can be used for a direct conversion as shown below.\r\n``` none\r\n.[] | [.type, .mode // &quot;NULLABLE&quot;, .name] | @csv\r\n```",
                "title": "Insert a key value pair in each object if it is not present using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1597397575,
        "creation_date": 1597386412,
        "last_edit_date": 1597388451,
        "question_id": 63407632,
        "body_markdown": "I am trying to add a particluar keyword in each line of a JSON file if it is not present already.\r\n\r\n**My iniital file:**\r\n\r\n    [{&quot;type&quot;: &quot;STRING&quot;, &quot;name&quot;: &quot;Article&quot;},\r\n    {&quot;type&quot;: &quot;STRING&quot;, &quot;name&quot;: &quot;Sellable_UOM&quot;},\r\n    {&quot;type&quot;: &quot;STRING&quot;, &quot;name&quot;: &quot;PriceFamilyCode&quot;},\r\n    {&quot;type&quot;: &quot;STRING&quot;, &quot;name&quot;: &quot;PriceFamilyDescription&quot;},\r\n    {&quot;type&quot;: &quot;STRING&quot;, &quot;name&quot;: &quot;SalesDistrict&quot;},\r\n    {&quot;type&quot;: &quot;DATE&quot;, &quot;name&quot;: &quot;FiscalWeekendDate&quot;},\r\n    {&quot;type&quot;: &quot;STRING&quot;, &quot;mode&quot;: &quot;REPEATED&quot;, &quot;name&quot;: &quot;export_sql&quot;},\r\n    {&quot;type&quot;: &quot;STRING&quot;, &quot;mode&quot;: &quot;REPEATED&quot;, &quot;name&quot;: &quot;post_sql&quot;}]\r\n\r\n**Expected output:**\r\n\r\n    [{&quot;type&quot;: &quot;STRING&quot;, &quot;mode&quot;: &quot;NULLABLE&quot;, &quot;name&quot;: &quot;Article&quot;},\r\n    {&quot;type&quot;: &quot;STRING&quot;, &quot;mode&quot;: &quot;NULLABLE&quot;, &quot;name&quot;: &quot;Sellable_UOM&quot;},\r\n    {&quot;type&quot;: &quot;STRING&quot;, &quot;mode&quot;: &quot;NULLABLE&quot;, &quot;name&quot;: &quot;PriceFamilyCode&quot;},\r\n    {&quot;type&quot;: &quot;STRING&quot;, &quot;mode&quot;: &quot;NULLABLE&quot;, &quot;name&quot;: &quot;PriceFamilyDescription&quot;},\r\n    {&quot;type&quot;: &quot;STRING&quot;, &quot;mode&quot;: &quot;NULLABLE&quot;, &quot;name&quot;: &quot;SalesDistrict&quot;},\r\n    {&quot;type&quot;: &quot;DATE&quot;, &quot;mode&quot;: &quot;NULLABLE&quot;, &quot;name&quot;: &quot;FiscalWeekendDate&quot;},\r\n    {&quot;type&quot;: &quot;STRING&quot;, &quot;mode&quot;: &quot;REPEATED&quot;, &quot;name&quot;: &quot;export_sql&quot;},\r\n    {&quot;type&quot;: &quot;STRING&quot;, &quot;mode&quot;: &quot;REPEATED&quot;, &quot;name&quot;: &quot;post_sql&quot;}]\r\n\r\n**Requirement:**\r\nIf in case the line dosent contain the **mode** value then insert it as &quot;mode&quot;: &quot;NULLABLE&quot; inbetween the type and name attributes.\r\n\r\nMy end result what i am trying to achive is to get the field and its corresponding datetype and mode as below, from the above expected output.\r\n\r\n**FInal result:**\r\n   \r\n        Article,STRING,NULLABLE \r\n        Sellable_UOM,STRING,NULLABLE\r\n        PriceFamilyCode,STRING,NULLABLE\r\n        PriceFamilyDescription,STRING,NULLABLE\r\n        SalesDistrict,STRING,NULLABLE\r\n        FiscalWeekendDate,DATE,NULLABLE\r\n        export_sql,STRING,REPEATED\r\n        post_sql,STRING,REPEATED\r\n\r\nThe command i tried to achive this is from the expected output json is,\r\n\r\n    jq -r &#39;.[] |[ .name, .type, .mode]|@csv&#39;  file1.json | sed s/&#39;&quot;&#39;//g",
        "link": "https://stackoverflow.com/questions/63407632/insert-a-key-value-pair-in-each-object-if-it-is-not-present-using-jq",
        "title": "Insert a key value pair in each object if it is not present using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1597391593,
                "creation_date": 1597391593,
                "answer_id": 63408747,
                "question_id": 63408713,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Easy enough:\r\n\r\n    jq -r &#39;.pools[] | &quot;\\(.id)=\\(.members|length)&quot;&#39;\r\n\r\n`-r` turns on raw (non-JSON) output so that we can format the output line directly.",
                "title": "json parsing using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1597391593,
        "creation_date": 1597391440,
        "question_id": 63408713,
        "body_markdown": "I am trying to parse a JSON file \r\n\r\ninput content:\r\n\r\n    {\r\n       &quot;pools&quot;:[\r\n          {\r\n             &quot;id&quot;:&quot;403add1f-25d9-4a24-99ff-12c5559fecfa&quot;,\r\n             &quot;members&quot;:[\r\n                {\r\n                   &quot;id&quot;:&quot;2b8e1155-aae0-4999-a038-ec900fd8e5b6&quot;\r\n                },\r\n                {\r\n                   &quot;id&quot;:&quot;3010bc81-e76d-462a-b4cc-2dc0888d65d2&quot;\r\n                }\r\n             ]\r\n          },\r\n          {\r\n             &quot;id&quot;:&quot;ranj-25d9-4a24-99ff-12c5559fecfa&quot;,\r\n             &quot;members&quot;:[\r\n                {\r\n                   &quot;id&quot;:&quot;ranj-aae0-4999-a038-ec900fd8e5b6&quot;\r\n                }\r\n             ]\r\n          }\r\n       ],\r\n       &quot;pools_links&quot;:[\r\n    \r\n       ]\r\n    }\r\n\r\nExpected output:\r\n\r\n    403add1f-25d9-4a24-99ff-12c5559fecfa=2\r\n    ranj-25d9-4a24-99ff-12c5559fecfa=1\r\n\r\n\r\nthe &#39;403add1f-25d9-4a24-99ff-12c5559fecfa&#39; is reading from the id, and the 2 is the number of members.\r\n\r\nDoes anyone have an idea of how to do it in one jq call?\r\n\r\nThanks.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63408713/json-parsing-using-jq",
        "title": "json parsing using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1597410477,
                "last_edit_date": 1597410477,
                "creation_date": 1597408474,
                "answer_id": 63412870,
                "question_id": 63412573,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `select` built-in yields `empty` unless at least one of its inputs meets the given criteria, and `empty` consumes almost anything around itself. Hence the empty result.\r\n\r\nInstead, use the `first` built-in for alternating between the `code` value from the object where `system` is `target`, and `null`. This also covers some other cases you didn&#39;t mention explicitly.\r\n```\r\n{ id, code: first((.coding[]? | select(.system == &quot;target&quot;) .code), null) }\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/4GrAHU_GCe)&lt;/sup&gt;",
                "title": "Copy value from grandchildren if it exists, use null otherwise"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1597410477,
        "creation_date": 1597407269,
        "last_edit_date": 1597410237,
        "question_id": 63412573,
        "body_markdown": "Given the JSON:\r\n\r\n    {\r\n        &quot;id&quot;: 1,\r\n        &quot;coding&quot;: [{\r\n            &quot;code&quot;: 1234,\r\n            &quot;system&quot;: &quot;target&quot;\r\n        }, {\r\n            &quot;code&quot;: 5678,\r\n            &quot;system&quot;: &quot;other&quot;\r\n        }]\r\n    }\r\n\r\nI can select the value of &quot;code&quot; where the &quot;system&quot; is &quot;target&quot;, thus:\r\n\r\n    {id: .id} + {&quot;code&quot;: .coding[]? | select(.system==&quot;target&quot;).code}\r\n\r\nTo produce:\r\n\r\n    {\r\n        &quot;id&quot;: 1,\r\n        &quot;code&quot;: 1234\r\n    }\r\n\r\nBut if the object whose &quot;system&quot; value is &quot;target&quot; does not exist in the array, thus:\r\n\r\n    {\r\n        &quot;id&quot;: 1,\r\n        &quot;coding&quot;: [{\r\n            &quot;code&quot;: 5678,\r\n            &quot;system&quot;: &quot;other&quot;\r\n        }]\r\n    }\r\n\r\nI want the following result:\r\n\r\n    {\r\n        &quot;id&quot;: 1,\r\n        &quot;code&quot;: null\r\n    }\r\n\r\nHowever, my above jq produces an empty object. How can I achieve what I want?",
        "link": "https://stackoverflow.com/questions/63412573/copy-value-from-grandchildren-if-it-exists-use-null-otherwise",
        "title": "Copy value from grandchildren if it exists, use null otherwise"
    },
    {
        "tags": [
            "json",
            "nested",
            "jq",
            "ellipsis"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1597425086,
                "creation_date": 1597425086,
                "answer_id": 63417215,
                "question_id": 63417006,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Update all members of `.hits.hits` to leave only the `id` field using the program below, I guess this is what you&#39;re looking for.\r\n```\r\n.hits.hits[] |= {id}\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/vilCNy-iTD)&lt;/sup&gt;",
                "title": "How to remove or ignore values from certain nesting level with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1597544731,
                "creation_date": 1597544731,
                "answer_id": 63432545,
                "question_id": 63417006,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I want to remove all items from a certain level of nesting\r\n\r\nHere&#39;s a function that does so for any given level, $n:\r\n```\r\ndef maxdepth($n):\r\n  . as $in\r\n  | reduce paths as $p (null;\r\n       if ($p|length) &gt; $n\r\n       then .\r\n       else ($in | getpath($p) ) as $v\r\n       | if ($p|length) == $n\r\n         then if (($v|type ==&quot;object&quot;) and ($v|length&gt;1))\r\n              then setpath($p; &quot;{...}&quot; )\r\n              elif (($v|type == &quot;array&quot;) and ($v|length&gt;1))\r\n              then setpath($p; &quot;[...]&quot; )\r\n              else setpath($p; $v) \r\n              end\r\n         else setpath($p; $v) \r\n         end\r\n       end) ;\r\n```\r\n### maxdepth(2)\r\nUsing your example, `maxdepth(2)` produces:\r\n```\r\n{\r\n  &quot;paging&quot;: {\r\n    &quot;next&quot;: &quot;items?page=12&quot;,\r\n    &quot;previous&quot;: &quot;items?page=10&quot;\r\n  },\r\n  &quot;hits&quot;: {\r\n    &quot;total&quot;: 10200,\r\n    &quot;max_score&quot;: 1,\r\n    &quot;hits&quot;: &quot;[...]&quot;\r\n  },\r\n  &quot;took&quot;: 11,\r\n  &quot;timed_out&quot;: false\r\n}\r\n```\r\n",
                "title": "How to remove or ignore values from certain nesting level with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1597548829,
        "creation_date": 1597424055,
        "last_edit_date": 1597548829,
        "question_id": 63417006,
        "body_markdown": "I have a deeply nested JSON, which is too large to look through; I want to remove all items from a certain level of nesting, preferably with `jq`.\r\n\r\nSay, the JSON is:\r\n\r\n```\r\n{\r\n  &quot;paging&quot;: {\r\n    &quot;next&quot;: &quot;items?page=12&quot;,\r\n    &quot;previous&quot;: &quot;items?page=10&quot;\r\n  },\r\n  &quot;hits&quot;: {\r\n    &quot;total&quot;: 10200,\r\n    &quot;max_score&quot;: 1,\r\n    &quot;hits&quot;: [\r\n      {\r\n        &quot;id&quot;: 1337,\r\n        &quot;really large struct 1&quot;: &quot;with long and complexed nested values&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1338,\r\n        &quot;really large struct 1&quot;: &quot;with long and complexed nested values&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;took&quot;: 11,\r\n  &quot;timed_out&quot;: false\r\n}\r\n```\r\n\r\nIn this example, I want to omit everything under `.hits.hits`, maybe replace it with an ellipsis (…) or simply ignore it. A good alternative would be to render only the `id` value in the example.\r\n\r\nThe fields like `paging`, `took`, and `timed_oud` are examples and could change, or be a rather long and wieldy list, so simply allowlisting (whitelisting) all stuff that should stay is not an option: I want to filter out a certain depth and not show that; filtering on certain denylisted (blacklisted) items like removing all `.hits.hits.*` is OK, though.\r\n\r\nI&#39;ve tried `jq &#39;.&#39; | cut -c1-40` and that removes the need for horizontal scrolling and/or wrapping, but not the long vertical scrolling. ",
        "link": "https://stackoverflow.com/questions/63417006/how-to-remove-or-ignore-values-from-certain-nesting-level-with-jq",
        "title": "How to remove or ignore values from certain nesting level with jq"
    },
    {
        "tags": [
            "json",
            "null",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1597446808,
                "creation_date": 1597446808,
                "answer_id": 63421039,
                "question_id": 63420788,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of `.time.total`, you could write:\r\n\r\n    (.time.total // 0)",
                "title": "jq: find and replace null with zero (0)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1597457385,
        "creation_date": 1597444551,
        "last_edit_date": 1597457385,
        "question_id": 63420788,
        "body_markdown": "Given this output:\r\n```\r\ncat file.json | jq -cr &#39;.[] | .name, .time.total, .dueOn&#39;\r\n```\r\n\r\nI get the output:\r\n\r\n```\r\nTask one\r\n35160\r\n2020-08-14\r\nTask two\r\nnull\r\nnull\r\nTask three\r\nnull\r\nnull\r\nTask 4\r\n2280\r\nnull\r\n```\r\n\r\nThe **time.total** value of &quot;null&quot; I&#39;d like to change to 0, so I can perform math on it. (I intend to divide by 3600 to covert the value to hours, e.g 1.25)\r\n\r\nI&#39;ve read countless SE articles, and no doubt my jq chops aren&#39;t where they need to be. But I hope there&#39;s a basic solution for this!\r\n\r\nDesired output would be:\r\n\r\n\r\n```\r\nTask one\r\n35160\r\n2020-08-14\r\nTask two\r\n0\r\nnull\r\nTask three\r\n0\r\nnull\r\nTask 4\r\n2280\r\nnull\r\n```",
        "link": "https://stackoverflow.com/questions/63420788/jq-find-and-replace-null-with-zero-0",
        "title": "jq: find and replace null with zero (0)"
    },
    {
        "tags": [
            "json",
            "jq",
            "transpose"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 19304791,
                    "reputation": 35,
                    "user_id": 14111850,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-wRkq8THnjk4/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnOttFIop3FlMsgEb6yhnn12KE7SQ/s256-rj/photo.jpg",
                    "display_name": "bb7",
                    "link": "https://stackoverflow.com/users/14111850/bb7"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1597532950,
                "post_id": 63431239,
                "comment_id": 112164475,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1597546690,
                "creation_date": 1597546690,
                "answer_id": 63432706,
                "question_id": 63431239,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a generic solution (notice there is no mention of &quot;a&quot; or &quot;b&quot;) using `transpose`:\r\n```\r\n(keys_unsorted | map(tojson)),   # the header line\r\n ([.[]] | transpose[])\r\n| @tsv\r\n```\r\n### Invocation\r\n\r\njq -r -f program.jq data.json\r\n### Output\r\n```\r\n&quot;a&quot;\t&quot;b&quot;\r\n1\t4\r\n2\t5\r\n3\t6\r\n```",
                "title": "jq: how to get 2 1d arrays side by side as output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1597546870,
        "creation_date": 1597529236,
        "last_edit_date": 1597546870,
        "question_id": 63431239,
        "body_markdown": "Say we have the following object in a json file:  \r\n&gt; {&quot;a&quot;: [1,2,3], &quot;b&quot;: [4,5,6]}\r\n\r\nHow can I get the following output?:\r\n\r\n     &quot;a&quot;  &quot;b&quot;\r\n      1    4\r\n      2    5\r\n      3    6\r\n       \r\n\r\nI&#39;ve only managed to get them one after another but not side by side:\r\n\r\n    &gt;jq -nc &#39;{a: [1,2,3], b: [4,5,6]}&#39;|jq &#39;&quot;a&quot;,.a[],&quot;b&quot;, .b[]&#39;\r\n     &quot;a&quot;\r\n      1\r\n      2\r\n      3\r\n     &quot;b&quot;\r\n      4\r\n      5\r\n      6\r\n\r\nthanks.\r\n\r\n\r\n\r\n      ",
        "link": "https://stackoverflow.com/questions/63431239/jq-how-to-get-2-1d-arrays-side-by-side-as-output",
        "title": "jq: how to get 2 1d arrays side by side as output"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1597537621,
                "creation_date": 1597537621,
                "answer_id": 63432005,
                "question_id": 63431948,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Found my answer in that --arg passed variables are strings and not interpreted as numbers https://stackoverflow.com/a/41773407/272648 so need to be converted\r\n\r\n```\r\njq -r --arg i $ip --arg host $h --arg v $value &#39;select(.Value &lt;=($v | tonumber) and .ClientRequestHost == $host and .ClientIP == $i)&#39; file.json\r\n```",
                "title": "jq --arg passed variable to select() not working without hard code value?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1597548759,
                "creation_date": 1597548759,
                "answer_id": 63432861,
                "question_id": 63431948,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Or use the command-line option `-—argjson`",
                "title": "jq --arg passed variable to select() not working without hard code value?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1597548759,
        "creation_date": 1597536869,
        "question_id": 63431948,
        "body_markdown": "Hi I am trying pass variables to jq but don&#39;t understand why some `--arg` variables work and some don&#39;t.\r\n\r\n```\r\njq --version\r\njq-1.6\r\n```\r\n\r\nExample doesn&#39;t work with `.Value &lt;=$v` and instead returns all .Values even greater than 10 and not as expected less than or equal to 10\r\n\r\n```\r\nh=hostname\r\nip=ipaddress\r\nvalue=10\r\njq -r --arg i $ip --arg host $h --arg v $value &#39;select(.Value &lt;=$v and .ClientRequestHost == $host and .ClientIP == $i)&#39; file.json\r\n```\r\n\r\nDoes work if .Value is hardcoded in `select()` to 10 `.Value &lt;=10` and filters output for .Value less than or equal to 10\r\n\r\n```\r\nh=hostname\r\nip=ipaddress\r\nvalue=10\r\njq -r --arg i $ip --arg host $h --arg v $value &#39;select(.Value &lt;=10 and .ClientRequestHost == $host and .ClientIP == $i)&#39; file.json\r\n```\r\n\r\nIn both examples the variables for $h and $i passed to jq select do work, just not the variable for $v ?",
        "link": "https://stackoverflow.com/questions/63431948/jq-arg-passed-variable-to-select-not-working-without-hard-code-value",
        "title": "jq --arg passed variable to select() not working without hard code value?"
    }
]