[
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1529502041,
                "last_edit_date": 1529502041,
                "creation_date": 1529481385,
                "answer_id": 50943112,
                "question_id": 50943035,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It should be pretty straightforward filter, use the `select` and `contain` constructs.\r\n\r\n    jq &#39;.[] | select( .name| contains(&quot;test&quot;)) | .id&#39;\r\n\r\nCall the filter with `-r` to remove the quotes and print the raw value.\r\n\r\n[jqplay-URL](https://jqplay.org/s/IKy-OKCpD3)",
                "title": "How do I return the id associated with the test json element?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1529502041,
        "creation_date": 1529481113,
        "question_id": 50943035,
        "body_markdown": "I return the following json from a curl. I&#39;ve simplified the ID&#39;s however my goal is to return the id related to the test object. The desired return value is `55555`.\r\n\r\nI&#39;m using jq to parse the string.\r\nhttps://stedolan.github.io/jq\r\n\r\n\r\n    [\r\n      {\r\n        &quot;attributes&quot;: null,\r\n        &quot;id&quot;: &quot;44444&quot;,\r\n        &quot;name&quot;: &quot;production&quot;,\r\n        &quot;type&quot;: &quot;system_group&quot;\r\n      },\r\n      {\r\n        &quot;attributes&quot;: null,\r\n        &quot;id&quot;: &quot;55555&quot;,\r\n        &quot;name&quot;: &quot;test&quot;,\r\n        &quot;type&quot;: &quot;system_group&quot;\r\n      },\r\n      {\r\n        &quot;attributes&quot;: null,\r\n        &quot;id&quot;: &quot;66666&quot;,\r\n        &quot;name&quot;: &quot;uat&quot;,\r\n        &quot;type&quot;: &quot;system_group&quot;\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/50943035/how-do-i-return-the-id-associated-with-the-test-json-element",
        "title": "How do I return the id associated with the test json element?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1529505886,
                "last_edit_date": 1529505886,
                "creation_date": 1529493368,
                "answer_id": 50946936,
                "question_id": 50943201,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Add an `if` condition to do the case conversion only _if_ the `name` field is not `null` as\r\n\r\n    map( if (.data_node.name != null) then .data_node.name |= ascii_downcase else . end )\r\n\r\nAs far as the error you are seeing, I&#39;d assume that the case conversion we apply does not apply to the `null` datatype in `jq` and only for string types.\r\n\r\nTo run it on the command-line directly without running as a script\r\n\r\n    jq &#39;map( if (.data_node.name != null) then .data_node.name |= ascii_downcase else . end )&#39; &lt; data3.json\r\n\r\n[jqplay-URL](https://jqplay.org/s/Ms1RjbKlQe)",
                "title": "Getting error &#39;explode input must be a string&#39; on using jq for case conversion"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1529582808,
                "creation_date": 1529582808,
                "answer_id": 50968201,
                "question_id": 50943201,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "More briefly and more robustly:\r\n\r\n    map(.data_node.name |= if type == &quot;string&quot; then ascii_downcase else . end)\r\n\r\nOr still more briefly:\r\n\r\n    map(.data_node.name |= ascii_downcase? // .)\r\n\r\n(These assume that jq is invoked without the -s option.)",
                "title": "Getting error &#39;explode input must be a string&#39; on using jq for case conversion"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1529582808,
        "creation_date": 1529481658,
        "last_edit_date": 1529484548,
        "question_id": 50943201,
        "body_markdown": "Looking to change all the values of name to Lower Case. \r\n\r\nI am currently running \r\n\r\n    map( .[].data_node.name |= ascii_downcase)\r\n\r\nand receive `jq: error (at data3.json:538): explode input must be a string` error.\r\n\r\nSample input:\r\n\r\n    [  \r\n       {  \r\n          &quot;data_node&quot;:{  \r\n             &quot;name&quot;:&quot;FRODO BAGGINS&quot;,\r\n             &quot;race&quot;:&quot;hobbit&quot;,\r\n             &quot;existence&quot;:&quot;middle earth&quot;\r\n          },\r\n          &quot;parent&quot;:&quot;bilbo baggins&quot;\r\n       },\r\n       {  \r\n          &quot;data_node&quot;:{  \r\n             &quot;name&quot;:&quot;SAMWISE GAMJEE&quot;,\r\n             &quot;race&quot;:&quot;hobbit&quot;,\r\n             &quot;existence&quot;:&quot;middle earth&quot;\r\n          },\r\n          &quot;parent&quot;:&quot;gamjee lord&quot;\r\n       },\r\n       {  \r\n             &quot;data_node&quot;:{  \r\n                 &quot;name&quot;:null,\r\n                 &quot;race&quot;:&quot;hobbit&quot;,\r\n                 &quot;existence&quot;:&quot;middle earth&quot;\r\n             },\r\n             &quot;parent&quot;:&quot;bilbo baggins&quot;\r\n           }\r\n        ]\r\n\r\n\r\nSample output:\r\n\r\n    [  \r\n       {  \r\n          &quot;data_node&quot;:{  \r\n             &quot;name&quot;:&quot;frodo baggins&quot;,\r\n             &quot;race&quot;:&quot;hobbit&quot;,\r\n             &quot;existence&quot;:&quot;middle earth&quot;\r\n          },\r\n          &quot;parent&quot;:&quot;bilbo baggins&quot;\r\n       },\r\n       {  \r\n          &quot;data_node&quot;:{  \r\n             &quot;name&quot;:&quot;samwise gamjee&quot;,\r\n             &quot;race&quot;:&quot;hobbit&quot;,\r\n             &quot;existence&quot;:&quot;middle earth&quot;\r\n          },\r\n          &quot;parent&quot;:&quot;gamjee lord&quot;\r\n       },\r\n       {  \r\n          &quot;data_node&quot;:{  \r\n             &quot;name&quot;: null,\r\n             &quot;race&quot;:&quot;hobbit&quot;,\r\n             &quot;existence&quot;:&quot;middle earth&quot;\r\n          },\r\n          &quot;parent&quot;:&quot;bilbo baggins&quot;\r\n       }\r\n    ]\r\n\r\nWhat&#39;s wrong with my current line of code and what&#39;s the solution to doing this right.\r\n",
        "link": "https://stackoverflow.com/questions/50943201/getting-error-explode-input-must-be-a-string-on-using-jq-for-case-conversion",
        "title": "Getting error &#39;explode input must be a string&#39; on using jq for case conversion"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1529554253,
                "last_edit_date": 1529554253,
                "creation_date": 1529486655,
                "answer_id": 50944704,
                "question_id": 50944224,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use a filter to get all the paths to all elements in the input and join them using `join`. You could also force the string conversion to avoid errors when joining numerals.\r\n\r\n    paths | map(tostring) | join(&quot;.&quot;)\r\n\r\n`paths` outputs the paths to all the elements in its input (except it does not output the empty list, representing . itself).",
                "title": "How to list all the keys inside a deep nested json using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1529554253,
        "creation_date": 1529485150,
        "last_edit_date": 1529488961,
        "question_id": 50944224,
        "body_markdown": "Iam Parsing a very Large JSON which is multilevel nested.\r\nSo i want to find al the keys in the nested json.\r\n\r\nWhat i did :\r\n\r\n    nsadmin@machine:~/$ jq &#39;keys&#39; 474.json\r\n    [\r\n      &quot;x&quot;,\r\n      &quot;y&quot;,\r\n      &quot;t&quot;,\r\n      &quot;report&quot;\r\n    ]\r\n\r\nWhat iam getting is the top level keys,but my report key has a value which is multi-level nested.So is there any way to print all keys inside this nested JSON using Jq.?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/50944224/how-to-list-all-the-keys-inside-a-deep-nested-json-using-jq",
        "title": "How to list all the keys inside a deep nested json using jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "unix",
            "jq",
            "unnest"
        ],
        "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": 1529509997,
                "post_id": 50950522,
                "comment_id": 88902327,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13778785,
                    "reputation": 567,
                    "user_id": 9944404,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9896c88273e37d7a54ca0db68e391c02?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user49",
                    "link": "https://stackoverflow.com/users/9944404/user49"
                },
                "reply_to_user": {
                    "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": 1529510539,
                "post_id": 50950522,
                "comment_id": 88902699,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1529510602,
                "post_id": 50950522,
                "comment_id": 88902744,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13778785,
                    "reputation": 567,
                    "user_id": 9944404,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9896c88273e37d7a54ca0db68e391c02?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user49",
                    "link": "https://stackoverflow.com/users/9944404/user49"
                },
                "reply_to_user": {
                    "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": 1529511053,
                "post_id": 50950522,
                "comment_id": 88902987,
                "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": 1529511511,
                "post_id": 50950522,
                "comment_id": 88903262,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1529511296,
                "creation_date": 1529511296,
                "answer_id": 50952795,
                "question_id": 50950522,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `*` operator, given two dictionaries, merges their contents. Thus,\r\n\r\n    jq &#39;[.[] | (. * .Row) | del(.Row)]&#39;\r\n\r\n...emits as output, when given your input:\r\n\r\n    [\r\n      {\r\n        &quot;fighter&quot;: &quot;1&quot;,\r\n        &quot;ganjalord&quot;: {\r\n          &quot;latitude&quot;: &quot;56.237480&quot;,\r\n          &quot;temp&quot;: 44\r\n        }\r\n      },\r\n      {\r\n        &quot;fighter&quot;: &quot;0&quot;,\r\n        &quot;ganjalord&quot;: {\r\n          &quot;latitude&quot;: &quot;53.237480&quot;,\r\n          &quot;temp&quot;: 42\r\n        }\r\n      }\r\n    ]",
                "title": "removing one layer of object nesting with JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1529604955,
                "last_edit_date": 1529604955,
                "creation_date": 1529514013,
                "answer_id": 50953471,
                "question_id": 50950522,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Applying the following filter to the &quot;input&quot; as shown, yields the desired result:\r\n\r\n    map( with_entries( if .key == &quot;Row&quot; then .value|to_entries[] else . end) )\r\n\r\nThe key to understanding this is that `with_entries` first applies `to_entries` to yield key/value pairs, and then applies `from_entries`.\r\n\r\nOf course, as with a solution based on `. * .Row` or `. * Row` (or `.+.Row` or `.Row+.`), the above solution will entail some loss of data if any of the hoisted key names coincide with the top-level key names.\r\n",
                "title": "removing one layer of object nesting with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1590124887,
        "creation_date": 1529504613,
        "last_edit_date": 1590124887,
        "question_id": 50950522,
        "body_markdown": "i have been tinkering with JQ to try and manipulate some data. Thus far, the following JSON output using my command:\r\n\r\n     map({Row: .[] })\r\n    |\tmap(select(.Row.ganjalord.latitude | test(&quot;SOME_TESTING_CONDITION&quot;)?))\r\n\r\ninput:\r\n\r\n    [\r\n      {\r\n        &quot;Row&quot;: {\r\n          &quot;ganjalord&quot;: {\r\n            &quot;latitude&quot;: &quot;56.237480&quot;,\r\n            &quot;temp&quot;: 44\r\n          }\r\n        },\r\n        &quot;fighter&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;Row&quot;: {\r\n          &quot;ganjalord&quot;: {\r\n            &quot;latitude&quot;: &quot;53.237480&quot;,\r\n            &quot;temp&quot;: 42\r\n          }\r\n        },\r\n        &quot;fighter&quot;: &quot;0&quot;\r\n      }\r\n    ]\r\n\r\n\r\nhow do i achieve the sample output where it is not nested by row? \r\n\r\nsample output:\r\n\r\n    [\r\n      {\r\n        &quot;ganjalord&quot;: {\r\n          &quot;latitude&quot;: &quot;56.237480&quot;,\r\n          &quot;temp&quot;: 44\r\n        },\r\n        &quot;fighter&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;ganjalord&quot;: {\r\n          &quot;latitude&quot;: &quot;53.237480&quot;,\r\n          &quot;temp&quot;: 42\r\n        },\r\n        &quot;fighter&quot;: &quot;0&quot;\r\n      }\r\n    ]\r\n\r\n\r\nDo i use a simple select statement to try and achieve this ?",
        "link": "https://stackoverflow.com/questions/50950522/removing-one-layer-of-object-nesting-with-jq",
        "title": "removing one layer of object nesting with JQ"
    },
    {
        "tags": [
            "json",
            "syntax",
            "nested",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1529545284,
                "last_edit_date": 1529545284,
                "creation_date": 1529519210,
                "answer_id": 50954836,
                "question_id": 50954003,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. Since jq is stream-oriented, you would just use `select(...)` rather than `map(select(...))`\r\n\r\n2. It looks like you intend to use `.requestHeaders.&quot;user-agent&quot;` in the criterion for selection. \r\n\r\n3. It&#39;s generally recommended to avoid using `cat` when possible.\r\n\r\n4. According to your stated requirements, you should drop the -c command-line option.\r\n\r\n5. Since &quot;Rcurl&quot; does not appear in your sample input, I&#39;ll use the string that does appear.\r\n\r\nSo in your case, you&#39;d end up with something like:\r\n\r\n    &lt; /logs/json.log jq &#39;\r\n      select(.requestHeaders.&quot;user-agent&quot; == &quot;curl/7.51.0&quot;)\r\n      | {isoDateTime, method, username,\r\n         &quot;requestHeaders.user-agent&quot;: .requestHeaders.&quot;user-agent&quot;}&#39;",
                "title": "Can I output a property with jq based on a nested property in the input?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1529572247,
        "creation_date": 1529516054,
        "last_edit_date": 1529572247,
        "question_id": 50954003,
        "body_markdown": "This follows on from https://stackoverflow.com/questions/29259249/extracting-selected-properties-from-a-nested-json-object-with-jq which lets the OP there get rid of a load of unwanted properties from a nested object. \r\n\r\nI&#39;ve got the same problem but instead of an array starting [, just have a stream of JSON objects, each like this:\r\n\r\n    {\r\n       &quot;localHostName&quot; : &quot;rest-2-17ve6&quot;,\r\n       &quot;port&quot; : &quot;80&quot;,\r\n       &quot;requestHeaders&quot; : {\r\n          &quot;x-forwarded-port&quot; : &quot;443&quot;,\r\n          &quot;x-forwarded-host&quot; : &quot;dummy.com&quot;,\r\n          &quot;content-length&quot; : &quot;15959431&quot;,\r\n          &quot;accept&quot; : &quot;*/*&quot;,\r\n          &quot;x-forwarded-for&quot; : &quot;10.1.9.11&quot;,\r\n          &quot;authorization&quot; : &quot;hash is present&quot;,\r\n          &quot;expect&quot; : &quot;100-continue&quot;,\r\n          &quot;forwarded&quot; : &quot;for=10.5.9.1;host=dummy.com;proto=https&quot;,\r\n          &quot;content-type&quot; : &quot;application/json&quot;,\r\n          &quot;host&quot; : &quot;dummy.com&quot;,\r\n          &quot;x-forwarded-proto&quot; : &quot;https&quot;,\r\n          &quot;user-agent&quot; : &quot;curl/7.51.0&quot;\r\n       },\r\n       &quot;uri&quot; : &quot;/2/data/saveList&quot;,\r\n       &quot;protocol&quot; : &quot;HTTP/1.1&quot;,\r\n       &quot;threadName&quot; : &quot;http-nio-8080-exec-10&quot;,\r\n       &quot;requestBytes&quot; : 15959431,\r\n       &quot;applicationDuration&quot; : 44135,\r\n       &quot;responseStatus&quot; : &quot;200&quot;,\r\n       &quot;remoteIpAddress&quot; : &quot;10.1.10.1&quot;,\r\n       &quot;responseHeaders&quot; : {\r\n          &quot;X-XSS-Protection&quot; : &quot;1; mode=block&quot;,\r\n          &quot;Content-Type&quot; : &quot;application/json;charset=UTF-8&quot;,\r\n          &quot;X-Content-Type-Options&quot; : &quot;nosniff&quot;,\r\n          &quot;Cache-Control&quot; : &quot;no-cache, no-store, max-age=0, must-revalidate&quot;,\r\n          &quot;Date&quot; : &quot;Wed, 20 Jun 2018 15:53:27 GMT&quot;,\r\n          &quot;Transfer-Encoding&quot; : &quot;chunked&quot;,\r\n          &quot;Vary&quot; : &quot;Accept-Encoding&quot;,\r\n          &quot;X-Frame-Options&quot; : &quot;DENY&quot;,\r\n          &quot;Expires&quot; : &quot;0&quot;,\r\n          &quot;Pragma&quot; : &quot;no-cache&quot;\r\n       },\r\n       &quot;isoDateTime&quot; : &quot;2018-06-20T15:52:42.466913985Z&quot;,\r\n       &quot;method&quot; : &quot;POST&quot;,\r\n       &quot;username&quot; : &quot;rd7y1&quot;,\r\n       &quot;localIpAddress&quot; : &quot;10.129.9.238&quot;,\r\n       &quot;responseBytes&quot; : 2,\r\n       &quot;requestContentExcerpt&quot; : &quot;blah&quot;,\r\n       &quot;totalDuration&quot; : 44869,\r\n       &quot;responseContentExcerpt&quot; : &quot; [] &quot;\r\n    }\r\n\r\nI want to filter the stream on the command line so I only get:\r\n\r\n    { \r\n       &quot;isoDateTime&quot; : &quot;2018-06-20T15:52:42.466913985Z&quot;,\r\n       &quot;method&quot; : &quot;POST&quot;,\r\n       &quot;username&quot; : &quot;rd7y1&quot;,\r\n       &quot;requestHeaders.user-agent&quot; : &quot;Rcurl&quot;\r\n    }\r\n\r\nI tried `cat /logs/json.log | jq -cC &#39;map(requestHeaders|={user-agent})&#39;` but I&#39;m getting a syntax error. ",
        "link": "https://stackoverflow.com/questions/50954003/can-i-output-a-property-with-jq-based-on-a-nested-property-in-the-input",
        "title": "Can I output a property with jq based on a nested property in the input?"
    },
    {
        "tags": [
            "installation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1529546101,
                "creation_date": 1529546101,
                "answer_id": 50959285,
                "question_id": 50955866,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Should I even worry about the failure of tests/onigtest?\r\n\r\nIf the only failures are related to onigtest, then most likely only the regex filters will be affected.\r\n\r\n&gt; what should I do about this failure?\r\n\r\nAccording to the jq [download page][1], there is a pre-built binary for FreeBSD, so you might try that.\r\n\r\nFrom your brief description, it&#39;s not clear to me what exactly you did, but if you haven&#39;t already done so, you might also consider building an executable from a git clone of &quot;master&quot; as per the guidelines on the download page; see also https://github.com/stedolan/jq/wiki/Installation#or-build-from-source\r\n\r\n&gt; What is the best and/or most proper way for me to get a copy of the test-suite.log file to the maintainer(s)?\r\n\r\nYou could create a ticket at https://github.com/stedolan/jq/issues\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/download/",
                "title": "Validation test failure for build of jq-1.5 on FreeBSD 9.x... Now what?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1529551746,
        "creation_date": 1529523497,
        "last_edit_date": 1529551746,
        "question_id": 50955866,
        "body_markdown": "A note in the README file said to ask questions here, so I am doing so.\r\n\r\nThe RIPEstat service has just shut off their own port 43 plain text service and now is forcing everyone to access their data using jq.  I have **zero** experience with or knowledge of jq, but I am forced to give it a try.  I have just built the thing successfully from sources (jq-1.5) on my crusty old FreeBSD 9.x system and the build completed OK, but one of the post-build verification tests (tests/onigtest) failed.  I am looking at the test-suite.log file but none of what&#39;s in there means anything to me.  (Unfortunately, I am new to stackoverflow also, and thus, I have no idea how to even upload a copy of that here so that the maintainer can peruse it.)\r\n\r\nSo, my questions:\r\n\r\n1)  Should I even worry about the failure of tests/onigtest?\r\n\r\n2)  If I should, then what should I do about this failure?\r\n\r\n3)  What is the best and/or most proper way for me to get a copy of the test-suite.log file to the maintainer(s)?",
        "link": "https://stackoverflow.com/questions/50955866/validation-test-failure-for-build-of-jq-1-5-on-freebsd-9-x-now-what",
        "title": "Validation test failure for build of jq-1.5 on FreeBSD 9.x... Now what?"
    },
    {
        "tags": [
            "json",
            "stream",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1529558148,
                "creation_date": 1529558148,
                "answer_id": 50960833,
                "question_id": 50960648,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From the `jq` man page:\r\n\r\n&gt; by default, jq reads a stream of JSON entities (including numbers and other  literals)  from\r\n       stdin.  Whitespace is only needed to separate entities such as 1 and 2, and true and false.\r\n\r\nIn your example, jq parses `1`, which is a valid JSON entity by itself, and then proceeds to parse `2` and `3`. In other words: the jq command parses the input `1 2 3` because it happens to be valid JSON entities separated by whitespace.\r\n\r\nIf you use the `--slurp` option, which prints an array of all the input entities, you can see that it treats `1`, `2` and `3` as separate entities:\r\n\r\n    # separate entities:\r\n    $ echo &#39;1 2 3&#39; | jq --slurp\r\n    [\r\n      1,\r\n      2,\r\n      3\r\n    ]\r\n    \r\n    # a single entity:\r\n    $ echo &#39;&quot;1 2 3&quot;&#39; | jq --slurp\r\n    [\r\n      &quot;1 2 3&quot;\r\n    ]\r\n\r\nFor comparison, the following inputs will fail to parse:\r\n\r\n    [1 2 3]\r\n    1, 2. 3\r\n\r\n",
                "title": "jq command parses invalid JSON ( numerics splited with space )"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1529572563,
        "creation_date": 1529557060,
        "last_edit_date": 1529572563,
        "question_id": 50960648,
        "body_markdown": "i think it is invalid as JSON.\r\nbut jq command does not raise error and parse it.\r\n\r\nWhat does mean that?\r\n\r\n    $ echo &#39;1 2 3&#39; | jq .\r\n    1\r\n    2\r\n    3\r\n\r\n( `version : jq-1.5` )",
        "link": "https://stackoverflow.com/questions/50960648/jq-command-parses-invalid-json-numerics-splited-with-space",
        "title": "jq command parses invalid JSON ( numerics splited with space )"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1529604713,
                "creation_date": 1529604713,
                "answer_id": 50975126,
                "question_id": 50974532,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to use a JSON parser to parse JSON data. As you have seen, trying to use regular expressions is too fragile.\r\n\r\nFirst, to store that tricky string into a variable for testing purposes: use a quoted heredoc:\r\n\r\n    $ result=$(cat &lt;&lt;&#39;END&#39;\r\n    [\r\n        {\r\n            &quot;id&quot;: 668,\r\n            &quot;overview&quot;: &quot;All versions of `react-marked-markdown` are vulnerable to cross-site scripting (XSS) via `href` attributes. This is exploitable if user is provided to `react-marked-markdown`\\n\\nProof of concept:\\n\\n```\\nimport React from &#39;react&#39;\\nimport ReactDOM from &#39;react-dom&#39;\\nimport { MarkdownPreview } from &#39;react-marked-markdown&#39;\\n\\nReactDOM.render(\\n&lt;MarkdownPreview\\nmarkedOptions={{ sanitize: true }}\\nvalue={&#39;[XSS](javascript: alert`1`)&#39;}\\n/&gt;,\\ndocument.getElementById(&#39;root&#39;)\\n)\\n```&quot;,\r\n            &quot;recommendation&quot;: &quot;No fix is currently available for this vulnerability. It is our recommendation to not install or use this module at this time if you allow user input into href values.&quot;,\r\n            &quot;cvss_vector&quot;: &quot;CVSS:3.0/AV:N/AC:L/PR:N/UI:R/S:C/C:H/I:H/A:N&quot;,\r\n            &quot;cvss_score&quot;: 9.3,\r\n            &quot;module&quot;: &quot;react-marked-markdown&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: 577,\r\n            &quot;overview&quot;: &quot;Versions of `lodash` before 4.17.5 are vulnerable to prototype pollution. \\n\\nThe vulnerable functions are &#39;defaultsDeep&#39;, &#39;merge&#39;, and &#39;mergeWith&#39; which allow a malicious user to modify the prototype of `Object` via `__proto__` causing the addition or modification of an existing property that will exist on all objects.\\n\\n&quot;,\r\n            &quot;recommendation&quot;: &quot;Update to version 4.17.5 or later.&quot;,\r\n            &quot;cvss_vector&quot;: null,\r\n            &quot;cvss_score&quot;: 2,\r\n            &quot;module&quot;: &quot;lodash&quot;,\r\n            &quot;version&quot;: &quot;3.10.1&quot;\r\n        }\r\n    ]\r\n    END\r\n    )\r\n\r\nThen, remove the overview keys using [tag:jq]\r\n\r\n    $ new_json=$(echo &quot;$result&quot; | jq &#39;map(del(.overview))&#39;)\r\n    $ echo &quot;$new_json&quot;\r\n    [\r\n      {\r\n        &quot;id&quot;: 668,\r\n        &quot;recommendation&quot;: &quot;No fix is currently available for this vulnerability. It is our recommendation to not install or use this module at this time if you allow user input into href values.&quot;,\r\n        &quot;cvss_vector&quot;: &quot;CVSS:3.0/AV:N/AC:L/PR:N/UI:R/S:C/C:H/I:H/A:N&quot;,\r\n        &quot;cvss_score&quot;: 9.3,\r\n        &quot;module&quot;: &quot;react-marked-markdown&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 577,\r\n        &quot;recommendation&quot;: &quot;Update to version 4.17.5 or later.&quot;,\r\n        &quot;cvss_vector&quot;: null,\r\n        &quot;cvss_score&quot;: 2,\r\n        &quot;module&quot;: &quot;lodash&quot;,\r\n        &quot;version&quot;: &quot;3.10.1&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "How to remove substring from a JSON string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1529638679,
        "creation_date": 1529602533,
        "last_edit_date": 1529638679,
        "question_id": 50974532,
        "body_markdown": "I have a following string.\r\n\r\n    result = &#39;[\r\n        {\r\n            &quot;id&quot;: 668,\r\n            &quot;overview&quot;: &quot;All versions of `react-marked-markdown` are vulnerable to cross-site scripting (XSS) via `href` attributes. This is exploitable if user is provided to `react-marked-markdown`\\n\\nProof of concept:\\n\\n```\\nimport React from &#39;react&#39;\\nimport ReactDOM from &#39;react-dom&#39;\\nimport { MarkdownPreview } from &#39;react-marked-markdown&#39;\\n\\nReactDOM.render(\\n&lt;MarkdownPreview\\nmarkedOptions={{ sanitize: true }}\\nvalue={&#39;[XSS](javascript: alert`1`)&#39;}\\n/&gt;,\\ndocument.getElementById(&#39;root&#39;)\\n)\\n```&quot;,\r\n            &quot;recommendation&quot;: &quot;No fix is currently available for this vulnerability. It is our recommendation to not install or use this module at this time if you allow user input into href values.&quot;,\r\n            &quot;cvss_vector&quot;: &quot;CVSS:3.0/AV:N/AC:L/PR:N/UI:R/S:C/C:H/I:H/A:N&quot;,\r\n            &quot;cvss_score&quot;: 9.3,\r\n            &quot;module&quot;: &quot;react-marked-markdown&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: 577,\r\n            &quot;overview&quot;: &quot;Versions of `lodash` before 4.17.5 are vulnerable to prototype pollution. \\n\\nThe vulnerable functions are &#39;defaultsDeep&#39;, &#39;merge&#39;, and &#39;mergeWith&#39; which allow a malicious user to modify the prototype of `Object` via `__proto__` causing the addition or modification of an existing property that will exist on all objects.\\n\\n&quot;,\r\n            &quot;recommendation&quot;: &quot;Update to version 4.17.5 or later.&quot;,\r\n            &quot;cvss_vector&quot;: null,\r\n            &quot;cvss_score&quot;: 2,\r\n            &quot;module&quot;: &quot;lodash&quot;,\r\n            &quot;version&quot;: &quot;3.10.1&quot;\r\n        }\r\n    ]&#39;\r\n\r\nHow can I remove &quot;overview&quot; field and values from this string. Because when I am trying to convert this string into a JSON object using &quot;${JsonOutput.toJson(result)}&quot; It gives me parse error because this overview section is having {}.\r\n\r\nThis is what i tried \r\n\r\n    result=result | sed &#39;s/&quot;overview&quot;:*\\\\(&quot;,&quot;\\)/\\\\1/g&#39;\r\n\r\nCan anyone help me here please.\r\n\r\nAbove string should look like this\r\n\r\n\r\n\r\n    [\r\n        {\r\n            &quot;id&quot;: 668,\r\n            &quot;recommendation&quot;: &quot;No fix is currently available for this vulnerability. It is our recommendation to not install or use this module at this time if you allow user input into href values.&quot;,\r\n            &quot;cvss_vector&quot;: &quot;CVSS:3.0/AV:N/AC:L/PR:N/UI:R/S:C/C:H/I:H/A:N&quot;,\r\n            &quot;cvss_score&quot;: 9.3,\r\n            &quot;module&quot;: &quot;react-marked-markdown&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: 577,\r\n            &quot;recommendation&quot;: &quot;Update to version 4.17.5 or later.&quot;,\r\n            &quot;cvss_vector&quot;: null,\r\n            &quot;cvss_score&quot;: 2,\r\n            &quot;module&quot;: &quot;lodash&quot;,\r\n            &quot;version&quot;: &quot;3.10.1&quot;\r\n        }\r\n    ]\r\n\r\n\r\nSo that i can convert it into a JSON object.",
        "link": "https://stackoverflow.com/questions/50974532/how-to-remove-substring-from-a-json-string",
        "title": "How to remove substring from a JSON string"
    },
    {
        "tags": [
            "json",
            "filter",
            "jq",
            "data-transform"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1529630641,
                "creation_date": 1529630641,
                "answer_id": 50979413,
                "question_id": 50978470,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are many possibilities, but the following filter, which uses a &quot;generate and test&quot; approach, does produce the desired result and illustrates some possible techniques:\r\n\r\n    .data.products[]\r\n    | {title} + (.skus[] | {color} + (.details | {longDescription}))\r\n    | select(.longDescription | contains(&quot;keywordA&quot;))\r\n",
                "title": "Filter a nested json by a key value using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1529634383,
        "creation_date": 1529621694,
        "last_edit_date": 1529634383,
        "question_id": 50978470,
        "body_markdown": "Novice jq user here, trying to filter a nested json using jq.\r\n\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;products&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;1&quot;,\r\n            &quot;title&quot;: &quot;item01&quot;,\r\n            &quot;description&quot;: &quot;item01 description&quot;,\r\n            &quot;skus&quot;: [\r\n              {\r\n                &quot;color&quot;: &quot;blue&quot;,\r\n                &quot;precision&quot;: 2,\r\n                &quot;details&quot;: {\r\n                  &quot;longDescription&quot;: &quot;This a long description with a keywordA&quot;\r\n                }\r\n              },\r\n              {\r\n                &quot;color&quot;: &quot;green&quot;,\r\n                &quot;precision&quot;: 1,\r\n                &quot;details&quot;: {\r\n                  &quot;longDescription&quot;: &quot;&quot;\r\n                }\r\n              }\r\n            ]\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;2&quot;,\r\n            &quot;title&quot;: &quot;item02&quot;,\r\n            &quot;description&quot;: &quot;item02 description&quot;,\r\n            &quot;skus&quot;: [\r\n              {\r\n                &quot;color&quot;: &quot;red&quot;,\r\n                &quot;precision&quot;: 2,\r\n                &quot;details&quot;: {\r\n                  &quot;longDescription&quot;: &quot;&quot;\r\n                }\r\n              },\r\n              {\r\n                &quot;color&quot;: &quot;yellow&quot;,\r\n                &quot;precision&quot;: 1,\r\n                &quot;details&quot;: {\r\n                  &quot;longDescription&quot;: &quot;&quot;\r\n                }\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nDesired output:\r\n\r\n    {\r\n      &quot;title&quot;: &quot;item01&quot;,\r\n      &quot;color&quot;: &quot;blue&quot;,\r\n      &quot;longDescription&quot;: &quot;This a long description with a keywordA&quot;\r\n    }\r\n\r\nI am able to get the title and the description `jq &#39;.data.products[] | {title: .title, longDescription: .skus[].details.longDescription } | select(.longDescription | contains(&quot;keywordA&quot;) )&#39;`\r\nResult:\r\n\r\n    {\r\n      &quot;title&quot;: &quot;item01&quot;,\r\n      &quot;longDescription&quot;: &quot;This a long description with a keywordA&quot;\r\n    }\r\n\r\nHowever, if I include color in the filter, I get inaccurate data.\r\n`jq &#39;.data.products[] | {title: .title, color:.skus[].color, longDescription: .skus[].details.longDescription } | select(.longDescription | contains(&quot;keywordA&quot;) )&#39;`\r\n\r\n    {\r\n      &quot;title&quot;: &quot;item01&quot;,\r\n      &quot;color&quot;: &quot;blue&quot;,\r\n      &quot;longDescription&quot;: &quot;This a long description with a keywordA&quot;\r\n    }\r\n    {\r\n      &quot;title&quot;: &quot;item01&quot;,\r\n      &quot;color&quot;: &quot;green&quot;,\r\n      &quot;longDescription&quot;: &quot;This a long description with a keywordA&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/50978470/filter-a-nested-json-by-a-key-value-using-jq",
        "title": "Filter a nested json by a key value using jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1529666691,
                "last_edit_date": 1529666691,
                "creation_date": 1529665922,
                "answer_id": 50986672,
                "question_id": 50986055,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. Your code is buggy, because `keys` sorts the keys.  What&#39;s needed here is `keys_unsorted`.\r\n\r\n2. If you want to accomplish everything in a single invocation of jq, you cannot start the pipeline with `result.fields[]`.\r\n\r\n3. The following does avoid one very small inefficiency of your approach:\r\n\r\n```\r\n    .result.fields\r\n    | (.[0] | keys_unsorted), \r\n      (.[] | [.[] | tostring])\r\n    | @csv\r\n```\r\n",
                "title": "Fine tuning jq filters to reduce repetition in filter string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1529666691,
        "creation_date": 1529663663,
        "question_id": 50986055,
        "body_markdown": "I have a complex JSON object produced from an API call (full JSON found in this [gist][1]). It&#39;s describing attributes of an entity (fields, parameters, child relationships, etc.). Using `jq`, I&#39;m trying to extract just one child field array and convert it to CSV where field keys are a single header row and values of each array item form the subsequent rows. (NOTE: fields are uniform across all items in the array.) \r\n\r\nSo far I&#39;m successful, but I feel as if my `jq` filter string could be better as there is a repetition of unpacking this array in two separate filters. \r\n\r\nHere is a redacted version of the JSON for reference: \r\n\r\n        {\r\n            ...\r\n            &quot;result&quot;: {\r\n                ... \r\n                &quot;fields&quot;: [\r\n                    {\r\n                        &quot;aggregatable&quot;: true,\r\n                        &quot;aiPredictionField&quot;: false,\r\n                        &quot;autoNumber&quot;: false,\r\n                        &quot;byteLength&quot;: 18,\r\n                        &quot;name&quot;: &quot;Id&quot;,\r\n                        ...\r\n                    },\r\n                    {\r\n                        &quot;aggregatable&quot;: true,\r\n                        &quot;aiPredictionField&quot;: false,\r\n                        &quot;autoNumber&quot;: false,\r\n                        &quot;byteLength&quot;: 18,\r\n                        &quot;name&quot;: &quot;OwnerId&quot;,\r\n                        ... \r\n                    },\r\n                    {\r\n                        &quot;aggregatable&quot;: false,\r\n                        &quot;aiPredictionField&quot;: false,\r\n                        &quot;autoNumber&quot;: false,\r\n                        &quot;byteLength&quot;: 0,\r\n                        &quot;name&quot;: &quot;IsDeleted&quot;,\r\n                        ...\r\n                    },\r\n                    ...\r\n                ],\r\n                ...\r\n            }\r\n        }\r\n\r\nSo far, here is the working command: \r\n\r\n    jq -r &#39;.result.fields | (.[0] | keys) , .[] | [.[] | tostring] | @csv&#39;\r\n\r\n    repeated array unpacking---^-------------^\r\n\r\nI could be happy with this, but I would prefer to unpack the `result.fields` array in the first filter so that it starts out like this: \r\n\r\n    jq -r &#39;.result.fields[] | ...\r\n\r\nOnly then there is no longer an array, just a set of objects. I tried several things but none of them gave me what I wanted. Here two things I tried before I realized that unpacking `.result.fields[]` destroyed anything array-like for me to work with (yep...slow learner here, and can be a bit thick):\r\n\r\n    jq -r &#39;.result.fields[] | ( keys | .[0] ) , [.[] | tostring] | @csv&#39;\r\n    jq -r &#39;.result.fields[] |  keys[0]  , [.[] | tostring] | @csv&#39; \r\n\r\nSo the real question is: can I unpack `result.fields` once and then work with what that gives me? And if not, is there a more efficient way to arrive at the CSV structure I&#39;m looking for? \r\n\r\n  [1]: https://gist.github.com/pchittum/eb28adc39cd7c95b51489805a409204e",
        "link": "https://stackoverflow.com/questions/50986055/fine-tuning-jq-filters-to-reduce-repetition-in-filter-string",
        "title": "Fine tuning jq filters to reduce repetition in filter string"
    },
    {
        "tags": [
            "bash",
            "docker",
            "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": 1529696123,
                "post_id": 50992645,
                "comment_id": 88983677,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 518507,
                    "reputation": 389,
                    "user_id": 1044619,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/279b6b6c71c95561bb894c693f5285ff?s=256&d=identicon&r=PG",
                    "display_name": "sosukeinu",
                    "link": "https://stackoverflow.com/users/1044619/sosukeinu"
                },
                "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": 1529762339,
                "post_id": 50992645,
                "comment_id": 88997500,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1529970177,
                "post_id": 50992645,
                "comment_id": 89058452,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1529970472,
                "post_id": 50992645,
                "comment_id": 89058503,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 518507,
                    "reputation": 389,
                    "user_id": 1044619,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/279b6b6c71c95561bb894c693f5285ff?s=256&d=identicon&r=PG",
                    "display_name": "sosukeinu",
                    "link": "https://stackoverflow.com/users/1044619/sosukeinu"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530022716,
                "post_id": 50992645,
                "comment_id": 89081381,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530023871,
                "post_id": 50992645,
                "comment_id": 89082176,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 518507,
                    "reputation": 389,
                    "user_id": 1044619,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/279b6b6c71c95561bb894c693f5285ff?s=256&d=identicon&r=PG",
                    "display_name": "sosukeinu",
                    "link": "https://stackoverflow.com/users/1044619/sosukeinu"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530025205,
                "post_id": 50992645,
                "comment_id": 89083058,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 518507,
                    "reputation": 389,
                    "user_id": 1044619,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/279b6b6c71c95561bb894c693f5285ff?s=256&d=identicon&r=PG",
                    "display_name": "sosukeinu",
                    "link": "https://stackoverflow.com/users/1044619/sosukeinu"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530026096,
                "post_id": 50992645,
                "comment_id": 89083611,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530026728,
                "post_id": 50992645,
                "comment_id": 89084011,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 518507,
                    "reputation": 389,
                    "user_id": 1044619,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/279b6b6c71c95561bb894c693f5285ff?s=256&d=identicon&r=PG",
                    "display_name": "sosukeinu",
                    "link": "https://stackoverflow.com/users/1044619/sosukeinu"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530027197,
                "post_id": 50992645,
                "comment_id": 89084302,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1529940953,
                "last_edit_date": 1529940953,
                "creation_date": 1529764992,
                "answer_id": 51002233,
                "question_id": 50992645,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "(1) I have verified that using bash, the sequence:\r\n\r\n    addJson=&#39;{ id: &quot;ee6b1042efee4fb07d2fe1a5079ce498567e6f5ac849413f0e623d4582da5bc9&quot;,\r\n      parent: &quot;80a2fb00dfe137a28c24fbc39fde656650cd68028d612e6f33912902d887b108&quot; }&#39;\r\n\r\n    jq &quot;$addJson + .&quot; configFile &gt; layerId.json\r\n\r\nsucceeds, where configFile has the contents shown in the updated question.\r\n\r\n(2) Similarly, I have verified that the following also succeeds:\r\n\r\n    imageOldConfig=&quot;$(jq --raw-output --compact-output &#39;{ id: .id } + if .parent then { parent: .parent } else {} end&#39; layerId.json)&quot;\r\n\r\n    jq --raw-output &quot;$imageOldConfig + del(.history, .rootfs)&quot; &lt;&lt;-&#39;EOJSON&#39;\r\n    &lt;JSON as in the question&gt;\r\n    EOJSON\r\n\r\nwhere `&lt;JSON as in the question&gt;` stands for the JSON shown in the question.\r\n\r\n(3) In general, it is not a good idea to pass shell $-variables into jq programs by shell string interpolation.\r\n\r\nFor example, rather than writing:\r\n\r\n    jq --raw-output &quot;$imageOldConfig + del(.history, .rootfs)&quot;\r\n\r\nit would be much better to write something like:\r\n\r\n    jq --raw-output --argjson imageOldConfig &quot;$imageOldConfig&quot; &#39;\r\n        $imageOldConfig + del(.history, .rootfs)&#39;\r\n",
                "title": "Docker Image Download with download-frozen-image-v2.sh on Windows"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1530125821,
                "last_edit_date": 1530125821,
                "creation_date": 1530058264,
                "answer_id": 51052892,
                "question_id": 50992645,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I can&#39;t tell you why this happens but it appears to be a problem with how jq parses the input file. It&#39;s segfaulting when reading the file. It&#39;s a [known issue](https://github.com/stedolan/jq/issues/1205) in the windows builds where the problem is triggered by the length of the paths to the files.\r\n\r\nFortunately, there is a way around this issue by modifying the script to [go against all conventional wisdom](http://porkmail.org/era/unix/award.html) and `cat` the file to jq.\r\n\r\nThe script isn&#39;t utilizing jq very well and builds some of the json manually so some additional fixes would be needed. It will have errors regarding `INVALID_CHARACTER` when parsing. It&#39;s probably a manifestation of [this issue](https://github.com/stedolan/jq/issues/1219) since the script is manually building a lot of the jq programs.\r\n\r\nI put up a gist with the [updated file](https://gist.github.com/JeffreyMercado/abf99779d42f9017d358bed9901daf55) that at least doesn&#39;t error out, check to see if it works as expected.\r\n\r\nChanges start at line [172](https://gist.github.com/JeffreyMercado/abf99779d42f9017d358bed9901daf55#file-download-frozen-image-v2-sh-L172) and [342](https://gist.github.com/JeffreyMercado/abf99779d42f9017d358bed9901daf55#file-download-frozen-image-v2-sh-L342).\r\n\r\nThe way it builds the manifest is just messy. I&#39;ve cleaned it up a bit removing all the string interpolations instead passing all parameters in as arguments to jq.\r\n\r\n\t# munge the top layer image manifest to have the appropriate image configuration for older daemons\r\n\tlocal imageOldConfig=&quot;$(cat &quot;$dir/$imageId/json&quot; | jq --raw-output --compact-output &#39;{ id: .id } + if .parent then { parent: .parent } else {} end&#39;)&quot;\r\n\tcat &quot;$dir/$configFile&quot; | jq --raw-output &quot;$imageOldConfig + del(.history, .rootfs)&quot; &gt; &quot;$dir/$imageId/json&quot;\r\n\r\n\tlocal manifestJsonEntry=&quot;$(\r\n\t\tjq --raw-output --compact-output -n \\\r\n\t\t\t--arg configFile &quot;$configFile&quot; \\\r\n\t\t\t--arg repoTags &quot;${image#library\\/}:$tag&quot; \\\r\n\t\t\t--argjson layers &quot;$(IFS=$&#39;\\n&#39;; jq --arg a &quot;${layerFiles[*]}&quot; -n &#39;$a | split(&quot;\\n&quot;)&#39;)&quot; \\\r\n\t\t\t&#39;{\r\n\t\t\t\tConfig: $configFile,\r\n\t\t\t\tRepoTags: [ $repoTags ],\r\n\t\t\t\tLayers: $layers\r\n\t\t\t}&#39;\r\n\t)&quot;",
                "title": "Docker Image Download with download-frozen-image-v2.sh on Windows"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1530125821,
        "creation_date": 1529687070,
        "last_edit_date": 1529940868,
        "question_id": 50992645,
        "body_markdown": "I am working on downloading a Docker Image on an internet-connected Windows machine that does not have (and cannot have) Docker installed on it, to transfer to an non-internet-connected Linux machine that does have Docker. I&#39;m using `git-bash` to run [download-frozen-image-v2.sh](https://github.com/moby/moby/blob/master/contrib/download-frozen-image-v2.sh). Everything is working as expected until the script begins to download the final layer of any given image. On the final layer the json file is being returned empty. Through echo statements, I&#39;m able to see that everything is working flawlessly until *lines 119-142*\r\n\r\n    jq &quot;$addJson + .&quot; &gt; &quot;$dir/$layerId/json&quot; &lt;&lt;-&#39;EOJSON&#39;\r\n    \t\t\t\t{\r\n    \t\t\t\t\t&quot;created&quot;: &quot;0001-01-01T00:00:00Z&quot;,\r\n    \t\t\t\t\t&quot;container_config&quot;: {\r\n    \t\t\t\t\t\t&quot;Hostname&quot;: &quot;&quot;,\r\n    \t\t\t\t\t\t&quot;Domainname&quot;: &quot;&quot;,\r\n    \t\t\t\t\t\t&quot;User&quot;: &quot;&quot;,\r\n    \t\t\t\t\t\t&quot;AttachStdin&quot;: false,\r\n    \t\t\t\t\t\t&quot;AttachStdout&quot;: false,\r\n    \t\t\t\t\t\t&quot;AttachStderr&quot;: false,\r\n    \t\t\t\t\t\t&quot;Tty&quot;: false,\r\n    \t\t\t\t\t\t&quot;OpenStdin&quot;: false,\r\n    \t\t\t\t\t\t&quot;StdinOnce&quot;: false,\r\n    \t\t\t\t\t\t&quot;Env&quot;: null,\r\n    \t\t\t\t\t\t&quot;Cmd&quot;: null,\r\n    \t\t\t\t\t\t&quot;Image&quot;: &quot;&quot;,\r\n    \t\t\t\t\t\t&quot;Volumes&quot;: null,\r\n    \t\t\t\t\t\t&quot;WorkingDir&quot;: &quot;&quot;,\r\n    \t\t\t\t\t\t&quot;Entrypoint&quot;: null,\r\n    \t\t\t\t\t\t&quot;OnBuild&quot;: null,\r\n    \t\t\t\t\t\t&quot;Labels&quot;: null\r\n    \t\t\t\t\t}\r\n    \t\t\t\t}\r\n    \t\t\tEOJSON\r\n\r\nOnly on the final layer, this code is resulting in an empty json file, which in-turn creates an error in *line 173*\r\n\r\n`jq --raw-output &quot;$imageOldConfig + del(.history, .rootfs)&quot; &quot;$dir/$configFile&quot; &gt; &quot;$dir/$imageId/json&quot;`\r\n\r\n    jq: error: syntax error, unexpected &#39;+&#39;, expecting $end (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n     + del(.history, .rootfs)\r\n    jq: 1 compile error\r\n\r\n**Update**\r\n\r\n****\r\n\r\n**Exact steps to replicate**\r\n\r\nPerform on Windows 10 computer.\r\n\r\n1) Install scoop for Windows [https://scoop.sh/](https://scoop.sh/)\r\n\r\n2) *in Powershell* `scoop install git curl jq go tar`\r\n\r\n3) `git-bash`\r\n\r\n4) *in git-bash* `curl -o download-frozen-image-v2.sh https://raw.githubusercontent.com/moby/moby/master/contrib/download-frozen-image-v2.sh`\r\n\r\n5) `bash download-frozen-image-vs.sh ubuntu ubuntu:latest`\r\n\r\nThe above will result in the aforementioned error.\r\n\r\n****\r\n\r\nin response to @peak below\r\n\r\nThe command I&#39;m using is `bash download-frozen-image-v2.sh ubuntu ubuntu:latest` which should download 5 layers. The first 4 download flawlessly, it is only the last layer that fails. I tried this process for several other images, and it always fails on the final layer.\r\n\r\n**addJson:** \r\n\r\n    { id: &quot;ee6b1042efee4fb07d2fe1a5079ce498567e6f5ac849413f0e623d4582da5bc9&quot;, parent: &quot;80a2fb00dfe137a28c24fbc39fde656650cd68028d612e6f33912902d887b108&quot; }\r\n\r\n**dir/configFile:** \r\n\r\n    ubuntu/113a43faa1382a7404681f1b9af2f0d70b182c569aab71db497e33fa59ed87e6.json\r\n    \r\n**dir/configFile contents:** \r\n\r\n    {\r\n    &quot;architecture&quot;: &quot;amd64&quot;,\r\n      &quot;config&quot;: {\r\n        &quot;Hostname&quot;: &quot;&quot;,\r\n        &quot;Domainname&quot;: &quot;&quot;,\r\n        &quot;User&quot;: &quot;&quot;,\r\n        &quot;AttachStdin&quot;: false,\r\n        &quot;AttachStdout&quot;: false,\r\n        &quot;AttachStderr&quot;: false,\r\n        &quot;Tty&quot;: false,\r\n        &quot;OpenStdin&quot;: false,\r\n        &quot;StdinOnce&quot;: false,\r\n        &quot;Env&quot;: [\r\n          &quot;PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin&quot;\r\n        ],\r\n        &quot;Cmd&quot;: [\r\n          &quot;/bin/bash&quot;\r\n        ],\r\n        &quot;ArgsEscaped&quot;: true,\r\n        &quot;Image&quot;: &quot;sha256:c2775c69594daa3ee360d8e7bbca93c65d9c925e89bd731f12515f9bf8382164&quot;,\r\n        &quot;Volumes&quot;: null,\r\n        &quot;WorkingDir&quot;: &quot;&quot;,\r\n        &quot;Entrypoint&quot;: null,\r\n        &quot;OnBuild&quot;: null,\r\n        &quot;Labels&quot;: null\r\n      },\r\n      &quot;container&quot;: &quot;6713e927cc43b61a4ce3950a69907336ff55047bae9393256e32613a54321c70&quot;,\r\n      &quot;container_config&quot;: {\r\n        &quot;Hostname&quot;: &quot;6713e927cc43&quot;,\r\n        &quot;Domainname&quot;: &quot;&quot;,\r\n        &quot;User&quot;: &quot;&quot;,\r\n        &quot;AttachStdin&quot;: false,\r\n        &quot;AttachStdout&quot;: false,\r\n        &quot;AttachStderr&quot;: false,\r\n        &quot;Tty&quot;: false,\r\n        &quot;OpenStdin&quot;: false,\r\n        &quot;StdinOnce&quot;: false,\r\n        &quot;Env&quot;: [\r\n          &quot;PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin&quot;\r\n        ],\r\n        &quot;Cmd&quot;: [\r\n          &quot;/bin/sh&quot;,\r\n          &quot;-c&quot;,\r\n          &quot;#(nop) &quot;,\r\n          &quot;CMD [\\&quot;/bin/bash\\&quot;]&quot;\r\n        ],\r\n        &quot;ArgsEscaped&quot;: true,\r\n        &quot;Image&quot;: &quot;sha256:c2775c69594daa3ee360d8e7bbca93c65d9c925e89bd731f12515f9bf8382164&quot;,\r\n        &quot;Volumes&quot;: null,\r\n        &quot;WorkingDir&quot;: &quot;&quot;,\r\n        &quot;Entrypoint&quot;: null,\r\n        &quot;OnBuild&quot;: null,\r\n        &quot;Labels&quot;: {}\r\n      },\r\n      &quot;created&quot;: &quot;2018-06-05T21:20:54.310450149Z&quot;,\r\n      &quot;docker_version&quot;: &quot;17.06.2-ce&quot;,\r\n      &quot;history&quot;: [\r\n        {\r\n          &quot;created&quot;: &quot;2018-06-05T21:20:51.286433694Z&quot;,\r\n          &quot;created_by&quot;: &quot;/bin/sh -c #(nop) ADD file:28c0771e44ff530dba3f237024acc38e8ec9293d60f0e44c8c78536c12f13a0b in / &quot;\r\n        },\r\n        {\r\n          &quot;created&quot;: &quot;2018-06-05T21:20:52.045074543Z&quot;,\r\n          &quot;created_by&quot;: &quot;/bin/sh -c set -xe \\t\\t&amp;&amp; echo &#39;#!/bin/sh&#39; &gt; /usr/sbin/policy-rc.d \\t&amp;&amp; echo &#39;exit 101&#39; &gt;&gt; /usr/sbin/policy-rc.d \\t&amp;&amp; chmod +x /usr/sbin/policy-rc.d \\t\\t&amp;&amp; dpkg-divert --local --rename --add /sbin/initctl \\t&amp;&amp; cp -a /usr/sbin/policy-rc.d /sbin/initctl \\t&amp;&amp; sed -i &#39;s/^exit.*/exit 0/&#39; /sbin/initctl \\t\\t&amp;&amp; echo &#39;force-unsafe-io&#39; &gt; /etc/dpkg/dpkg.cfg.d/docker-apt-speedup \\t\\t&amp;&amp; echo &#39;DPkg::Post-Invoke { \\&quot;rm -f /var/cache/apt/archives/*.deb /var/cache/apt/archives/partial/*.deb /var/cache/apt/*.bin || true\\&quot;; };&#39; &gt; /etc/apt/apt.conf.d/docker-clean \\t&amp;&amp; echo &#39;APT::Update::Post-Invoke { \\&quot;rm -f /var/cache/apt/archives/*.deb /var/cache/apt/archives/partial/*.deb /var/cache/apt/*.bin || true\\&quot;; };&#39; &gt;&gt; /etc/apt/apt.conf.d/docker-clean \\t&amp;&amp; echo &#39;Dir::Cache::pkgcache \\&quot;\\&quot;; Dir::Cache::srcpkgcache \\&quot;\\&quot;;&#39; &gt;&gt; /etc/apt/apt.conf.d/docker-clean \\t\\t&amp;&amp; echo &#39;Acquire::Languages \\&quot;none\\&quot;;&#39; &gt; /etc/apt/apt.conf.d/docker-no-languages \\t\\t&amp;&amp; echo &#39;Acquire::GzipIndexes \\&quot;true\\&quot;; Acquire::CompressionTypes::Order:: \\&quot;gz\\&quot;;&#39; &gt; /etc/apt/apt.conf.d/docker-gzip-indexes \\t\\t&amp;&amp; echo &#39;Apt::AutoRemove::SuggestsImportant \\&quot;false\\&quot;;&#39; &gt; /etc/apt/apt.conf.d/docker-autoremove-suggests&quot;\r\n        },\r\n        {\r\n          &quot;created&quot;: &quot;2018-06-05T21:20:52.712120056Z&quot;,\r\n          &quot;created_by&quot;: &quot;/bin/sh -c rm -rf /var/lib/apt/lists/*&quot;\r\n        },\r\n        {\r\n          &quot;created&quot;: &quot;2018-06-05T21:20:53.405342638Z&quot;,\r\n          &quot;created_by&quot;: &quot;/bin/sh -c sed -i &#39;s/^#\\\\s*\\\\(deb.*universe\\\\)$/\\\\1/g&#39; /etc/apt/sources.list&quot;\r\n        },\r\n        {\r\n          &quot;created&quot;: &quot;2018-06-05T21:20:54.091704323Z&quot;,\r\n          &quot;created_by&quot;: &quot;/bin/sh -c mkdir -p /run/systemd &amp;&amp; echo &#39;docker&#39; &gt; /run/systemd/container&quot;\r\n        },\r\n        {\r\n          &quot;created&quot;: &quot;2018-06-05T21:20:54.310450149Z&quot;,\r\n          &quot;created_by&quot;: &quot;/bin/sh -c #(nop)  CMD [\\&quot;/bin/bash\\&quot;]&quot;,\r\n          &quot;empty_layer&quot;: true\r\n        }\r\n      ],\r\n      &quot;os&quot;: &quot;linux&quot;,\r\n      &quot;rootfs&quot;: {\r\n        &quot;type&quot;: &quot;layers&quot;,\r\n        &quot;diff_ids&quot;: [\r\n          &quot;sha256:db9476e6d963ed2b6042abef1c354223148cdcdbd6c7416c71a019ebcaea0edb&quot;,\r\n          &quot;sha256:3a89e0d8654e098e949764b1cb23018e27f299b0931c5fd41c207d610ff356c4&quot;,\r\n          &quot;sha256:904d60939c360b5f528b886c1b534855a008f9a7fd411d4977e09aa7de74c834&quot;,\r\n          &quot;sha256:a20a262b87bd8a00717f3b30c001bcdaf0fd85d049e6d10500597caa29c013c5&quot;,\r\n          &quot;sha256:b6f13d447e00fba3b9bd10c1e5c6697e913462f44aa24af349bfaea2054e32f4&quot;\r\n        ]\r\n      }\r\n    }\r\n\r\n\r\nAny help in figuring out what is occurring here would be greatly appreciated.\r\n\r\nThank you.\r\n",
        "link": "https://stackoverflow.com/questions/50992645/docker-image-download-with-download-frozen-image-v2-sh-on-windows",
        "title": "Docker Image Download with download-frozen-image-v2.sh on Windows"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1529708724,
                "creation_date": 1529708724,
                "answer_id": 50996522,
                "question_id": 50996434,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do something like this:\r\n\r\nSyntax `jq &#39;.keyName&lt;array/single value&gt;&#39;`\r\n\r\n    cat file.json | jq &#39;.cars[]&#39; // retunts array of cars\r\n    cat file.json | jq &#39;.cars[].name&#39; // retunts list of names\r\n    cat file.json | jq &#39;.cars[].models[]&#39; // retunts array of car models\r\n\r\n",
                "title": "Select value in array Json using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1529710452,
                "creation_date": 1529710452,
                "answer_id": 50996694,
                "question_id": 50996434,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With this filter in the file cars.jq:\r\n\r\n    .cars[]\r\n    | select(.models|index($model))\r\n    | .name\r\n\r\nand your JSON in cars.json, the invocation:\r\n\r\n    jq --arg model Panda -f cars.jq cars.json\r\n\r\nyields:\r\n\r\n    &quot;Fiat&quot;\r\n\r\nOf course there are many other ways in which the model name can be passed in to the jq program.\r\n\r\nAs a one-liner:\r\n\r\n    jq --arg model Panda &#39;.cars[] | select(.models|index($model)) | .name&#39; cars.json",
                "title": "Select value in array Json using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1529711831,
                "creation_date": 1529711831,
                "answer_id": 50996798,
                "question_id": 50996434,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t know why you are requesting jq. In plain vanilla Javascript, the solution is very simple. I don&#39;t know if this is the most efficient way, but I would recommend a simple, easy to understand plain vanilla solution over anything else. Unless efficiency is an issue and a sufficiently more efficient solution can be found. Here, I&#39;ve hardcoded the model &quot;Focus&quot; in the function call and this returns the name &quot;Ford&quot;.\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-html --&gt;\r\n\r\n    &lt;html&gt;\r\n        &lt;head&gt;\r\n            &lt;script&gt;\r\n                function getNameOfModel(model) {\r\n                    var nameOfModel = &quot;Unknown&quot;;\r\n                    var jsonData = {&quot;cars&quot;: [\r\n                        { &quot;name&quot;:&quot;Ford&quot;, &quot;models&quot;:[ &quot;Fiesta&quot;, &quot;Focus&quot;, &quot;Mustang&quot; ] },\r\n                        { &quot;name&quot;:&quot;BMW&quot;, &quot;models&quot;:[ &quot;320&quot;, &quot;X3&quot;, &quot;X5&quot; ] },\r\n                        { &quot;name&quot;:&quot;Fiat&quot;, &quot;models&quot;:[ &quot;500&quot;, &quot;Panda&quot; ] }\r\n                        ]};\r\n                    var jsonArray = jsonData[&quot;cars&quot;];\r\n                    var i = 0;\r\n                    while (i &lt; jsonArray.length) {\r\n                        if (jsonArray[i][&quot;models&quot;].includes(model)) {\r\n                            nameOfModel = jsonArray[i][&quot;name&quot;];\r\n                            i = jsonArray.length;\r\n                        }\r\n                        i++;\r\n                    }\r\n                    document.getElementById(&quot;carName&quot;).innerHTML = nameOfModel;\r\n                }            \r\n            &lt;/script&gt;\r\n        &lt;/head&gt;\r\n        &lt;body&gt;\r\n            &lt;div&gt;&lt;p id=&quot;carName&quot;&gt;&lt;/p&gt;&lt;/div&gt;\r\n            &lt;script&gt;getNameOfModel(&quot;Focus&quot;);&lt;/script&gt;\r\n        &lt;/body&gt;\r\n    &lt;/html&gt;\r\n\r\n&lt;!-- end snippet --&gt;\r\n",
                "title": "Select value in array Json using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1529711831,
        "creation_date": 1529707885,
        "question_id": 50996434,
        "body_markdown": "I have one json file.\r\n\r\n    {\r\n    &quot;cars&quot;: \r\n    [\r\n        { &quot;name&quot;:&quot;Ford&quot;, &quot;models&quot;:[ &quot;Fiesta&quot;, &quot;Focus&quot;, &quot;Mustang&quot; ] },\r\n        { &quot;name&quot;:&quot;BMW&quot;, &quot;models&quot;:[ &quot;320&quot;, &quot;X3&quot;, &quot;X5&quot; ] },\r\n        { &quot;name&quot;:&quot;Fiat&quot;, &quot;models&quot;:[ &quot;500&quot;, &quot;Panda&quot; ] }\r\n    ]\r\n    }\r\n\r\nI need to give one of the models as input and I want the corresponding name of the car will be the output.\r\n\r\nUsing jq, I wish to achieve. Please help.\r\n",
        "link": "https://stackoverflow.com/questions/50996434/select-value-in-array-json-using-jq",
        "title": "Select value in array Json using jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "command-line-interface",
            "key-value",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1529893879,
                "last_edit_date": 1529893879,
                "creation_date": 1529739175,
                "answer_id": 50999016,
                "question_id": 50997834,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. The given data is not valid JSON but it is valid [HJSON][1], so the first step in the following jq-oriented solution is to use hjson to convert the data to JSON:\r\n\r\n    `hjson -j input.hjson `\r\n\r\n2. The concept of what values should be regarded as &quot;null&quot; might change over time, so in the following let&#39;s define a filter that can be used to capture whichever definition is appropriate, e.g.\r\n```\r\n    def isnull: . == null or (type==&quot;string&quot; and test(&quot;null&quot;)); \r\n```\r\n\r\n(Perhaps a better definition would use `test(&quot;^ *null *$&quot;)`.)\r\n\r\n3. If you want to delete all keys whose value `isnull`, you could use `walk/1`:\r\n\r\n```\r\n    walk(if type==&quot;object&quot;\r\n         then with_entries(select(.value|isnull|not))\r\n         else . end)\r\n```\r\n\r\n(If your jq does not have walk, you could simply copy-and-paste its definition from https://github.com/stedolan/jq/blob/master/src/builtin.jq or elsewhere on the web.)\r\n\r\nAssuming your jq has `walk`, we could therefore write:\r\n\r\n    hjson -j input.hjson |\r\n      jq &#39;def isnull: . == null or (type==&quot;string&quot; and test(&quot;null&quot;)); \r\n          walk(if type==&quot;object&quot; \r\n               then with_entries(select(.value|isnull|not))\r\n               else . end)&#39;\r\n\r\n4. If you want to &quot;walk&quot; the input but restrict attention to specific keys, you can easily modify the selection criterion in (3).\r\n\r\n### delkey\r\n\r\nIf you want the scope of the changes to be as narrow as possible, you could use `map_values`, e.g. in conjunction with a helper function for checking and possibly deleting a specific key:\r\n\r\n      # key is assumed to be a filter, e.g. .foo\r\n      def delkey(key): if key | isnull then del(key) else . end;\r\n      .dets |= map_values(.config |= (delkey(.th) | delkey(.sf)))\r\n\r\n### delkeys\r\n\r\nIf there are several specific keys to be checked, it might be more convenient to define a function for checking a list of keys:\r\n     \r\n    # keys is assumed to be an array of strings\r\n    def delkeys(keys):\r\n      with_entries(select(.key as $k\r\n        | (keys|index($k)) and (.value|isnull) | not));\r\n        \r\n    .dets |= map_values(.config |= delkeys([&quot;th&quot;, &quot;sf&quot;]))\r\n\r\n\r\n  [1]: http://hjson.org/",
                "title": "using jq delete key value pair when value contains a specific string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1529893879,
        "creation_date": 1529726595,
        "last_edit_date": 1529742313,
        "question_id": 50997834,
        "body_markdown": "Using jq I need to delete a specific key:value pair if value contains string &quot;null&quot;. The string could be &quot; null&quot; or &quot;null &quot;. Hence need to use contains and not exact string match. If not a string it will be a number\r\n\r\nMy sample json is as below: (The null value is expected only in the &#39;th&#39; and &#39;sf&#39; keys)\r\n\r\n    &#39;dets&#39;:{\r\n       &#39;S1&#39;:{\r\n            &#39;type&#39;:&#39;class&#39;,\r\n            &#39;input&#39;: [12,7,6,19],\r\n            &#39;config&#39;:{\r\n                    &#39;file&#39;:&#39;sfile1&#39;,\r\n                     &#39;th&#39;: -10,\r\n                     &#39;sf&#39;: &#39;null&#39;\r\n                    }\r\n             },\r\n        &#39;S2&#39;:{\r\n            &#39;type&#39;:&#39;class&#39;,\r\n            &#39;input&#39;: [12,7,6,19],\r\n            &#39;config&#39;:{\r\n                    &#39;file&#39;:&#39;sfile2&#39;,\r\n                     &#39;th&#39;: -5,\r\n                     &#39;sf&#39;: 3\r\n                    }\r\n             },\r\n        &#39;S3&#39;:{\r\n            &#39;type&#39;:&#39;bottom&#39;,\r\n            &#39;input&#39;: [12,7,16],\r\n            &#39;config&#39;:{\r\n                    &#39;file&#39;:&#39;sfile3&#39;,\r\n                     &#39;th&#39;: &#39; null&#39;,\r\n                     &#39;sf&#39;: &#39;null &#39;\r\n                    }\r\n             }\r\n        }\r\n\r\nThe required output should be like:\r\n\r\n        &#39;dets&#39;:{\r\n       &#39;S1&#39;:{\r\n            &#39;type&#39;:&#39;class&#39;,\r\n            &#39;input&#39;: [12,7,6,19],\r\n            &#39;config&#39;:{\r\n                    &#39;file&#39;:&#39;sfile1&#39;,\r\n                     &#39;th&#39;: -10\r\n                    }\r\n             },\r\n        &#39;S2&#39;:{\r\n            &#39;type&#39;:&#39;class&#39;,\r\n            &#39;input&#39;: [12,7,6,19],\r\n            &#39;config&#39;:{\r\n                    &#39;file&#39;:&#39;sfile2&#39;,\r\n                     &#39;th&#39;: -5,\r\n                     &#39;sf&#39;: 3\r\n                    }\r\n             },\r\n        &#39;S3&#39;:{\r\n            &#39;type&#39;:&#39;bottom&#39;,\r\n            &#39;input&#39;: [12,7,16],\r\n            &#39;config&#39;:{\r\n                    &#39;file&#39;:&#39;sfile3&#39;\r\n                    }\r\n             }\r\n        }\r\n\r\nI believe something on the lines of del(.[][].config.smoothing_span | select(contains(&quot;null&quot;))) but i am running into a problem since type is different.",
        "link": "https://stackoverflow.com/questions/50997834/using-jq-delete-key-value-pair-when-value-contains-a-specific-string",
        "title": "using jq delete key value pair when value contains a specific string"
    },
    {
        "tags": [
            "arguments",
            "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": 1530024308,
                "post_id": 51043662,
                "comment_id": 89082450,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1530020670,
                "creation_date": 1530020670,
                "answer_id": 51044427,
                "question_id": 51043662,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Security wise, it&#39;s a bad idea to pass password in command line, but I hope you know what you&#39;re doing. \r\n\r\nAssuming that, you need to modify your `jq` command like this:\r\n\r\n    jq --arg p &quot;password&quot; &#39;.password = $p | .basicAuthPassword =  $p&#39; &lt; input.json\r\n\r\n",
                "title": "Create a json file using jq and multiple variables"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1530024168,
                "creation_date": 1530024168,
                "answer_id": 51045653,
                "question_id": 51043662,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the password is already an environment variable (which may not be such a good idea though), then to avoid exposing it on the command-line, you could use the `env` builtin, along the lines of:\r\n\r\n    .password = env.password\r\n\r\netc.\r\n\r\nAn alternative to consider would be putting the password into a temporary file, and then using the --argfile command-line option, for example.  Or if your shell supports it, `--argfile pw &lt;(echo &quot;\\&quot;$password\\&quot;&quot;)`",
                "title": "Create a json file using jq and multiple variables"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1530024168,
        "creation_date": 1530018320,
        "last_edit_date": 1530019957,
        "question_id": 51043662,
        "body_markdown": "I have a json file like this:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;Job&quot;,\r\n      &quot;type&quot;: &quot;xdb&quot;,\r\n      &quot;typeLogoUrl&quot;: &quot;public/app/plugins/logo.svg&quot;,\r\n      &quot;access&quot;: &quot;proxy&quot;,\r\n      &quot;url&quot;: &quot;http://xdb:80&quot;,\r\n      &quot;password&quot;: {},\r\n      &quot;user&quot;: &quot;xx&quot;,\r\n      &quot;database&quot;: &quot;Job&quot;,\r\n      &quot;basicAuth&quot;: true,\r\n      &quot;basicAuthUser&quot;: &quot;xx&quot;,\r\n      &quot;basicAuthPassword&quot;: {},\r\n      &quot;withCredentials&quot;: true,\r\n      &quot;isDefault&quot;: false,\r\n      &quot;jsonData&quot;: {},\r\n      &quot;secureJsonFields&quot;: null\r\n    }\r\n\r\nNow all I want is to pass environment variables to key password and basicAuthPassword and to generate new json file as below:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;Job&quot;,\r\n      &quot;type&quot;: &quot;xdb&quot;,\r\n      &quot;typeLogoUrl&quot;: &quot;public/app/plugins/logo.svg&quot;,\r\n      &quot;access&quot;: &quot;proxy&quot;,\r\n      &quot;url&quot;: &quot;http://xdb:80&quot;,\r\n      &quot;password&quot;: &quot;password&quot; ,\r\n      &quot;user&quot;: &quot;xx&quot;,\r\n      &quot;database&quot;: &quot;Job&quot;,\r\n      &quot;basicAuth&quot;: true,\r\n      &quot;basicAuthUser&quot;: &quot;xx&quot;,\r\n      &quot;basicAuthPassword&quot;: &quot;password&quot;,\r\n      &quot;withCredentials&quot;: true,\r\n      &quot;isDefault&quot;: false,\r\n      &quot;jsonData&quot;: {},\r\n      &quot;secureJsonFields&quot;: null\r\n    }\r\n\r\nI have tried like below to replace at least one key and it&#39;s giving me null.\r\n\r\n    /usr/local/bin/jq -n --arg &quot;password&quot; &#39;.password = $arg&#39; &lt; input.json\r\n\r\nCan anyone suggest me how to achieve this?",
        "link": "https://stackoverflow.com/questions/51043662/create-a-json-file-using-jq-and-multiple-variables",
        "title": "Create a json file using jq and multiple variables"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530056530,
                "post_id": 51051719,
                "comment_id": 89096478,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10264917,
                    "reputation": 85,
                    "user_id": 7575178,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/64f85c6cfd721ce7dc79bcafc43e96ba?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "L. Howes",
                    "link": "https://stackoverflow.com/users/7575178/l-howes"
                },
                "reply_to_user": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530085789,
                "post_id": 51051719,
                "comment_id": 89104913,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1541624012,
                "creation_date": 1541624012,
                "answer_id": 53197645,
                "question_id": 51051719,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you want something like this:\r\n\r\n\r\n    # Print out your top example input\r\n    echo &#39;{&quot;id&quot;:319,&quot;policyItems&quot;:[{&quot;accesses&quot;:[{&quot;type&quot;:&quot;consume&quot;,&quot;isAllowed&quot;:true},{&quot;type&quot;:&quot;create&quot;,&quot;isAllowed&quot;:true}],&quot;users&quot;:[&quot;foo&quot;],&quot;groups&quot;:[]},{&quot;accesses&quot;:[{&quot;type&quot;:&quot;publish&quot;,&quot;isAllowed&quot;:true},{&quot;type&quot;:&quot;create&quot;,&quot;isAllowed&quot;:true}],&quot;users&quot;:[],&quot;groups&quot;:[&quot;bar&quot;]}]}\r\n    {&quot;id&quot;:320,&quot;policyItems&quot;:[{&quot;accesses&quot;:[{&quot;type&quot;:&quot;publish&quot;,&quot;isAllowed&quot;:true},{&quot;type&quot;:&quot;create&quot;,&quot;isAllowed&quot;:true}],&quot;users&quot;:[&quot;foo&quot;],&quot;groups&quot;:[]},{&quot;accesses&quot;:[{&quot;type&quot;:&quot;consume&quot;,&quot;isAllowed&quot;:true},{&quot;type&quot;:&quot;create&quot;,&quot;isAllowed&quot;:true}],&quot;users&quot;:[],&quot;groups&quot;:[&quot;bar&quot;]}]}&#39; \\\r\n    | jq -n &#39;[inputs | .id as $id | .policyItems[] | {&quot;id&quot;: $id, &quot;access_type&quot;: (reduce .accesses[].type as $item ([]; . + [$item])), &quot;users_groups&quot;: (.users + .groups)}]&#39;\r\n\r\nHere&#39;s what&#39;s happening:\r\n\r\n * `echo &#39;{&quot;id&quot;:...` We are echoing out your input\r\n * `| jq` Piping that to `jq` \r\n * `jq -n &#39;[inputs | ...]` We accept the echoed input into `jq` as a streaming filter `inputs` (instead of `.`) so that we process the entire input all at once in order to wrap the result in the outer brackets. \r\n  * The `-n` is important here because it instructs `jq` not use piped input implicitly.\r\n * `.id as $id` We save off the parent ID into the `$id` variable for future reference\r\n * `| policyItems[]` We are iterating over the policyItems array, which is what you seem to want to group your results by\r\n * `| {&quot;id&quot;: $id, ...` Here we are beginning to construct the results, and referring back to the `$id` we saved off.\r\n * `&quot;access_type&quot;: (reduce .accesses[].type as $item ([]; . + [$item])), ...` Here we use the `reduce` filter to combine the access types into a single array\r\n * ` &quot;users_groups&quot;: (.users + .groups)}` And we finally combine the `&quot;users&quot;` and `&quot;groups&quot;` arrays into one single array\r\n\r\nAll off this allows us to return an output like:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 319,\r\n        &quot;access_type&quot;: [\r\n          &quot;consume&quot;,\r\n          &quot;create&quot;\r\n        ],\r\n        &quot;users_groups&quot;: [\r\n          &quot;foo&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: 319,\r\n        &quot;access_type&quot;: [\r\n          &quot;publish&quot;,\r\n          &quot;create&quot;\r\n        ],\r\n        &quot;users_groups&quot;: [\r\n          &quot;bar&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: 320,\r\n        &quot;access_type&quot;: [\r\n          &quot;publish&quot;,\r\n          &quot;create&quot;\r\n        ],\r\n        &quot;users_groups&quot;: [\r\n          &quot;foo&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: 320,\r\n        &quot;access_type&quot;: [\r\n          &quot;consume&quot;,\r\n          &quot;create&quot;\r\n        ],\r\n        &quot;users_groups&quot;: [\r\n          &quot;bar&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\n\r\n",
                "title": "JQ getting incorrect output for nested arrays"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1541624012,
        "creation_date": 1530049201,
        "last_edit_date": 1530085742,
        "question_id": 51051719,
        "body_markdown": "I&#39;m trying to use JQ to convert a json file into a csv file. I&#39;ve managed to do this for the file, but during testing I&#39;ve found the output is not as expected. Please could you help as I&#39;ve spent hours and hours trying to fix it but can&#39;t seem to get there.\r\n\r\nIdeally I&#39;d also like to combine the users and groups into one, but I can live without that.\r\n\r\nThis is a cut down version of my json file.\r\n\r\n    [\r\n\t  {\r\n\t\t&quot;id&quot;: 319,\r\n\t\t&quot;policyItems&quot;: [\r\n\t\t  {\r\n\t\t\t&quot;accesses&quot;: [\r\n\t\t\t  {\r\n\t\t\t\t&quot;type&quot;: &quot;consume&quot;,\r\n\t\t\t\t&quot;isAllowed&quot;: true\r\n\t\t\t  },\r\n\t\t\t  {\r\n\t\t\t\t&quot;type&quot;: &quot;create&quot;,\r\n\t\t\t\t&quot;isAllowed&quot;: true\r\n\t\t\t  }\r\n\t\t\t],\r\n\t\t\t&quot;users&quot;: [\r\n\t\t\t  &quot;foo&quot;\r\n\t\t\t],\r\n\t\t\t&quot;groups&quot;: []\r\n\t\t  },\r\n\t\t  {\r\n\t\t\t&quot;accesses&quot;: [\r\n\t\t\t  {\r\n\t\t\t\t&quot;type&quot;: &quot;publish&quot;,\r\n\t\t\t\t&quot;isAllowed&quot;: true\r\n\t\t\t  },\r\n\t\t\t  {\r\n\t\t\t\t&quot;type&quot;: &quot;create&quot;,\r\n\t\t\t\t&quot;isAllowed&quot;: true\r\n\t\t\t  }\r\n\t\t\t],\r\n\t\t\t&quot;users&quot;: [],\r\n\t\t\t&quot;groups&quot;: [\r\n\t\t\t  &quot;bar&quot;\r\n\t\t\t]\r\n\t\t  }\r\n\t\t]\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 320,\r\n\t\t&quot;policyItems&quot;: [\r\n\t\t  {\r\n\t\t\t&quot;accesses&quot;: [\r\n\t\t\t  {\r\n\t\t\t\t&quot;type&quot;: &quot;publish&quot;,\r\n\t\t\t\t&quot;isAllowed&quot;: true\r\n\t\t\t  },\r\n\t\t\t  {\r\n\t\t\t\t&quot;type&quot;: &quot;create&quot;,\r\n\t\t\t\t&quot;isAllowed&quot;: true\r\n\t\t\t  }\r\n\t\t\t],\r\n\t\t\t&quot;users&quot;: [\r\n\t\t\t  &quot;foo&quot;\r\n\t\t\t],\r\n\t\t\t&quot;groups&quot;: []\r\n\t\t  },\r\n\t\t  {\r\n\t\t\t&quot;accesses&quot;: [\r\n\t\t\t  {\r\n\t\t\t\t&quot;type&quot;: &quot;consume&quot;,\r\n\t\t\t\t&quot;isAllowed&quot;: true\r\n\t\t\t  },\r\n\t\t\t  {\r\n\t\t\t\t&quot;type&quot;: &quot;create&quot;,\r\n\t\t\t\t&quot;isAllowed&quot;: true\r\n\t\t\t  }\r\n\t\t\t],\r\n\t\t\t&quot;users&quot;: [],\r\n\t\t\t&quot;groups&quot;: [\r\n\t\t\t  &quot;bar&quot;\r\n\t\t\t]\r\n\t\t  }\r\n\t\t]\r\n\t\t}\r\n    ]\r\n\r\nI tried various versions of this JQ code, but for id=319 user=foo should have access consume and create, and group=bar should have have access publish and create. But I always end up with both foo and bar having access consume, publish and create (or something else wrong).\r\n\r\nI&#39;ve tried:\r\n\r\n    cat file.json | jq -r &#39;[.[] | select(has(&quot;policyItems&quot;)) |{&quot;id&quot;, &quot;users&quot;:(.policyItems[] | .users), &quot;groups&quot;:(.policyItems[] | .groups), &quot;access_type&quot;:([.policyItems[].accesses[] | .type])} ] &#39;\r\n\r\nOutput:\r\n\r\n\t\t  [\r\n\t\t  {\r\n\t\t\t&quot;id&quot;: 319,\r\n\t\t\t&quot;users&quot;: [\r\n\t\t\t  &quot;foo&quot;\r\n\t\t\t],\r\n\t\t\t&quot;groups&quot;: [],\r\n\t\t\t&quot;access_type&quot;: [\r\n\t\t\t  &quot;consume&quot;,\r\n\t\t\t  &quot;create&quot;,\r\n\t\t\t  &quot;publish&quot;,\r\n\t\t\t  &quot;create&quot;\r\n\t\t\t]\r\n\t\t  },\r\n\t\t  {\r\n\t\t\t&quot;id&quot;: 319,\r\n\t\t\t&quot;users&quot;: [\r\n\t\t\t  &quot;foo&quot;\r\n\t\t\t],\r\n\t\t\t&quot;groups&quot;: [\r\n\t\t\t  &quot;bar&quot;\r\n\t\t\t],\r\n\t\t\t&quot;access_type&quot;: [\r\n\t\t\t  &quot;consume&quot;,\r\n\t\t\t  &quot;create&quot;,\r\n\t\t\t  &quot;publish&quot;,\r\n\t\t\t  &quot;create&quot;\r\n\t\t\t]\r\n\t\t  },\r\n\t\t  {\r\n\t\t\t&quot;id&quot;: 319,\r\n\t\t\t&quot;users&quot;: [],\r\n\t\t\t&quot;groups&quot;: [],\r\n\t\t\t&quot;access_type&quot;: [\r\n\t\t\t  &quot;consume&quot;,\r\n\t\t\t  &quot;create&quot;,\r\n\t\t\t  &quot;publish&quot;,\r\n\t\t\t  &quot;create&quot;\r\n\t\t\t]\r\n\t\t  },\r\n\t\t  {\r\n\t\t\t&quot;id&quot;: 319,\r\n\t\t\t&quot;users&quot;: [],\r\n\t\t\t&quot;groups&quot;: [\r\n\t\t\t  &quot;bar&quot;\r\n\t\t\t],\r\n\t\t\t&quot;access_type&quot;: [\r\n\t\t\t  &quot;consume&quot;,\r\n\t\t\t  &quot;create&quot;,\r\n\t\t\t  &quot;publish&quot;,\r\n\t\t\t  &quot;create&quot;\r\n\t\t\t]\r\n\t\t  },\r\n\t\t  {\r\n\t\t\t&quot;id&quot;: 320,\r\n\t\t\t&quot;users&quot;: [\r\n\t\t\t  &quot;foo&quot;\r\n\t\t\t],\r\n\t\t\t&quot;groups&quot;: [],\r\n\t\t\t&quot;access_type&quot;: [\r\n\t\t\t  &quot;publish&quot;,\r\n\t\t\t  &quot;create&quot;,\r\n\t\t\t  &quot;consume&quot;,\r\n\t\t\t  &quot;create&quot;\r\n\t\t\t]\r\n\t\t  },\r\n\t\t  {\r\n\t\t\t&quot;id&quot;: 320,\r\n\t\t\t&quot;users&quot;: [\r\n\t\t\t  &quot;foo&quot;\r\n\t\t\t],\r\n\t\t\t&quot;groups&quot;: [\r\n\t\t\t  &quot;bar&quot;\r\n\t\t\t],\r\n\t\t\t&quot;access_type&quot;: [\r\n\t\t\t  &quot;publish&quot;,\r\n\t\t\t  &quot;create&quot;,\r\n\t\t\t  &quot;consume&quot;,\r\n\t\t\t  &quot;create&quot;\r\n\t\t\t]\r\n\t\t  },\r\n\t\t  {\r\n\t\t\t&quot;id&quot;: 320,\r\n\t\t\t&quot;users&quot;: [],\r\n\t\t\t&quot;groups&quot;: [],\r\n\t\t\t&quot;access_type&quot;: [\r\n\t\t\t  &quot;publish&quot;,\r\n\t\t\t  &quot;create&quot;,\r\n\t\t\t  &quot;consume&quot;,\r\n\t\t\t  &quot;create&quot;\r\n\t\t\t]\r\n\t\t  },\r\n\t\t  {\r\n\t\t\t&quot;id&quot;: 320,\r\n\t\t\t&quot;users&quot;: [],\r\n\t\t\t&quot;groups&quot;: [\r\n\t\t\t  &quot;bar&quot;\r\n\t\t\t],\r\n\t\t\t&quot;access_type&quot;: [\r\n\t\t\t  &quot;publish&quot;,\r\n\t\t\t  &quot;create&quot;,\r\n\t\t\t  &quot;consume&quot;,\r\n\t\t\t  &quot;create&quot;\r\n\t\t\t]\r\n\t\t  }\r\n\t\t  ]\r\n\r\nI also tried:\r\n\r\n    cat file.json | jq  &#39; map({id, &quot;access_type&quot;:([.policyItems[].accesses[] | .type])[], &quot;users&quot;:(.policyItems[] | .users)[], &quot;groups&quot;:(.policyItems[] | .groups)}) &#39;\r\n\r\nWhich provides output:\r\n    \r\n    \t[\r\n\t{\r\n\t\t&quot;id&quot;: 319,\r\n\t\t&quot;access_type&quot;: &quot;consume&quot;,\r\n\t\t&quot;users&quot;: &quot;foo&quot;,\r\n\t\t&quot;groups&quot;: []\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 319,\r\n\t\t&quot;access_type&quot;: &quot;consume&quot;,\r\n\t\t&quot;users&quot;: &quot;foo&quot;,\r\n\t\t&quot;groups&quot;: [\r\n\t\t  &quot;public&quot;\r\n\t\t]\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 319,\r\n\t\t&quot;access_type&quot;: &quot;create&quot;,\r\n\t\t&quot;users&quot;: &quot;foo&quot;,\r\n\t\t&quot;groups&quot;: []\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 319,\r\n\t\t&quot;access_type&quot;: &quot;create&quot;,\r\n\t\t&quot;users&quot;: &quot;foo&quot;,\r\n\t\t&quot;groups&quot;: [\r\n\t\t  &quot;public&quot;\r\n\t\t]\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 319,\r\n\t\t&quot;access_type&quot;: &quot;publish&quot;,\r\n\t\t&quot;users&quot;: &quot;foo&quot;,\r\n\t\t&quot;groups&quot;: []\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 319,\r\n\t\t&quot;access_type&quot;: &quot;publish&quot;,\r\n\t\t&quot;users&quot;: &quot;foo&quot;,\r\n\t\t&quot;groups&quot;: [\r\n\t\t  &quot;public&quot;\r\n\t\t]\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 319,\r\n\t\t&quot;access_type&quot;: &quot;create&quot;,\r\n\t\t&quot;users&quot;: &quot;foo&quot;,\r\n\t\t&quot;groups&quot;: []\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 319,\r\n\t\t&quot;access_type&quot;: &quot;create&quot;,\r\n\t\t&quot;users&quot;: &quot;foo&quot;,\r\n\t\t&quot;groups&quot;: [\r\n\t\t  &quot;public&quot;\r\n\t\t]\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 320,\r\n\t\t&quot;access_type&quot;: &quot;publish&quot;,\r\n\t\t&quot;users&quot;: &quot;foo&quot;,\r\n\t\t&quot;groups&quot;: []\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 320,\r\n\t\t&quot;access_type&quot;: &quot;publish&quot;,\r\n\t\t&quot;users&quot;: &quot;foo&quot;,\r\n\t\t&quot;groups&quot;: [\r\n\t\t  &quot;public&quot;\r\n\t\t]\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 320,\r\n\t\t&quot;access_type&quot;: &quot;create&quot;,\r\n\t\t&quot;users&quot;: &quot;foo&quot;,\r\n\t\t&quot;groups&quot;: []\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 320,\r\n\t\t&quot;access_type&quot;: &quot;create&quot;,\r\n\t\t&quot;users&quot;: &quot;foo&quot;,\r\n\t\t&quot;groups&quot;: [\r\n\t\t  &quot;public&quot;\r\n\t\t]\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 320,\r\n\t\t&quot;access_type&quot;: &quot;consume&quot;,\r\n\t\t&quot;users&quot;: &quot;foo&quot;,\r\n\t\t&quot;groups&quot;: []\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 320,\r\n\t\t&quot;access_type&quot;: &quot;consume&quot;,\r\n\t\t&quot;users&quot;: &quot;foo&quot;,\r\n\t\t&quot;groups&quot;: [\r\n\t\t  &quot;public&quot;\r\n\t\t]\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 320,\r\n\t\t&quot;access_type&quot;: &quot;create&quot;,\r\n\t\t&quot;users&quot;: &quot;foo&quot;,\r\n\t\t&quot;groups&quot;: []\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 320,\r\n\t\t&quot;access_type&quot;: &quot;create&quot;,\r\n\t\t&quot;users&quot;: &quot;foo&quot;,\r\n\t\t&quot;groups&quot;: [\r\n\t\t  &quot;public&quot;\r\n\t\t]\r\n\t\t}\r\n\t\t]\r\n\r\nThanks in advance.\r\n\r\n**Edit:**\r\nMy expected output would be something like this where users and groups are combined and correctly show the correct access.\r\n\r\n      [\r\n      {\r\n        &quot;id&quot;: 319,\r\n        &quot;users_groups&quot;: [\r\n          &quot;foo&quot;,\r\n\t\t  &quot;bar&quot;\r\n        ],\r\n        &quot;access_type&quot;: [\r\n          &quot;create&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: 319,\r\n        &quot;users_groups&quot;: [\r\n          &quot;foo&quot;\r\n        ],\r\n        &quot;access_type&quot;: [\r\n          &quot;consume&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: 319,\r\n        &quot;users_groups&quot;: [&quot;bar&quot;],\r\n        &quot;access_type&quot;: [\r\n          &quot;publish&quot;\r\n        ]\r\n      },\r\n\t  ...",
        "link": "https://stackoverflow.com/questions/51051719/jq-getting-incorrect-output-for-nested-arrays",
        "title": "JQ getting incorrect output for nested arrays"
    },
    {
        "tags": [
            "sed",
            "syntax",
            "syntax-error",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1530085690,
                "last_edit_date": 1530085690,
                "creation_date": 1530081944,
                "answer_id": 51056186,
                "question_id": 51055912,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your syntax to access array is wrong. To get the IP address, use this:\r\n\r\n    aws efs describe-mount-targets --file-system-id fs-089b5e31 | \r\n      jq &#39;.MountTargets[0].IpAddress&#39;\r\n\r\nThe `MountTargets` is an array from which you want the first object. \r\n\r\nIf you need raw data (without double quotes) use `-r` option in the `jq` command.",
                "title": "Getting value from json parameter doesn&#39;t work (jq: 1 compile error)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1530086840,
        "creation_date": 1530080859,
        "last_edit_date": 1530086840,
        "question_id": 51055912,
        "body_markdown": "I am using awscli and trying to get the value of **IpAddress** from the output of my query.\r\n\r\nI tried to use **jq** but I get a compile error.\r\n\r\nThis is the case:\r\n\r\n    output=&quot;$(aws efs describe-mount-targets --file-system-id fs-089b5e31)&quot;\r\n    echo $output\r\n    { &quot;MountTargets&quot;: [ { &quot;MountTargetId&quot;: &quot;fsmt-bb29e666&quot;, &quot;IpAddress&quot;: &quot;172.20.33.255&quot;, &quot;OwnerId&quot;: &quot;668225551666&quot;, &quot;SubnetId&quot;: &quot;subnet-0b61377039d31e666&quot;, &quot;NetworkInterfaceId&quot;: &quot;eni-045f6ea1376662bdf&quot;, &quot;FileSystemId&quot;: &quot;fs-089b5e66&quot;, &quot;LifeCycleState&quot;: &quot;available&quot; } ] }\r\n\r\nAnd this is the command I am using to get the IpAddress:\r\n\r\n    echo array | jq &#39;.[]MountTarget[]s.IpAddress&#39;\r\n\r\nThe error I get is this:\r\n\r\n    parse error: Invalid numeric literal at line 2, column 0\r\n    ubuntu@ip-10-10-16-245:~/infra-devops/kops/vector$ echo array | jq &#39;.[]MountTarget[]s.IpAddress&#39;\r\n    jq: error: syntax error, unexpected IDENT, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .[]MountTarget[]s.IpAddress\r\n    jq: 1 compile error\r\n\r\n\r\nIs my query is the problem or maybe I better use sed instead?",
        "link": "https://stackoverflow.com/questions/51055912/getting-value-from-json-parameter-doesnt-work-jq-1-compile-error",
        "title": "Getting value from json parameter doesn&#39;t work (jq: 1 compile error)"
    },
    {
        "tags": [
            "variables",
            "syntax",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1530086307,
                "last_edit_date": 1530086307,
                "creation_date": 1530085935,
                "answer_id": 51057379,
                "question_id": 51056808,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When a variable is used to specify a key name, it must be enclosed in parentheses: \r\n\r\n    {($key): .}\r\n\r\nIn fact, whenever a key-value pair is specified with a colon, the key must be enclosed in parentheses unless it is a JSON string constant.",
                "title": "How to use a JQ variable as an object key?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1530088543,
        "creation_date": 1530084205,
        "last_edit_date": 1530088543,
        "question_id": 51056808,
        "body_markdown": "When I quote the key, JQ does not evaluate it:\r\n\r\n    $ echo value | jq -sR --arg key a &#39;{&quot;$key&quot;: .}&#39;\r\n    {\r\n      &quot;$key&quot;: &quot;value\\n&quot;\r\n    }\r\n\r\nAnd when I do not quote it, JQ reports a syntax error:\r\n\r\n    $ echo value | jq -sR --arg key a &#39;{$key: .}&#39;\r\n    jq: error: syntax error, unexpected &#39;:&#39;, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    {$key: .}     \r\n    jq: 1 compile error\r\n\r\nWhat is the right syntax?",
        "link": "https://stackoverflow.com/questions/51056808/how-to-use-a-jq-variable-as-an-object-key",
        "title": "How to use a JQ variable as an object key?"
    },
    {
        "tags": [
            "bash",
            "wso2-api-manager",
            "jq",
            "backticks"
        ],
        "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": 1530135282,
                "post_id": 51071637,
                "comment_id": 89133230,
                "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": 1530135383,
                "post_id": 51071637,
                "comment_id": 89133263,
                "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": 1530135758,
                "post_id": 51071637,
                "comment_id": 89133407,
                "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": 1530135838,
                "post_id": 51071637,
                "comment_id": 89133444,
                "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": 1530135871,
                "post_id": 51071637,
                "comment_id": 89133458,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9929339,
                    "reputation": 2198,
                    "user_id": 7349864,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5bf7797b638f8ab345456be096bd62d?s=256&d=identicon&r=PG",
                    "display_name": "Sourcerer",
                    "link": "https://stackoverflow.com/users/7349864/sourcerer"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530135955,
                "post_id": 51071637,
                "comment_id": 89133486,
                "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": 1530135969,
                "post_id": 51071637,
                "comment_id": 89133492,
                "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": 1530136146,
                "post_id": 51071637,
                "comment_id": 89133546,
                "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": 1530136323,
                "post_id": 51071637,
                "comment_id": 89133619,
                "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": 1530138970,
                "post_id": 51071637,
                "comment_id": 89134411,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9929339,
                    "reputation": 2198,
                    "user_id": 7349864,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5bf7797b638f8ab345456be096bd62d?s=256&d=identicon&r=PG",
                    "display_name": "Sourcerer",
                    "link": "https://stackoverflow.com/users/7349864/sourcerer"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530182575,
                "post_id": 51071637,
                "comment_id": 89149976,
                "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": 1530183176,
                "post_id": 51071637,
                "comment_id": 89150409,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1530136645,
                "last_edit_date": 1530136645,
                "creation_date": 1530135639,
                "answer_id": 51071806,
                "question_id": 51071637,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` does not have any problem at all with backticks in literal values. You can see that as follows:\r\n\r\n    $ jq &#39;.value&#39; &lt;&lt;&lt;&#39;{&quot;otherKey&quot;: &quot;`otherValue`&quot;, &quot;value&quot;: &quot;desired value `with backticks`&quot;}&#39;\r\n    &quot;desired value `with backticks`&quot;\r\n\r\nWith respect to the code given in the question, though, it&#39;s vastly overcomplicated. Rather than muddle through what could be wrong, consider the following replacement (which doesn&#39;t need to read `count` at all, and calls `jq` only once):\r\n\r\n    # Aside: Using all-caps names is bad practice. Don&#39;t do this.\r\n    APINAME=SwaggerPetstore\r\n    APIVERSION=1.0.0\r\n    \r\n    getAPIId() {\r\n      [[ $1 ]] || { echo &#39;Usage: getAPIId &quot;$json&quot;&#39; &gt;&amp;2; return 1; }\r\n      jq -er \\\r\n           --arg target_name &quot;$APINAME&quot; \\\r\n           --arg target_version &quot;$APIVERSION&quot; &#39;\r\n        .list[] |\r\n        select(.name == $target_name) |\r\n        select(.version == $target_version) |\r\n        .id&#39; &lt;&lt;&lt;&quot;$1&quot;\r\n    }\r\n\r\n...returns, when called as follows:\r\n\r\n    s=&#39;{\r\n      &quot;count&quot;: 1,\r\n      &quot;next&quot;: &quot;&quot;,\r\n      &quot;previous&quot;: &quot;&quot;,\r\n      &quot;list&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;6d2822e5-a90d-4738-b7b7-ef7d7848cb48&quot;,\r\n          &quot;name&quot;: &quot;SwaggerPetstore&quot;,\r\n          &quot;description&quot;: &quot;`special key`&quot;,\r\n          &quot;context&quot;: &quot;/v2&quot;,\r\n          &quot;version&quot;: &quot;1.0.0&quot;,\r\n          &quot;provider&quot;: &quot;admin&quot;,\r\n          &quot;status&quot;: &quot;CREATED&quot;,\r\n          &quot;thumbnailUri&quot;: null\r\n        }\r\n      ],\r\n      &quot;pagination&quot;: {\r\n        &quot;total&quot;: 1,\r\n        &quot;offset&quot;: 0,\r\n        &quot;limit&quot;: 25\r\n      }\r\n    }&#39;\r\n\r\n    getAPIId &quot;$s&quot;; echo &quot;Exit status is $?&quot; &gt;&amp;2\r\n\r\n...the correct result of:\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    6d2822e5-a90d-4738-b7b7-ef7d7848cb48\r\n    Exit status is 0\r\n\r\n...whereas if we run it again with an invalid name or version to search for:\r\n\r\n    APINAME=NotFound getAPIId &quot;$s&quot;; echo &quot;Exit status is $?&quot; &gt;&amp;2\r\n\r\n...correctly reflects that:\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    Exit status is 4",
                "title": "jq script with back tick in JSON value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1530136645,
        "creation_date": 1530134687,
        "question_id": 51071637,
        "body_markdown": "I&#39;m using jq inside a bash script, to parse a JSON returned by an API REST service\r\n\r\nThis is my code (getting .count value)\r\n\r\n    # getAPIId\r\n    # Parse the answer of query API to get the API ID (checking version name)\r\n    # return (echo to stdout) the APIID\r\n    function getAPIId() {\r\n    \tlocal apiId\r\n    \tlocal version\r\n    \tlocal -i count\t\t\t\r\n    \r\n    \tif [ -z $1 ]\r\n    \tthen\r\n    \t\techo &quot;Use: getAPIId \\$apiQuery&quot; &gt;&amp;2\r\n    \t\texit 1\r\n    \telse\t\r\n    \t\t# Parse answer to API info\r\n    \t\tcount=$(echo &quot;$1&quot;|jq -r &#39;.count&#39;)\r\n    \t\tif [ &quot;$count&quot; == &quot;0&quot; ]\r\n    \t\tthen\r\n    \t\t\techo $1 &gt;&amp;2\r\n    \t\t\techo &quot;ERROR: Cannot find an API called ${APINAME}&quot; &gt;&amp;2\r\n    \t\t\treturn 1\r\n    \t\telse\r\n    \t\t\tfor ((i=0; i&lt;count; i++))\r\n    \t\t\tdo\r\n    \t\t\t\tversion=$(echo $1|jq -r &#39;.list[&#39;$i&#39;].version&#39;)\r\n    \t\t\t\tif [ &quot;$APIVERSION&quot; == &quot;$version&quot; ] &amp;&amp; [ &quot;$APINAME&quot; == &quot;$name&quot; ]\r\n    \t\t\t\tthen\r\n    \t\t\t\t\tapiId=$(echo $1|jq -r &#39;.list[&#39;$i&#39;].id&#39;)\r\n    \t\t\t\t\techo &quot;$apiId&quot;\r\n    \t\t\t\t\treturn 0\r\n    \t\t\t\tfi\r\n    \t\t\tdone\r\n    \t\tfi\r\n    \tfi\r\n    \treturn 1\r\n    \r\n    }\r\n\r\nThis is the JSON file I try to parse\r\n\r\n    {&quot;count&quot;:1,&quot;next&quot;:&quot;&quot;,&quot;previous&quot;:&quot;&quot;,&quot;list&quot;:[{&quot;id&quot;:&quot;6d2822e5-a90d-4738-b7b7-ef7d7848cb48&quot;,&quot;name&quot;:&quot;SwaggerPetstore&quot;,\r\n    &quot;description&quot;:&quot;`special key`&quot;,&quot;context&quot;:&quot;/v2&quot;,&quot;version&quot;:&quot;1.0.0&quot;,&quot;provider&quot;:&quot;admin&quot;,&quot;status&quot;:&quot;CREATED&quot;,&quot;thumbnailUri&quot;:null}],&quot;pagination&quot;:{&quot;total&quot;:1,&quot;offset&quot;:0,&quot;limit&quot;:25}}\r\n\r\nAs you see, the field description contains back tick value. In this case, jq fails and return empty string (as not found value for count)\r\n\r\nHow can avoid the problem with backtick?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51071637/jq-script-with-back-tick-in-json-value",
        "title": "jq script with back tick in JSON value"
    },
    {
        "tags": [
            "shell",
            "jq",
            "fish"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1530186472,
                "post_id": 51080019,
                "comment_id": 89152572,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3794922,
                    "reputation": 16354,
                    "user_id": 3150338,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u5zKy.jpg?s=256",
                    "display_name": "faho",
                    "link": "https://stackoverflow.com/users/3150338/faho"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530198317,
                "post_id": 51080019,
                "comment_id": 89160711,
                "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": 1530198746,
                "post_id": 51080019,
                "comment_id": 89161014,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1530184819,
                "creation_date": 1530184819,
                "answer_id": 51081622,
                "question_id": 51080019,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq is a funny beast. I don&#39;t know why your script just outputs the $jq_args contents.\r\n\r\n\r\nIt has a --slurpfile option that reads a file of JSON strings into an array variable. This saves you from dynamically constructing both the JSON array and the jq script body\r\n\r\n    $ function jqs\r\n            jq -r --slurpfile keys (printf &#39;&quot;%s&quot;\\n&#39; $argv[2..-1] | psub) \\\r\n                &#39;with_entries(select([.key] | inside($keys)))&#39; $argv[1]\r\n    end    \r\n    \r\n    $ cat file.json\r\n    {&quot;foo&quot;:&quot;a&quot;,&quot;bar&quot;:&quot;b&quot;,&quot;baz&quot;:&quot;c&quot;}\r\n    \r\n    $ jqs file.json foo baz\r\n    {\r\n      &quot;foo&quot;: &quot;a&quot;,\r\n      &quot;baz&quot;: &quot;c&quot;\r\n    }\r\n\r\n",
                "title": "How to write a fish function that delegates to jq?"
            },
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1530198404,
                "last_edit_date": 1530198404,
                "creation_date": 1530184865,
                "answer_id": 51081636,
                "question_id": 51080019,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt;I am new to shell programming, so I might have messed up my quotes.\r\n\r\nThat&#39;s basically it.\r\n\r\nIt appears you&#39;ve added one layer of quotes too many.\r\n\r\nIn fish (and most other shells, including e.g. bash and zsh), quotes are only special to the shell when used literally.\r\n\r\nThat means when a variable contains `&quot;some string&quot;`, then `echo $variable` will print `&quot;some string&quot;` - which means that the `echo` command received the string _with the quotes_ (note: bash would also apply word-splitting here, so it would actually receive `&quot;some` and `string&quot;`, even though you might assume it is quoted).\r\n\r\nI would suggest you go through your function one by one and simply `echo` the variables. Then imagine you passed _that exact string_ to `jq` - would it work?\r\n\r\nE.g. the `$key_names` bit:\r\n\r\n    set key_names (for key in $argv[2..-1]; echo &quot;\\\\\\&quot;$key\\\\\\&quot;&quot;; end)\r\n\r\nThe purpose of this is obviously to escape all the keys (which are the arguments from the second onwards) for use with `jq`. That means they need to be quoted _once_. They don&#39;t need to be quoted a second time because the shell does not care about non-literal quotes.\r\n\r\nSo any key should look like `&quot;key&quot;`.\r\n\r\nBut when we put\r\n\r\n    printf &#39;%s\\n&#39; $key_names\r\n\r\n(which will print each key on its own line)\r\n\r\nafter this, we see\r\n\r\n    \\&quot;bar\\&quot;\r\n    \\&quot;baz\\&quot;\r\n    \\&quot;qux\\&quot;\r\n\r\nThat&#39;s _two_ layers of quoting! The quotes themselves, and the backslashes escaping them.\r\n\r\nSo let&#39;s remove one:\r\n\r\n   set key_names (for key in $argv[2..-1]; echo &quot;\\&quot;$key\\&quot;&quot;; end)\r\n\r\nThis will result in `&quot;bar&quot;`, `&quot;baz&quot;` and `&quot;qux&quot;`.\r\n\r\n(This can be simplified to  `set key_names \\&quot;$argv[2..-1]\\&quot;` by using fish&#39;s [cartesian product](http://fishshell.com/docs/current/index.html#cartesian-product))\r\n\r\nNow for the next bit:\r\n\r\n    set jq_args &quot;\\&quot;with_entries(select([.key] | inside([$key_names_joined])))\\&quot;&quot;\r\n\r\nYour intention here is to run this as if you had\r\n\r\n    jq -r &quot;with_entries(select([.key] | inside([\\&quot;bar\\&quot;,\\&quot;baz\\&quot;,\\&quot;qux\\&quot;])))&quot; foo.json\r\n\r\nOn the commandline. But when you use variables, you don&#39;t need to quote the string inside them again - all the splitting and other expansions have already happened once the value is assigned, and does not happen again when the variable is substituted.\r\n\r\nSo simply remove the escaped quotes\r\n\r\n    set jq_args &quot;with_entries(select([.key] | inside([$key_names_joined])))&quot;\r\n\r\nand your function should work.\r\n\r\nThe result is:\r\n\r\n    function jq_select_keys --description &#39;Selects given keys from json input&#39;\r\n        set key_names \\&quot;$argv[2..-1]\\&quot;\r\n        set key_names_joined (string join &quot;,&quot; $key_names)\r\n        set jq_args &quot;with_entries(select([.key] | inside([$key_names_joined])))&quot;\r\n        echo &quot;Command: jq -r $jq_args $argv[1]&quot;\r\n        jq -r $jq_args $argv[1]\r\n    end\r\n",
                "title": "How to write a fish function that delegates to jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1530198404,
        "creation_date": 1530180063,
        "question_id": 51080019,
        "body_markdown": "I am trying to write a fish function called `jq_select_keys` that selects a subset of keys from a given JSON. \r\n\r\nThe jq incantation to do this piece of magic is:\r\n\r\n    jq -r &quot;with_entries(select([.key] | inside([\\&quot;bar\\&quot;,\\&quot;baz\\&quot;,\\&quot;qux\\&quot;])))&quot; file.json\r\n\r\nNow I&#39;m trying to define a handy function called jq_select_keys that will take the filename and the keys that I am interested in, and spit out the subset. Here is what I came up with:\r\n\r\n    function jq_select_keys --description &#39;Selects given keys from json input&#39;\r\n      set key_names (for key in $argv[2..-1]; echo &quot;\\\\\\&quot;$key\\\\\\&quot;&quot;; end)\r\n      set key_names_joined (string join &quot;,&quot; $key_names)\r\n      set jq_args &quot;\\&quot;with_entries(select([.key] | inside([$key_names_joined])))\\&quot;&quot;\r\n      echo &quot;Command: jq -r $jq_args $argv[1]&quot;\r\n      jq -r $jq_args $argv[1]\r\n    end\r\n\r\nWhen I run `jq_select_keys foo.json bar baz qux` on my fish shell, I get the following output:\r\n\r\n    Command: jq -r &quot;with_entries(select([.key] | inside([\\&quot;bar\\&quot;,\\&quot;baz\\&quot;,\\&quot;qux\\&quot;])))&quot; foo.json\r\n    with_entries(select([.key] | inside([&quot;bar&quot;,&quot;baz&quot;,&quot;qux&quot;])))\r\n\r\nNow, the interesting bit is that I can copy paste the output of the echo statement, and it runs as expected. But the output I get is just the query string that I passed to jq. \r\n\r\nI am new to shell programming, so I might have messed up my quotes. But other than that, I have no clue how to get this thing to work! ",
        "link": "https://stackoverflow.com/questions/51080019/how-to-write-a-fish-function-that-delegates-to-jq",
        "title": "How to write a fish function that delegates to jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1530263880,
                "last_edit_date": 1530263880,
                "creation_date": 1530263450,
                "answer_id": 51098211,
                "question_id": 51091583,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is very well explained in [jq - FAQ](https://github.com/stedolan/jq/wiki/FAQ#frequently-asked-questions) under recursive traversal using `walk/1`. I&#39;ve used a standard implementation of `walk/1` from [jq-builtins](https://github.com/stedolan/jq/blob/master/src/builtin.jq) page, since the version I have doesn&#39;t have it present by default.\r\n\r\nFrom the documentation for `walk/1` - recursively walks the input JSON entity, changing each encountered key, `k`, to `(k|filter)`, where `filter` is the specified filter, which may be any `jq` expression. \r\n\r\nI&#39;ve used the following filter in my script\r\n\r\n    # Apply f to composite entities recursively, and to atoms\r\n    def walk(f):\r\n      . as $in\r\n      | if type == &quot;object&quot; then\r\n          reduce keys_unsorted[] as $key\r\n            ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n      elif type == &quot;array&quot; then map( walk(f) ) | f\r\n      else f\r\n      end;\r\n     \r\n    def translate_keys(f):\r\n      walk( if type == &quot;object&quot; then\r\n                with_entries( if .key | contains(&quot;groups&quot;) then\r\n                                 .key |= &quot;newgroups&quot;\r\n                              elif .key | contains(&quot;items&quot;) then\r\n                                 .key |= &quot;newitems&quot;\r\n                              else\r\n                                 . end\r\n                            )\r\n            else\r\n                . end\r\n          );\r\n     \r\n     \r\n    translate_keys(.)\r\n\r\nand ran the script as\r\n\r\n    jq -f script.jq json\r\n\r\nwhich produced the result you needed.\r\n\r\n",
                "title": "jq: Recursively rename keys"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1530417468,
                "creation_date": 1530417468,
                "answer_id": 51120273,
                "question_id": 51091583,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the problem requires that &quot;items&quot; only be renamed in a subtree under a &quot;groups&quot; key, then a walk within a walk would be called for:\r\n\r\n    walk(if type == &quot;object&quot; and has(&quot;groups&quot;)\r\n         then .newGroups = .groups | del(.groups)\r\n         | walk(if type == &quot;object&quot; and has(&quot;items&quot;)\r\n                then .newItems = .items | del(.items)\r\n                else . end)\r\n         else . end)\r\n\r\n",
                "title": "jq: Recursively rename keys"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1530417468,
        "creation_date": 1530222044,
        "last_edit_date": 1530260418,
        "question_id": 51091583,
        "body_markdown": "I have JSON with structure like what&#39;s shown below. &quot;groups&quot; may be nested under &quot;items&quot; to any arbitrary depth, so I need to write an expression that visits every &quot;groups&quot; and &quot;items&quot; property (or parent object); static paths won&#39;t do.\r\n\r\n    {\r\n        &quot;groups&quot;: [{\r\n            &quot;name&quot;: &quot;group1&quot;,\r\n            &quot;items&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;item1&quot;,\r\n                    &quot;groups&quot;: [\r\n                        {\r\n                            &quot;name&quot;: &quot;nestedGroup1&quot;,\r\n                            &quot;items&quot;: [\r\n                                {\r\n                                    &quot;name&quot;: &quot;nestedItem1&quot;,\r\n                                    &quot;groups&quot;: []\r\n                                },{\r\n                                    &quot;name&quot;: &quot;nestedItem2&quot;,\r\n                                    &quot;groups&quot;: []\r\n                            }]\r\n                        }\r\n                    ]\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;item2&quot;,\r\n                    &quot;groups&quot;: []\r\n                }\r\n            ]\r\n        }]\r\n    }\r\n\r\nHow can I recursively rename all &quot;groups&quot; to say &quot;newGroups&quot; and &quot;items&quot; to &quot;newItems&quot;? If you break it down, I know I need to create new keys at each level and delete the old ones, but I&#39;m having trouble expressing that. I&#39;ve tried several variations on things like\r\n\r\n\r\n    .. |= if type == &quot;object&quot; and has(&quot;groups&quot;) then . + { newGroups: .groups } else . end\r\n\r\n\r\nto perform the first step, but this results in copying the top-level &quot;groups&quot; value to &quot;newGroups&quot; while leaving the nested &quot;groups&quot; unchanged. The remaining values within &quot;groups&quot; then also get sibling &quot;newGroups&quot; with their nested &quot;groups&quot; with no &quot;newGroups&quot; siblings etc.\r\n\r\nFrom observation, my understanding is that the paths generated by the `..` operator are evaluated first, so the newly added key is never traversed. So then I tried variations on the above, replacing `..` with `recurse` both with and without arguments, thinking that it would take the value produced by the RHS and feed it back in to the LHS, like this:\r\n\r\n\r\n    { newGroups: .groups } | recurse |= if type == &quot;object&quot; and has(&quot;groups&quot;) then . + { newGroups: .groups } elif type == &quot;object&quot; and has(&quot;items&quot;) then . + { newItems: .items } else . end\r\n\r\nThe result is closer, but still so far away. The recursion kind of works, but only on keys that already existed; the new ones appended to the object are not visited.\r\n\r\nI&#39;ve also tried messing about with `paths`, `getpath`, and `setpath` to try to solve the problem that way but run into problems there as well. Please help me get unstuck!",
        "link": "https://stackoverflow.com/questions/51091583/jq-recursively-rename-keys",
        "title": "jq: Recursively rename keys"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1530260248,
                "creation_date": 1530260248,
                "answer_id": 51097272,
                "question_id": 51093319,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -c &#39;.issues[] | .id as $id\r\n           | .fields.links[] | to_entries[]\r\n           | {&quot;id&quot;: $id, &quot;link&quot;: {&quot;linktype&quot;: .key, &quot;id&quot;: .value.id}}&#39; file\r\n\r\nThe output:\r\n\r\n    {&quot;id&quot;:&quot;2&quot;,&quot;link&quot;:{&quot;linktype&quot;:&quot;inlink&quot;,&quot;id&quot;:&quot;red&quot;}}\r\n    {&quot;id&quot;:&quot;3&quot;,&quot;link&quot;:{&quot;linktype&quot;:&quot;outlink&quot;,&quot;id&quot;:&quot;yellow&quot;}}\r\n    {&quot;id&quot;:&quot;4&quot;,&quot;link&quot;:{&quot;linktype&quot;:&quot;inlink&quot;,&quot;id&quot;:&quot;green&quot;}}\r\n    {&quot;id&quot;:&quot;4&quot;,&quot;link&quot;:{&quot;linktype&quot;:&quot;outlink&quot;,&quot;id&quot;:&quot;blue&quot;}}\r\n\r\n",
                "title": "Reporting every (optional) subelement"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1530260248,
        "creation_date": 1530237607,
        "question_id": 51093319,
        "body_markdown": "Want to parse the following:\r\n\r\n    {\r\n      &quot;issues&quot;: [\r\n        { &quot;id&quot;: &quot;1&quot;, &quot;fields&quot;: { &quot;links&quot;: [] } },\r\n        { &quot;id&quot;: &quot;2&quot;, &quot;fields&quot;: { &quot;links&quot;: [ { &quot;inlink&quot;: { &quot;id&quot;: &quot;red&quot; } } ] } },\r\n        { &quot;id&quot;: &quot;3&quot;, &quot;fields&quot;: { &quot;links&quot;: [ { &quot;outlink&quot;: { &quot;id&quot;: &quot;yellow&quot; } } ] } },\r\n        { &quot;id&quot;: &quot;4&quot;, &quot;fields&quot;: { &quot;links&quot;: [ { &quot;inlink&quot;: { &quot;id&quot;: &quot;green&quot; } }, { &quot;outlink&quot;: { &quot;id&quot;: &quot;blue&quot; } } ] } }\r\n      ]\r\n    }\r\n\r\ninto elements that represent the `links` elements, one for one, like this (note that `id 1` is missing and `id 4` appears twice:\r\n\r\n    \r\n      { &quot;id&quot;: &quot;2&quot;, &quot;link&quot;: { &quot;linktype&quot;: &quot;inlink&quot;, &quot;id&quot;: &quot;red&quot; } },\r\n      { &quot;id&quot;: &quot;3&quot;, &quot;link&quot;: { &quot;linktype&quot;: &quot;outlink&quot;, &quot;id&quot;: &quot;yellow&quot; } },\r\n      { &quot;id&quot;: &quot;4&quot;, &quot;link&quot;: { &quot;linktype&quot;: &quot;inlink&quot;, &quot;id&quot;: &quot;green&quot; } },\r\n      { &quot;id&quot;: &quot;4&quot;, &quot;link&quot;: { &quot;linktype&quot;: &quot;outlink&quot;, &quot;id&quot;: &quot;blue&quot; } }\r\n\r\n\r\n\r\nThe following `jq` works for `inlink` or `outlink` separately\r\n\r\n    .issues[] | .id as $id | .fields.links[] | .inlink.id as $lid | {$id,$lid}\r\n\r\ngiving\r\n\r\n    { &quot;id&quot;: &quot;2&quot;, &quot;lid&quot;: &quot;red&quot; }\r\n    { &quot;id&quot;: &quot;3&quot;, &quot;lid&quot;: null }\r\n    { &quot;id&quot;: &quot;4&quot;, &quot;lid&quot;: &quot;green&quot; }\r\n    { &quot;id&quot;: &quot;4&quot;, &quot;lid&quot;: null }\r\n\r\nbut can&#39;t figure out how to track both types simultaneously or introduce the key `linktype`. Any ideas?",
        "link": "https://stackoverflow.com/questions/51093319/reporting-every-optional-subelement",
        "title": "Reporting every (optional) subelement"
    },
    {
        "tags": [
            "bash",
            "variables",
            "select",
            "syntax",
            "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": 1530246101,
                "post_id": 51094066,
                "comment_id": 89176443,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530246223,
                "post_id": 51094066,
                "comment_id": 89176465,
                "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": 1530248435,
                "post_id": 51094066,
                "comment_id": 89176986,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2496079,
                    "reputation": 27,
                    "user_id": 2172430,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9f784ea02c43064df0ee1f5a06a90e82?s=256&d=identicon&r=PG",
                    "display_name": "user2172430",
                    "link": "https://stackoverflow.com/users/2172430/user2172430"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530270306,
                "post_id": 51094066,
                "comment_id": 89187793,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2496079,
                    "reputation": 27,
                    "user_id": 2172430,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9f784ea02c43064df0ee1f5a06a90e82?s=256&d=identicon&r=PG",
                    "display_name": "user2172430",
                    "link": "https://stackoverflow.com/users/2172430/user2172430"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530298407,
                "post_id": 51094066,
                "comment_id": 89202672,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1530298390,
        "creation_date": 1530244789,
        "last_edit_date": 1530298390,
        "question_id": 51094066,
        "body_markdown": "I am trying to do a select statement and I am having issues passing in a variable. My code pattern is shown below : \r\n\r\n    sD=$(hostname)\r\n    echo $sD #prints TEST\r\n\r\n    select (.name==&quot;$sD&quot;) # this line isnt working. When i do\r\n\r\n    select (.name==&quot;TEST&quot;) # it works properly",
        "link": "https://stackoverflow.com/questions/51094066/select-statement-with-variable-not-working",
        "title": "Select statement with variable not working"
    },
    {
        "tags": [
            "json",
            "error-handling",
            "compilation",
            "runtime-error",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1530262685,
                "creation_date": 1530262685,
                "answer_id": 51097969,
                "question_id": 51097759,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Provided you fixed your JSON file by adding comma to separate the elements `tag`, `filepath` and `hostname`:\r\n\r\n    {\r\n      &quot;environment&quot;: {\r\n        &quot;stage&quot;: {\r\n          &quot;testing&quot;: [\r\n            {\r\n              &quot;tag&quot;: &quot;1.0&quot;,\r\n              &quot;filepath&quot;: &quot;C:/test/conf&quot;,\r\n              &quot;hostname&quot;: &quot;test&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\nYou can use this `jq` command:\r\n\r\n    jq -r &#39;.environment.stage.testing[].filepath&#39; env.json\r\n\r\nNotice the keyword `filepath` instead of `filePath` in your command.\r\n\r\n    \r\n",
                "title": "jq error while parsing json file inside jenkins Shell"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1530418172,
                "creation_date": 1530418172,
                "answer_id": 51120331,
                "question_id": 51097759,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. The posted data conforms with the requirements of [HJSON][1], and can be converted to JSON by:\r\n\r\n    hjson -j\r\n\r\n2. The jq filter includes `.filePath` whereas the HJSON only includes a key named &quot;filepath&quot;.\r\n\r\n3. The filter that corresponds with the posted data is:\r\n\r\n    .environment.stage.testing[].filepath\r\n\r\nPutting the above together:\r\n\r\n\r\n    $ hjson -j &lt; so-jenkins-shell.hjson |\r\n      jq -r &#39;.environment.stage.testing[].filepath&#39;\r\n    C:/test/conf\r\n\r\n\r\n  [1]: http://hjson.org/",
                "title": "jq error while parsing json file inside jenkins Shell"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1530418172,
        "creation_date": 1530262043,
        "question_id": 51097759,
        "body_markdown": "I want to parse the value of the filepath from the json. while parsing it via jq and seeing issue with respect to &lt;jq&gt; not defined at top level. Please find the json details and the error below:\r\n    \r\n    &quot;environment&quot;:{\r\n                 &quot;stage&quot;:{\r\n                           &quot;testing&quot;:[\r\n    {\r\n     &quot;tag&quot;:&quot;1.0&quot;\r\n      &quot;filepath&quot;:&quot;C:/test/conf&quot;\r\n       &quot;hostname&quot;:&quot;test&quot;\r\n    }]}}\r\n    \r\n    **command Used in Execute shell:**\r\n     jq -r &quot;.&#39;environment.stage.testing[].filePath&#39; env.json\r\n    \r\n    **Error Faced**:\r\n    jq: error: environments/0 is not defined at &lt;top-level&gt;, line 1:\r\n    environment.stage.testing[].filePath\r\n    jq: 1 compile error\r\n    \r\n    TIA",
        "link": "https://stackoverflow.com/questions/51097759/jq-error-while-parsing-json-file-inside-jenkins-shell",
        "title": "jq error while parsing json file inside jenkins Shell"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1530299939,
                "creation_date": 1530299939,
                "answer_id": 51108141,
                "question_id": 51099819,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Filter the records from `.array` before building the array fed to `@csv`.\r\n\r\n    jq -r &#39;.array[] | \r\n             select(.uniqV | startswith(&quot;BAD-&quot;) | not) |\r\n             [.uniqV, .v1, .v2, .v3] |\r\n             @csv&#39; something.json",
                "title": "Exclude JSON array fields for specifc values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1530299939,
        "creation_date": 1530268596,
        "last_edit_date": 1530272235,
        "question_id": 51099819,
        "body_markdown": "Let&#39;s say I want to extract a `CSV` taking specific fields from a big `json` file generated from an `API`... everything of interest is inside an array.\r\n\r\n    jq -r &quot;.array[] | [.uniqV,.V1,.V2,.V3] | @csv&quot; something.json\r\n\r\n\r\n... but if the unique value starts with a certain string (say, BAD-), I want to exclude the array member entirely.\r\nI could do something like this...\r\n\r\n    jq -r &quot;.array[] | [.uniqV,.v1,.v2,.v3] | @csv&quot; something.json | egrep -v ^\\&quot;BAD-\r\n\r\n... but it would be nicer / more efficient to exclude this pattern within `jq` itself. How could that be accomplished?\r\n",
        "link": "https://stackoverflow.com/questions/51099819/exclude-json-array-fields-for-specifc-values",
        "title": "Exclude JSON array fields for specifc values"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1530283230,
                "last_edit_date": 1530283230,
                "creation_date": 1530281404,
                "answer_id": 51103653,
                "question_id": 51103560,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Like this:\r\n\r\n    jq &#39;path(recurse|select(.name?==&quot;Name 2&quot;))[0]&#39; file.json\r\n\r\n",
                "title": "Select main parent property name of a property name using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1530283373,
        "creation_date": 1530281085,
        "last_edit_date": 1530283373,
        "question_id": 51103560,
        "body_markdown": "I have the following JSON file:\r\n\r\n    {\r\n        &quot;foo&quot;: {\r\n            &quot;name&quot;: &quot;Name 1&quot;,\r\n            &quot;color&quot;: &quot;green&quot;,\r\n            &quot;something_else&quot;: {\r\n                &quot;name&quot; : &quot;Name 2&quot;\r\n            }\r\n        },\r\n        &quot;bar&quot;: {\r\n            &quot;name&quot;: &quot;Name 3&quot;,\r\n            &quot;color&quot;: &quot;red&quot;\r\n        }\r\n    }\r\n\r\n\r\nHow to get the proprety name `foo` from `&quot;Name 2&quot;` using jq ?\r\nI tried \r\n\r\n    .[] |select(.&quot;name&quot;==&quot;Name 2&quot;)\r\n\r\nAnd how to get a list `[foo,bar]` (all main parents) from the property name `name` ?",
        "link": "https://stackoverflow.com/questions/51103560/select-main-parent-property-name-of-a-property-name-using-jq",
        "title": "Select main parent property name of a property name using jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1588664445,
                "last_edit_date": 1588664445,
                "creation_date": 1530445666,
                "answer_id": 51123004,
                "question_id": 51115902,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -sR &#39;{&quot;Environment&quot;:\r\n                {&quot;Variables&quot;: [split(&quot;\\n&quot;)[:-1][] | rtrimstr(&quot;\\\\r&quot;) \r\n                                 | split(&quot;=&quot;) | {(.[0]): .[1]}\r\n                              ]  | add\r\n                }\r\n            }&#39; input.txt\r\n\r\nThe output:\r\n\r\n    {\r\n      &quot;Environment&quot;: {\r\n        &quot;Variables&quot;: {\r\n          &quot;key1&quot;: &quot;value1&quot;,\r\n          &quot;key2&quot;: &quot;value2&quot;,\r\n          &quot;key3&quot;: &quot;value3&quot;,\r\n          &quot;key4&quot;: &quot;value4&quot;\r\n        }\r\n      }\r\n    }\r\n\r\n## Caveat\r\nThis solution assumes `=` does not appear in the &quot;value&quot; section of the input strings.\r\n",
                "title": "Convert text file with key=value pair to specific json format in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1588666490,
                "last_edit_date": 1588666490,
                "creation_date": 1588664202,
                "answer_id": 61608023,
                "question_id": 51115902,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following approach allows `=` to appear in the value portion of the `key=value` strings:\r\n\r\nInvocation: jq -n -R -f program.jq input.txt\r\n\r\nprogram.jq:\r\n\r\n```\r\n[inputs | sub(&quot;\\\\\\\\r$&quot;;&quot;&quot;) | capture(&quot;^(?&lt;key&gt;[^=]*)=(?&lt;value&gt;.*)&quot;)]\r\n| from_entries\r\n| {Environment: { Variables: .}}\r\n```",
                "title": "Convert text file with key=value pair to specific json format in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1588666490,
        "creation_date": 1530369723,
        "last_edit_date": 1530443201,
        "question_id": 51115902,
        "body_markdown": "I have a text file with  following values in \r\ninput.txt\r\n\r\n    key1=value1\\r\r\n    key2=value2\r\n    key3=value3\\r\r\n    key4=value4\r\n\r\n\r\nneed the jq rexpression to convert it to  below json format  by removing &quot;\\r&quot; also\r\n\r\noutput.json\r\n\r\n    {\r\n\t&quot;Environment&quot;: {\r\n\t\t&quot;Variables&quot;: {\r\n\t\t\t&quot;key1&quot;: &quot;value1&quot;,\r\n\t\t\t&quot;key2&quot;: &quot;value2&quot;,\r\n\t\t\t&quot;key3&quot;: &quot;value3&quot;,\r\n\t\t\t&quot;key4&quot;: &quot;value4&quot;\r\n\t\t}\r\n\t}\r\n}\r\n\r\nI have tried the below expression and getting the \r\n\r\n    jq -Rs [ split(&quot;\\n&quot;)[] | select(length &gt; 0) | split(&quot;=&quot;) | {(.[0]): .[1]} ] \r\n\r\nand getting the below output\r\n\r\n    [\r\n      {\r\n       &quot;key1ey1&quot;: &quot;Value1\\r&quot;\r\n      },\r\n      {\r\n       &quot;key2&quot;: &quot;value2&quot;\r\n      },\r\n      {\r\n       &quot;key3&quot;: &quot;value3\\r&quot;\r\n      },\r\n      {\r\n       &quot;key4&quot;: &quot;value4&quot;\r\n      }\r\n  \r\n    ]\r\n\r\n  \r\n  \r\n  \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51115902/convert-text-file-with-key-value-pair-to-specific-json-format-in-jq",
        "title": "Convert text file with key=value pair to specific json format in jq"
    },
    {
        "tags": [
            "json",
            "sorting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1530466155,
                "creation_date": 1530466155,
                "answer_id": 51125483,
                "question_id": 51125135,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` tries to parse values like `ObjectId(&quot;5aaaa017e4b09780301b6c18&quot;)` as numeric value and gives you an expected error in terms of JSON validation.\r\n\r\nIf your `testout.out` file would be as follows:\r\n\r\n    { &quot;_id&quot; : &quot;ObjectId(\\&quot;5aaaa017e4b09780301b6c18\\&quot;)&quot;, &quot;account&quot; : &quot;abc&quot;, &quot;profile&quot; : &quot;catch&quot;, &quot;settings&quot; : { &quot;region&quot; : &quot;us-east-1&quot; } }\r\n    { &quot;_id&quot; : &quot;ObjectId(\\&quot;5ad894fbe4b0657c569ed5d8\\&quot;)&quot;, &quot;account&quot; : &quot;def&quot;, &quot;profile&quot; : &quot;test&quot;, &quot;settings&quot; : { &quot;region&quot; : &quot;eu-central-1&quot; } }\r\n    { &quot;_id&quot; : &quot;ObjectId(\\&quot;5ae127dee4b06990170a0eb4\\&quot;)&quot;, &quot;account&quot; : &quot;ght&quot;, &quot;profile&quot; : &quot;main&quot;, &quot;settings&quot; : { &quot;region&quot; : &quot;us-east-1&quot; } }\r\n\r\nyou&#39;ll be able to perform the needed sorting:\r\n\r\n    jq -sc &#39;sort_by(.settings.region)[]&#39; testout.out\r\n\r\nThe output:\r\n\r\n    {&quot;_id&quot;:&quot;ObjectId(\\&quot;5ad894fbe4b0657c569ed5d8\\&quot;)&quot;,&quot;account&quot;:&quot;def&quot;,&quot;profile&quot;:&quot;test&quot;,&quot;settings&quot;:{&quot;region&quot;:&quot;eu-central-1&quot;}}\r\n    {&quot;_id&quot;:&quot;ObjectId(\\&quot;5aaaa017e4b09780301b6c18\\&quot;)&quot;,&quot;account&quot;:&quot;abc&quot;,&quot;profile&quot;:&quot;catch&quot;,&quot;settings&quot;:{&quot;region&quot;:&quot;us-east-1&quot;}}\r\n    {&quot;_id&quot;:&quot;ObjectId(\\&quot;5ae127dee4b06990170a0eb4\\&quot;)&quot;,&quot;account&quot;:&quot;ght&quot;,&quot;profile&quot;:&quot;main&quot;,&quot;settings&quot;:{&quot;region&quot;:&quot;us-east-1&quot;}}\r\n\r\n",
                "title": "how to properly use jq to sort json output"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1530500837,
                "last_edit_date": 1530500837,
                "creation_date": 1530477906,
                "answer_id": 51126891,
                "question_id": 51125135,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could probably get away with this pre-filter to convert the JSON-like objects to valid JSON:\r\n\r\n     sed &#39;s/: ObjectId(&quot;\\([^&quot;]*\\)&quot;)/: &quot;ObjectId(\\1)&quot;/g&#39; ",
                "title": "how to properly use jq to sort json output"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1530500837,
        "creation_date": 1530463086,
        "question_id": 51125135,
        "body_markdown": "Need some assistance configuring this `jq` command against `json` type output. \r\n\r\nExample `testout.out`:\r\n\r\n    { &quot;_id&quot; : ObjectId(&quot;5aaaa017e4b09780301b6c18&quot;), &quot;account&quot; : &quot;abc&quot;, &quot;profile&quot; : &quot;catch&quot;, &quot;settings&quot; : { &quot;region&quot; : &quot;us-east-1&quot; } }\r\n    { &quot;_id&quot; : ObjectId(&quot;5ad894fbe4b0657c569ed5d8&quot;), &quot;account&quot; : &quot;def&quot;, &quot;profile&quot; : &quot;test&quot;, &quot;settings&quot; : { &quot;region&quot; : &quot;eu-central-1&quot; } }\r\n    { &quot;_id&quot; : ObjectId(&quot;5ae127dee4b06990170a0eb4&quot;), &quot;account&quot; : &quot;ght&quot;, &quot;profile&quot; : &quot;main&quot;, &quot;settings&quot; : { &quot;region&quot; : &quot;us-east-1&quot; } }\r\n\r\nI&#39;m trying to sort by `region`.\r\n\r\nTrying this command:\r\n\r\n    cat testout.out | jq -s -c &#39;sort_by(.region) |.[]&#39;\r\n\r\n\r\nGetting this output:\r\n`parse error: Invalid numeric literal at line 1, column 20`\r\n\r\nExpecting alphabetical sort on `region`:\r\n\r\n    { &quot;_id&quot; : ObjectId(&quot;5ad894fbe4b0657c569ed5d8&quot;), &quot;account&quot; : &quot;def&quot;, &quot;profile&quot; : &quot;test&quot;, &quot;settings&quot; : { &quot;region&quot; : &quot;eu-central-1&quot; } }\r\n    { &quot;_id&quot; : ObjectId(&quot;5aaaa017e4b09780301b6c18&quot;), &quot;account&quot; : &quot;abc&quot;, &quot;profile&quot; : &quot;catch&quot;, &quot;settings&quot; : { &quot;region&quot; : &quot;us-east-1&quot; } }\r\n    { &quot;_id&quot; : ObjectId(&quot;5ae127dee4b06990170a0eb4&quot;), &quot;account&quot; : &quot;ght&quot;, &quot;profile&quot; : &quot;main&quot;, &quot;settings&quot; : { &quot;region&quot; : &quot;us-east-1&quot; } }",
        "link": "https://stackoverflow.com/questions/51125135/how-to-properly-use-jq-to-sort-json-output",
        "title": "how to properly use jq to sort json output"
    },
    {
        "tags": [
            "json",
            "linux",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1530487034,
                "creation_date": 1530487034,
                "answer_id": 51127658,
                "question_id": 51127531,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of trying to put literal newlines in your data, split the data into separate arrays (one per line of desired output), and pass each one to `@csv`.\r\n\r\n    s=&#39;{&quot;things&quot;:[{&quot;thing_name&quot;:&quot;Bestco&quot;,&quot;thing_id&quot;:1},{&quot;thing_name&quot;:&quot;GreatCo&quot;,&quot;thing_id&quot;:2},{&quot;thing_name&quot;:&quot;DressCo&quot;,&quot;thing_id&quot;:3}]}&#39;\r\n\r\n    jq -r &#39;.things[] | [.thing_name, .thing_id] | @csv&#39; &lt;&lt;&lt;&quot;$s&quot;\r\n\r\n...properly emits:\r\n\r\n    &quot;Bestco&quot;,1\r\n    &quot;GreatCo&quot;,2\r\n    &quot;DressCo&quot;,3",
                "title": "jq array of hashes to csv"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1530496663,
        "creation_date": 1530485435,
        "last_edit_date": 1530496663,
        "question_id": 51127531,
        "body_markdown": "So I have a data source like this:\r\n\r\n    {\r\n      &quot;things&quot;: [\r\n        {\r\n          &quot;thing_name&quot;: &quot;Bestco&quot;,\r\n          &quot;thing_id&quot;: 1\r\n        },\r\n        {\r\n          &quot;thing_name&quot;: &quot;GreatCo&quot;,\r\n          &quot;thing_id&quot;: 2\r\n        },\r\n        {\r\n          &quot;thing_name&quot;: &quot;DressCo&quot;,\r\n          &quot;thing_id&quot;: 3\r\n        }\r\n      ]\r\n    }\r\n\r\nI want to get output like this:\r\n\r\n    $ echo &#39;{&quot;things&quot;:[{&quot;thing_name&quot;:&quot;Bestco&quot;,&quot;thing_id&quot;:1},{&quot;thing_name&quot;:&quot;GreatCo&quot;,&quot;thing_id&quot;:2},{&quot;thing_name&quot;:&quot;DressCo&quot;,&quot;thing_id&quot;:3}]}&#39; |\r\n      jq -r &#39;.things | map(.thing_name, .thing_id, &quot;\\n&quot;) | @csv&#39; |\r\n      sed -e &#39;s/,&quot;$//g&#39; -e &#39;s/^&quot;,//g&#39; -e &#39;s/^&quot;$//g&#39;\r\n    &quot;Bestco&quot;,1\r\n    &quot;GreatCo&quot;,2\r\n    &quot;DressCo&quot;,3\r\n\r\n    $ \r\n\r\nUsing a fake parameter seems like a hack and then needs to be clean up by sed to work. How do I do this with just jq.",
        "link": "https://stackoverflow.com/questions/51127531/jq-array-of-hashes-to-csv",
        "title": "jq array of hashes to csv"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1530521156,
                "last_edit_date": 1530521156,
                "creation_date": 1530515217,
                "answer_id": 51130738,
                "question_id": 51130649,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You _don&#39;t_ need an `awk` statement inside the while loop, but just read the key value pairs inside the `read` command itself.\r\n\r\nAlso storing `awk` output in a variable and later parsing is an anti-pattern. You could use the process substitution feature provided by the shell, the `&lt; &lt;()` part will slurp the output of a command as if it were appearing on a file (or) use the here-strings\r\n\r\n    json=$(cat &lt;&lt;-EOF\r\n    {\r\n        &quot;kind&quot;: &quot;Secret&quot;,\r\n        &quot;apiVersion&quot;: &quot;v1&quot;,\r\n        &quot;metadata&quot;: {\r\n          &quot;name&quot;: &quot;$SECRET_ID&quot;\r\n        },\r\n        &quot;stringData&quot;: {\r\n        }\r\n    }\r\n    EOF\r\n    )\r\n\r\n    while read -r key value; do\r\n        json=$(echo &quot;$json&quot; | jq &quot;.stringData += { \\&quot;$key\\&quot; : \\&quot;$value\\&quot; }&quot;)\r\n    done&lt; &lt;(awk -F= &#39;!($1 &amp;&amp; $2 &amp;&amp; NF==2) { print &quot;File failed validation on line &quot; NR | &quot;cat 1&gt;&amp;2&quot;; next } { print $1, $2 }&#39; $f)\r\n\r\nYou could now use the variable `&quot;$json&quot;` in the `curl` as  \r\n\r\n    curl -k \\\r\n      -X PUT \\\r\n      -d @- \\\r\n      -H &quot;Authorization: Bearer $TOKEN&quot; \\\r\n      -H &quot;Accept: application/json&quot; \\\r\n      -H &quot;Content-Type: application/json&quot; \\\r\n      &quot;$SERVER_URL/api/v1/namespaces/$NAMESPACE/secrets/$SECRET_ID&quot; &lt;&lt;&lt;&quot;$json&quot;",
                "title": "jq shell script: aggregate iteration content into json body"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1530521156,
        "creation_date": 1530514867,
        "last_edit_date": 1530518026,
        "question_id": 51130649,
        "body_markdown": "I&#39;m creating a shell script.\r\n\r\nI need to create a curl json body according the a `key-value` list content. This content is splitted by way of a `awk` which generate a two column table:\r\n\r\n    KVS_VARIABLES=$(awk -F= &#39;!($1 &amp;&amp; $2 &amp;&amp; NF==2) { print &quot;File failed validation on line &quot; NR | &quot;cat 1&gt;&amp;2&quot;; next } { print $1, $2 }&#39; $f)\r\n\r\nExample output:\r\n\r\n    VAR1 VAL1\r\n    VAR2 VAL2\r\n    VAR3 VAL3\r\n\r\nSo, this table is iterated on a while iteration and each `key` and `value` are splitted:\r\n\r\n    echo &quot;$KVS_VARIABLES&quot; | while read -r kv\r\n      do\r\n        key=$(echo $kv | awk &#39;{print $1}&#39;)\r\n        value=$(echo $kv | awk &#39;{print $2}&#39;)\r\n      done\r\n\r\nSo, I need some way to aggregate this content into a json document in order to send it out using `curl`:\r\n\r\n    curl -k \\\r\n      -X PUT \\\r\n      -d @- \\\r\n      -H &quot;Authorization: Bearer $TOKEN&quot; \\\r\n      -H &quot;Accept: application/json&quot; \\\r\n      -H &quot;Content-Type: application/json&quot; \\\r\n      &quot;$SERVER_URL/api/v1/namespaces/$NAMESPACE/secrets/$SECRET_ID&quot; &lt;&lt;-EOF\r\n      {\r\n        &quot;kind&quot;: &quot;Secret&quot;,\r\n        &quot;apiVersion&quot;: &quot;v1&quot;,\r\n        &quot;metadata&quot;: {\r\n          &quot;name&quot;: &quot;$SECRET_ID&quot;\r\n        },\r\n        &quot;stringData&quot;: {\r\n          &quot;$key&quot;: &quot;$value&quot;     &lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;(1)&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;\r\n        }\r\n      }\r\n    EOF\r\n\r\nSo, on `&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;(1)&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;` I need to aggregate each `key` and `value` propagation.`\r\n\r\nSo, in this case I&#39;d need to generate:\r\n\r\n    &quot;VAR1&quot;: &quot;VAL1&quot;,\r\n    &quot;VAR2&quot;: &quot;VAL2&quot;,\r\n    &quot;VAR3&quot;: &quot;VAL3&quot;\r\n\r\nand then insert it inside &quot;stringData&quot;:\r\n\r\n    {\r\n        &quot;kind&quot;: &quot;Secret&quot;,\r\n        &quot;apiVersion&quot;: &quot;v1&quot;,\r\n        &quot;metadata&quot;: {\r\n          &quot;name&quot;: &quot;$SECRET_ID&quot;\r\n        },\r\n        &quot;stringData&quot;: {\r\n           &lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;(1)&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;&gt;\r\n        }\r\n    }\r\n\r\nSo, after all:\r\n\r\n    {\r\n        &quot;kind&quot;: &quot;Secret&quot;,\r\n        &quot;apiVersion&quot;: &quot;v1&quot;,\r\n        &quot;metadata&quot;: {\r\n          &quot;name&quot;: &quot;$SECRET_ID&quot;\r\n        },\r\n        &quot;stringData&quot;: {\r\n           &quot;VAR1&quot;: &quot;VAL1&quot;,\r\n           &quot;VAR2&quot;: &quot;VAL2&quot;,\r\n           &quot;VAR3&quot;: &quot;VAL3&quot;\r\n        }\r\n    }\r\n\r\n`jq` is installed.\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/51130649/jq-shell-script-aggregate-iteration-content-into-json-body",
        "title": "jq shell script: aggregate iteration content into json body"
    },
    {
        "tags": [
            "json",
            "regex",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 26,
                "is_accepted": true,
                "score": 26,
                "last_activity_date": 1530523744,
                "creation_date": 1530523744,
                "answer_id": 51132938,
                "question_id": 51132305,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `paths/1` instead of `path` because the former ignores null paths. Also with `path` you need to add a filter logic to ignore the `null` which does not match any of the regex conditions\r\n\r\n    paths(select(.name? | match(&quot;Name [0-9]&quot;)))[0]\r\n\r\nSee [jq - documetation - paths/1](https://stedolan.github.io/jq/manual/)",
                "title": "jq: Select property value using regex"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 14,
        "last_activity_date": 1530523744,
        "creation_date": 1530521558,
        "question_id": 51132305,
        "body_markdown": "I have the following json Object:\r\n\r\n    {\r\n        &quot;foo&quot;: {\r\n            &quot;name&quot;: &quot;Name 1&quot;,\r\n            &quot;color&quot;: &quot;green&quot;,\r\n            &quot;something_else&quot;: {\r\n                &quot;name&quot; : &quot;Name 2&quot;\r\n            }\r\n    \r\n        },\r\n        &quot;bar&quot;: {\r\n            &quot;name&quot;: &quot;Something else&quot;,\r\n            &quot;color&quot;: &quot;red&quot;\r\n        }\r\n    }\r\n\r\n\r\n\r\nTo get all possible parents properties of the property called &quot;name&quot; using jq I tried :\r\n\r\n    path(recurse|select(.name? !=&quot;&quot;))[0] \r\n\r\nAnd it works and give back :\r\n\r\n    &quot;foo&quot;\r\n    &quot;foo&quot;\r\n    &quot;bar&quot;\r\n\r\nNow I want to apply regex to filter the property value, say I want to consider only all properties called `name` that have a value beginning with &quot;Name&quot; and followed by a number like `&quot;Name 2&quot;`, to get:\r\n\r\n    &quot;foo&quot;\r\n    &quot;foo&quot;\r\n\r\n\r\nI tried this:\r\n\r\n    path(recurse|select(.name? =~ match(/Name */)))[0] \r\n\r\n\r\n\r\nHow to use match and how to place it correctly inside the query ?",
        "link": "https://stackoverflow.com/questions/51132305/jq-select-property-value-using-regex",
        "title": "jq: Select property value using regex"
    },
    {
        "tags": [
            "jq",
            "collect"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1620438,
                    "reputation": 15661,
                    "user_id": 1497139,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/3FVKA.png?s=256",
                    "display_name": "Wolfgang Fahl",
                    "link": "https://stackoverflow.com/users/1497139/wolfgang-fahl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1641821737,
                "post_id": 51132530,
                "comment_id": 124899324,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1530523429,
                "creation_date": 1530523429,
                "answer_id": 51132824,
                "question_id": 51132530,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With *double* `split`:\r\n\r\n    echo -e &quot;a 1\\nb 2&quot; | jq -sR &#39;split(&quot;\\n&quot;)[:-1] | map(split(&quot; &quot;))&#39;\r\n\r\nThe output:\r\n\r\n    [\r\n      [\r\n        &quot;a&quot;,\r\n        &quot;1&quot;\r\n      ],\r\n      [\r\n        &quot;b&quot;,\r\n        &quot;2&quot;\r\n      ]\r\n    ]\r\n\r\n",
                "title": "What is the jq equivalent for the slurp option?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1530539227,
                "creation_date": 1530539227,
                "answer_id": 51137716,
                "question_id": 51132530,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Before the advent of `inputs`, the answer to the question was &quot;No&quot;.  With `inputs` and the -n command-line option:\r\n    \r\n    $ echo -e &quot;a 1\\nb 2&quot; | jq -nR &#39;[inputs|split(&quot; &quot;)]&#39; \r\n    [\r\n      [\r\n        &quot;a&quot;,\r\n        &quot;1&quot;\r\n      ],\r\n      [\r\n        &quot;b&quot;,\r\n        &quot;2&quot;\r\n      ]\r\n    ]",
                "title": "What is the jq equivalent for the slurp option?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1530859536,
        "creation_date": 1530522375,
        "last_edit_date": 1530859536,
        "question_id": 51132530,
        "body_markdown": "This generates a list of arrays:\r\n\r\n    $ echo -e &quot;a 1\\nb 2&quot; | jq -R &#39;split(&quot; &quot;)&#39;\r\n    [\r\n      &quot;a&quot;,\r\n      &quot;1&quot;\r\n    ]\r\n    [\r\n      &quot;b&quot;,\r\n      &quot;2&quot;\r\n    ]\r\n\r\nWhen I slurp the input I get an array:\r\n\r\n    $ echo -e &quot;a 1\\nb 2&quot; | jq -R &#39;split(&quot; &quot;)&#39; | jq -s .\r\n    [\r\n      [\r\n        &quot;a&quot;,\r\n        &quot;1&quot;\r\n      ],\r\n      [\r\n        &quot;b&quot;,\r\n        &quot;2&quot;\r\n      ]\r\n    ]\r\n\r\nBut when I try to convert the list into an array without slurping it, I get a list of arrays instead of a single array:\r\n\r\n    $ echo -e &quot;a 1\\nb 2&quot; | jq -R &#39;[split(&quot; &quot;)]&#39;\r\n    [\r\n      [\r\n        &quot;a&quot;,\r\n        &quot;1&quot;\r\n      ]\r\n    ]\r\n    [\r\n      [\r\n        &quot;b&quot;,\r\n        &quot;2&quot;\r\n      ]\r\n    ]\r\n\r\nIs it possible to slurp the result of the `split` without piping the result into a new instance of `jq`?",
        "link": "https://stackoverflow.com/questions/51132530/what-is-the-jq-equivalent-for-the-slurp-option",
        "title": "What is the jq equivalent for the slurp option?"
    },
    {
        "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": 1530546108,
                "post_id": 51137733,
                "comment_id": 89263299,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10264917,
                    "reputation": 85,
                    "user_id": 7575178,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/64f85c6cfd721ce7dc79bcafc43e96ba?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "L. Howes",
                    "link": "https://stackoverflow.com/users/7575178/l-howes"
                },
                "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": 1530547842,
                "post_id": 51137733,
                "comment_id": 89264178,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1530570275,
                "last_edit_date": 1530570275,
                "creation_date": 1530545529,
                "answer_id": 51139486,
                "question_id": 51137733,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following filter groups by &quot;type&quot; as the question seems to require:\r\n\r\n    map(.id as $id\r\n        | [.foo[]\r\n          | {id: $id, bar: .bar[].type} +\r\n            {&quot;users_groups&quot;: (.users + .groups)[]} ]\r\n        | group_by(.bar)\r\n        | map(.[0] + {&quot;users_groups&quot;: [.[].users_groups]}) )\r\n\r\n## Output\r\n\r\n    [\r\n      [\r\n        {\r\n          &quot;id&quot;: 100,\r\n          &quot;bar&quot;: &quot;execute&quot;,\r\n          &quot;users_groups&quot;: [\r\n            &quot;admin_2&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: 100,\r\n          &quot;bar&quot;: &quot;read&quot;,\r\n          &quot;users_groups&quot;: [\r\n            &quot;admin_1&quot;,\r\n            &quot;admin_2&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: 100,\r\n          &quot;bar&quot;: &quot;write&quot;,\r\n          &quot;users_groups&quot;: [\r\n            &quot;admin_1&quot;\r\n          ]\r\n        }\r\n      ],\r\n      [\r\n        {\r\n          &quot;id&quot;: 101,\r\n          &quot;bar&quot;: &quot;read&quot;,\r\n          &quot;users_groups&quot;: [\r\n            &quot;admin_3&quot;\r\n          ]\r\n        }\r\n      ]\r\n    ]\r\n\r\n## Variations\r\nTo achieve the array-of-objects output format, simply tack on `| [.[][]]`;\r\nit would similarly be trivially easy to ensure that `.bar` is array-valued, though that might be pointless given that the grouping is by `.type`. \r\n",
                "title": "Convert a complex JSON file into a simple JSON file using JQ without getting cartesian product"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1530570275,
        "creation_date": 1530539271,
        "last_edit_date": 1530540083,
        "question_id": 51137733,
        "body_markdown": "I want to convert a complex JSON file into a simple JSON file using JQ. However, the query I&#39;m using generates an incorrect output.\r\n\r\nMy (cut down) JSON file:\r\n\r\n\t[\r\n\t  {\r\n\t\t&quot;id&quot;: 100,\r\n\t\t&quot;foo&quot;: [\r\n\t\t  {\r\n\t\t\t&quot;bar&quot;: [\r\n\t\t\t  {&quot;type&quot;: &quot;read&quot;},\r\n\t\t\t  {&quot;type&quot;: &quot;write&quot;}\r\n\t\t\t],\r\n\t\t\t&quot;users&quot;: [&quot;admin_1&quot;],\r\n\t\t\t&quot;groups&quot;: []\r\n\t\t  },\r\n\t\t  {\r\n\t\t\t&quot;bar&quot;: [\r\n\t\t\t  {&quot;type&quot;: &quot;execute&quot;},\r\n\t\t\t  { &quot;type&quot;: &quot;read&quot;}\r\n\t\t\t],\r\n\t\t\t&quot;users&quot;: [],\r\n\t\t\t&quot;groups&quot;: [&quot;admin_2&quot;]\r\n\t\t  }\r\n\t\t]\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 101,\r\n\t\t&quot;foo&quot;: [\r\n\t\t  {\r\n\t\t\t&quot;bar&quot;: [\r\n\t\t\t  {&quot;type&quot;: &quot;read&quot;}\r\n\t\t\t],\r\n\t\t\t&quot;users&quot;: [\r\n\t\t\t  &quot;admin_3&quot;\r\n\t\t\t],\r\n\t\t\t&quot;groups&quot;: []\r\n\t\t  }\r\n\t\t]\r\n\t  }\r\n\t]\r\n\t\r\nI need to generate a flatter JSON file and combine the users and groups into one field, similar to this:\r\n\r\n\t [\r\n\t  {\r\n\t\t&quot;id&quot;: 100,\r\n\t\t&quot;users_groups&quot;: [\r\n\t\t  &quot;admin_1&quot;,\r\n\t\t  &quot;admin_2&quot;\r\n\t\t],\r\n\t\t&quot;bar&quot;: [&quot;read&quot;]\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 100,\r\n\t\t&quot;users_groups&quot;: [&quot;admin_1&quot;],\r\n\t\t&quot;bar&quot;: [&quot;write&quot;]\r\n\t  },\r\n\t  {\r\n\t\t&quot;id&quot;: 100,\r\n\t\t&quot;users_groups&quot;: [&quot;admin_2&quot;],\r\n\t\t&quot;bar&quot;: [&quot;execute&quot;]\r\n\t  },\r\n\t   {\r\n\t\t&quot;id&quot;: 101,\r\n\t\t&quot;users_groups&quot;: [&quot;admin_3&quot;],\r\n\t\t&quot;bar&quot;: [&quot;read&quot;]\r\n\t  }\r\n\t ]\t\r\n\t \r\nEverything I try in JQ results in me getting an incorrect output (where admin_1 incorrectly has bar=execute and admin_2 incorrectly has bar=write), similar to the following:\r\n\r\n\t[\r\n\t  {\r\n\t\t&quot;id&quot;: 100,\r\n\t\t&quot;users_groups&quot;: [\r\n\t\t  &quot;admin_1&quot;,\r\n\t\t  &quot;admin_2&quot;\r\n\t\t],\r\n\t\t&quot;bar&quot;: [&quot;read&quot;, &quot;write&quot;, &quot;execute&quot;]\r\n\t  },\r\n\t   {\r\n\t\t&quot;id&quot;: 101,\r\n\t\t&quot;users_groups&quot;: [&quot;admin_3&quot;],\r\n\t\t&quot;bar&quot;: [&quot;read&quot;]\r\n\t  }\r\n\t ] \r\n\t \r\nI have tried many vairiats of this query - any idea what I should be doing instead?\r\n\r\n\t\tcat file.json | jq -r &#39;[.[] | select(has(&quot;foo&quot;)) |{&quot;id&quot;, &quot;users&quot;:(.foo[] | .users), &quot;groups&quot;:(.foo[] | .groups), &quot;bar&quot;:([.foo[].bar[] | .type])} ] &#39;",
        "link": "https://stackoverflow.com/questions/51137733/convert-a-complex-json-file-into-a-simple-json-file-using-jq-without-getting-car",
        "title": "Convert a complex JSON file into a simple JSON file using JQ without getting cartesian product"
    },
    {
        "tags": [
            "json",
            "edit",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1530600358,
                "creation_date": 1530600358,
                "answer_id": 51148150,
                "question_id": 51147753,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes it is, provided you add a comma on line 8 after the closing bracket `}` (otherwise `jq` won&#39;t parse your input JSON data):\r\n\r\n    $ jq &#39;.x.x3=&quot;x3val&quot;|.x.x4=&quot;x4val&quot;&#39; file\r\n    {\r\n      &quot;a&quot;: &quot;aVal&quot;,\r\n      &quot;x&quot;: {\r\n        &quot;x1&quot;: &quot;x1Val&quot;,\r\n        &quot;x2&quot;: &quot;x2Val&quot;,\r\n        &quot;x3&quot;: &quot;x3val&quot;,\r\n        &quot;x4&quot;: &quot;x4val&quot;\r\n      },\r\n      &quot;y&quot;: {\r\n        &quot;y1&quot;: &quot;y1Val&quot;\r\n      }\r\n    }\r\n\r\nAlternatively if you need to pass values as argument, use the option `--arg`:\r\n\r\n    jq --arg v3 &quot;x3val&quot; --arg v4 &quot;x4val&quot; &#39;.x.x3=$v3|.x.x4=$v4&#39; file\r\n\r\n",
                "title": "Append JSON Objects using jq"
            },
            {
                "up_vote_count": 16,
                "is_accepted": true,
                "score": 16,
                "last_activity_date": 1530600398,
                "creation_date": 1530600398,
                "answer_id": 51148168,
                "question_id": 51147753,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Of course, it&#39;s pretty simple for **`jq`**:\r\n\r\n    jq &#39;.x += {&quot;x3&quot;: &quot;x3Val&quot;,&quot;x4&quot;: &quot;x4Val&quot;}&#39; file.json\r\n\r\nThe output:\r\n\r\n    {\r\n      &quot;a&quot;: &quot;aVal&quot;,\r\n      &quot;x&quot;: {\r\n        &quot;x1&quot;: &quot;x1Val&quot;,\r\n        &quot;x2&quot;: &quot;x2Val&quot;,\r\n        &quot;x3&quot;: &quot;x3Val&quot;,\r\n        &quot;x4&quot;: &quot;x4Val&quot;\r\n      },\r\n      &quot;y&quot;: {\r\n        &quot;y1&quot;: &quot;y1Val&quot;\r\n      }\r\n    }\r\n\r\n",
                "title": "Append JSON Objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 10,
        "last_activity_date": 1530601268,
        "creation_date": 1530598581,
        "last_edit_date": 1530601268,
        "question_id": 51147753,
        "body_markdown": "I&#39;ve below `JSON` structure \r\n\r\n    {\r\n    \r\n        &quot;a&quot;: &quot;aVal&quot;,\r\n        &quot;x&quot;: {\r\n          &quot;x1&quot;: &quot;x1Val&quot;,\r\n          &quot;x2&quot;: &quot;x2Val&quot;\r\n        }\r\n        &quot;y&quot;: {\r\n          &quot;y1&quot;: &quot;y1Val&quot;\r\n        }\r\n    }\r\n\r\nI want to add `&quot;x3&quot;: &quot;x3Val&quot;,&quot;x4&quot;: &quot;x4Val&quot;` to `x`. So the output should be \r\n\r\n    {\r\n        ...\r\n        &quot;x&quot;: {\r\n          ....\r\n          &quot;x3&quot;: &quot;x3Val&quot;,\r\n          &quot;x4&quot;: &quot;x4Val&quot;,\r\n        }\r\n        ...\r\n    }\r\n\r\nIs it possible using [jq](https://github.com/stedolan/jq) ?",
        "link": "https://stackoverflow.com/questions/51147753/append-json-objects-using-jq",
        "title": "Append JSON Objects using jq"
    },
    {
        "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": 1530641037,
                "post_id": 51157550,
                "comment_id": 89304541,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1530640923,
                "last_edit_date": 1530640923,
                "creation_date": 1530640573,
                "answer_id": 51160483,
                "question_id": 51157550,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest approach is to use `walk/1`, which however was only introduced after the release of jq 1.5.  The following therefore includes its definition:\r\n\r\n    # Apply f to composite entities recursively, and to atoms\r\n    def walk(f): \r\n      . as $in\r\n      | if type == &quot;object&quot; then\r\n          reduce keys[] as $key\r\n            ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n      elif type == &quot;array&quot; then map( walk(f) ) | f\r\n      else f\r\n      end;\r\n  \r\n    walk(if type==&quot;array&quot; and length==1 and (.[0]|type) == &quot;object&quot; then .[0] else . end)\r\n\r\nOf course many variants are possible, e.g. along the lines of your program:\r\n\r\n    walk(if type==&quot;array&quot; and length==1 then .[0] else . end)\r\n\r\n\r\n",
                "title": "jq ~ is there a better way to collapse single object arrays?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1530641344,
        "creation_date": 1530629576,
        "last_edit_date": 1530641344,
        "question_id": 51157550,
        "body_markdown": "**Question:**\r\nIs this the best way to do this ?\r\n\r\nTool:\r\n\r\n`jq --version\r\njq-1.5-1-a5b5cbe`\r\n\r\n**Requirement:**  To recursively identify arrays `[]` that only contain a single object `{}` and to convert the array back to a standard object `{}`.  Essentially to strip out the parent array when its not needed.\r\n\r\n**What seems to be working:**\r\n\r\n`(..|select(type==&quot;array&quot; and .[1] == null ) | . ) |= add | .`\r\n\r\n**Use case:**\r\nGoogle Custom Search JSON contains numerous arrays, many of which are single object arrays.  Logstash `input`, `codec =&gt; json` and/or `json` filter seems not to be able to automatically turn single object arrays into elasticsearch fields.",
        "link": "https://stackoverflow.com/questions/51157550/jq-is-there-a-better-way-to-collapse-single-object-arrays",
        "title": "jq ~ is there a better way to collapse single object arrays?"
    },
    {
        "tags": [
            "json",
            "linux",
            "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": 1530645814,
                "post_id": 51160906,
                "comment_id": 89306629,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1530645479,
                "creation_date": 1530645479,
                "answer_id": 51161585,
                "question_id": 51160906,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I still don&#39;t know if the json I&#39;m getting is bad or if this is a bug in jq. I found this solution using sed to make the array not empty.\r\n\r\n    $ echo &#39;[{&quot;thing-1&quot; : &quot;meta1&quot;,&quot;thing-2&quot; : &quot;meta2&quot;,&quot;thing-n&quot; : &quot;metan&quot;,&quot;subThings&quot;:[]}]&#39; | sed &#39;s/\\[ *\\]/[null]/g&#39; | jq &#39;[.[] | {&quot;thing-1&quot;,&quot;thing-5&quot;,&quot;subThing-2&quot;:.subThings[][&quot;subThing-2&quot;],}]&#39;\r\n    [\r\n      {\r\n        &quot;thing-1&quot;: &quot;meta1&quot;,\r\n        &quot;thing-5&quot;: null,\r\n        &quot;subThing-2&quot;: null\r\n      }\r\n    ]\r\n    $",
                "title": "jq returns nothing if nested array is empty"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1530649806,
                "creation_date": 1530649806,
                "answer_id": 51162433,
                "question_id": 51160906,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re attempting to generate objects based on the existence of `subThings` objects. That&#39;s effectively what `.subThings[]` does in the context of `{&quot;thing-1&quot;,&quot;thing-5&quot;,&quot;subThing-2&quot;:.subThings[][&quot;subThing-2&quot;]}`.\r\n\r\nYou need to evaluate the `subThings` separately and replace with `null` if there are none, otherwise it will just simply be `empty` which yields nothing (which is what you&#39;re seeing here).\r\n\r\n    map({ &quot;thing-1&quot;, &quot;thing-5&quot;, &quot;subThing-2&quot;: (.subThings[].&quot;subThing-2&quot; // null) })",
                "title": "jq returns nothing if nested array is empty"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1530814021,
        "creation_date": 1530642450,
        "last_edit_date": 1530814021,
        "question_id": 51160906,
        "body_markdown": "here the array subThings is populated\r\n\r\n    $ echo &#39;[{&quot;thing-1&quot; : &quot;meta1&quot;,&quot;thing-2&quot; : &quot;meta2&quot;,&quot;thing-n&quot; : &quot;metan&quot;,&quot;subThings&quot;:[{&quot;subThing-1&quot; : &quot;subMeta1&quot;,&quot;subThing-2&quot; : &quot;subMeta2&quot;,&quot;subThing-n&quot; : &quot;subMetan&quot;}]}]&#39; | jq &#39;.&#39;\r\n    [\r\n      {\r\n        &quot;subThings&quot;: [\r\n          {\r\n            &quot;subThing-n&quot;: &quot;subMetan&quot;,\r\n            &quot;subThing-2&quot;: &quot;subMeta2&quot;,\r\n            &quot;subThing-1&quot;: &quot;subMeta1&quot;\r\n          }\r\n        ],\r\n        &quot;thing-n&quot;: &quot;metan&quot;,\r\n        &quot;thing-2&quot;: &quot;meta2&quot;,\r\n        &quot;thing-1&quot;: &quot;meta1&quot;\r\n      }\r\n    ]\r\n\r\nyou can see here that missing keys are just set to null.\r\n\r\n    $ echo &#39;[{&quot;thing-1&quot; : &quot;meta1&quot;,&quot;thing-2&quot; : &quot;meta2&quot;,&quot;thing-n&quot; : &quot;metan&quot;,&quot;subThings&quot;:[{&quot;subThing-1&quot; : &quot;subMeta1&quot;,&quot;subThing-2&quot; : &quot;subMeta2&quot;,&quot;subThing-n&quot; : &quot;subMetan&quot;}]}]&#39; |\r\n     jq &#39;[.[] | {&quot;thing-1&quot;,&quot;thing-5&quot;,&quot;subThing-2&quot;:.subThings[][&quot;subThing-2&quot;],}]&#39;\r\n    [\r\n      {\r\n        &quot;subThing-2&quot;: &quot;subMeta2&quot;,\r\n        &quot;thing-5&quot;: null,\r\n        &quot;thing-1&quot;: &quot;meta1&quot;\r\n      }\r\n    ]\r\n\r\nhere the array subThings is empty\r\n\r\n    $ echo &#39;[{&quot;thing-1&quot; : &quot;meta1&quot;,&quot;thing-2&quot; : &quot;meta2&quot;,&quot;thing-n&quot; : &quot;metan&quot;,&quot;subThings&quot;:[]}]&#39; | jq &#39;.&#39;\r\n    [\r\n      {\r\n        &quot;subThings&quot;: [],\r\n        &quot;thing-n&quot;: &quot;metan&quot;,\r\n        &quot;thing-2&quot;: &quot;meta2&quot;,\r\n        &quot;thing-1&quot;: &quot;meta1&quot;\r\n      }\r\n    ]\r\ninstead of nulls for subThing-2 it wipes out all the data.\r\n\r\n    $ echo &#39;[{&quot;thing-1&quot; : &quot;meta1&quot;,&quot;thing-2&quot; : &quot;meta2&quot;,&quot;thing-n&quot; : &quot;metan&quot;,&quot;subThings&quot;:[]}]&#39; |\r\n      jq &#39;[.[] | {&quot;thing-1&quot;,&quot;thing-5&quot;,&quot;subThing-2&quot;:.subThings[][&quot;subThing-2&quot;],}]&#39;\r\n    []\r\n    $ \r\n\r\nWhy?&lt;br&gt;\r\nIs there a different way to get the data without the empty array wiping everything out?",
        "link": "https://stackoverflow.com/questions/51160906/jq-returns-nothing-if-nested-array-is-empty",
        "title": "jq returns nothing if nested array is empty"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq",
            "string-comparison"
        ],
        "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": 1530777579,
                "post_id": 51183360,
                "comment_id": 89354159,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1530778960,
                "last_edit_date": 1530778960,
                "creation_date": 1530776947,
                "answer_id": 51185932,
                "question_id": 51183360,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The value of arrayA is not JSON so I am going to let you figure out how to extract the values of Line_Number and Status from arrayA (but see below).  Once those values are available, one could proceed as illustrated here:\r\n\r\n\r\n    #!/bin/bash\r\n    \r\n    bbview=&#39;...&#39; # as above\r\n    \r\n    echo &quot;$bbview&quot; |\r\n      jq --arg Line_Number SS001 --arg Status Yes &#39;\r\n        .tbl_am_api\r\n        | map(select(.Line_Number==$Line_Number and .Status==$Status)) &#39;\r\n        \r\n## Output\r\n\r\n    [\r\n      {\r\n        &quot;Modified_User&quot;: &quot;user1&quot;,\r\n        &quot;Modified_Time&quot;: &quot;04-Jul-2018 01:40:05&quot;,\r\n        &quot;Line_Number&quot;: &quot;SS001&quot;,\r\n        &quot;Service_Type&quot;: &quot;BB3&quot;,\r\n        &quot;Status&quot;: &quot;Yes&quot;,\r\n        &quot;ID&quot;: 3144526000014338000,\r\n        &quot;Added_Time&quot;: &quot;04-May-2018 11:37:29&quot;\r\n      }\r\n    ]\r\n\r\n## true/false\r\n\r\nUnder a different reading of the question, the following variant might be relevant:\r\n\r\n    echo &quot;$bbview&quot; |\r\n      jq --arg Line_Number SS001 --arg Status Yes &#39;\r\n        .tbl_am_api\r\n        | map(select(.Line_Number==$Line_Number) | .Status==$Status) &#39;\r\n\r\n## arrayA\r\n\r\nIf you are using a version of bash that supports associative arrays, you could define arrayA as an associative array, like so:\r\n\r\n    declare -A arrayA\r\n    arrayA=([Line_Number]=SS001 [Service_Type]=BB3 [Status]=Yes)\r\n\r\nThen to retrieve the value associated with Line_Number, you would write: `${arrayA[Line_Number]}`; etc.\r\n\r\n",
                "title": "How to compare Json data with array using Shell Script?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1530778960,
        "creation_date": 1530764577,
        "last_edit_date": 1530777227,
        "question_id": 51183360,
        "body_markdown": "I have one json e.g \r\n\r\n    var bbview ={  \r\n       &quot;tbl_am_api&quot;:[  \r\n          {  \r\n             &quot;Modified_User&quot;:&quot;user1&quot;,\r\n             &quot;Modified_Time&quot;:&quot;04-Jul-2018 01:40:05&quot;,\r\n             &quot;Line_Number&quot;:&quot;SS001&quot;,\r\n             &quot;Service_Type&quot;:&quot;BB3&quot;,\r\n             &quot;Status&quot;:&quot;Yes&quot;,\r\n             &quot;ID&quot;:3144526000014337832,\r\n             &quot;Added_Time&quot;:&quot;04-May-2018 11:37:29&quot;\r\n          },\r\n          {  \r\n             &quot;Modified_User&quot;:&quot;user2&quot;,\r\n             &quot;Modified_Time&quot;:&quot;04-Jul-2018 01:40:05&quot;,\r\n             &quot;Line_Number&quot;:&quot;SS002&quot;,\r\n             &quot;Service_Type&quot;:&quot;BB2&quot;,\r\n             &quot;Status&quot;:&quot;Yes&quot;,\r\n             &quot;ID&quot;:3144526000014337832,\r\n             &quot;Added_Time&quot;:&quot;04-May-2018 11:37:29&quot;\r\n          },\r\n          {  \r\n             &quot;Modified_User&quot;:&quot;user3&quot;,\r\n             &quot;Modified_Time&quot;:&quot;04-Jul-2018 01:40:05&quot;,\r\n             &quot;Line_Number&quot;:&quot;SS004&quot;,\r\n             &quot;Service_Type&quot;:&quot;BB1&quot;,\r\n             &quot;Status&quot;:&quot;No&quot;,\r\n             &quot;ID&quot;:3144526000014337832,\r\n             &quot;Added_Time&quot;:&quot;04-May-2018 11:37:29&quot;\r\n          }\r\n       ]\r\n    };\r\n\r\nI want to compare this json data and array. Primary key as Line Number.\r\n\r\n    arrayA = {[{Line_Number : SS001, Service_Type : BB3; Status : Yes}]}\r\n\r\narrayA have Line_Number SS001. Find this Line_Number in json and compare Service_Type value and Status value are same or not. I want to write with Shell Script in bash file. I am not proficient in shell script. Please help me.\r\n\r\nUpdate:\r\nI tried with following bash code. But still fail. Please advice me\r\n\r\n    echo &quot;Download FMS AM API File&quot;\r\n    rm -rf tbl_am_api_Report?authtoken=da84d49f334c33b88d30dd2c947a4ff0 &amp;&amp; wget -q https://creator.zoho.com/api/json/fixed-management-system/view/tbl_am_api_Report?authtoken=da84d49f334c33b88d30dd2c947a4ff0&amp;scope=creatorapi&amp;zc_ownername=tmlbroadband &lt; /dev/null\r\n    \r\n    cat &gt; tbl_api_Report?authtoken=da84d49f334c33b88d30dd2c947a4ff0 //read json file\r\n    for row in $(echo &quot;${apiview}&quot; | jq -r &#39;.[] | @base64&#39;); do\r\n        _jq() {\r\n         echo ${row} | base64 --decode | jq -r ${1}\r\n        }\r\n    \r\n       echo $(_jq &#39;.name&#39;) &gt;&gt; info.txt\r\n    done\r\n    \r\n    mail -s &quot;Test email&quot; aa@gmail.com -A info.txt &lt; /dev/null\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51183360/how-to-compare-json-data-with-array-using-shell-script",
        "title": "How to compare Json data with array using Shell Script?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1530774456,
                "last_edit_date": 1530774456,
                "creation_date": 1530773928,
                "answer_id": 51185094,
                "question_id": 51184524,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The idea is right, but the `data[]` array should be outside the `select` statement,\r\n\r\n    jq &#39;.data[] | select(.properties[].value == &quot;client_release&quot;) | .id&#39;\r\n\r\nTo put it in the CSV format as indicated in the question, put the result into an array and use the `@csv` construct\r\n\r\n    jq --raw-output &#39;[.data[] | select(.properties[].value == &quot;client_release&quot;) | .id] | @csv&#39;\r\n\r\n",
                "title": "Get parent element id while parsing json data with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1530775133,
                "last_edit_date": 1530775133,
                "creation_date": 1530774826,
                "answer_id": 51185328,
                "question_id": 51184524,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following filter avoids duplications and might be more efficient than using select(.properties[].value ...):\r\n\r\n    .data\r\n    | map(select(.properties | any(.[]; .value == &quot;client_release&quot;)) | .id)\r\n    | join(&quot;,&quot;)\r\n\r\n(You could alternatively use `@csv` at the end if you want the values of .id as JSON strings.)\r\n\r\n \r\n## &quot;repositoryId&quot;\r\n\r\nIf attention should only be paid to the value corresponding to &quot;repositoryId&quot;, then you could\r\nuse `from_entries`, e.g.:\r\n\r\n    .data\r\n    | map(select(.properties | from_entries.repositoryId == &quot;client_release&quot;) | .id)\r\n    | join(&quot;,&quot;)\r\n\r\n\r\n",
                "title": "Get parent element id while parsing json data with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1530784121,
        "creation_date": 1530771732,
        "last_edit_date": 1530784121,
        "question_id": 51184524,
        "body_markdown": "I want to print ID of parent element when child element value is `client_release` from JSON data.\r\n\r\nif\r\n    data.properties.value== &quot;client_release&quot;\r\n\r\nthen output should be \r\n\r\n    abcd1g2f,hirk5d7b3l\r\n\r\nI tried below, but no luck\r\n\r\n    jq &#39;.data[].properties[]|select(.value==&quot;client_release&quot;)|.id&#39;\r\n\r\nJSON data is below:\r\n\r\n    {  \r\n       &quot;data&quot;:[  \r\n          {  \r\n             &quot;id&quot;:&quot;abcd1g2f&quot;,\r\n             &quot;resourceURI&quot;:&quot;https://somerepo.com/service/local/privileges/abcd1g2f&quot;,\r\n             &quot;name&quot;:&quot;release1&quot;,\r\n             &quot;description&quot;:&quot;release1&quot;,\r\n             &quot;type&quot;:&quot;target&quot;,\r\n             &quot;userManaged&quot;:true,\r\n             &quot;properties&quot;:[  \r\n                {  \r\n                   &quot;key&quot;:&quot;repositoryGroupId&quot;,\r\n                   &quot;value&quot;:&quot;&quot;\r\n                },\r\n                {  \r\n                   &quot;key&quot;:&quot;method&quot;,\r\n                   &quot;value&quot;:&quot;create,read&quot;\r\n                },\r\n                {  \r\n                   &quot;key&quot;:&quot;repositoryId&quot;,\r\n                   &quot;value&quot;:&quot;client_release&quot;\r\n                },\r\n                {  \r\n                   &quot;key&quot;:&quot;repositoryTargetId&quot;,\r\n                   &quot;value&quot;:&quot;1&quot;\r\n                }\r\n             ]\r\n          },\r\n          {  \r\n             &quot;id&quot;:&quot;asdf1k4g&quot;,\r\n             &quot;resourceURI&quot;:&quot;https://somerepo.com/service/local/privileges/asdf1k4g&quot;,\r\n             &quot;name&quot;:&quot;release2&quot;,\r\n             &quot;description&quot;:&quot;release2&quot;,\r\n             &quot;type&quot;:&quot;target&quot;,\r\n             &quot;userManaged&quot;:true,\r\n             &quot;properties&quot;:[  \r\n                {  \r\n                   &quot;key&quot;:&quot;repositoryGroupId&quot;,\r\n                   &quot;value&quot;:&quot;&quot;\r\n                },\r\n                {  \r\n                   &quot;key&quot;:&quot;method&quot;,\r\n                   &quot;value&quot;:&quot;read&quot;\r\n                },\r\n                {  \r\n                   &quot;key&quot;:&quot;repositoryId&quot;,\r\n                   &quot;value&quot;:&quot;formal_release&quot;\r\n                },\r\n                {  \r\n                   &quot;key&quot;:&quot;repositoryTargetId&quot;,\r\n                   &quot;value&quot;:&quot;1&quot;\r\n                }\r\n             ]\r\n          },\r\n          {  \r\n             &quot;id&quot;:&quot;hirk5d7b3l&quot;,\r\n             &quot;resourceURI&quot;:&quot;https://somerepo.com/service/local/privileges/hirk5d7b3l&quot;,\r\n             &quot;name&quot;:&quot;release3&quot;,\r\n             &quot;description&quot;:&quot;release3&quot;,\r\n             &quot;type&quot;:&quot;target&quot;,\r\n             &quot;userManaged&quot;:true,\r\n             &quot;properties&quot;:[  \r\n                {  \r\n                   &quot;key&quot;:&quot;repositoryGroupId&quot;,\r\n                   &quot;value&quot;:&quot;&quot;\r\n                },\r\n                {  \r\n                   &quot;key&quot;:&quot;method&quot;,\r\n                   &quot;value&quot;:&quot;create,read&quot;\r\n                },\r\n                {  \r\n                   &quot;key&quot;:&quot;repositoryId&quot;,\r\n                   &quot;value&quot;:&quot;client_release&quot;\r\n                },\r\n                {  \r\n                   &quot;key&quot;:&quot;repositoryTargetId&quot;,\r\n                   &quot;value&quot;:&quot;1&quot;\r\n                }\r\n             ]\r\n          }\r\n       ]\r\n    }",
        "link": "https://stackoverflow.com/questions/51184524/get-parent-element-id-while-parsing-json-data-with-jq",
        "title": "Get parent element id while parsing json data with jq"
    },
    {
        "tags": [
            "shell",
            "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": 1530801004,
                "post_id": 51193201,
                "comment_id": 89369168,
                "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": 1530801842,
                "post_id": 51193201,
                "comment_id": 89369816,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1530801031,
        "creation_date": 1530799003,
        "last_edit_date": 1530801031,
        "question_id": 51193201,
        "body_markdown": "When i execute below command, it is printing the required thing i.e abcd1g2f\r\n\r\n    cat priv.json | jq &#39;.data | map(select(.properties | any(.[]; .value == &quot;client_release&quot;)) |.id)[0]&#39;\r\n\r\nbut when i execute same from shell script (this is requirement), it is printing null. can someone please help me?\r\n\r\nbelow is the shell script (test.sh) i wrote:\r\n\r\n    get_priv0=$(cat priv.json | jq &#39;.data | map(select(.properties | any(.[]; .value == &quot;$1&quot;)) |.id)[0]&#39;)\r\n    echo $get_priv0\r\n\r\ncommand which i executed\r\n\r\n    ./test.sh client_release\r\n\r\nJSON file (priv.json) is below:\r\n\r\n    {\r\n\t&quot;data&quot;: [{\r\n\t\t&quot;id&quot;: &quot;abcd1g2f&quot;,\r\n\t\t&quot;resourceURI&quot;: &quot;https://somerepo.com/service/local/privileges/abcd1g2f&quot;,\r\n\t\t&quot;name&quot;: &quot;release1&quot;,\r\n\t\t&quot;description&quot;: &quot;release1&quot;,\r\n\t\t&quot;type&quot;: &quot;target&quot;,\r\n\t\t&quot;userManaged&quot;: true,\r\n\t\t&quot;properties&quot;: [{\r\n\t\t\t&quot;key&quot;: &quot;repositoryGroupId&quot;,\r\n\t\t\t&quot;value&quot;: &quot;&quot;\r\n\t\t}, {\r\n\t\t\t&quot;key&quot;: &quot;method&quot;,\r\n\t\t\t&quot;value&quot;: &quot;create,read&quot;\r\n\t\t}, {\r\n\t\t\t&quot;key&quot;: &quot;repositoryId&quot;,\r\n\t\t\t&quot;value&quot;: &quot;client_release&quot;\r\n\t\t}, {\r\n\t\t\t&quot;key&quot;: &quot;repositoryTargetId&quot;,\r\n\t\t\t&quot;value&quot;: &quot;1&quot;\r\n\t\t}]\r\n\t}, {\r\n\t\t&quot;id&quot;: &quot;asdf1k4g&quot;,\r\n\t\t&quot;resourceURI&quot;: &quot;https://somerepo.com/service/local/privileges/asdf1k4g&quot;,\r\n\t\t&quot;name&quot;: &quot;release2&quot;,\r\n\t\t&quot;description&quot;: &quot;release2&quot;,\r\n\t\t&quot;type&quot;: &quot;target&quot;,\r\n\t\t&quot;userManaged&quot;: true,\r\n\t\t&quot;properties&quot;: [{\r\n\t\t\t&quot;key&quot;: &quot;repositoryGroupId&quot;,\r\n\t\t\t&quot;value&quot;: &quot;&quot;\r\n\t\t}, {\r\n\t\t\t&quot;key&quot;: &quot;method&quot;,\r\n\t\t\t&quot;value&quot;: &quot;read&quot;\r\n\t\t}, {\r\n\t\t\t&quot;key&quot;: &quot;repositoryId&quot;,\r\n\t\t\t&quot;value&quot;: &quot;formal_release&quot;\r\n\t\t}, {\r\n\t\t\t&quot;key&quot;: &quot;repositoryTargetId&quot;,\r\n\t\t\t&quot;value&quot;: &quot;1&quot;\r\n\t\t}]\r\n\t}, {\r\n\t\t&quot;id&quot;: &quot;hirk5d7b3l&quot;,\r\n\t\t&quot;resourceURI&quot;: &quot;https://somerepo.com/service/local/privileges/hirk5d7b3l&quot;,\r\n\t\t&quot;name&quot;: &quot;release3&quot;,\r\n\t\t&quot;description&quot;: &quot;release3&quot;,\r\n\t\t&quot;type&quot;: &quot;target&quot;,\r\n\t\t&quot;userManaged&quot;: true,\r\n\t\t&quot;properties&quot;: [{\r\n\t\t\t&quot;key&quot;: &quot;repositoryGroupId&quot;,\r\n\t\t\t&quot;value&quot;: &quot;&quot;\r\n\t\t}, {\r\n\t\t\t&quot;key&quot;: &quot;method&quot;,\r\n\t\t\t&quot;value&quot;: &quot;create,read&quot;\r\n\t\t}, {\r\n\t\t\t&quot;key&quot;: &quot;repositoryId&quot;,\r\n\t\t\t&quot;value&quot;: &quot;client_release&quot;\r\n\t\t}, {\r\n\t\t\t&quot;key&quot;: &quot;repositoryTargetId&quot;,\r\n\t\t\t&quot;value&quot;: &quot;1&quot;\r\n\t\t}]\r\n\t}]\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/51193201/shell-script-for-executing-a-command-which-accepts-command-line-arguments-and-st",
        "title": "shell script for executing a command which accepts command line arguments and store output to a variable"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530831325,
                "post_id": 51200224,
                "comment_id": 89383356,
                "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": 1530831400,
                "post_id": 51200224,
                "comment_id": 89383367,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13904865,
                    "reputation": 1,
                    "user_id": 10039509,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-YaeyTjf-PRc/AAAAAAAAAAI/AAAAAAAAAAA/AAnnY7qwYV7BSEwP2DrybUfJD-hdo8ubEQ/mo/s256-rj/photo.jpg",
                    "display_name": "sudhakar",
                    "link": "https://stackoverflow.com/users/10039509/sudhakar"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530886438,
                "post_id": 51200224,
                "comment_id": 89405547,
                "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": 1530889184,
                "post_id": 51200224,
                "comment_id": 89407020,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13904865,
                    "reputation": 1,
                    "user_id": 10039509,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-YaeyTjf-PRc/AAAAAAAAAAI/AAAAAAAAAAA/AAnnY7qwYV7BSEwP2DrybUfJD-hdo8ubEQ/mo/s256-rj/photo.jpg",
                    "display_name": "sudhakar",
                    "link": "https://stackoverflow.com/users/10039509/sudhakar"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531105689,
                "post_id": 51200224,
                "comment_id": 89454404,
                "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": 1531105806,
                "post_id": 51200224,
                "comment_id": 89454427,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13904865,
                    "reputation": 1,
                    "user_id": 10039509,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-YaeyTjf-PRc/AAAAAAAAAAI/AAAAAAAAAAA/AAnnY7qwYV7BSEwP2DrybUfJD-hdo8ubEQ/mo/s256-rj/photo.jpg",
                    "display_name": "sudhakar",
                    "link": "https://stackoverflow.com/users/10039509/sudhakar"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531145285,
                "post_id": 51200224,
                "comment_id": 89473771,
                "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": 1531145901,
                "post_id": 51200224,
                "comment_id": 89474176,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13904865,
                    "reputation": 1,
                    "user_id": 10039509,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-YaeyTjf-PRc/AAAAAAAAAAI/AAAAAAAAAAA/AAnnY7qwYV7BSEwP2DrybUfJD-hdo8ubEQ/mo/s256-rj/photo.jpg",
                    "display_name": "sudhakar",
                    "link": "https://stackoverflow.com/users/10039509/sudhakar"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531146990,
                "post_id": 51200224,
                "comment_id": 89474978,
                "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": 1531147662,
                "post_id": 51200224,
                "comment_id": 89475444,
                "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": 1531147743,
                "post_id": 51200224,
                "comment_id": 89475497,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13904865,
                    "reputation": 1,
                    "user_id": 10039509,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-YaeyTjf-PRc/AAAAAAAAAAI/AAAAAAAAAAA/AAnnY7qwYV7BSEwP2DrybUfJD-hdo8ubEQ/mo/s256-rj/photo.jpg",
                    "display_name": "sudhakar",
                    "link": "https://stackoverflow.com/users/10039509/sudhakar"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531149269,
                "post_id": 51200224,
                "comment_id": 89476500,
                "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": 1531149624,
                "post_id": 51200224,
                "comment_id": 89476712,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13904865,
                    "reputation": 1,
                    "user_id": 10039509,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-YaeyTjf-PRc/AAAAAAAAAAI/AAAAAAAAAAA/AAnnY7qwYV7BSEwP2DrybUfJD-hdo8ubEQ/mo/s256-rj/photo.jpg",
                    "display_name": "sudhakar",
                    "link": "https://stackoverflow.com/users/10039509/sudhakar"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531151393,
                "post_id": 51200224,
                "comment_id": 89477813,
                "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": 1531152277,
                "post_id": 51200224,
                "comment_id": 89478329,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13904865,
                    "reputation": 1,
                    "user_id": 10039509,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-YaeyTjf-PRc/AAAAAAAAAAI/AAAAAAAAAAA/AAnnY7qwYV7BSEwP2DrybUfJD-hdo8ubEQ/mo/s256-rj/photo.jpg",
                    "display_name": "sudhakar",
                    "link": "https://stackoverflow.com/users/10039509/sudhakar"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531152856,
                "post_id": 51200224,
                "comment_id": 89478643,
                "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": 1531152980,
                "post_id": 51200224,
                "comment_id": 89478714,
                "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": 1531153118,
                "post_id": 51200224,
                "comment_id": 89478778,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13904865,
                    "reputation": 1,
                    "user_id": 10039509,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-YaeyTjf-PRc/AAAAAAAAAAI/AAAAAAAAAAA/AAnnY7qwYV7BSEwP2DrybUfJD-hdo8ubEQ/mo/s256-rj/photo.jpg",
                    "display_name": "sudhakar",
                    "link": "https://stackoverflow.com/users/10039509/sudhakar"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531153293,
                "post_id": 51200224,
                "comment_id": 89478873,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13904865,
                    "reputation": 1,
                    "user_id": 10039509,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-YaeyTjf-PRc/AAAAAAAAAAI/AAAAAAAAAAA/AAnnY7qwYV7BSEwP2DrybUfJD-hdo8ubEQ/mo/s256-rj/photo.jpg",
                    "display_name": "sudhakar",
                    "link": "https://stackoverflow.com/users/10039509/sudhakar"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531317794,
                "post_id": 51200224,
                "comment_id": 89552597,
                "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": 1531318449,
                "post_id": 51200224,
                "comment_id": 89553150,
                "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": 1531318924,
                "post_id": 51200224,
                "comment_id": 89553499,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13904865,
                    "reputation": 1,
                    "user_id": 10039509,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-YaeyTjf-PRc/AAAAAAAAAAI/AAAAAAAAAAA/AAnnY7qwYV7BSEwP2DrybUfJD-hdo8ubEQ/mo/s256-rj/photo.jpg",
                    "display_name": "sudhakar",
                    "link": "https://stackoverflow.com/users/10039509/sudhakar"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531319642,
                "post_id": 51200224,
                "comment_id": 89554067,
                "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": 1531320161,
                "post_id": 51200224,
                "comment_id": 89554502,
                "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": 1531320228,
                "post_id": 51200224,
                "comment_id": 89554546,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13904865,
                    "reputation": 1,
                    "user_id": 10039509,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-YaeyTjf-PRc/AAAAAAAAAAI/AAAAAAAAAAA/AAnnY7qwYV7BSEwP2DrybUfJD-hdo8ubEQ/mo/s256-rj/photo.jpg",
                    "display_name": "sudhakar",
                    "link": "https://stackoverflow.com/users/10039509/sudhakar"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531320277,
                "post_id": 51200224,
                "comment_id": 89554572,
                "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": 1531320420,
                "post_id": 51200224,
                "comment_id": 89554671,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13904865,
                    "reputation": 1,
                    "user_id": 10039509,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-YaeyTjf-PRc/AAAAAAAAAAI/AAAAAAAAAAA/AAnnY7qwYV7BSEwP2DrybUfJD-hdo8ubEQ/mo/s256-rj/photo.jpg",
                    "display_name": "sudhakar",
                    "link": "https://stackoverflow.com/users/10039509/sudhakar"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531321554,
                "post_id": 51200224,
                "comment_id": 89555468,
                "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": 1531321718,
                "post_id": 51200224,
                "comment_id": 89555574,
                "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": 1531321784,
                "post_id": 51200224,
                "comment_id": 89555622,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13904865,
                    "reputation": 1,
                    "user_id": 10039509,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-YaeyTjf-PRc/AAAAAAAAAAI/AAAAAAAAAAA/AAnnY7qwYV7BSEwP2DrybUfJD-hdo8ubEQ/mo/s256-rj/photo.jpg",
                    "display_name": "sudhakar",
                    "link": "https://stackoverflow.com/users/10039509/sudhakar"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531322522,
                "post_id": 51200224,
                "comment_id": 89556131,
                "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": 1531322623,
                "post_id": 51200224,
                "comment_id": 89556185,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13904865,
                    "reputation": 1,
                    "user_id": 10039509,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-YaeyTjf-PRc/AAAAAAAAAAI/AAAAAAAAAAA/AAnnY7qwYV7BSEwP2DrybUfJD-hdo8ubEQ/mo/s256-rj/photo.jpg",
                    "display_name": "sudhakar",
                    "link": "https://stackoverflow.com/users/10039509/sudhakar"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531430311,
                "post_id": 51200224,
                "comment_id": 89605827,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1530889131,
                "last_edit_date": 1530889131,
                "creation_date": 1530829505,
                "answer_id": 51200665,
                "question_id": 51200224,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have verified that the problem does NOT arise when using jq 1.4, jq 1.5, or the &quot;development&quot; version (master), on MacOS.\r\n\r\nNevertheless, I think it would be worthwhile to upgrade to jq 1.5 or later.\r\n\r\nThe following might well work: replace \r\n`(.group2.field1)` by `(.group2|.field1)` and similarly for `(.group2.field2)`",
                "title": "jq is hanging when trying to extract data from json"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1530889131,
        "creation_date": 1530826670,
        "question_id": 51200224,
        "body_markdown": "My Json file has following structure\r\n\r\n\r\n    {\r\n    &quot;group0&quot;: [\r\n        {\r\n            &quot;id&quot;: 9,\r\n            &quot;href&quot;: &quot;href1&quot;,\r\n            &quot;name&quot;: &quot;Americas&quot;,\r\n            &quot;group1&quot;: [\r\n                {\r\n                    &quot;id&quot;: 8,\r\n                    &quot;href&quot;: &quot;href2&quot;,\r\n                    &quot;name&quot;: &quot;Anguilla (UK)&quot;,\r\n                    &quot;type&quot;: &quot;country&quot;,\r\n                    &quot;code&quot;: &quot;ai&quot;,\r\n                    &quot;group2&quot;: {\r\n                        &quot;field1&quot;: 9,\r\n                        &quot;field2&quot;: 1,\r\n                        &quot;field3&quot;: 1\r\n                    }\r\n                },\r\n                {\r\n                    &quot;id&quot;: 9,\r\n                    &quot;href&quot;: &quot;href3&quot;,\r\n                    &quot;name&quot;: &quot;Antigua and Barbuda&quot;,\r\n                    &quot;type&quot;: &quot;country&quot;,\r\n                    &quot;code&quot;: &quot;ag&quot;,\r\n                    &quot;group2&quot;: {\r\n                        &quot;field1&quot;: 9,\r\n                        &quot;field2&quot;: 1,\r\n                        &quot;field3&quot;: 2\r\n                    }\r\n                },\r\n                {\r\n                    &quot;id&quot;: 10,\r\n                    &quot;href&quot;: &quot;href4&quot;,\r\n                    &quot;name&quot;: &quot;Argentina&quot;,\r\n                    &quot;type&quot;: &quot;country&quot;,\r\n                    &quot;code&quot;: &quot;ar&quot;,\r\n                    &quot;group2&quot;: {\r\n                        &quot;field1&quot;: 8,\r\n                        &quot;field2&quot;: 1,\r\n                        &quot;field3&quot;: 2\r\n                    },\r\n                    &quot;group3&quot;: [\r\n                        {\r\n                            &quot;id&quot;: 599,\r\n                            &quot;href&quot;: &quot;&quot;,\r\n                            &quot;name&quot;: &quot;Rosario and Santa Fe (both Santa Fe province)&quot;,\r\n                            &quot;field3&quot;: 3\r\n                        }\r\n                    ]\r\n                }\r\n                \r\n            ]\r\n        },\r\n        {\r\n            &quot;id&quot;: 10,\r\n            &quot;href&quot;: &quot;href5&quot;,\r\n            &quot;name&quot;: &quot;Asia &amp; the Pacific&quot;,\r\n            &quot;group1&quot;: [\r\n                {\r\n                    &quot;id&quot;: 1,\r\n                    &quot;href&quot;: &quot;href6&quot;,\r\n                    &quot;name&quot;: &quot;Afghanistan&quot;,\r\n                    &quot;type&quot;: &quot;country&quot;,\r\n                    &quot;code&quot;: &quot;af&quot;,\r\n                    &quot;group2&quot;: {\r\n                        &quot;field1&quot;: 10,\r\n                        &quot;field2&quot;: 3,\r\n                        &quot;field3&quot;: 5\r\n                    }\r\n                },\r\n                {\r\n                    &quot;id&quot;: 14,\r\n                    &quot;href&quot;: &quot;href7&quot;,\r\n                    &quot;name&quot;: &quot;Australia&quot;,\r\n                    &quot;type&quot;: &quot;country&quot;,\r\n                    &quot;code&quot;: &quot;au&quot;,\r\n                    &quot;group2&quot;: {\r\n                        &quot;field1&quot;: 7,\r\n                        &quot;field2&quot;: 1,\r\n                        &quot;field3&quot;: 2\r\n                    }\r\n                },\r\n                {\r\n                    &quot;id&quot;: 19,\r\n                    &quot;href&quot;: &quot;href8&quot;,\r\n                    &quot;name&quot;: &quot;Bangladesh&quot;,\r\n                    &quot;type&quot;: &quot;country&quot;,\r\n                    &quot;code&quot;: &quot;bd&quot;,\r\n                    &quot;group2&quot;: {\r\n                        &quot;field1&quot;: 9,\r\n                        &quot;field2&quot;: 2,\r\n                        &quot;field3&quot;: 3\r\n                    },\r\n                    &quot;group3&quot;: [\r\n                        {\r\n                            &quot;id&quot;: 216,\r\n                            &quot;href&quot;: &quot;&quot;,\r\n                            &quot;name&quot;: &quot;Chittagong Hill Tracts; Dhaka&quot;,\r\n                            &quot;field3&quot;: 4\r\n                        }\r\n                    ]\r\n                }\r\n                \r\n            ]\r\n        }  \r\n    ]\r\n}\r\n\r\n\r\ni want to extract the fileds group1.field0, group1.name,group2.field1, group1.field3\r\n\r\nthe command i am running is below\r\n\r\n    jq &#39;.group0[].group1[]|&quot;\\(.name)|\\(.field0)|\\(.group2.field1)|\\(.group2.field3)&quot;&#39; sample.json\r\n\r\nwhen i run the above command in Solaris it just hangs and does nothing. when i run the below command i am getting data\r\n\r\n    jq &#39;.group0[].group1[]|&quot;\\(.name)|\\(.field0)&quot;&#39; sample.json\r\n\r\ncan someone please help me what am i doing wrong. the first command is working on jqplay.org which uses jq version 1.5 and jq version on our server is 1.4. i don&#39;t know whether lower version may be the issue(latest version for Solaris is 1.4 only).",
        "link": "https://stackoverflow.com/questions/51200224/jq-is-hanging-when-trying-to-extract-data-from-json",
        "title": "jq is hanging when trying to extract data from json"
    },
    {
        "tags": [
            "json",
            "sorting",
            "datetime",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1530895916,
                "creation_date": 1530895916,
                "answer_id": 51214761,
                "question_id": 51214375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The filter `sort_by/1` will sort your timestamps in chronological order, but it requires an array as input, so you could write:\r\n\r\n    .items \r\n    | map({ &quot;id&quot; : .id,  &quot;date&quot; : (.path |  scan(&quot;[0-9]{8}\\\\.[0-9-]*&quot;)) })\r\n    | sort_by(.date)\r\n    | .[-1]\r\n\r\nThe trailing `.[-1]` selects the last item, so with your input the result would be:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;V0FEQS1TbmFwc2hvdHM6MzhjZDQ3NTQwMTBkNGJhOWM4YjQ0NmRjYzFkODkxM2U&quot;,\r\n      &quot;date&quot;: &quot;20180703.204941-2&quot;\r\n    }",
                "title": "Sort / filter multiple objects in JQ by date"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1530895996,
        "creation_date": 1530894242,
        "last_edit_date": 1530895996,
        "question_id": 51214375,
        "body_markdown": "I&#39;m trying to use JQ to find the most recent artifact in a Nexus API query.  Right now, my JSON output looks something like:\r\n\r\n    {\r\n      &quot;items&quot; : [ {\r\n        &quot;downloadUrl&quot; : &quot;https://nexus.ama.org/repository/Snapshots/org/sso/browser-manager/1.0-SNAPSHOT/browser-manager-1.0-20180703.144121-1.jar&quot;,\r\n        &quot;path&quot; : &quot;org/sso/browser-manager/1.0-SNAPSHOT/browser-manager-1.0-20180703.144121-1.jar&quot;,\r\n        &quot;id&quot; : &quot;V0FEQS1TbmFwc2hvdHM6MzhjZDQ3NTQwMTBkNGJhOTY1N2JiOTEyMTM1ZGRjZWQ&quot;,\r\n        &quot;repository&quot; : &quot;Snapshots&quot;,\r\n        &quot;format&quot; : &quot;maven2&quot;,\r\n        &quot;checksum&quot; : {\r\n          &quot;sha1&quot; : &quot;7ac324905fb1ff15ef6020f256fcb5c9f54113ca&quot;,\r\n          &quot;md5&quot; : &quot;bb25c483a183001dfdc58c07a71a98ed&quot;\r\n        }\r\n      }, {\r\n        &quot;downloadUrl&quot; : &quot;https://nexus.ama.org/repository/Snapshots/org/sso/browser-manager/1.0-SNAPSHOT/browser-manager-1.0-20180703.204941-2.jar&quot;,\r\n        &quot;path&quot; : &quot;org/sso/browser-manager/1.0-SNAPSHOT/browser-manager-1.0-20180703.204941-2.jar&quot;,\r\n        &quot;id&quot; : &quot;V0FEQS1TbmFwc2hvdHM6MzhjZDQ3NTQwMTBkNGJhOWM4YjQ0NmRjYzFkODkxM2U&quot;,\r\n        &quot;repository&quot; : &quot;Snapshots&quot;,\r\n        &quot;format&quot; : &quot;maven2&quot;,\r\n        &quot;checksum&quot; : {\r\n          &quot;sha1&quot; : &quot;b4ba2049ea828391c720f49b6668a66a8b0bca9c&quot;,\r\n          &quot;md5&quot; : &quot;6757c55c0e6d933dc90e398204cca966&quot;\r\n        }\r\n      } ],\r\n      &quot;continuationToken&quot; : null\r\n    }\r\n\r\nI&#39;ve managed to use JQ to repackage the data as:\r\n\r\n    .items[] | { &quot;id&quot; : .id,  &quot;date&quot; : (.path |  scan(&quot;[0-9]{8}\\\\.[0-9-]*&quot;)) } \r\n\r\noutput:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;V0FEQS1TbmFwc2hvdHM6MzhjZDQ3NTQwMTBkNGJhOTY1N2JiOTEyMTM1ZGRjZWQ&quot;,\r\n      &quot;date&quot;: &quot;20180703.144121-1&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;V0FEQS1TbmFwc2hvdHM6MzhjZDQ3NTQwMTBkNGJhOWM4YjQ0NmRjYzFkODkxM2U&quot;,\r\n      &quot;date&quot;: &quot;20180703.204941-2&quot;\r\n    }\r\n\r\n\r\nNow I&#39;m a little stuck trying to figure out which of the two JSON objects is the most recent.  How can I sort by date and extract the id for that object?\r\n\r\nIs there a better way to filter/sort this data?  My example has only 2 items[] in the JSON response, but there may be a larger number of them.",
        "link": "https://stackoverflow.com/questions/51214375/sort-filter-multiple-objects-in-jq-by-date",
        "title": "Sort / filter multiple objects in JQ by date"
    },
    {
        "tags": [
            "json",
            "jq",
            "pathname"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530908253,
                "post_id": 51217020,
                "comment_id": 89415393,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25438,
                    "reputation": 284449,
                    "user_id": 65387,
                    "user_type": "registered",
                    "accept_rate": 66,
                    "profile_image": "https://www.gravatar.com/avatar/c0377fc1b08293d3362611978913a32b?s=256&d=identicon&r=PG",
                    "display_name": "mpen",
                    "link": "https://stackoverflow.com/users/65387/mpen"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530908486,
                "post_id": 51217020,
                "comment_id": 89415467,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25438,
                    "reputation": 284449,
                    "user_id": 65387,
                    "user_type": "registered",
                    "accept_rate": 66,
                    "profile_image": "https://www.gravatar.com/avatar/c0377fc1b08293d3362611978913a32b?s=256&d=identicon&r=PG",
                    "display_name": "mpen",
                    "link": "https://stackoverflow.com/users/65387/mpen"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1530909083,
                "post_id": 51217020,
                "comment_id": 89415666,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1530909681,
                "creation_date": 1530909681,
                "answer_id": 51217343,
                "question_id": 51217020,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**`jq`** approach:\r\n\r\n    jq &#39;if (.roles[] | contains(&quot;mysql&quot;)) then {(input_filename | gsub(&quot;.*/|\\\\.json$&quot;;&quot;&quot;)): .}\r\n        else empty end&#39; ./file1.json ./file2.json | jq -s &#39;add&#39;\r\n\r\nThe expected output:\r\n\r\n    {\r\n      &quot;file1&quot;: {\r\n        &quot;roles&quot;: [\r\n          &quot;mysql&quot;\r\n        ]\r\n      },\r\n      &quot;file2&quot;: {\r\n        &quot;roles&quot;: [\r\n          &quot;mysql&quot;,\r\n          &quot;php&quot;\r\n        ]\r\n      }\r\n    }\r\n\r\n",
                "title": "jq: convert array to object indexed by filename?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1530933582,
                "creation_date": 1530933582,
                "answer_id": 51219620,
                "question_id": 51217020,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your jq has `inputs` (as does jq 1.5) then the task can be accomplished with just one invocation of jq.\r\nAlso, it might be more efficient to use `any` than iterating over all the elements of `.roles`.\r\n\r\nThe trick is to invoke jq with the -n option, e.g.\r\n\r\n    jq -n &#39;\r\n      [inputs\r\n       | select(.roles and any(.roles[]; contains(&quot;mysql&quot;)))\r\n       | {(input_filename | gsub(&quot;.*/|\\\\.json$&quot;;&quot;&quot;)): .}]\r\n      | add&#39; file*.json\r\n",
                "title": "jq: convert array to object indexed by filename?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1530937889,
        "creation_date": 1530907868,
        "last_edit_date": 1530937889,
        "question_id": 51217020,
        "body_markdown": "Using [jq](https://stedolan.github.io/jq/) how can I convert an array into object indexed by filename, or read multiple files into one object indexed by their filename?\r\n\r\ne.g.\r\n\r\n    jq -s &#39;map(select(.roles[]? | contains (&quot;mysql&quot;)))&#39; -C dir/file1.json dir/file2.json\r\n\r\nThis gives me the data I want, but I need to know which file they came from.\r\n\r\nSo instead of\r\n\r\n    [\r\n        { &quot;roles&quot;: [&quot;mysql&quot;] },\r\n        { &quot;roles&quot;: [&quot;mysql&quot;, &quot;php&quot;] }\r\n    ]\r\n\r\nfor output, I want:\r\n\r\n    {\r\n        &quot;file1&quot;: { &quot;roles&quot;: [&quot;mysql&quot;] },\r\n        &quot;file2&quot;: { &quot;roles&quot;: [&quot;mysql&quot;, &quot;php&quot;] }\r\n    }\r\n\r\nI do want the &quot;.json&quot; file extension stripped too *if possible*, and just the basename (dir excluded).\r\n\r\n\r\n----------\r\n\r\n### Example\r\n\r\n#### file1.json\r\n\r\n    { &quot;roles&quot;: [&quot;mysql&quot;] }\r\n\r\n#### file2.json\r\n\r\n    { &quot;roles&quot;: [&quot;mysql&quot;, &quot;php&quot;] }\r\n\r\n#### file3.json\r\n\r\n    { }\r\n\r\nMy real files obviously have other stuff in them too, but that should be enough for this example. file3 is simply to demonstrate &quot;roles&quot; is sometimes missing.\r\n\r\nIn other words: I&#39;m trying to find files that contain &quot;mysql&quot; in their list of &quot;roles&quot;. I need the filename and contents combined into one JSON object.\r\n\r\n----\r\n\r\nTo simplify the problem further:\r\n\r\n\r\n    jq &#39;input_filename&#39; f1 f2\r\n\r\nGives me all the filenames like I want, but I don&#39;t know how to combine them into one object or array.\r\n\r\n\r\nWhereas,\r\n\r\n    jq -s &#39;map(input_filename)&#39; f1 f2\r\n\r\nGives me *the same* filename repeated once for each file. e.g. `[ &quot;f1&quot;, &quot;f1&quot; ]` instead of `[ &quot;f1&quot;, &quot;f2&quot; ]`\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51217020/jq-convert-array-to-object-indexed-by-filename",
        "title": "jq: convert array to object indexed by filename?"
    },
    {
        "tags": [
            "json",
            "bash",
            "variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2358033,
                    "reputation": 6765,
                    "user_id": 2065427,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/848f5560970be5de8e578bd3c618a493?s=256&d=identicon&r=PG",
                    "display_name": "kael",
                    "link": "https://stackoverflow.com/users/2065427/kael"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531089560,
                "post_id": 51228673,
                "comment_id": 89451979,
                "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": 1531093039,
                "post_id": 51228673,
                "comment_id": 89452481,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1531021996,
                "last_edit_date": 1531021996,
                "creation_date": 1531021543,
                "answer_id": 51228674,
                "question_id": 51228673,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You simply use bash&#39;s `$&#39;\\30&#39;` syntax to insert the special character in-line, like so: `echo &#39;[&quot;one&quot;,&quot;two&quot;,&quot;three&quot;]&#39; | jq &#39;. | join(&quot;&#39;$&#39;\\30&#39;&#39;&quot;)&#39;`.\r\n\r\nHere&#39;s the whole working example:\r\n\r\n    data=&#39;[&quot;one&quot;,&quot;two&quot;,&quot;three&quot;]&#39;\r\n    \r\n    IFS=$&#39;\\30&#39;\r\n    for rec in $(echo &quot;$data&quot; | jq &#39;. | join(&quot;&#39;$&#39;\\30&#39;&#39;&quot;)&#39;); do\r\n        echo &quot;Record: $rec&quot;\r\n    done\r\n    unset IFS\r\n\r\nThis prints\r\n\r\n    Record: one\r\n    Record: two\r\n    Record: three\r\n\r\nas expected.\r\n\r\n**NOTE:** It&#39;s important not to quote the subshell in the for loop. If you quote it, it will be taken as a single argument, regardless of the RecordSeparator characters. If you don&#39;t quote it, it will work as expected.",
                "title": "How to use non-displaying characters like newline (\\n) and tab (\\t) with jq&#39;s &quot;join&quot; function"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1531099714,
                "last_edit_date": 1531099714,
                "creation_date": 1531071732,
                "answer_id": 51234555,
                "question_id": 51228673,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The recommended way to solve the problem is to use the -c command-line\r\noption, e.g. as follows:\r\n\r\n    echo &quot;$data&quot; | jq -c &#39;.[]&#39; |\r\n    while read -r rec\r\n    do\r\n        echo &quot;Record: $rec&quot;\r\n    done\r\n\r\nOutput:\r\n\r\n    Record: &quot;one&quot;\r\n    Record: &quot;two&quot;\r\n    Record: &quot;three&quot;\r\n\r\n## Problems with the OP&#39;s proposed answer\r\n\r\nThere are several problems with the proposal in the OP&#39;s answer based on `$&#39;\\30&#39;`\r\n\r\nFirst, it doesn&#39;t work reliably, e.g. using bash on a Mac\r\nthe output is: `Record: &quot;one\\u0018two\\u0018three&quot;`;\r\nthis is because jq correctly converts octal 30 to `\\u0018`\r\nwithin the JSON string.\r\n\r\nSecond, RS is ASCII decimal 30, i.e. octal 36, which\r\nwould be written as `$&#39;\\36&#39;` in the shell.\r\nIf you use this value instead, the program produces:\r\n`Record: &quot;one\\u001etwo\\u001ethree&quot;` because that is\r\nthe correct JSON string with embedded RS characters.  (For the record `$&#39;\\30&#39;` is Control-X.)\r\n    \r\n\r\nThird, as noted by Charles Duffy, &quot;for rec in $(...) is inherently buggy.&quot;\r\n\r\nFourth, any approach which assumes jq will in future accept\r\nillegal JSON strings is brittle in the sense that in the\r\nfuture, jq might disallow them or at least require a command-line\r\nswitch to allow them.\r\n\r\nFifth, `unset IFS` is not guaranteed to restore IFS to its state beforehand.\r\n\r\n",
                "title": "How to use non-displaying characters like newline (\\n) and tab (\\t) with jq&#39;s &quot;join&quot; function"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1531221013,
                "last_edit_date": 1531221013,
                "creation_date": 1531074519,
                "answer_id": 51234929,
                "question_id": 51228673,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `jq -j` to eliminate literal newlines between records and use only your own delimiter. This works in your simple case:\r\n\r\n    #!/usr/bin/env bash\r\n    data=&#39;[&quot;one&quot;,&quot;two&quot;,&quot;three&quot;]&#39;\r\n    sep=$&#39;\\x1e&#39; # works only for non-NUL characters, see NUL version below\r\n    while IFS= read -r -d &quot;$sep&quot; rec || [[ $rec ]]; do\r\n      printf &#39;Record: %q\\n&#39; &quot;$rec&quot;\r\n    done &lt; &lt;(jq -j --arg sep &quot;$sep&quot; &#39;join($sep)&#39; &lt;&lt;&lt;&quot;$data&quot;)\r\n\r\n...but it also works in a more interesting scenario where naive answers fail:\r\n\r\n    #!/usr/bin/env bash\r\n    data=&#39;[&quot;two\\nlines&quot;,&quot;*&quot;]&#39;\r\n    while IFS= read -r -d $&#39;\\x1e&#39; rec || [[ $rec ]]; do\r\n      printf &#39;Record: %q\\n&#39; &quot;$rec&quot;\r\n    done &lt; &lt;(jq -j &#39;join(&quot;\\u001e&quot;)&#39; &lt;&lt;&lt;&quot;$data&quot;)\r\n\r\nreturns (when run on Cygwin, hence the CRLF):\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    Record: $&#39;two\\r\\nlines&#39;\r\n    Record: \\*\r\n\r\n---\r\n\r\nThat said, if using this in anger, I would suggest using NUL delimiters, and filtering them out from the input values:\r\n\r\n    #!/usr/bin/env bash\r\n    data=&#39;[&quot;two\\nlines&quot;,&quot;three\\ttab-separated\\twords&quot;,&quot;*&quot;,&quot;nul\\u0000here&quot;]&#39;\r\n    while IFS= read -r -d &#39;&#39; rec || [[ $rec ]]; do\r\n      printf &#39;Record: %q\\n&#39; &quot;$rec&quot;\r\n    done &lt; &lt;(jq -j &#39;[.[] | gsub(&quot;\\u0000&quot;; &quot;@NUL@&quot;)] | join(&quot;\\u0000&quot;)&#39; &lt;&lt;&lt;&quot;$data&quot;)\r\n\r\nNUL is a good choice because it&#39;s a character than *can&#39;t be stored in C strings* (like the ones bash uses) at all, so there&#39;s no loss in the range of data which can be faithfully conveyed when they&#39;re excised -- if they *did* make it through to the shell, it would (depending on version) either discard them, or truncate the string at the point when one first appears.",
                "title": "How to use non-displaying characters like newline (\\n) and tab (\\t) with jq&#39;s &quot;join&quot; function"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1531160629,
                "creation_date": 1531160629,
                "answer_id": 51251854,
                "question_id": 51228673,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The RS character is special in jq when used with the `--seq` command-line option.  For example, with a JSON array stored in a shell variable named `data` we could invoke jq as follows:\r\n\r\n    $ jq -n --seq --argjson arg &#39;[1,2]&#39; &#39;$arg | .[]&#39;\r\n\r\nHere is a transcript:\r\n\r\n    $ data=&#39;[&quot;one&quot;,&quot;two&quot;,&quot;three&quot;]&#39;\r\n    $ jq -n --seq --argjson arg &quot;$data&quot; &#39;$arg | .[]&#39; | tr $&#39;\\36&#39; X\r\n    X&quot;one&quot;\r\n    X&quot;two&quot;\r\n    X&quot;three&quot;\r\n    $\r\n",
                "title": "How to use non-displaying characters like newline (\\n) and tab (\\t) with jq&#39;s &quot;join&quot; function"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1689339024,
                "creation_date": 1689339024,
                "answer_id": 76687862,
                "question_id": 51228673,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Sirrt for the necroposting, but it might help someone:\r\n\r\nusing jq&#39;s flag `--raw-output`: \r\n\r\n`[&quot;one&quot;,&quot;two&quot;,&quot;three&quot;] | jq --raw-output &#39;join(&quot;\\t&quot;)&#39;` produces `one\ttwo\tthree` (with tab characters)",
                "title": "How to use non-displaying characters like newline (\\n) and tab (\\t) with jq&#39;s &quot;join&quot; function"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 5,
        "last_activity_date": 1689339024,
        "creation_date": 1531021543,
        "last_edit_date": 1531089304,
        "question_id": 51228673,
        "body_markdown": "I couldn&#39;t find this anywhere on the internet, so figured I&#39;d add it as documentation.\r\n\r\nI wanted to join a json array around the non-displaying character `\\30` (&quot;RecordSeparator&quot;) so I could safely iterate over it in bash, but I couldn&#39;t quite figure out how to do it. I tried `echo &#39;[&quot;one&quot;,&quot;two&quot;,&quot;three&quot;]&#39; | jq &#39;join(&quot;\\30&quot;)&#39;` and a couple permutations of that, but it didn&#39;t work.\r\n\r\nTurns out the solution is pretty simple.... (See answer)",
        "link": "https://stackoverflow.com/questions/51228673/how-to-use-non-displaying-characters-like-newline-n-and-tab-t-with-jqs-j",
        "title": "How to use non-displaying characters like newline (\\n) and tab (\\t) with jq&#39;s &quot;join&quot; function"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1531158714,
                "last_edit_date": 1531158714,
                "creation_date": 1531147730,
                "answer_id": 51248331,
                "question_id": 51247664,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need to _loop_ over the JSON objects here, using `jq`, you could just interpolate the variable inside each object and do your logic as needed. Since the fields in the JSON could contain spaces between them using a custom delimiter `|` to split them and use that in the `read` command of the `bash` loop\r\n\r\n    jq --raw-output &#39;.items[] | &quot;\\(.id)|\\(.title)|\\(.isLocked)&quot;&#39; json |\r\n        while IFS=&quot;|&quot; read -r id title flag; do\r\n            printf &#39;%s|%s|%s\\n&#39; &quot;$id&quot; &quot;$title&quot; &quot;$flag&quot;\r\n        done\r\n\r\nDo what ever with the variables `id`, `title` and `flag` in the shell context now. If you want to use more variables, just add them to the original `jq` filter.\r\n\r\nIf you don&#39;t want the loop to run in a sub-shell, use the process substitution technique provided by the `bash` shell. Doing it runs in the same parent shell and makes the output of commands under `&lt;(cmd)` as if it were appear in a temporary file\r\n \r\n    while IFS=&quot;|&quot; read -r id title flag; do\r\n        printf &#39;%s|%s|%s\\n&#39; &quot;$id&quot; &quot;$title&quot; &quot;$flag&quot;\r\n    done&lt; &lt;(jq --raw-output &#39;.items[] | &quot;\\(.id)|\\(.title)|\\(.isLocked)&quot;&#39; json)",
                "title": "JSON keys and bash variables in a loop"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1531158714,
        "creation_date": 1531145576,
        "last_edit_date": 1531145808,
        "question_id": 51247664,
        "body_markdown": "I need to capture all the spaces/chat-rooms they use and ensure the new accounts get connected to all those spaces. I can use `curl` to call the service Spark API and get the list of spaces, and process that with `jq` to put it in a respectable format.  What I end up with is a series of 50 to 900 (depending on the use) JSON objects (one per space/room). \r\n\r\n    {  \r\n       &quot;items&quot;:[  \r\n          {  \r\n             &quot;id&quot;:&quot;Y2lzY29zcGFyazovL3VzL1JPT00vNGY0Y2Q5NDAtN2JkZi0xMWU4LThiMjMtMTU0YzAyNTI0YzBh&quot;,\r\n             &quot;title&quot;:&quot;(CISCO INTERNAL): FTB - CMS Opportunity&quot;,\r\n             &quot;type&quot;:&quot;group&quot;,\r\n             &quot;isLocked&quot;:false,\r\n             &quot;lastActivity&quot;:&quot;2018-06-29T21:05:55.994Z&quot;,\r\n             &quot;creatorId&quot;:&quot;Y2lzY29zcGFyazovL3VzL1BFT1BMRS9kMWI3MDRhNS05ZmU0LTQ3MTYtOGY2Zi02OGEyNjVjZGQ5YzM&quot;,\r\n             &quot;created&quot;:&quot;2018-06-29T20:59:27.316Z&quot;\r\n          },\r\n          {  \r\n             &quot;id&quot;:&quot;Y2lzY29zcGFyazovL3VzL1JPT00vMTQxODk5MTAtN2JiYS0xMWU4LThiOWUtMjMwOWM4Y2NiYWMz&quot;,\r\n             &quot;title&quot;:&quot;USU Cisco Webex EDU Program&quot;,\r\n             &quot;type&quot;:&quot;group&quot;,\r\n             &quot;isLocked&quot;:true,\r\n             &quot;lastActivity&quot;:&quot;2018-06-29T19:46:14.993Z&quot;,\r\n             &quot;creatorId&quot;:&quot;Y2lzY29zcGFyazovL3VzL1BFT1BMRS8wZThjMzg3Yy0zNzc5LTRlYTEtYmY2My1mNzZmMDJkYzVjM2M&quot;,\r\n             &quot;created&quot;:&quot;2018-06-29T16:32:56.609Z&quot;\r\n          },\r\n          {  \r\n             &quot;id&quot;:&quot;Y2lzY29zcGFyazovL3VzL1JPT00vZjYyNDg1NjAtNzg5Yy0xMWU4LTlmYzItNGZhYzQwZWE4MTA4&quot;,\r\n             &quot;title&quot;:&quot;Darren TeamSpace Space&quot;,\r\n             &quot;type&quot;:&quot;group&quot;,\r\n             &quot;isLocked&quot;:false,\r\n             &quot;lastActivity&quot;:&quot;2018-06-26T15:00:03.332Z&quot;,\r\n             &quot;teamId&quot;:&quot;Y2lzY29zcGFyazovL3VzL1RFQU0vZWQ5Mzc1ZDAtZjE1MC0xMWU1LWFjNWUtNTNiMzQxMDkxMTU1&quot;,\r\n             &quot;creatorId&quot;:&quot;Y2lzY29zcGFyazovL3VzL1BFT1BMRS83YTBkMTJiMS1lODMxLTRkNmItYTAzMS0xMDU4Y2UwOTAwZTU&quot;,\r\n             &quot;created&quot;:&quot;2018-06-25T17:26:57.561Z&quot;\r\n          }\r\n       ]\r\n    }\r\n\r\nWhat I&#39;d like to do here is create a quick and dirty script that can then process this JSON file in a loop, pulling the keys in as variables \r\n\r\n    (items.id = $id, items.title = $title, etc.) \r\n\r\nwith the associated values from the file, so I can perform some basic &quot;if then else&quot; evaluations (check if `isLocked` is `true` or `false`) and then execute some other API calls using the other variables.  For some reason, and it&#39;s probably my lack of familiarity with `jq`, I can&#39;t get the loop and variable extraction to work properly.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51247664/json-keys-and-bash-variables-in-a-loop",
        "title": "JSON keys and bash variables in a loop"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1531150077,
                "creation_date": 1531150077,
                "answer_id": 51249066,
                "question_id": 51248893,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of `del` you could use `map(select(..))`, excluding the part you need.\r\n\r\n    jq &#39;.data |= map(select(.checkId != &quot;201805111305QIN0A-TQCYEITA&quot;))&#39;\r\n\r\nOr using your actual `del` command, doing the reverse of above\r\n\r\n    jq &#39;del(.data[] | select(.checkId == &quot;201805111305QIN0A-TQCYEITA&quot;))&#39;\r\n\r\n",
                "title": "How to remove an object from a JSON file preserving the file structure"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1531150114,
        "creation_date": 1531149553,
        "last_edit_date": 1531150114,
        "question_id": 51248893,
        "body_markdown": "I have a JSON file with the following structure:\r\n\r\n    {\r\n      &quot;data&quot;: [\r\n        {\r\n           &quot;subId&quot;: &quot;201805111305QIN0A&quot;,\r\n           &quot;checkId&quot;: &quot;201805111305QIN0A-CPIFK5ZG&quot;\r\n        },\r\n        {\r\n           &quot;subId&quot;: &quot;201805111305QIN0A&quot;,\r\n           &quot;checkId&quot;: &quot;201805111305QIN0A-F7HGMZUV&quot;\r\n        },\r\n        {\r\n           &quot;subId&quot;: &quot;201805111305QIN0A&quot;,\r\n           &quot;checkId&quot;: &quot;201805111305QIN0A-TQCYEITA&quot;\r\n        },\r\n        {\r\n           &quot;subId&quot;: &quot;201805111323U8B1D&quot;,\r\n           &quot;checkId&quot;: &quot;201805111323U8B1D-HO648V2L&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nWhat I would like to do is remove the object where the checkId = &quot;**201805111305QIN0A-TQCYEITA**&quot; and make my file look like this:\r\n\r\n    {\r\n      &quot;data&quot;: [\r\n        {\r\n           &quot;subId&quot;: &quot;201805111305QIN0A&quot;,\r\n           &quot;checkId&quot;: &quot;201805111305QIN0A-CPIFK5ZG&quot;\r\n        },\r\n        {\r\n           &quot;subId&quot;: &quot;201805111305QIN0A&quot;,\r\n           &quot;checkId&quot;: &quot;201805111305QIN0A-F7HGMZUV&quot;\r\n        },\r\n        {\r\n           &quot;subId&quot;: &quot;201805111323U8B1D&quot;,\r\n           &quot;checkId&quot;: &quot;201805111323U8B1D-HO648V2L&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n\r\nTo do this I am using the following command line:\r\n\r\n    jq -r &#39;.data[] | del(select (.checkId==&quot;201805111305QIN0A-TQCYEITA&quot;)) | select (.!=null)&#39; /var/data-disable.js\r\n\r\nI was able to delete the desired object, but **the output of the jq command does not preserve the structure of my JSON file**, which looks exactly like this:\r\n\r\n    {\r\n      &quot;subId&quot;: &quot;201805111305QIN0A&quot;,\r\n      &quot;checkId&quot;: &quot;201805111305QIN0A-CPIFK5ZG&quot;\r\n    }\r\n    {\r\n      &quot;subId&quot;: &quot;201805111305QIN0A&quot;,\r\n      &quot;checkId&quot;: &quot;201805111305QIN0A-F7HGMZUV&quot;\r\n    }\r\n    {\r\n      &quot;subId&quot;: &quot;201805111323U8B1D&quot;,\r\n      &quot;checkId&quot;: &quot;201805111323U8B1D-HO648V2L&quot;\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/51248893/how-to-remove-an-object-from-a-json-file-preserving-the-file-structure",
        "title": "How to remove an object from a JSON file preserving the file structure"
    },
    {
        "tags": [
            "json",
            "filtering",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1531209627,
                "creation_date": 1531209627,
                "answer_id": 51259992,
                "question_id": 51259744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "How about:\r\n\r\n    jq -r &#39;.links | map(select(.rel=&quot;node&quot;) | .href ) | first&#39;\r\n\r\n",
                "title": "How can I use jq to extract the value of href in this JSON snippet?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1531210491,
                "last_edit_date": 1531210491,
                "creation_date": 1531209880,
                "answer_id": 51260063,
                "question_id": 51259744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I found that this works\r\n`jq -r &#39;.links[] | select(.rel == &quot;node&quot;) .href&#39;`\r\nI&#39;m not sure of the pros/cons vs Hans&#39; answer",
                "title": "How can I use jq to extract the value of href in this JSON snippet?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1531235638,
        "creation_date": 1531208743,
        "last_edit_date": 1531235638,
        "question_id": 51259744,
        "body_markdown": "I have an API returning JSON similar to the sample below\r\n\r\n    {\r\n      &quot;href&quot;: &quot;https://www.mycompany.com/api/services/myservice/instances/service-instance-3&quot;,\r\n      &quot;id&quot;: &quot;si-555aa555a555&quot;,\r\n      &quot;links&quot;: [\r\n        {\r\n          &quot;rel&quot;: &quot;node&quot;,\r\n          &quot;href&quot;: &quot;https://www.mycompany.com/api/nodes/node-aa5a5a55&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI want to be able to parse the value `https://www.mycompany.com/api/nodes/node-aa5a5a55` from the `links` array where the `rel` value is `node`.  How can I construct a `jq` filter to achieve this?",
        "link": "https://stackoverflow.com/questions/51259744/how-can-i-use-jq-to-extract-the-value-of-href-in-this-json-snippet",
        "title": "How can I use jq to extract the value of href in this JSON snippet?"
    },
    {
        "tags": [
            "json",
            "nested",
            "jq",
            "tree-traversal"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1531235369,
                "creation_date": 1531235369,
                "answer_id": 51268707,
                "question_id": 51264999,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In brief, `walk` is your friend.\r\n\r\n(If it is not available in your jq, simply include its def in your jq program; the def can easily be found by googling: jq def walk)\r\n\r\nSome variation of the following should solve the immediate problem:\r\n\r\n    walk( if type == &quot;object&quot; then {a,b} else . end )",
                "title": "Filter keys of the objects in a deeply nested JSON with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1656145263,
                "creation_date": 1656145263,
                "answer_id": 72752324,
                "question_id": 51264999,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `|=` operator to do what you want on nested levels.\r\n\r\nThere is also a fairly simple function you can use to pick specific paths out of json objects.\r\n\r\n[This stackoverflow.com thread](https://stackoverflow.com/questions/72745488/how-to-filter-object-containing-nested-keys-and-lists-to-specific-keys-with-jq) has a more in-depth explanation.",
                "title": "Filter keys of the objects in a deeply nested JSON with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1680502221,
                "creation_date": 1680502221,
                "answer_id": 75916455,
                "question_id": 51264999,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe this works for you:\r\n\r\n    map({ k1 : [(.k1[]|{a,b})], k2 : [(.k2[]|{a,b})] })\r\n\r\n[test1][1]\r\n\r\nor this:\r\n\r\n    [.[]|{ k1 : [(.k1[]|{a,b})], k2 : [(.k2[]|{a,b})] }]\r\n\r\n[test2][2]\r\n\r\n\r\n  [1]: https://jqplay.org/s/9fHe4vETsqv\r\n  [2]: https://jqplay.org/s/aUAB6l5Roi6",
                "title": "Filter keys of the objects in a deeply nested JSON with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1680502221,
        "creation_date": 1531225062,
        "last_edit_date": 1531235503,
        "question_id": 51264999,
        "body_markdown": "Given the following input\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;k1&quot;:[{&quot;a&quot;:1,&quot;b&quot;:2,&quot;c&quot;:3,&quot;d&quot;:4,&quot;e&quot;:5,&quot;f&quot;:6}],\r\n        &quot;k2&quot;:[{&quot;a&quot;:1,&quot;b&quot;:2,&quot;c&quot;:3,&quot;d&quot;:4,&quot;e&quot;:5,&quot;f&quot;:6}]\r\n      }\r\n    ]\r\n\r\nhow should I proceed to obtain the following output?\r\n\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;k1&quot;:[{&quot;a&quot;:1,&quot;b&quot;:2}],\r\n        &quot;k2&quot;:[{&quot;a&quot;:1,&quot;b&quot;:2}]\r\n      }\r\n    ]\r\n\r\ni.e. I have some objects deeply in the JSON, and I want to remove all keys in those nested objects except `&quot;a&quot;` and `&quot;b&quot;`, and keep the original JSON structure.\r\n\r\nNote however that the original object might have dozens of keys, I only want to keep 2 or 3 of them.\r\n\r\nFor simple top-level operations I was able to select subsets of objects with `{a:.a, b:.b}` or `{a,b}` syntax, but in the nested context I don&#39;t know how to proceed and preserve the JSON structure.\r\n\r\nIn general, what is the best attitude to do operations on a deeply nested level, without altering the parent levels?",
        "link": "https://stackoverflow.com/questions/51264999/filter-keys-of-the-objects-in-a-deeply-nested-json-with-jq",
        "title": "Filter keys of the objects in a deeply nested JSON with jq"
    },
    {
        "tags": [
            "json",
            "file",
            "join",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1531309590,
                "last_edit_date": 1531309590,
                "creation_date": 1531243107,
                "answer_id": 51270964,
                "question_id": 51269833,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem can easily be solved using the def of hashJoin given in the SO page that you cite.\r\n\r\n## Solution using jq 1.5 or higher\r\n\r\nIf you have jq 1.5 or higher, you could use this invocation:\r\n\r\n    jq -n --slurpfile f1 file1.json --slurpfile f2 file2.json -f join.jq\r\n\r\nwhere join.jq contains the second def of hashJoin, together with:\r\n\r\n    hashJoin($f1; $f2; .key)[]\r\n\r\n## Solution using jq 1.4\r\n\r\nIf you have jq 1.4, the trickiness is to read each of the two files separately as an array. Here&#39;s one approach that assumes bash:\r\n\r\n    jq -n --argfile f1 &lt;(jq -s . file1.json) --argfile f2 &lt;(jq -s . file2.json) -f join.jq \r\n\r\nwhere join.jq is as above.\r\n\r\nIf you cannot use bash, then it might be simplest to create temporary files.\r\n\r\n\r\n",
                "title": "JQ Join JSON files by key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1531416314,
        "creation_date": 1531238707,
        "last_edit_date": 1531416314,
        "question_id": 51269833,
        "body_markdown": "Looks like [it&#39;s][1] not actual for jq 1.4, could you provide any other ways to join JSON files by key?\r\ne.g\r\n\r\n    {\r\n        &quot;key&quot;: &quot;874102296-1&quot;,\r\n        &quot;que_lat&quot;: &quot;40&quot;\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;874102296-2&quot;,\r\n      &quot;que_lat&quot;: &quot;406790&quot;\r\n    }\r\n\r\nand\r\n    \r\n    {\r\n      &quot;key&quot;: &quot;874102296-1&quot;,\r\n      &quot;in_time&quot;: &quot;1530874104733&quot;,\r\n      &quot;latency&quot;: &quot;12864258288242&quot;\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;874102296-2&quot;,\r\n      &quot;in_time&quot;: &quot;1530874104746&quot;\r\n    }\r\n\r\nAs a result, i&#39;d like to have something like this:\r\n\r\n    {\r\n      &quot;key&quot;: &quot;874102296-1&quot;,\r\n      &quot;in_time&quot;: &quot;1530874104733&quot;,\r\n      &quot;full_latency&quot;: &quot;12864258288242&quot;,\r\n      &quot;que_lat&quot;: &quot;40&quot;\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;874102296-2&quot;,\r\n      &quot;in_time&quot;: &quot;1530874104746&quot;,\r\n      &quot;que_lat&quot;: &quot;406790&quot;\r\n    }\r\n\r\nThanks!\r\n\r\n  [1]: https://stackoverflow.com/questions/39830426/join-two-json-files-based-on-common-key-with-jq-utility-or-alternative-way-from",
        "link": "https://stackoverflow.com/questions/51269833/jq-join-json-files-by-key",
        "title": "JQ Join JSON files by key"
    },
    {
        "tags": [
            "json",
            "replace",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1531252963,
                "creation_date": 1531252963,
                "answer_id": 51273157,
                "question_id": 51272561,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; What&#39;s the correct approach to walk through entire JSON in this case?\r\n\r\nThe answer is `walk`!\r\n\r\nIf your jq does not already have `walk/1`, you can google for it easily enough (jq &quot;def walk&quot;), and then include its def before using it, e.g. as follows:\r\n\r\n    walk(if type == &quot;object&quot; and has(&quot;description&quot;) and .description == null\r\n         then .description = &quot;DUMMY DESCRIPTION&quot;\r\n         else . end)",
                "title": "jq, replace null values on any level, not touching non-null or not existing"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1531259340,
                "creation_date": 1531259340,
                "answer_id": 51274358,
                "question_id": 51272561,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One option you could consider is using streams. You&#39;ll get paths and values to every item in the input. With that you could look for name/value pairs with the name `&quot;description&quot;` and update the value.\r\n\r\n    $ jq --arg replacement &quot;DUMMY DESCRIPTION&quot; &#39;\r\n    fromstream(tostream | if length == 2 and .[0][-1] == &quot;description&quot;\r\n        then .[1] |= (. // $replacement)\r\n        else .\r\n    end)\r\n    &#39; input.json\r\n",
                "title": "jq, replace null values on any level, not touching non-null or not existing"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1531259340,
        "creation_date": 1531250060,
        "last_edit_date": 1531251852,
        "question_id": 51272561,
        "body_markdown": "please assist to a newbie in jq. :)\r\n\r\nI have to update a field with specific name that might occur on any level of JSON structure - and might not. Like with all *.description fields in JSON below:\r\n\r\n    {\r\n            &quot;a&quot;: {\r\n                    &quot;b&quot;: [{\r\n                                    &quot;name&quot;: &quot;b0&quot;,\r\n                                    &quot;description&quot;: &quot;b0 has description&quot;\r\n                            },\r\n                            {\r\n                                    &quot;name&quot;: &quot;b1&quot;,\r\n                                    &quot;description&quot;: null\r\n                            },\r\n                            {\r\n                                    &quot;name&quot;: &quot;b2&quot;\r\n                            }\r\n                    ],\r\n                    &quot;description&quot;: null\r\n            },\r\n            &quot;s&quot;: &quot;Some string value&quot;\r\n    }\r\n\r\nI need to update &quot;description&quot; value with some dummy value if only it has null value, but do not touch existing values and do not create new fields where they do not exist. So desired result in this case is:\r\n\r\n    {\r\n            &quot;a&quot;: {\r\n                    &quot;b&quot;: [{\r\n                                    &quot;name&quot;: &quot;b0&quot;,\r\n                                    &quot;description&quot;: &quot;b0 has description&quot;\r\n                            },\r\n                            {\r\n                                    &quot;name&quot;: &quot;b1&quot;,\r\n                                    &quot;description&quot;: &quot;DUMMY DESCRIPTION&quot;\r\n                            },\r\n                            {\r\n                                    &quot;name&quot;: &quot;b2&quot;\r\n                            }\r\n                    ],\r\n                    &quot;description&quot;: &quot;DUMMY DESCRIPTION&quot;\r\n            },\r\n            &quot;s&quot;: &quot;Some string value&quot;\r\n    }\r\n\r\nHere, .a.b[0].description left untouched because it existed and was not null; .a.b[1].description and .a.description are forced to &quot;DUMMY DESCRIPTION&quot; because these field existed and were null; and .a.b[2] as well as root level left untouched because there was no description field at all.\r\n\r\nIf for example I try to use command on known paths like below\r\n \r\n    jq &#39;.known.level.description //= &quot;DUMMY DESCRIPTION&quot;&#39; ........\r\n\r\nit fails to skip non-existing fields like .a.b[2].description; and, sure, it works on known positions in JSON only. And if I try to do recursive search like:\r\n\r\n    jq &#39;.. | .description? //= &quot;DUMMY DESCRIPTION&quot;&#39; ........\r\n\r\nit does not seem to work correctly on arrays.\r\n\r\nWhat&#39;s the correct approach to walk through entire JSON in this case? Thanks!",
        "link": "https://stackoverflow.com/questions/51272561/jq-replace-null-values-on-any-level-not-touching-non-null-or-not-existing",
        "title": "jq, replace null values on any level, not touching non-null or not existing"
    },
    {
        "tags": [
            "kubernetes",
            "jq",
            "kubectl"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4400607,
                    "reputation": 5623,
                    "user_id": 3593896,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/fZYLQ.jpg?s=256",
                    "display_name": "Webber",
                    "link": "https://stackoverflow.com/users/3593896/webber"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531299069,
                "post_id": 51280969,
                "comment_id": 89539558,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1090987,
                    "reputation": 3978,
                    "user_id": 1085632,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd856dcd42c710d3f2338996dcd6a4f3?s=256&d=identicon&r=PG",
                    "display_name": "grdl",
                    "link": "https://stackoverflow.com/users/1085632/grdl"
                },
                "reply_to_user": {
                    "account_id": 4400607,
                    "reputation": 5623,
                    "user_id": 3593896,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/fZYLQ.jpg?s=256",
                    "display_name": "Webber",
                    "link": "https://stackoverflow.com/users/3593896/webber"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531300018,
                "post_id": 51280969,
                "comment_id": 89540198,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1604466,
                    "reputation": 3229,
                    "user_id": 1484823,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/37aa094a5d6142b51279425ce45f87b8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Guillaume Berche",
                    "link": "https://stackoverflow.com/users/1484823/guillaume-berche"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1752662898,
                "post_id": 51280969,
                "comment_id": 140593641,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1531300290,
                "creation_date": 1531300290,
                "answer_id": 51281577,
                "question_id": 51280969,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So i&#39;ve tested your command and it works perfectly. You are however missing a quote at the end of your command.\r\n\r\n    kubectl get pod nginx-5dfd5597bb-tp8h7 --watch -o json | jq &#39;.metadata.name&#39;\r\n\r\ngives me \r\n\r\n    &quot;nginx-5dfd5597bb-tp8h7&quot;\r\n\r\nif you can this command to work but not your own; it is probably related to the brackets and quotes or missing object keys.",
                "title": "How to apply a jq filter to kubectl output in watch mode?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 7,
        "last_activity_date": 1531412869,
        "creation_date": 1531298547,
        "last_edit_date": 1531412869,
        "question_id": 51280969,
        "body_markdown": "I want to filter the output of a `kubectl` command running in `--watch` mode to keep an eye on changes to a certain k8s annotation. I&#39;m using the following command:\r\n\r\n`kubectl get pod my-pod --watch -o json | jq &#39;.metadata.annotations[&quot;my-annotation&quot;]&#39;`\r\n\r\nProblem is - nothing is printed until I stop the command. I&#39;d like the `jq` to process the input and print it as the changes to `my-pod` happen.\r\n\r\nI tried using the `--unbuffered` flag but it doesn&#39;t fix it.",
        "link": "https://stackoverflow.com/questions/51280969/how-to-apply-a-jq-filter-to-kubectl-output-in-watch-mode",
        "title": "How to apply a jq filter to kubectl output in watch mode?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "variables",
            "iteration",
            "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": 1531312725,
                "post_id": 51284997,
                "comment_id": 89548770,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8667854,
                    "reputation": 11642,
                    "user_id": 6487675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8e6b3f7a2aba683dcc4be24ba028d2bf?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dWinder",
                    "link": "https://stackoverflow.com/users/6487675/dwinder"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531331553,
                "post_id": 51284997,
                "comment_id": 89560802,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1091724,
                    "reputation": 402,
                    "user_id": 1107793,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/76FQI.jpg?s=256",
                    "display_name": "JdeHaan",
                    "link": "https://stackoverflow.com/users/1107793/jdehaan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531333605,
                "post_id": 51284997,
                "comment_id": 89561714,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7123842,
                    "reputation": 29513,
                    "user_id": 5684257,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/938a4e35c2fb712a8f71a5584f5ed80e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "HTNW",
                    "link": "https://stackoverflow.com/users/5684257/htnw"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531355686,
                "post_id": 51284997,
                "comment_id": 89569137,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1531335575,
                "creation_date": 1531335575,
                "answer_id": 51292497,
                "question_id": 51284997,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Consider first this filter:\r\n\r\n    (.a | keys_unsorted[]) as $k1\r\n    | (.a |.[$k1][]) as $k2\r\n    | (.h |.[$k2][]) as $k3\r\n    | [$k1, $k2, $k3]\r\n\r\n\r\nWith your data, the invocation:\r\n\r\n    jq -c -f filter.jq input.json\r\n\r\nproduces:\r\n\r\n    [&quot;b&quot;,&quot;c&quot;,&quot;i&quot;]\r\n    [&quot;b&quot;,&quot;c&quot;,&quot;j&quot;]\r\n    [&quot;b&quot;,&quot;d&quot;,&quot;k&quot;]\r\n    [&quot;e&quot;,&quot;f&quot;,&quot;l&quot;]\r\n    [&quot;e&quot;,&quot;f&quot;,&quot;m&quot;]\r\n    [&quot;e&quot;,&quot;f&quot;,&quot;n&quot;]\r\n    [&quot;e&quot;,&quot;g&quot;,&quot;o&quot;]\r\n\r\nThe rest is left as an exercise :-)\r\n\r\n",
                "title": "JQ reusing results"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1531597174,
        "creation_date": 1531310534,
        "last_edit_date": 1531597174,
        "question_id": 51284997,
        "body_markdown": "My input, command and first (partial) results:\r\n\r\n    echo &#39;\r\n    {\r\n      &quot;a&quot;: {\r\n        &quot;b&quot;: [\r\n          &quot;c&quot;,\r\n          &quot;d&quot;\r\n        ],\r\n        &quot;e&quot;: [\r\n          &quot;f&quot;,\r\n          &quot;g&quot;\r\n        ]\r\n      },\r\n      &quot;h&quot;: {\r\n        &quot;c&quot;: [\r\n          &quot;i&quot;,\r\n          &quot;j&quot;\r\n        ],\r\n        &quot;d&quot;: [\r\n          &quot;k&quot;\r\n        ],\r\n        &quot;f&quot;: [\r\n          &quot;l&quot;,\r\n          &quot;m&quot;,\r\n          &quot;n&quot;\r\n        ],\r\n        &quot;g&quot;: [\r\n          &quot;o&quot;\r\n        ]\r\n      }\r\n    }&#39; | jq &#39;.a | keys_unsorted[]&#39;\r\n    &quot;b&quot;\r\n    &quot;e&quot;\r\n\r\nI would like to iterate over the results&#39; (&quot;b&quot;, &quot;e&quot;) arrays ([&quot;c&quot;, &quot;d&quot;] and [&quot;f&quot;, &quot;g&quot;]) and reuse that result of that query to search the second part of my tree (the &quot;h&quot; part), iterating of the arrays of the outcome and display those.\r\n\r\nSo my complete result would look like this:\r\n\r\n    &quot;b&quot;, &quot;c&quot;, &quot;i&quot;\r\n    &quot;b&quot;, &quot;c&quot;, &quot;j&#39;\n    &quot;b&quot;, &quot;d&quot;, &quot;k&quot;\n    &quot;e&quot;, &quot;f&quot;, &quot;l&quot;\n    &quot;e&quot;, &quot;f&quot;, &quot;m&quot;\n    &quot;e&quot;, &quot;f&quot;, &quot;n&quot;\n    &quot;e&quot;, &quot;g&quot;, &quot;o&quot;\r\n\r\nCatch is, I would like to do this in a single query, because of resources/time constraints in the final solution.\r\n\r\nI tried (a lot of) things, like &quot;keys as $k ...&quot; but am not able to wrap my brain around it on how to use this.\r\n\r\nCan someone give me a hint or show me a working solution and tell me how it works?\r\n\r\nThanks in advance!\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51284997/jq-reusing-results",
        "title": "JQ reusing results"
    },
    {
        "tags": [
            "json",
            "edit",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1531331944,
                "last_edit_date": 1531331944,
                "creation_date": 1531331532,
                "answer_id": 51291602,
                "question_id": 51291542,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Simply update your `.columns` property:\r\n\r\n    .versions[].columns\r\n     |= map(if (.type == &quot;varchar&quot; and .length &lt; 255) then .length = 255 else . end)\r\n\r\nhttps://jqplay.org/s/xjMiqANQ3p",
                "title": "How to get back full file after assignment with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1531416116,
        "creation_date": 1531331320,
        "last_edit_date": 1531416116,
        "question_id": 51291542,
        "body_markdown": "[jq▸play example](https://jqplay.org/s/Hta2KrMn-G)\r\n\r\nThis filter:\r\n\r\n    .versions[].columns[] | select(.type == &quot;varchar&quot; and .length &lt; 255) | .length = 255\r\n\r\nUpdates my data how I&#39;d like, but I want to get back the full file/input in the end, not just the columns that were modified. How can I do that?\r\n\r\nI don&#39;t want to delete the columns that don&#39;t match the `select` (just leave them unchanged)",
        "link": "https://stackoverflow.com/questions/51291542/how-to-get-back-full-file-after-assignment-with-jq",
        "title": "How to get back full file after assignment with jq?"
    },
    {
        "tags": [
            "json",
            "jq",
            "aws-security-group"
        ],
        "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": 1531363327,
                "post_id": 51294701,
                "comment_id": 89570536,
                "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": 1531471160,
                "post_id": 51294701,
                "comment_id": 89617484,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1531479339,
                "last_edit_date": 1531479339,
                "creation_date": 1531475393,
                "answer_id": 51322385,
                "question_id": 51294701,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your intention is to create a new `CidrIp` rule added when the value is `10.219.0.0/16`, do the following. Note that this does _not_ preserve the order of the elements in the array and adds the new IP to the tail end\r\n\r\n\r\n    jq &#39;if   .IpRanges[] | select(.CidrIp | contains(&quot;10.219.0.0/16&quot;) )\r\n        then .IpRanges += [ { &quot;cidrIp&quot; : &quot;10.10.0.0/16&quot; } ]\r\n        else . end&#39; ingressJSON\r\n    \r\nTo store this output in a variable and to be later used in your `aws` command, store the output above to a shell variable. And pass it to the command with proper quotes as `&quot;$awsRule&quot;`\r\n\r\n    awsRule=$(jq &#39;if   .IpRanges[] | select(.CidrIp | contains(&quot;10.219.0.0/16&quot;) )\r\n                  then .IpRanges += [ { &quot;cidrIp&quot; : &quot;10.10.0.0/16&quot; } ]\r\n                  else . end&#39; ingressJSON)\r\n\r\n\r\n",
                "title": "Parse AWS security group with jq and add new ingress rule"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1531717923,
                "creation_date": 1531717923,
                "answer_id": 51354938,
                "question_id": 51294701,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The answer I eventually figured out was to construct a simple SG json format that I use to feed it back to the aws ec2 statement.  This approach took me awhile to figure out but it was quite elegant and I think it was what I was going for. \r\n\r\n    # search for the matching pattern and write to the output file\r\n    aws ec2 describe-security-groups --region ${i} |   \\\r\n      jq -r --arg e_cidr &quot;${existing_cidr}&quot; \\\r\n         --arg n_cidr &quot;${new_cidr}&quot; \\\r\n         &#39;.SecurityGroups[] | .GroupId as $gid | .IpPermissions[] | .FromPort as $port | .IpProtocol as $protocol | \r\n         .IpRanges[] | select(.CidrIp == $e_cidr) | .Description as $desc |\r\n         [{ GroupId:$gid, IpProtocol:$protocol, FromPort:$port, ToPort:$port, IpRanges:[{CidrIp:$n_cidr, Description:$desc}] }] &#39; -c   \\\r\n         | tee -a ${regional_file} \r\n\r\nThis will produce a json file similar to this format,\r\n\r\n    [{\r\n    &quot;GroupId&quot;: &quot;sg-60d78e12&quot;,\r\n    &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n    &quot;FromPort&quot;: 443,\r\n    &quot;ToPort&quot;: 443,\r\n    &quot;IpRanges&quot;: [\r\n      {\r\n        &quot;CidrIp&quot;: &quot;12.179.53.18/32&quot;,\r\n        &quot;Description&quot;: &quot;Chicago Primary&quot;\r\n      }\r\n    ]\r\n    }]\r\n\r\nThen what I did was to drop the &quot;GroupId&quot; key value from the json statement, then feed into the aws ec2 command line to add the new ingress rule with the same protocol and port as of the original cidr block.  This work nicely and took a little while to get to this conclusion.\r\n\r\n        \twhile read -r sg_pattern\r\n    \t    do\r\n    \t\tgid=$( echo $sg_pattern | jq &#39;.[]|.GroupId&#39; -r )\r\n\r\n            # remove the GroupId key to prepare the ip_permissions json\r\n            ip_permissions=$( echo $sg_pattern | jq &#39;.[] | [ del(.GroupId) ]&#39; -r )\r\n    \t\techo &quot; ---&gt; adding new SG rule for ${ip_permissions}.&quot; \r\n    \t\taws ec2 authorize-security-group-ingress --group-id $gid --ip-permissions &quot;${ip_permissions}&quot;\r\n\r\n    \tdone &lt; ${regional_file}",
                "title": "Parse AWS security group with jq and add new ingress rule"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1531717923,
        "creation_date": 1531346142,
        "last_edit_date": 1531375068,
        "question_id": 51294701,
        "body_markdown": "The problem I’m trying to solve is to search for AWS SG group and add a new rule (eg: 10.10.0.0/16) to the same ingress rule block(port, protocal,cidr) where when the pattern is “CidrIp”: “10.219.0.0/16” matched.  \r\n\r\nFound match: - https://gist.github.com/mfang329/49575d6eb7ddb93e8f926648f9ba06e9\r\n\r\n    {\r\n    \t&quot;PrefixListIds&quot;: [],\r\n    \t&quot;FromPort&quot;: -1,\r\n    \t&quot;IpRanges&quot;: [{\r\n    \t\t\t&quot;CidrIp&quot;: &quot;10.219.0.0/16&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;Description&quot;: &quot;testing for vpc transit connectivity&quot;,\r\n    \t\t\t&quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n    \t\t}\r\n    \t],\r\n    \t&quot;ToPort&quot;: -1,\r\n    \t&quot;IpProtocol&quot;: &quot;icmp&quot;,\r\n    \t&quot;UserIdGroupPairs&quot;: [{\r\n    \t\t&quot;UserId&quot;: &quot;abcde80269151&quot;,\r\n    \t\t&quot;Description&quot;: &quot;default SG VPC - peering &quot;,\r\n    \t\t&quot;GroupId&quot;: &quot;sg-33511e41&quot;\r\n    \t}],\r\n    \t&quot;Ipv6Ranges&quot;: []\r\n    }\r\n\r\nChange to - https://gist.github.com/mfang329/b5e892cf2fee2da4b7e67106cd15b3b2\r\n\r\n    {\r\n    \t&quot;PrefixListIds&quot;: [],\r\n    \t&quot;FromPort&quot;: -1,\r\n    \t&quot;IpRanges&quot;: [{\r\n    \t\t\t&quot;CidrIp&quot;: &quot;10.219.0.0/16&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;CidrIp&quot;: &quot;10.10.0.0/16&quot;\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;Description&quot;: &quot;testing for vpc transit connectivity&quot;,\r\n    \t\t\t&quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n    \t\t}\r\n    \t],\r\n    \t&quot;ToPort&quot;: -1,\r\n    \t&quot;IpProtocol&quot;: &quot;icmp&quot;,\r\n    \t&quot;UserIdGroupPairs&quot;: [{\r\n    \t\t&quot;UserId&quot;: &quot;abcde80269151&quot;,\r\n    \t\t&quot;Description&quot;: &quot;default SG VPC - peering &quot;,\r\n    \t\t&quot;GroupId&quot;: &quot;sg-33511e41&quot;\r\n    \t}],\r\n    \t&quot;Ipv6Ranges&quot;: []\r\n    }\r\n\r\nModify the SG with the following, but how do I express the jq to query these information and use them as the input for following aws cli?  I know there are commands flags with JQ but I would like to what is the simplest solution to attack this problem?\r\n\r\n\r\n    aws ec2 revoke-security-group-ingress \\\r\n     — group-id sg-33511e41 \\\r\n     — port -1 \\\r\n     — protocol icmp \\\r\n     — cidr 10.10.0.0/16;\r\n\r\n\r\n----------\r\n\r\n\r\nFull security group JSON format - https://gist.github.com/mfang329/a1871731fe82e5255ccc571648ad4886*",
        "link": "https://stackoverflow.com/questions/51294701/parse-aws-security-group-with-jq-and-add-new-ingress-rule",
        "title": "Parse AWS security group with jq and add new ingress rule"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1531486612,
                "post_id": 51325368,
                "comment_id": 89626212,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3595907,
                    "reputation": 5832,
                    "user_id": 3000629,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fd7f5c9cce7faba20cc43901b5d03ffd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Poshi",
                    "link": "https://stackoverflow.com/users/3000629/poshi"
                },
                "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": 1531486680,
                "post_id": 51325368,
                "comment_id": 89626270,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1531488109,
                "last_edit_date": 1531488109,
                "creation_date": 1531486314,
                "answer_id": 51325558,
                "question_id": 51325368,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Please refer to this issue on GitHub there are many responses posted here which might help you with your problem: https://github.com/stedolan/jq/issues/1526\r\n\r\n\r\nI&#39;ll post one of the solutions here however:\r\n\r\n    jq &#39;.[&quot;E23763&quot;]&#39; test.json\r\n\r\nAnother Solution as said by @Inian is:\r\n\r\n    jq &#39;.&quot;E23763&quot;&#39; json\r\n\r\nWithout the [], in this case it was the correct solution but try both nonetheless\r\n\r\n\r\nBasically the parser is buggy and treats `.E` as the beginning of a number.\r\n",
                "title": "Failure in extracting the contents of a json field"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1531488109,
        "creation_date": 1531485692,
        "question_id": 51325368,
        "body_markdown": "I have a (not so complicated) json file and I need to extract its contents using `bash`. I want to use `jq` for the processing, it should be straightforward. The problem is that I&#39;m getting a weird error in the processing that I don&#39;t know how to solve (because I don&#39;t know what is causing it).\r\n\r\nA minimal sample causing me problems:\r\n\r\n    {\r\n      &quot;E23763&quot;: {\r\n        &quot;data&quot;: &quot;information&quot;\r\n      }\r\n    }\r\n\r\nIf I just run jq to pretty-print it, it works:\r\n\r\n    $ cat test.json | jq .\r\n    {\r\n      &quot;E23763&quot;: {\r\n        &quot;data&quot;: &quot;information&quot;\r\n      }\r\n    }\r\n\r\nBut if I try to extract the first field, it fails criptically:\r\n\r\n    $ cat test.json | jq .E23763\r\n    jq: error: Invalid numeric literal at EOF at line 1, column 7 (while parsing &#39;.E23763&#39;) at &lt;top-level&gt;, line 1:\r\n    .E23763\r\n    jq: 1 compile error\r\n\r\nThe expected result would had been:\r\n\r\n    {\r\n      &quot;data&quot;: &quot;information&quot;\r\n    }\r\n\r\nAnyone found a similar issue? Why it is complaining about a numeric literal when he is really looking into a string?\r\n\r\nQuotation didn&#39;t seem to matter here, same error.",
        "link": "https://stackoverflow.com/questions/51325368/failure-in-extracting-the-contents-of-a-json-field",
        "title": "Failure in extracting the contents of a json field"
    },
    {
        "tags": [
            "json",
            "regex",
            "environment-variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1531511791,
                "creation_date": 1531511791,
                "answer_id": 51332050,
                "question_id": 51331595,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the -r command-line option,\r\n\r\n    .[]\r\n    | &quot;\\(.Name|split(&quot;/&quot;)|.[-1])=\\(.Value)&quot;\r\n\r\nyields:\r\n\r\n    AWS_ACCESS_KEY_ID=ABC123\r\n    AWS_SECRET_ACCESS_KEY=abcdefghijkl\r\n    ENDPOINT=https://amazonaws.com\r\n\r\nThis seems to correspond to what you&#39;ve asked for, but this approach has the potential disadvantage that it assumes something about &quot;=&quot;, so please be careful!\r\n",
                "title": "Convert JSON from AWS SSM to environment variables using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1550094422,
                "creation_date": 1550094422,
                "answer_id": 54679958,
                "question_id": 51331595,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As the previous comment but use &#39;@sh&#39; to escape the value\r\n```.[]\r\n| &quot;\\(.Name|split(&quot;/&quot;)|.[-1])=\\(.Value | @sh)&quot;\r\n```",
                "title": "Convert JSON from AWS SSM to environment variables using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1550094422,
        "creation_date": 1531509693,
        "last_edit_date": 1531733412,
        "question_id": 51331595,
        "body_markdown": "I have done some research on this and feel as if I&#39;m about 80% there but struggling to adjust the jq output as required due to splitting one of the strings.\r\n\r\nI&#39;m trying to convert the JSON output from AWS SSM to environment variables. \r\n\r\nAWS command \r\n\r\n    aws ssm get-parameters-by-path \\\r\n    --path /qa/es \\\r\n    --with-decryption \\\r\n    --query &#39;Parameters[*].{Name:Name,Value:Value}&#39; \\\r\n\r\nOutput\r\n\r\n    [\r\n        {\r\n            &quot;Name&quot;: &quot;/qa/es/AWS_ACCESS_KEY_ID&quot;,\r\n            &quot;Value&quot;: &quot;ABC123&quot;\r\n        },\r\n        {\r\n            &quot;Name&quot;: &quot;/qa/es/AWS_SECRET_ACCESS_KEY&quot;,\r\n            &quot;Value&quot;: &quot;abcdefghijkl&quot;\r\n        },\r\n        {\r\n            &quot;Name&quot;: &quot;/qa/es/ENDPOINT&quot;,\r\n            &quot;Value&quot;: &quot;https://amazonaws.com&quot;\r\n        }\r\n    ]\r\n\r\nMy required output from jq, note I&#39;m only after the environment variable AFTER the last /. There may be cases where this could be /qa/es/something/nested/ENV_VAR\r\n\r\n    AWS_ACCESS_KEY_ID=ABC123\r\n    AWS_SECRET_ACCESS_KEY=abcdefghijkl\r\n    ENDPOINT=https://amazonaws.com\r\n\r\nOnce I have this I can utilise the answer here to set the environment variables. https://stackoverflow.com/questions/48512914/exporting-json-to-environment-variables/48515341?noredirect=1#comment84051241_48515341\r\n\r\nThe closest I have got is \r\n\r\n    jq -r &quot;map(\\&quot;\\(try(.Name |= split(\\&quot;/\\&quot;)))=\\(.Value|tostring)\\&quot;)|.[]&quot; params.json\r\n\r\nWhich gives me \r\n\r\n    {&quot;Name&quot;:[&quot;&quot;,&quot;qa&quot;,&quot;es&quot;,&quot;AWS_ACCESS_KEY_ID&quot;],&quot;Value&quot;:&quot;ABC123&quot;}=ABC123\r\n    {&quot;Name&quot;:[&quot;&quot;,&quot;qa&quot;,&quot;es&quot;,&quot;AWS_SECRET_ACCESS_KEY&quot;],&quot;Value&quot;:&quot;abcdefghijkl&quot;}=abcdefghijkl\r\n    {&quot;Name&quot;:[&quot;&quot;,&quot;qa&quot;,&quot;es&quot;,&quot;ENDPOINT&quot;],&quot;Value&quot;:&quot;https://amazonaws.com&quot;}=https://amazonaws.com\r\n\r\nClose, but not close enough! Can anyone point me in the right direction here?",
        "link": "https://stackoverflow.com/questions/51331595/convert-json-from-aws-ssm-to-environment-variables-using-jq",
        "title": "Convert JSON from AWS SSM to environment variables using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13768853,
                    "reputation": 1233,
                    "user_id": 9936841,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/YHxEO.jpg?s=256",
                    "display_name": "MrSmile",
                    "link": "https://stackoverflow.com/users/9936841/mrsmile"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531527267,
                "post_id": 51333916,
                "comment_id": 89643637,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13955929,
                    "reputation": 21,
                    "user_id": 10078321,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/2223566354326969/picture?type=large",
                    "display_name": "Jess",
                    "link": "https://stackoverflow.com/users/10078321/jess"
                },
                "reply_to_user": {
                    "account_id": 13768853,
                    "reputation": 1233,
                    "user_id": 9936841,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/YHxEO.jpg?s=256",
                    "display_name": "MrSmile",
                    "link": "https://stackoverflow.com/users/9936841/mrsmile"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531528581,
                "post_id": 51333916,
                "comment_id": 89643844,
                "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": 1531613944,
                "post_id": 51333916,
                "comment_id": 89661955,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1531538308,
                "last_edit_date": 1531538308,
                "creation_date": 1531534219,
                "answer_id": 51334650,
                "question_id": 51333916,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After fixing your input so that it is properly semicolon-separated:\r\n\r\n    jq -R &#39;split(&quot;;&quot;)\r\n    | map(gsub(&quot;^\\&quot;|\\&quot;$&quot;;&quot;&quot;))\r\n    | {title:.[1],\r\n       price: .[2],\r\n       description: { plain_text: .[3] }}&#39; input.csv\r\n\r\nyields:\r\n\r\n    {\r\n      &quot;title&quot;: &quot;Product Name&quot;,\r\n      &quot;price&quot;: &quot;Price&quot;,\r\n      &quot;description&quot;: {\r\n        &quot;plain_text&quot;: &quot;Description&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;title&quot;: &quot;Example&quot;,\r\n      &quot;price&quot;: &quot;200&quot;,\r\n      &quot;description&quot;: {\r\n        &quot;plain_text&quot;: &quot;Descripcion here...&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;title&quot;: &quot;Example2&quot;,\r\n      &quot;price&quot;: &quot;300&quot;,\r\n      &quot;description&quot;: {\r\n        &quot;plain_text&quot;: &quot;Some here...&quot;\r\n      }\r\n    }",
                "title": "Bash cvs file to json new file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1531739767,
                "last_edit_date": 1531739767,
                "creation_date": 1531534829,
                "answer_id": 51334697,
                "question_id": 51333916,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Well, that previous `jq` answer is more elegant.  I did this, using only bash...  Since I was done I put it here anyway, but I feel a bit silly after that nice answer from @peak.\r\n\r\nTo the OP, the first one is free.  For future questions, users here will **help** you, but you have to get started and face a particular issue you need help with ;-)\r\n\r\n\r\n    #!/bin/bash\r\n    \r\n    csvfile=&#39;input.csv&#39;\r\n    \r\n    # Make sure the file exists\r\n    if [ ! -f $csvfile ]\r\n    then\r\n        echo &quot;ERROR: file $csvfile does not exist.&quot;\r\n        exit 1\r\n    fi\r\n    \r\n    # Read the input file line per line\r\n    while read line\r\n    do\r\n        # Capture the information out of the line, fields separated by ;\r\n        IFS=&#39;;&#39; read pid pname price desc &lt;&lt;&lt; $line\r\n    \r\n        # Output the JSON for this line\r\n        echo &#39;{&#39;\r\n        echo &quot;    \\&quot;title\\&quot;:$pname,&quot;\r\n        echo &quot;    \\&quot;price\\&quot;:$price,&quot;\r\n        echo &quot;    \\&quot;description\\&quot;: {&quot;\r\n        echo &quot;        \\&quot;plain_text\\&quot;:$desc&quot;\r\n        echo &quot;    },&quot;\r\n        echo &quot;    \\&quot;Predifined\\&quot;:\\&quot;static content\\&quot;,&quot;\r\n        echo &quot;    \\&quot;Another Predifined\\&quot;:\\&quot;static content\\&quot;&quot;\r\n        echo &#39;}&#39;\r\n    \r\n        # Just to split the line&#39;s output\r\n        echo &quot;&quot;\r\n    done &lt;$csvfile\r\n\r\nWhich produces this output:\r\n\r\n    {\r\n        &quot;title&quot;:&quot;Product Name&quot;,\r\n        &quot;price&quot;:&quot;Price&quot;,\r\n        &quot;description&quot;: {\r\n            &quot;plain_text&quot;:&quot;Description&quot;\r\n        },\r\n        &quot;Predifined&quot;:&quot;static content&quot;,\r\n        &quot;Another Predifined&quot;:&quot;static content&quot;\r\n    }\r\n    \r\n    {\r\n        &quot;title&quot;:&quot;Example&quot;,\r\n        &quot;price&quot;:&quot;200&quot;,\r\n        &quot;description&quot;: {\r\n            &quot;plain_text&quot;:&quot;Descripcion here...&quot;\r\n        },\r\n        &quot;Predifined&quot;:&quot;static content&quot;,\r\n        &quot;Another Predifined&quot;:&quot;static content&quot;\r\n    }\r\n    \r\n    {\r\n        &quot;title&quot;:&quot;Example2&quot;,\r\n        &quot;price&quot;:&quot;300&quot;,\r\n        &quot;description&quot;: {\r\n            &quot;plain_text&quot;:&quot;Some here...&quot;\r\n        },\r\n        &quot;Predifined&quot;:&quot;static content&quot;,\r\n        &quot;Another Predifined&quot;:&quot;static content&quot;\r\n    }\r\n\r\n\r\n----------\r\n\r\n2nd version of the same script, this one will output each product section into it&#39;s own JSON file.  Note that I remove the first line of the CSV file since it is just headers and I do not want to create a file for the headers.\r\n\r\n    #!/bin/bash\r\n    \r\n    csvfile=&#39;input.csv&#39;\r\n    \r\n    # Make sure the file exists\r\n    if [ ! -f $csvfile ]\r\n    then\r\n        echo &quot;ERROR: file $csvfile does not exist.&quot;\r\n        exit 1\r\n    fi\r\n    \r\n    # Read the input file line per line\r\n    sed &#39;1d&#39; $csvfile | while read line\r\n    do\r\n        # Capture the information out of the line, fields separated by ;\r\n        IFS=&#39;;&#39; read pid pname price desc &lt;&lt;&lt; $line\r\n    \r\n        # Strip the &quot; from $pid and define the output filename\r\n        output_filename=&quot;$(echo $pid | tr -d &#39;&quot;&#39;).json&quot;\r\n    \r\n        # Output the JSON for this line\r\n        echo &#39;{&#39;                                               &gt;$output_filename\r\n        echo &quot;    \\&quot;title\\&quot;:$pname,&quot;                          &gt;&gt;$output_filename\r\n        echo &quot;    \\&quot;price\\&quot;:$price,&quot;                          &gt;&gt;$output_filename\r\n        echo &quot;    \\&quot;description\\&quot;: {&quot;                         &gt;&gt;$output_filename\r\n        echo &quot;        \\&quot;plain_text\\&quot;:$desc&quot;                   &gt;&gt;$output_filename\r\n        echo &quot;    },&quot;                                         &gt;&gt;$output_filename\r\n        echo &quot;    \\&quot;Predifined\\&quot;:\\&quot;static content\\&quot;,&quot;         &gt;&gt;$output_filename\r\n        echo &quot;    \\&quot;Another Predifined\\&quot;:\\&quot;static content\\&quot;&quot;  &gt;&gt;$output_filename\r\n        echo &#39;}&#39;                                              &gt;&gt;$output_filename\r\n    \r\n        # Just to split the line output\r\n        echo &quot;&quot;                                               &gt;&gt;$output_filename\r\n    done\r\n\r\n\r\nSome might comment that using a here doc instead of doing multiple echo statements like this would be more efficient, but I find that here docs mess up the indentation, and I started from the original script, it was faster like this.\r\n",
                "title": "Bash cvs file to json new file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -4,
        "last_activity_date": 1531739767,
        "creation_date": 1531524057,
        "last_edit_date": 1531525242,
        "question_id": 51333916,
        "body_markdown": "i m lie to use  bash to import data  from  cvs  to json  file\r\nExample Cvs\r\n\r\n    &quot;Product ID&quot;;&quot;Product Name&quot;;&quot;Price&quot;;&quot;Description&quot;;\r\n    &quot;1;&quot;Example&quot;;&quot;200&quot;;&quot;Descripcion here...&quot;;\r\n    &quot;2;&quot;Example2&quot;;&quot;300&quot;;&quot;Some here...&quot;;\r\n\r\nAnd i want  some like this:\r\n\r\n    {\r\n    &quot;title&quot;:&quot;Example&quot;,\r\n    &quot;price&quot;:200,\r\n    &quot;description&quot;: {\r\n          &quot;plain_text&quot;: &quot;Some here...&quot;\r\n       },\r\n    &quot;Predifined&quot;:static content,\r\n    &quot;Another Predifined&quot;:static content,\r\n    } \r\nHere is the script i try to use \r\n\r\n \r\n\r\n\r\n\r\nHow i can make this ? thx ",
        "link": "https://stackoverflow.com/questions/51333916/bash-cvs-file-to-json-new-file",
        "title": "Bash cvs file to json new file"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq",
            "wp-api"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13929204,
                    "reputation": 602,
                    "user_id": 10057757,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sOt8O.jpg?s=256",
                    "display_name": "hnicke",
                    "link": "https://stackoverflow.com/users/10057757/hnicke"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531545305,
                "post_id": 51335414,
                "comment_id": 89645997,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1766087,
                    "reputation": 9058,
                    "user_id": 1952287,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://i.sstatic.net/X6rDPkcg.png?s=256",
                    "display_name": "GʀᴜᴍᴘʏCᴀᴛ",
                    "link": "https://stackoverflow.com/users/1952287/g%ca%80%e1%b4%9c%e1%b4%8d%e1%b4%98%ca%8fc%e1%b4%80%e1%b4%9b"
                },
                "reply_to_user": {
                    "account_id": 13929204,
                    "reputation": 602,
                    "user_id": 10057757,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sOt8O.jpg?s=256",
                    "display_name": "hnicke",
                    "link": "https://stackoverflow.com/users/10057757/hnicke"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531545928,
                "post_id": 51335414,
                "comment_id": 89646095,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1531547026,
                "creation_date": 1531547026,
                "answer_id": 51335636,
                "question_id": 51335414,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are 2 issues here:\r\n\r\n1. `slug` is not a root level element in your example json. The root level element is an array. If you want to access the `slug` property of each element of the array, you can do so like this:\r\n\r\n        jq &#39;.[].slug&#39; $IDENTIFIER.json\r\n\r\n2. Your example json has trailing commas after the last property of each array element. Remove the commas after `&quot;taxonomy&quot;: &quot;category&quot;`.\r\n\r\nIf I take your sample json, remove the errant commas, save it to a plain text file called `test.json` and run the following command:\r\n\r\n    jq &#39;.[].slug&#39; test.json\r\n\r\nI get the following output:\r\n\r\n    &quot;foo&quot;\r\n    &quot;bar&quot;\r\n    &quot;mon&quot;\r\n    &quot;fort&quot;\r\n",
                "title": "Why is my jq failing on my JSON?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1531547350,
                "creation_date": 1531547350,
                "answer_id": 51335671,
                "question_id": 51335414,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## Preprocessing\r\nUnfortunately, the JSON-like data shown as having been produced by curl is not strictly JSON.  jq does not have a &quot;relaxed JSON&quot; mode, so in order to use jq, you will have to preprocess the JSON-like data, e.g. using hjson (see http://hjson.org/):\r\n\r\n    $ hjson -j input.qjson &gt; input.json\r\n\r\n## jq\r\n\r\nWith the JSON in input.json:\r\n\r\n    $ jq -c &#39;map(.slug)&#39; input.json\r\n    [&quot;foo&quot;,&quot;bar&quot;,&quot;mon&quot;,&quot;fort&quot;]",
                "title": "Why is my jq failing on my JSON?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1531558182,
                "last_edit_date": 1531558182,
                "creation_date": 1531557791,
                "answer_id": 51336809,
                "question_id": 51335414,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "your string is not json, notice how the last member of your objects ends with a comma,\r\n\r\n`{foo:&quot;bar&quot;,baz:9,}` \r\n\r\nthis is legal in javascript, but it&#39;s illegal in json. if you are supposed to be receiving json from that endpoint, then contact the people behind it and tell them to fix the bug (it&#39;s breaking the json specs by ending objects&#39;s last member with a comma, which is illegal in json.) - until it&#39;s fixed, i guess you can patch it with a little regex, but it&#39;s a dirty quickfix, and probably not very reliable, but running it through  \r\n\r\n`perl -p -0777 -e &#39;s/\\&quot;\\,\\s*}/\\&quot;}/g;&#39;` makes it legal json..",
                "title": "Why is my jq failing on my JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1546709296,
        "creation_date": 1531544817,
        "last_edit_date": 1531545904,
        "question_id": 51335414,
        "body_markdown": "Haven&#39;t used `jq` before but I&#39;m wanting to build a shell script that will get a JSON response and extract just the values.  To learn I thought I would try on my blog&#39;s WP API but for some reason I&#39;m getting an error of:\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:322): Cannot index array with string &quot;slug&quot;\r\n\r\nWhen researching for and testing previous questions:\r\n\r\n* [jq: Cannot index array with string][1]\r\n* [jq is sed for JSON][2]\r\n* [JSON array to bash variables using jq][3]\r\n* [How to use `jq` in a shell pipeline?][4]\r\n* [How to extract data from a JSON file][5]\r\n\r\nThe above reading I&#39;ve tried to code:\r\n\r\n    URL=&quot;http://foobar.com&quot;\r\n    RESPONSE=$(curl -so /dev/null -w &quot;%{http_code}&quot; $URL)\r\n    WPAPI=&quot;/wp-json/wp/v2&quot;\r\n    IDENTIFIER=&quot;categories&quot;\r\n    \r\n    if ((&quot;$RESPONSE&quot; == 200)); then\r\n    \tcurl -s {$URL$WPAPI&quot;/&quot;$IDENTIFIER&quot;/&quot;} | jq &#39;.&#39; &gt;&gt; $IDENTIFIER.json\r\n    \tresult=$(jq .slug $IDENTIFIER.json)\r\n    \techo $result\r\n    else\r\n    \techo &quot;Not returned status 200&quot;;\r\n    fi\r\n\r\nAn additional attempt changing the `jq` after the `curl`:\r\n\r\n    curl -s {$URL$WPAPI&quot;/&quot;$IDENTIFIER&quot;/&quot;} | jq &#39;.&#39; | $IDENTIFIER.json\r\n    result=(jq -r &#39;.slug&#39; $IDENTIFIER.json)\r\n    echo $result\r\n\r\nI can modify the uncompress with the python JSON tool:\r\n\r\n    result=(curl -s {$URL$WPAPI&quot;/&quot;$IDENTIFIER&quot;/&quot;} | python -m json.tool &gt; $IDENTIFIER.json)\r\n\r\nI can save the JSON to a file but when I use `jq` I cannot get just the slug and here are my other trys:\r\n\r\n    catCalled=$(curl -s {$URL$WPAPI&quot;/&quot;$IDENTIFIER&quot;/&quot;} | python -m json.tool | ./jq -r &#39;.slug&#39;)\r\n    echo $catCalled\r\n\r\nMy end goal is to try to use `jq` in a shell script and build a slug array  with `jq`.  What am I doing wrong in my `jq` and can I use `jq` on a string without creating a file?\r\n\r\n\r\n----------\r\nReturn from `curl` after uncompress per comment request:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 4,\r\n        &quot;count&quot;: 18,\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;link&quot;: &quot;http://foobar.com/category/foo/&quot;,\r\n        &quot;name&quot;: &quot;Foo&quot;,\r\n        &quot;slug&quot;: &quot;foo&quot;,\r\n        &quot;taxonomy&quot;: &quot;category&quot;,\r\n      },\r\n      {\r\n        &quot;id&quot;: 8,\r\n        &quot;count&quot;: 9,\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;link&quot;: &quot;http://foobar.com/category/bar/&quot;,\r\n        &quot;name&quot;: &quot;Bar&quot;,\r\n        &quot;slug&quot;: &quot;bar&quot;,\r\n        &quot;taxonomy&quot;: &quot;category&quot;,\r\n      },\r\n      {\r\n        &quot;id&quot;: 5,\r\n        &quot;count&quot;: 1,\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;link&quot;: &quot;http://foobar.com/category/mon/&quot;,\r\n        &quot;name&quot;: &quot;Mon&quot;,\r\n        &quot;slug&quot;: &quot;mon&quot;,\r\n        &quot;taxonomy&quot;: &quot;category&quot;,\r\n      },\r\n      {\r\n        &quot;id&quot;: 11,\r\n        &quot;count&quot;: 8,\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;link&quot;: &quot;http://foobar.com/category/fort/&quot;,\r\n        &quot;name&quot;: &quot;Fort&quot;,\r\n        &quot;slug&quot;: &quot;fort&quot;,\r\n        &quot;taxonomy&quot;: &quot;category&quot;,\r\n      }\r\n    ]\r\n\r\neventually my goal is trying to get the name of the slug&#39;s into an array like: \r\n\r\n    catArray=(&#39;foo&#39;,&#39;bar&#39;,&#39;mon&#39;, &#39;fort&#39;)\r\n\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/34543829/jq-cannot-index-array-with-string\r\n  [2]: https://robots.thoughtbot.com/jq-is-sed-for-json\r\n  [3]: https://unix.stackexchange.com/questions/413878/json-array-to-bash-variables-using-jq\r\n  [4]: https://stackoverflow.com/questions/33247228/how-to-use-jq-in-a-shell-pipeline\r\n  [5]: https://unix.stackexchange.com/questions/243428/how-to-extract-data-from-a-json-file",
        "link": "https://stackoverflow.com/questions/51335414/why-is-my-jq-failing-on-my-json",
        "title": "Why is my jq failing on my JSON?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 20,
                "is_accepted": true,
                "score": 20,
                "last_activity_date": 1660230747,
                "last_edit_date": 1660230747,
                "creation_date": 1531588793,
                "answer_id": 51341700,
                "question_id": 51338701,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Support for the [`JQ_COLORS` environment variable][1] was added to the development version on April 29, 2017 (that is, *after* the release of jq 1.5), with the following documentation:\r\n\r\n&gt;   To configure alternative colors just set the `JQ_COLORS`  \r\n&gt; environment variable to colon-delimited list of partial terminal  \r\n&gt; escape sequences like `&quot;1;31&quot;`, in this order:\r\n&gt; \r\n&gt;     - color for `null`\r\n&gt;     - color for `false`\r\n&gt;     - color for `true`\r\n&gt;     - color for numbers\r\n&gt;     - color for strings\r\n&gt;     - color for arrays\r\n&gt;     - color for objects\r\n&gt; \r\n&gt;   The default color scheme is the same as setting  \r\n&gt; `&quot;JQ_COLORS=1;30:0;39:0;39:0;39:0;32:1;39:1;39&quot;`.\r\n&gt; \r\n&gt;   This is not a manual for VT100/ANSI escapes.  However, each of  \r\n&gt; these color specifications should consist of two numbers separated  \r\n&gt; by a semi-colon, where the first number is one of these:\r\n&gt; \r\n&gt;     - 1 (bright)\r\n&gt;     - 2 (dim)\r\n&gt;     - 4 (underscore)\r\n&gt;     - 5 (blink)\r\n&gt;     - 7 (reverse)\r\n&gt;     - 8 (hidden)\r\n&gt; \r\n&gt;   and the second is one of these:\r\n&gt; \r\n&gt;     - 30 (black)\r\n&gt;     - 31 (red)\r\n&gt;     - 32 (green)\r\n&gt;     - 33 (yellow)\r\n&gt;     - 34 (blue)\r\n&gt;     - 35 (magenta)\r\n&gt;     - 36 (cyan)\r\n&gt;     - 37 (white)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Colors",
                "title": "How do I customize the colors used by &#39;jq -C&#39;?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1697704780,
                "creation_date": 1697704780,
                "answer_id": 77322205,
                "question_id": 51338701,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since @peak&#39;s [answer in 2018](https://stackoverflow.com/a/51341700/3547184), the jqlang project has merged [jqlang/jq#2703](https://github.com/jqlang/jq/pull/2703) which now provides a way to change the color of object _keys_ by appending an additional number set. Example:\r\n\r\n```bash\r\n# tested with jq-1.7\r\nexport JQ_COLORS=&quot;2;33:2;33:0;33:0;36:1;32:0;35:1;35:2;34&quot;\r\n```\r\n\r\nThe above example sets:\r\n\r\n - null: dim yellow\r\n - false: dim yellow\r\n - true: yellow\r\n - numbers: cyan\r\n - strings: bright green\r\n - arrays: magenta\r\n - objects: bright magenta\r\n - object _keys_: dim blue\r\n\r\nSee the [jq v1.7 manual on colors](https://jqlang.github.io/jq/manual/v1.7/#colors) for more details.",
                "title": "How do I customize the colors used by &#39;jq -C&#39;?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 15,
        "last_activity_date": 1703585885,
        "creation_date": 1531572820,
        "last_edit_date": 1703585885,
        "question_id": 51338701,
        "body_markdown": "How do I specify colors other than the defaults used for [`jq --color-output`][1]?\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/v1.5/#Invokingjq",
        "link": "https://stackoverflow.com/questions/51338701/how-do-i-customize-the-colors-used-by-jq-c",
        "title": "How do I customize the colors used by &#39;jq -C&#39;?"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "command-line",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10930,
                    "reputation": 802218,
                    "user_id": 20862,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/2343ae368d3241278581ce6c87f62a25?s=256&d=identicon&r=PG",
                    "display_name": "Ignacio Vazquez-Abrams",
                    "link": "https://stackoverflow.com/users/20862/ignacio-vazquez-abrams"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1531710713,
                "post_id": 51354091,
                "comment_id": 89680703,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 10930,
                    "reputation": 802218,
                    "user_id": 20862,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/2343ae368d3241278581ce6c87f62a25?s=256&d=identicon&r=PG",
                    "display_name": "Ignacio Vazquez-Abrams",
                    "link": "https://stackoverflow.com/users/20862/ignacio-vazquez-abrams"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531728502,
                "post_id": 51354091,
                "comment_id": 89686589,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1531716757,
                "creation_date": 1531716757,
                "answer_id": 51354783,
                "question_id": 51354091,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Bash is not a good language for handling JSON data, best is to use a higher level language. Here is a sample implementation in Ruby 2.4 (for the `transform_values` method):\r\n\r\n    #!/usr/bin/env ruby                                                             \r\n    require &#39;json&#39;                                                                  \r\n                                                                                    \r\n    def parse(v)                                                                    \r\n      v = JSON.parse(v) rescue v                                                    \r\n      if v.respond_to? :transform_values                                            \r\n        v.transform_values {|w| parse(w)}                                           \r\n      elsif v.respond_to? :map                                                      \r\n        v.map{|w| parse(w)}                                                         \r\n      else                                                                          \r\n        v                                                                           \r\n      end                                                                           \r\n    end                                                                             \r\n                                                                                    \r\n    puts JSON.pretty_generate parse(ARGF.read)\r\n\r\n    \r\nHere is a sample run on a modified example, that includes arrays:\r\n\r\n\r\n    $ cat file\r\n    {\r\n        &quot;requestType&quot;: [ &quot;{\\&quot;a\\&quot;: \\&quot;b\\&quot;}&quot;, 123 ],\r\n        &quot;response&quot;: {\r\n            &quot;size&quot;: 2,\r\n            &quot;text&quot;: &quot;{\\&quot;recordID\\&quot;:1, \\&quot;title\\&quot;:\\&quot;Hello\\&quot;, \\&quot;content\\&quot;:\\&quot;Lorem ipsum\\&quot;}&quot;,\r\n            &quot;arr&quot;: &quot;[1,2,3]&quot;\r\n        },\r\n        &quot;scheme&quot;: &quot;{\\&quot;scheme\\&quot;:\\&quot;https\\&quot;}&quot;\r\n    }\r\n\r\n    $ ./test.rb file\r\n    {\r\n      &quot;requestType&quot;: [\r\n        {\r\n          &quot;a&quot;: &quot;b&quot;\r\n        },\r\n        123\r\n      ],\r\n      &quot;response&quot;: {\r\n        &quot;size&quot;: 2,\r\n        &quot;text&quot;: {\r\n          &quot;recordID&quot;: 1,\r\n          &quot;title&quot;: &quot;Hello&quot;,\r\n          &quot;content&quot;: &quot;Lorem ipsum&quot;\r\n        },\r\n        &quot;arr&quot;: [\r\n          1,\r\n          2,\r\n          3\r\n        ]\r\n      },\r\n      &quot;scheme&quot;: {\r\n        &quot;scheme&quot;: &quot;https&quot;\r\n      }\r\n    }\r\n\r\n",
                "title": "Convert all JSON string to JSON"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1531810898,
                "last_edit_date": 1531810898,
                "creation_date": 1531728421,
                "answer_id": 51357227,
                "question_id": 51354091,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your jq has `walk` then you can simply write:\r\n\r\n    walk(if type==&quot;string&quot; then fromjson? // . else . end)\r\n\r\nOtherwise, you can copy-and-paste the definition of `walk/1`, which can readily be found by googling `jq def walk`.\r\n\r\n\r\n## Roll your own\r\n\r\nAlternatively:\r\n\r\n    def dej:\r\n      if type == &quot;string&quot; then fromjson? // . \r\n      elif type == &quot;object&quot; then map_values(dej)\r\n      elif type == &quot;array&quot; then map(dej)\r\n      else .\r\n      end;\r\n\r\n    dej\r\n\r\n## Deep de-jsonification\r\nIf you want `dej` as defined above to be applied as many times as required to achieve quiescence, then you could use this definition:\r\n\r\n    def dejx:\r\n      def dej:\r\n        if type == &quot;string&quot; then fromjson? // . \r\n        elif type == &quot;object&quot; then map_values(dej)\r\n        elif type == &quot;array&quot; then map(dej)\r\n        else .\r\n        end;\r\n      dej as $d | if . == $d then . else $d|dejx end;\r\n\r\n\r\n## Using `fromjson` directly\r\nFor simple cases, you can just use `fromjson`, e.g. in your case:\r\n\r\n    .scheme |= fromjson\r\n\t| .response.text |= fromjson\r\n",
                "title": "Convert all JSON string to JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1531810898,
        "creation_date": 1531710619,
        "question_id": 51354091,
        "body_markdown": "I have a JSON object that contains strings of JSON at various levels in the JSON such as the one below that I want converted to as nested JSON.\r\n\r\nInput:\r\n\r\n    {\r\n        &quot;requestType&quot;: &quot;POST&quot;,\r\n        &quot;response&quot;: {\r\n            &quot;size&quot;: 2,\r\n            &quot;text&quot;: &quot;{\\&quot;recordID\\&quot;:1, \\&quot;title\\&quot;:\\&quot;Hello\\&quot;, \\&quot;content\\&quot;:\\&quot;Lorem ipsum\\&quot;}&quot;\r\n        },\r\n        &quot;scheme&quot;: &quot;{\\&quot;scheme\\&quot;:\\&quot;https\\&quot;}&quot;\r\n    }\r\n\r\nOutput:\r\n\r\n    {\r\n        &quot;requestType&quot;:&quot;POST&quot;,\r\n        &quot;response&quot;:{\r\n            &quot;size&quot;:2,\r\n            &quot;text&quot;:{\r\n                &quot;recordID&quot;:1,\r\n                &quot;title&quot;:&quot;Hello&quot;,\r\n                &quot;content&quot;:&quot;Lorem ipsum&quot;\r\n            }\r\n        },\r\n        &quot;scheme&quot;:{\r\n            &quot;scheme&quot;:&quot;https&quot;\r\n        }\r\n    }\r\n\r\nI know it&#39;s possible to convert one specific object using `fromjson` but is there an easier way to convert all occurrances of these string to json?",
        "link": "https://stackoverflow.com/questions/51354091/convert-all-json-string-to-json",
        "title": "Convert all JSON string to JSON"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1531749324,
                "creation_date": 1531749324,
                "answer_id": 51363558,
                "question_id": 51363314,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to write the results to a temporary file and rename that to the original one:\r\n\r\n    ./jq-linux64 --arg city tehran &#39;.HotelInfo +{city: $city}&#39; 74687.json &gt; temp.json\r\n    mv temp.json 74687.json",
                "title": "Update file after adding new object with JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1531749415,
                "creation_date": 1531749415,
                "answer_id": 51363582,
                "question_id": 51363314,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `sponge` or write to a temporary file, and then &quot;mv&quot; it.\r\n\r\nFor further details and alternatives, see the following Q in the [jq FAQ][1]:\r\n\r\n&#119928;: How can &quot;in-place&quot; editing of a JSON file be accomplished? What is jq&#39;s equivalent of sed -i?\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "Update file after adding new object with JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1531753258,
                "last_edit_date": 1531753258,
                "creation_date": 1531750863,
                "answer_id": 51363996,
                "question_id": 51363314,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to keep your original json structure and just append the new value you could use:\r\n\r\n    $ jq &#39;.HotelInfo.city = &quot;tehran&quot;&#39; 74687.json &gt; 74687.jso.tmp\r\n    $ mv 74687.json.tmp 74687.json\r\n\r\nThis will update the file with all previous fields/objects if any:\r\n\r\n    {\r\n      &quot;HotelInfo&quot;: {\r\n        &quot;HotelURL&quot;: &quot;http://www.tripadvisor.com/aaa.html&quot;,\r\n        &quot;HotelID&quot;: &quot;74687&quot;,\r\n        &quot;Price&quot;: &quot;$156&quot;,\r\n        &quot;city&quot;: &quot;tehran&quot;\r\n      }\r\n    }\r\n\r\n\r\nIf you just want to create a new structure removing other possible keys within `.HotelInfo`\r\n    \r\n    $ jq --arg city tehran &#39;.HotelInfo +{city: $city}&#39; 74687.json &gt; 74687.jso.tmp \r\n    $ mv 74687.json.tmp 74687.json\r\n\r\nThis will create the file with the `Hotelinfo` object contents only:\r\n\r\n    {\r\n      &quot;HotelURL&quot;: &quot;http://www.tripadvisor.com/aaa.html&quot;,\r\n      &quot;HotelID&quot;: &quot;74687&quot;,\r\n      &quot;Price&quot;: &quot;$156&quot;,\r\n      &quot;city&quot;: &quot;tehran&quot;\r\n    }\r\n\r\n",
                "title": "Update file after adding new object with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1531817212,
        "creation_date": 1531748627,
        "last_edit_date": 1531817212,
        "question_id": 51363314,
        "body_markdown": "I&#39;m new in using `jq` library, Here i&#39;m reading `HotelInfo` field of my json:\r\n\r\n    ./jq-linux64 &#39;.HotelInfo&#39; 74687.json\r\n    \r\n    {\r\n      &quot;HotelURL&quot;: &quot;http://www.tripadvisor.com/aaa.html&quot;,\r\n      &quot;HotelID&quot;: &quot;74687&quot;,\r\n      &quot;Price&quot;: &quot;$156&quot;\r\n    }\r\n\r\nNow, i&#39;m going to add `{city: tehran}` object to this array :\r\n\r\n    ./jq-linux64 --arg city tehran &#39;.HotelInfo +{city: $city}&#39; 74687.json \r\n    \r\n    {\r\n      &quot;HotelURL&quot;: &quot;http://www.tripadvisor.com/aaa.html&quot;,\r\n      &quot;HotelID&quot;: &quot;74687&quot;,\r\n      &quot;Price&quot;: &quot;$156&quot;,\r\n      &quot;city&quot;: &quot;tehran&quot;\r\n    }\r\n\r\nAnd it&#39;s done, but this doesn&#39;t reflect on file too and file still not updated with this new record, How can i update the json file as well?",
        "link": "https://stackoverflow.com/questions/51363314/update-file-after-adding-new-object-with-jq",
        "title": "Update file after adding new object with JQ"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "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": 1531844565,
                "post_id": 51370588,
                "comment_id": 89744225,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1531779065,
                "creation_date": 1531779065,
                "answer_id": 51370751,
                "question_id": 51370588,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, let&#39;s focus on solving the problem without worrying about keyList.  \r\n\r\nThis can be done conveniently using `tostream` and the following helper function:\r\n\r\n    # s should be a stream of [key, value] pairs\r\n    def aggregate(s):\r\n     reduce s as $x ({}; .[$x[0]] += [$x[1]] );\r\n\r\nThe main filter can then be written as:\r\n\r\n    aggregate( tostream\r\n      | select(length==2 and (.[0][-1] | type == &quot;string&quot;))\r\n      | [.[0][-1], .[1]] )\r\n\r\nAs it happens, this produces the result for the original problem:\r\n\r\n    {\r\n      &quot;key1&quot;: [\r\n        &quot;valueA&quot;\r\n      ],\r\n      &quot;key11&quot;: [\r\n        &quot;lastvalue&quot;\r\n      ],\r\n      &quot;key2&quot;: [\r\n        123456\r\n      ],\r\n      &quot;key4&quot;: [\r\n        &quot;anotherValue41&quot;,\r\n        &quot;anotherValue42&quot;\r\n      ],\r\n      &quot;key5&quot;: [\r\n        &quot;anotherValue51&quot;,\r\n        &quot;anotherValue52&quot;\r\n      ],\r\n      &quot;key6&quot;: [\r\n        999,\r\n        666\r\n      ]\r\n    }\r\n    \r\n## keyList\r\nTo satisfy the requirement about keyList, let&#39;s suppose the list is made available as `$keyList`.\r\n\r\nThen we can achieve the desired result by simply adding one more `select` condition using `index`:\r\n\r\n\r\n    aggregate( tostream\r\n      | select(length==2 and (.[0][-1] | type == &quot;string&quot;))\r\n      | [.[0][-1], .[1]]\r\n      | select(.[0] as $k | $keyList|index($k) )) \r\n\r\n\r\n",
                "title": "JQ getting terminal unique values and filtering by keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1531806021,
        "creation_date": 1531777998,
        "last_edit_date": 1531806021,
        "question_id": 51370588,
        "body_markdown": "I am discovering jq and it is amazing stuff. Posted some on GitHub and they told me to post usage question here.\r\n\r\nI am trying to get a list of key/value from a json and filter to keep unique value per keys that belong to a list/array.\r\ninput json is \r\n\r\n    {\r\n    &quot;key0&quot;: {\r\n    &quot;key1&quot;: &quot;valueA&quot;,\r\n    &quot;key2&quot;: 123456,\r\n    &quot;key3&quot;: [{\r\n      &quot;key4&quot;: &quot;anotherValue41&quot;,\r\n      &quot;key5&quot;: &quot;anotherValue51&quot;,\r\n      &quot;key6&quot;: 999\r\n    }, {\r\n      &quot;key4&quot;: &quot;anotherValue42&quot;,\r\n      &quot;key5&quot;: &quot;anotherValue52&quot;,\r\n      &quot;key6&quot;: 666\r\n    }],\r\n    \t&quot;key10&quot;: {\r\n    \t\t&quot;key11&quot;: &quot;lastvalue&quot;\r\n    \t}\r\n    }\r\n    }\r\n\r\nmy keyList is \r\n\r\n    [&quot;key1&quot;,&quot;key2&quot;,&quot;key4&quot;,&quot;key5&quot;,&quot;key6&quot;,&quot;key9&quot;,&quot;key11&quot;]\r\n\r\nexpected result is to retain only key/values that match with the keylist and to group the values by the keys.\r\n\r\n\r\n    {\r\n    &quot;key1&quot;: [&quot;valueA&quot;],\r\n    &quot;key2&quot;: [123456],\r\n    &quot;key4&quot;: [&quot;anotherValue41&quot;, &quot;anotherValue42&quot;],\r\n    &quot;key5&quot;: [&quot;anotherValue51&quot;, &quot;anotherValue52&quot;],\r\n    &quot;key6&quot;: [999, 666],\r\n    &quot;key11&quot;: &quot;lastvalue&quot;\r\n    }\r\n\r\n\r\nI have tried to use keys but I cannot revert back to the values… All other samples I have found have repeating json structures.\r\n\r\nI hope I am clear enough.\r\n\r\n\r\nThanks\r\nCyril",
        "link": "https://stackoverflow.com/questions/51370588/jq-getting-terminal-unique-values-and-filtering-by-keys",
        "title": "JQ getting terminal unique values and filtering by keys"
    },
    {
        "tags": [
            "arrays",
            "json",
            "variables",
            "iteration",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1531826822,
                "last_edit_date": 1531826822,
                "creation_date": 1531826269,
                "answer_id": 51380070,
                "question_id": 51379550,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your intention is just to append an element to an object, it would be better to use `+=` as\r\n\r\n    jq &#39;.e += { &quot;h&quot; : &quot;i&quot; }&#39;\r\n\r\nIn action,\r\n\r\n    echo &#39;{ &quot;e&quot;: { &quot;f&quot;: &quot;g&quot; } }&#39; | jq &#39;.e += { &quot;h&quot; : &quot;i&quot; }&#39;\r\n    {\r\n      &quot;e&quot;: {\r\n        &quot;f&quot;: &quot;g&quot;,\r\n        &quot;h&quot;: &quot;i&quot;\r\n      }\r\n    }\r\n\r\n",
                "title": "JQ How to add a node to a complete tree"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1531826822,
        "creation_date": 1531824657,
        "question_id": 51379550,
        "body_markdown": "Adding a field to a tree is straightforward:\r\n\r\n    echo &#39;{ &quot;a&quot;: &quot;b&quot; }&#39; | jq &#39;.&#39;\r\n    {\r\n      &quot;a&quot;: &quot;b&quot;\r\n    }\r\n    echo &#39;{ &quot;a&quot;: &quot;b&quot; }&#39; | jq &#39;. + { c: &quot;d&quot; }&#39;\r\n    {\r\n      &quot;a&quot;: &quot;b&quot;,\r\n      &quot;c&quot;: &quot;d&quot;\r\n    }\r\n\r\nBut adding a field to an existing object does not work as was expected, by displaying only the modified subtree:\r\n\r\n    echo &#39;{ &quot;e&quot;: { &quot;f&quot;: &quot;g&quot; } }&#39; | jq &#39;.&#39; \r\n    {\r\n      &quot;e&quot;: {\r\n        &quot;f&quot;: &quot;g&quot;\r\n      }\r\n    }\r\n    echo &#39;{ &quot;e&quot;: { &quot;f&quot;: &quot;g&quot; } }&#39; | jq &#39;.e + { h: &quot;i&quot; }&#39; \r\n    {\r\n      &quot;f&quot;: &quot;g&quot;,\r\n      &quot;h&quot;: &quot;i&quot;\r\n    }\r\n\r\nTried various workarounds but none gave what was needed :\r\n\r\n    echo &#39;{ &quot;e&quot;: { &quot;f&quot;: &quot;g&quot; } }&#39; | jq &#39;. as $k | .e + { h: &quot;i&quot; } | $k + .&#39;\r\n    {\r\n      &quot;e&quot;: {\r\n        &quot;f&quot;: &quot;g&quot;\r\n      },\r\n      &quot;f&quot;: &quot;g&quot;,\r\n      &quot;h&quot;: &quot;i&quot;\r\n    }\r\n\r\n    echo &#39;{ &quot;e&quot;: { &quot;f&quot;: &quot;g&quot; } }&#39; | jq &#39;. as $k | .e + { h: &quot;i&quot; } | $k + .e&#39;\r\n    {\r\n      &quot;e&quot;: {\r\n        &quot;f&quot;: &quot;g&quot;\r\n      }\r\n    }\r\n\r\nDesired output:\r\n\r\n    {\r\n      &quot;e&quot;: {\r\n        &quot;f&quot;: &quot;g&quot;,\r\n        &quot;h&quot;: &quot;i&quot;\r\n      }\r\n    }\r\n\r\nCan somebody show me the errors of my ways?",
        "link": "https://stackoverflow.com/questions/51379550/jq-how-to-add-a-node-to-a-complete-tree",
        "title": "JQ How to add a node to a complete tree"
    },
    {
        "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": 1531856367,
                "post_id": 51388895,
                "comment_id": 89750073,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10266894,
                    "reputation": 959,
                    "user_id": 7576611,
                    "user_type": "registered",
                    "accept_rate": 29,
                    "profile_image": "https://lh4.googleusercontent.com/-5qWm5XliK5c/AAAAAAAAAAI/AAAAAAAAAAs/GoUmSiF72uI/s256-rj/photo.jpg",
                    "display_name": "Shabbir Bata",
                    "link": "https://stackoverflow.com/users/7576611/shabbir-bata"
                },
                "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": 1531858157,
                "post_id": 51388895,
                "comment_id": 89750910,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1531856647,
                "creation_date": 1531856647,
                "answer_id": 51389108,
                "question_id": 51388895,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If by `$**$NEW_ARTIFACTORY_LOCATION**` you intend to signify the value of the environment variable $NEW_ARTIFACTORY_LOCATION, then you could use `env.NEW_ARTIFACTORY_LOCATION`, e.g.\r\n\r\n    .taskDefinition.containerDefinitions[].environment\r\n    | map(if .name == &quot;ARTIFACT_LOCATION&quot; \r\n         then . + {&quot;value&quot; : env.NEW_ARTIFACTORY_LOCATION} \r\n         else . end)&#39;\r\n\r\nAlternatively, you could use the `--arg NAME VALUE` command-line option.",
                "title": "Unable to map variable value referencing in JQ for JSON"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1531856647,
        "creation_date": 1531855611,
        "last_edit_date": 1531856078,
        "question_id": 51388895,
        "body_markdown": "I am trying to update an environment variable value in my json. Can I do this by making use of a variable as reference?\r\n\r\nThis works:\r\n\r\n    cat taskdef.json | jq &#39;\r\n      .taskDefinition.containerDefinitions[].environment\r\n      | map(if .name == &quot;ARTIFACT_LOCATION&quot; \r\n            then . + {&quot;value&quot; : &quot;2&quot;} \r\n            else . end)&#39;\r\n\r\nThis does not: \r\n\r\n     cat taskdef.json | jq &#39;\r\n       .taskDefinition.containerDefinitions[].environment\r\n       | map(if .name == &quot;ARTIFACT_LOCATION&quot; \r\n             then . + {&quot;value&quot; : &quot;**$NEW_ARTIFACTORY_LOCATION**&quot;} \r\n             else . end)&#39;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51388895/unable-to-map-variable-value-referencing-in-jq-for-json",
        "title": "Unable to map variable value referencing in JQ for JSON"
    },
    {
        "tags": [
            "json",
            "sed",
            "quotes",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5871097,
                    "reputation": 1316,
                    "user_id": 4623415,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c26a51d7e2d0c5e2ac1c1b2129fa32a6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "sachav",
                    "link": "https://stackoverflow.com/users/4623415/sachav"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1531862724,
                "post_id": 51390257,
                "comment_id": 89752934,
                "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": 2,
                "creation_date": 1532007694,
                "post_id": 51390257,
                "comment_id": 89819370,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1531898401,
                "creation_date": 1531898401,
                "answer_id": 51395871,
                "question_id": 51390257,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**`sed`** + **`jq`** solution:\r\n\r\n    sed -E &#39;s/&quot;/\\\\&amp;/4g; s/\\\\&quot;(,)?$/&quot;\\1/&#39; input.json | jq -s &#39;.&#39;\r\n\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;a&quot;: &quot;value1&quot;,\r\n        &quot;b&quot;: &quot;value with \\&quot;quotes\\&quot;2&quot;,\r\n        &quot;c&quot;: &quot;value with \\&quot;more\\&quot; than one set of \\&quot;quotes\\&quot;3&quot;\r\n      },\r\n      {\r\n        &quot;a&quot;: &quot;value4&quot;,\r\n        &quot;b&quot;: &quot;value with \\&quot;quotes\\&quot;5&quot;,\r\n        &quot;c&quot;: &quot;value with \\&quot;more\\&quot; than one set of \\&quot;quotes\\&quot;6&quot;\r\n      },\r\n      {\r\n        &quot;a&quot;: &quot;value7&quot;,\r\n        &quot;b&quot;: &quot;value with \\&quot;quotes\\&quot;8&quot;,\r\n        &quot;c&quot;: &quot;value with \\&quot;more\\&quot; than one set of \\&quot;quotes\\&quot;9&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "How to escape quotes in a JSON value with JQ when JSON is not valid yet"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1531898401,
        "creation_date": 1531861937,
        "question_id": 51390257,
        "body_markdown": "I have invalid JSON like this:\r\n\r\n    {\r\n       &quot;a&quot;: &quot;value1&quot;,\r\n       &quot;b&quot;: &quot;value2&quot;,\r\n       &quot;c&quot;: &quot;value3&quot;\r\n    }\r\n    {\r\n       &quot;a&quot;: &quot;value4&quot;,\r\n       &quot;b&quot;: &quot;value5&quot;,\r\n       &quot;c&quot;: &quot;value6&quot;\r\n    }\r\n    {\r\n       &quot;a&quot;: &quot;value7&quot;,\r\n       &quot;b&quot;: &quot;value8&quot;,\r\n       &quot;c&quot;: &quot;value9&quot;\r\n    }\r\n\r\nI can easily make it valid with JQ -- `jq . -s` -- which outputs:\r\n\r\n    [\r\n       {\r\n           &quot;a&quot;: &quot;value1&quot;,\r\n           &quot;b&quot;: &quot;value2&quot;,\r\n           &quot;c&quot;: &quot;value3&quot;\r\n       },\r\n       {\r\n           &quot;a&quot;: &quot;value4&quot;,\r\n           &quot;b&quot;: &quot;value5&quot;,\r\n           &quot;c&quot;: &quot;value6&quot;\r\n       },\r\n       {\r\n           &quot;a&quot;: &quot;value7&quot;,\r\n           &quot;b&quot;: &quot;value8&quot;,\r\n           &quot;c&quot;: &quot;value9&quot;\r\n       }\r\n    ]\r\n\r\nBut when my invalid JSON contains quotes...\r\n\r\n    {\r\n       &quot;a&quot;: &quot;value1&quot;,\r\n       &quot;b&quot;: &quot;value with &quot;quotes&quot;2&quot;,\r\n       &quot;c&quot;: &quot;value with &quot;more&quot; than one set of &quot;quotes&quot;3&quot;\r\n    }\r\n    {\r\n       &quot;a&quot;: &quot;value4&quot;,\r\n       &quot;b&quot;: &quot;value with &quot;quotes&quot;5&quot;,\r\n       &quot;c&quot;: &quot;value with &quot;more&quot; than one set of &quot;quotes&quot;6&quot;\r\n    }\r\n    {\r\n       &quot;a&quot;: &quot;value7&quot;,\r\n       &quot;b&quot;: &quot;value with &quot;quotes&quot;8&quot;,\r\n       &quot;c&quot;: &quot;value with &quot;more&quot; than one set of &quot;quotes&quot;9&quot;\r\n    }\r\n\r\n...that JQ command obviously won&#39;t work because of the quotes within quotes.\r\n\r\nMy goal is to make my original JSON completely valid both in (1) structure and  (2) with quotes in values escaped. I don&#39;t want any other quotes escaped than those inside the value -- for example:\r\n\r\n`&quot;c&quot;: &quot;value with \\&quot;more\\&quot; than one set of \\&quot;quotes\\&quot;9&quot;,`\r\n\r\nI have written a number of one-off Bash sed scripts to search and replace unescaped quotes with escaped quotes, but as use cases grow so do the number of scripts. It seems like JQ may be powerful and elegant enough to handle a use case like this, if I knew how to use JQ better.\r\n\r\nI have tried various combinations of JQ&#39;s slurp, raw input, and raw output functions. All I accomplish is switching back and forth between everything escaped or my original problematic JSON. `c` is the only key whose value will ever have quotes within it.\r\n\r\nThere may also be another solution besides sed or JQ that addresses this in a wise way. A command-line solution is ideal, because I don&#39;t know C#, Java, or JavaScript. Python might be acceptable if there is simply no way to accomplish it with JQ.\r\n\r\nThank you for any help or ideas.",
        "link": "https://stackoverflow.com/questions/51390257/how-to-escape-quotes-in-a-json-value-with-jq-when-json-is-not-valid-yet",
        "title": "How to escape quotes in a JSON value with JQ when JSON is not valid yet"
    },
    {
        "tags": [
            "json",
            "stream",
            "jq",
            "reduction",
            "memory-efficient"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1531947834,
                "last_edit_date": 1531947834,
                "creation_date": 1531941554,
                "answer_id": 51409529,
                "question_id": 51409156,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Found it :)\r\n\r\n    $ cat input.json |\r\n      jq -sc &#39;reduce range(0,length) as $i ( .; .[$i].b = ($i+1)) |.[]&#39;\r\n    {&quot;a&quot;:&quot;test1&quot;,&quot;b&quot;:1}\r\n    {&quot;a&quot;:&quot;test2&quot;,&quot;b&quot;:2}\r\n    {&quot;a&quot;:&quot;test3&quot;,&quot;b&quot;:3}\r\n\r\n",
                "title": "Count number of records processed in jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1531947109,
                "creation_date": 1531947109,
                "answer_id": 51410802,
                "question_id": 51409156,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq 1.5 has `inputs`, which opens the door to an efficient solution:\r\n\r\n    jq -nc &#39;\r\n      foreach inputs as $x (-1; .+1; \r\n        . as $n | $x | .[&quot;b&quot;] = $n)&#39; stream.json\r\n    {&quot;a&quot;:&quot;test1&quot;,&quot;b&quot;:0}\r\n    {&quot;a&quot;:&quot;test2&quot;,&quot;b&quot;:1}\r\n    {&quot;a&quot;:&quot;test3&quot;,&quot;b&quot;:2}\r\n\r\n",
                "title": "Count number of records processed in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1531947834,
        "creation_date": 1531940044,
        "last_edit_date": 1531947159,
        "question_id": 51409156,
        "body_markdown": "I&#39;m starting to play with jq and now I stuck when I try to increment a field value while interacting with each object of the input.\r\n\r\nInput file has:\r\n\r\n    {&quot;a&quot; : &quot;test1&quot;, &quot;b&quot; : 0}\r\n    {&quot;a&quot; : &quot;test2&quot;, &quot;b&quot; : 0}\r\n    {&quot;a&quot; : &quot;test3&quot;, &quot;b&quot; : 0}\r\n\r\nPS: There is no array, only 1 object in each line.\r\n\r\nDesired output:\r\n\r\n    {&quot;a&quot; : &quot;test1&quot;, &quot;b&quot; : 0}\r\n    {&quot;a&quot; : &quot;test2&quot;, &quot;b&quot; : 1}\r\n    {&quot;a&quot; : &quot;test3&quot;, &quot;b&quot; : 2}\r\n\r\nI found few examples showing how to do with arrays but nothing like this one.\r\n\r\nThank you!\r\n",
        "link": "https://stackoverflow.com/questions/51409156/count-number-of-records-processed-in-jq",
        "title": "Count number of records processed in jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "shell",
            "jq",
            "memory-efficient"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 34241,
                    "reputation": 59390,
                    "user_id": 96588,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/425fed56a46504d37ec907d99b09ecde?s=256&d=identicon&r=PG",
                    "display_name": "l0b0",
                    "link": "https://stackoverflow.com/users/96588/l0b0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1531961917,
                "post_id": 51412721,
                "comment_id": 89797373,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1532933662,
                "last_edit_date": 1532933662,
                "creation_date": 1531962670,
                "answer_id": 51412951,
                "question_id": 51412721,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The below is hackery, to be sure -- but *memory-efficient* hackery, even with an arbitrarily long list:\r\n\r\n    jq -c --stream &#39;select(length==2)|.[1]&#39; &lt;huge.json \\\r\n    | jq -nc &#39;foreach inputs as $i (null; null; [$i,try input,try input])&#39;\r\n\r\nThe first piece of the pipeline streams in your input JSON file, emitting one line per element, assuming the array consists of atomic values (where [] and {} are here included as atomic values). Because it runs in streaming mode it doesn&#39;t need to store the entire content in memory, despite being a single document.\r\n\r\nThe second piece of the pipeline repeatedly reads up to three items and assembles them into a list.\r\n\r\nThis should avoid needing more than three pieces of data in memory at a time.",
                "title": "How to split an array into chunks with jq?"
            },
            {
                "up_vote_count": 31,
                "is_accepted": false,
                "score": 31,
                "last_activity_date": 1532015065,
                "last_edit_date": 1532015065,
                "creation_date": 1531968552,
                "answer_id": 51413629,
                "question_id": 51412721,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is an (undocumented) builtin, `_nwise`, that meets the functional requirements:\r\n\r\n    $ jq -nc &#39;[1,2,3,4,5,6,7,8,9,10] | _nwise(3)&#39;\r\n    \r\n    [1,2,3]\r\n    [4,5,6]\r\n    [7,8,9]\r\n    [10]\r\n\r\nAlso:\r\n\r\n    $ jq -nc &#39;_nwise([1,2,3,4,5,6,7,8,9,10];3)&#39; \r\n    [1,2,3]\r\n    [4,5,6]\r\n    [7,8,9]\r\n    [10]\r\n\r\nIncidentally, `_nwise` can be used for both arrays and strings.\r\n\r\n(I believe it&#39;s undocumented because there was some doubt about an appropriate name.)\r\n\r\n\r\n## TCO-version\r\n\r\nUnfortunately, the builtin version is carelessly defined, and will not perform well for large arrays.  Here is an optimized version (it should be about as efficient as a non-recursive version):\r\n\r\n    def nwise($n):\r\n     def _nwise:\r\n       if length &lt;= $n then . else .[0:$n] , (.[$n:]|_nwise) end;\r\n     _nwise;\r\n\r\nFor an array of size 3 million, this is quite performant:\r\n3.91s on an old Mac, 162746368 max resident size.\r\n\r\nNotice that this version (using tail-call optimized recursion) is actually faster than the version of `nwise/2` using `foreach` shown elsewhere on this page.\r\n\r\n",
                "title": "How to split an array into chunks with jq?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1532935273,
                "last_edit_date": 1532935273,
                "creation_date": 1531970386,
                "answer_id": 51413843,
                "question_id": 51412721,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the array is too large to fit comfortably in memory, then I&#39;d adopt the strategy suggested by @CharlesDuffy -- that is, stream the array elements into a second invocation of jq using a stream-oriented version of `nwise`, such as:\r\n\r\n    def nwise(stream; $n):\r\n      foreach (stream, nan) as $x ([];\r\n        if length == $n then [$x] else . + [$x] end;\r\n        if (.[-1] | isnan) and length&gt;1 then .[:-1]\r\n        elif length == $n then .\r\n        else empty\r\n        end);\r\n\r\nThe &quot;driver&quot; for the above would be:\r\n\r\n    nwise(inputs; 3)\r\n\r\nBut please remember to use the -n command-line option.\r\n\r\nTo create the stream from an arbitrary array:\r\n\r\n    $ jq -cn --stream &#39;\r\n        fromstream( inputs | (.[0] |= .[1:])\r\n                    | select(. != [[]]) )&#39; huge.json \r\n\r\nSo the shell pipeline might look like this:\r\n  \r\n    $ jq -cn --stream &#39;\r\n        fromstream( inputs | (.[0] |= .[1:])\r\n                    | select(. != [[]]) )&#39; huge.json |\r\n      jq -n -f nwise.jq\r\n\r\n\r\nThis approach is quite performant.  For grouping a stream of 3 million items into groups of 3 using `nwise/2`,\r\n\r\n    /usr/bin/time -lp\r\n\r\nfor the second invocation of jq gives:\r\n\r\n    user         5.63\r\n    sys          0.04\r\n       1261568  maximum resident set size\r\n\r\nCaveat: this definition uses `nan` as an end-of-stream marker.  Since `nan` is not a JSON value, this cannot be a problem for handling JSON streams.\r\n\r\n\r\n",
                "title": "How to split an array into chunks with jq?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1532019019,
                "last_edit_date": 1532019019,
                "creation_date": 1532016489,
                "answer_id": 51427354,
                "question_id": 51412721,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following stream-oriented definition of `window/3`, due to C&#233;dric Connes\r\n(github:connesc), generalizes `_nwise`, \r\nand illustrates a\r\n&quot;boxing technique&quot; that circumvents the need to use an\r\nend-of-stream marker, and can therefore be used\r\nif the stream contains the non-JSON value `nan`.  A definition\r\nof `_nwise/1` in terms of `window/3` is also included.\r\n\r\nThe first argument of `window/3` is interpreted as a stream.  $size is the window size and $step specifies the number of values to be skipped.  For example,\r\n\r\n    window(1,2,3; 2; 1)\r\n\r\nyields:\r\n\r\n    [1,2]\r\n    [2,3]\r\n\r\n### window/3 and _nsize/1\r\n\r\n    def window(values; $size; $step):\r\n      def checkparam(name; value): if (value | isnormal) and value &gt; 0 and (value | floor) == value then . else error(&quot;window \\(name) must be a positive integer&quot;) end;\r\n      checkparam(&quot;size&quot;; $size)\r\n    | checkparam(&quot;step&quot;; $step)\r\n      # We need to detect the end of the loop in order to produce the terminal partial group (if any).\r\n      # For that purpose, we introduce an artificial null sentinel, and wrap the input values into singleton arrays in order to distinguish them.\r\n    | foreach ((values | [.]), null) as $item (\r\n        {index: -1, items: [], ready: false};\r\n        (.index + 1) as $index\r\n        # Extract items that must be reused from the previous iteration\r\n        | if (.ready | not) then .items\r\n          elif $step &gt;= $size or $item == null then []\r\n          else .items[-($size - $step):]\r\n          end\r\n        # Append the current item unless it must be skipped\r\n        | if ($index % $step) &lt; $size then . + $item\r\n          else .\r\n          end\r\n        | {$index, items: ., ready: (length == $size or ($item == null and length &gt; 0))};\r\n        if .ready then .items else empty end\r\n      );\r\n    \r\n    def _nwise($n): window(.[]; $n; $n);\r\n    \r\n### Source:\r\nhttps://gist.github.com/connesc/d6b87cbacae13d4fd58763724049da58\r\n",
                "title": "How to split an array into chunks with jq?"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1665614782,
                "last_edit_date": 1665614782,
                "creation_date": 1665613927,
                "answer_id": 74048614,
                "question_id": 51412721,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "here&#39;s a simple one that worked for me:\r\n```jq\r\ndef chunk(n):\r\n    range(length/n|ceil) as $i | .[n*$i:n*$i+n];\r\n```\r\n\r\nexample usage:\r\n```shell\r\njq -n \\\r\n&#39;def chunk(n): range(length/n|ceil) as $i | .[n*$i:n*$i+n];\r\n[range(5)] | chunk(2)&#39;\r\n[\r\n  0,\r\n  1\r\n]\r\n[\r\n  2,\r\n  3\r\n]\r\n[\r\n  4\r\n]\r\n```\r\n\r\n\r\nbonus: it doesn&#39;t use recursion and doesn&#39;t rely on `_nwise`, so it also works with [`jaq`](https://github.com/01mf02/jaq).",
                "title": "How to split an array into chunks with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 25,
        "last_activity_date": 1665614782,
        "creation_date": 1531960416,
        "last_edit_date": 1531975492,
        "question_id": 51412721,
        "body_markdown": "I have a very large JSON file containing an array. Is it possible to use `jq` to split this array into several smaller arrays of a fixed size? Suppose my input was this: `[1,2,3,4,5,6,7,8,9,10]`, and I wanted to split it into 3 element long chunks. The desired output from `jq` would be:\r\n\r\n    [1,2,3]\r\n    [4,5,6]\r\n    [7,8,9]\r\n    [10]\r\n\r\nIn reality, my input array has nearly three million elements, all UUIDs.",
        "link": "https://stackoverflow.com/questions/51412721/how-to-split-an-array-into-chunks-with-jq",
        "title": "How to split an array into chunks with jq?"
    },
    {
        "tags": [
            "openstack",
            "jq",
            "terraform"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2649209,
                    "reputation": 57233,
                    "user_id": 2291321,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/fea90c708303be83a7490750e6dbe137?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ydaetskcoR",
                    "link": "https://stackoverflow.com/users/2291321/ydaetskcor"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531990504,
                "post_id": 51417144,
                "comment_id": 89807577,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4522835,
                    "reputation": 694,
                    "user_id": 4210388,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/yAapG.jpg?s=256",
                    "display_name": "Markus",
                    "link": "https://stackoverflow.com/users/4210388/markus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531992427,
                "post_id": 51417144,
                "comment_id": 89808831,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3838064,
                    "reputation": 43,
                    "user_id": 3181946,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/dvaVq.jpg?s=256",
                    "display_name": "epcim",
                    "link": "https://stackoverflow.com/users/3181946/epcim"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531993933,
                "post_id": 51417144,
                "comment_id": 89809910,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3838064,
                    "reputation": 43,
                    "user_id": 3181946,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/dvaVq.jpg?s=256",
                    "display_name": "epcim",
                    "link": "https://stackoverflow.com/users/3181946/epcim"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1531994077,
                "post_id": 51417144,
                "comment_id": 89810021,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1532029042,
                "creation_date": 1532029042,
                "answer_id": 51430576,
                "question_id": 51417144,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s assume the two related objects are in a file named two.json.  Then one way to merge the information from both objects is using the `-s` command-line option, e.g.\r\n\r\n    jq -s &#39;\r\n      (.[0].primary.attributes | {address, fixed_ip})\r\n      + {name: .[1].primary.attributes.name}&#39; two.json\r\n\r\n### Output\r\n\r\nWith your example input, the output would be:\r\n\r\n    {\r\n      &quot;address&quot;: &quot;209.66.89.143&quot;,\r\n      &quot;fixed_ip&quot;: &quot;10.10.10.5&quot;,\r\n      &quot;name&quot;: &quot;ctl01&quot;\r\n    }\r\n    \r\n       \r\n\r\n \r\n\r\n\r\n",
                "title": "JQ Cross reference or how to replace one value with another part of the input"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1532363489,
        "creation_date": 1531986602,
        "last_edit_date": 1532363489,
        "question_id": 51417144,
        "body_markdown": "I want to parse terraform.tfstate (where openstack provider is used), to return instance name and it&#39;s internal + floating IP (if assigned).\r\n\r\nFirst select what we are interested in:\r\n\r\n    jq -r &#39;.modules?[]|.resources[]?|select(.type == &quot;openstack_compute_floatingip_v2&quot;, .type == &quot;openstack_compute_instance_v2&quot;)&#39; &lt; terraform.tfstate\r\n\r\n    \r\nFor simplicity, pre-parsed example with the above part (one FIP and one instance):\r\n\r\n    {\r\n      &quot;type&quot;: &quot;openstack_compute_floatingip_v2&quot;,\r\n      &quot;depends_on&quot;: [\r\n        &quot;openstack_networking_router_interface_v2.management&quot;\r\n      ],\r\n      &quot;primary&quot;: {\r\n        &quot;id&quot;: &quot;48b039fc-a9fa-4672-934a-32d6d267f280&quot;,\r\n        &quot;attributes&quot;: {\r\n          &quot;address&quot;: &quot;209.66.89.143&quot;,\r\n          &quot;fixed_ip&quot;: &quot;10.10.10.5&quot;,\r\n          &quot;id&quot;: &quot;48b039fc-a9fa-4672-934a-32d6d267f280&quot;,\r\n          &quot;instance_id&quot;: &quot;597e75e8-834d-4f05-8408-e2e6e733577e&quot;,\r\n          &quot;pool&quot;: &quot;public&quot;,\r\n          &quot;region&quot;: &quot;RegionOne&quot;\r\n        },\r\n        &quot;meta&quot;: {},\r\n        &quot;tainted&quot;: false\r\n      },\r\n      &quot;deposed&quot;: [],\r\n      &quot;provider&quot;: &quot;provider.openstack&quot;\r\n    }\r\n    {\r\n      &quot;type&quot;: &quot;openstack_compute_instance_v2&quot;,\r\n      &quot;depends_on&quot;: [\r\n        &quot;openstack_compute_floatingip_v2.management&quot;,\r\n        &quot;openstack_compute_secgroup_v2.ssh_only&quot;,\r\n        &quot;openstack_networking_network_v2.management&quot;\r\n      ],\r\n      &quot;primary&quot;: {\r\n        &quot;id&quot;: &quot;597e75e8-834d-4f05-8408-e2e6e733577e&quot;,\r\n        &quot;attributes&quot;: {\r\n          &quot;access_ip_v4&quot;: &quot;10.10.10.5&quot;,\r\n          &quot;access_ip_v6&quot;: &quot;&quot;,\r\n          &quot;all_metadata.%&quot;: &quot;1&quot;,\r\n          &quot;all_metadata.habitat&quot;: &quot;sup&quot;,\r\n          &quot;availability_zone&quot;: &quot;nova&quot;,\r\n          &quot;flavor_id&quot;: &quot;eb36e84e-17c1-42ab-b359-4380f6f524ae&quot;,\r\n          &quot;flavor_name&quot;: &quot;m1.large&quot;,\r\n          &quot;force_delete&quot;: &quot;false&quot;,\r\n          &quot;id&quot;: &quot;597e75e8-834d-4f05-8408-e2e6e733577e&quot;,\r\n          &quot;image_id&quot;: &quot;c574aeed-e47c-4fb7-9da0-75550b76ee56&quot;,\r\n          &quot;image_name&quot;: &quot;ubuntu-16.04&quot;,\r\n          &quot;key_pair&quot;: &quot;vault-etcd_test_tf&quot;,\r\n          &quot;metadata.%&quot;: &quot;1&quot;,\r\n          &quot;metadata.habitat&quot;: &quot;sup&quot;,\r\n          &quot;name&quot;: &quot;ctl01&quot;,\r\n          &quot;network.#&quot;: &quot;1&quot;,\r\n          &quot;network.0.access_network&quot;: &quot;false&quot;,\r\n          &quot;network.0.fixed_ip_v4&quot;: &quot;10.10.10.5&quot;,\r\n          &quot;network.0.fixed_ip_v6&quot;: &quot;&quot;,\r\n          &quot;network.0.floating_ip&quot;: &quot;&quot;,\r\n          &quot;network.0.mac&quot;: &quot;02:c6:61:f9:ee:7e&quot;,\r\n          &quot;network.0.name&quot;: &quot;management&quot;,\r\n          &quot;network.0.port&quot;: &quot;&quot;,\r\n          &quot;network.0.uuid&quot;: &quot;f2468669-e321-4eb4-9ede-003e362a8988&quot;,\r\n          &quot;region&quot;: &quot;RegionOne&quot;,\r\n          &quot;security_groups.#&quot;: &quot;1&quot;,\r\n          &quot;security_groups.1845949017&quot;: &quot;vault-etcd_test_ssh_only&quot;,\r\n          &quot;stop_before_destroy&quot;: &quot;false&quot;\r\n        },\r\n        &quot;meta&quot;: {\r\n          &quot;e2bfb730-ecaa-11e6-8f88-34363bc7c4c0&quot;: {\r\n            &quot;create&quot;: 1800000000000,\r\n            &quot;delete&quot;: 1800000000000,\r\n            &quot;update&quot;: 1800000000000\r\n          }\r\n        },\r\n        &quot;tainted&quot;: false\r\n      },\r\n      &quot;deposed&quot;: [],\r\n      &quot;provider&quot;: &quot;provider.openstack&quot;\r\n    }\r\n    \r\n\r\nRequired is to take from `&quot;type&quot;: &quot;openstack_compute_floatingip_v2&quot;` replace `.primary.attributes.address` and `.fixed_ip` and from corresponding `.instance_id` the `.name`. \r\n\r\nSo, sth like:\r\n\r\n    \r\n    {&quot;address&quot;: &quot;209.66.89.143&quot;,\r\n    &quot;fixed_ip&quot;: &quot;10.10.10.5&quot;,\r\n    &quot;name&quot;: &quot;ctl01&quot;}\r\n    \r\n\r\n\r\n\r\nWell, I came with an idea while using walk, but miss how to actually assign the proper value from corresponding instance id:\r\n\r\n    jq -r &quot;$(cat floating.jq)&quot; terraform.tfstate\r\n\r\nfloating.jq:\r\n\r\n    def walk(f):\r\n          . as $in\r\n          | if type == &quot;object&quot; then\r\n              reduce keys[] as $key\r\n                ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n          elif type == &quot;array&quot; then map( walk(f) ) | f\r\n          else f\r\n          end;\r\n    .modules?[]|.resources[]?|select(.type == \r\n        &quot;openstack_compute_floatingip_v2&quot;, .type == \r\n        &quot;openstack_compute_instance_v2&quot;)|\r\n        .primary|walk( if  type == &quot;object&quot; and .attributes.address then \r\n        .attributes.instance_id |= &quot;REFERRED VALUE HERE&quot;) else . end)\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51417144/jq-cross-reference-or-how-to-replace-one-value-with-another-part-of-the-input",
        "title": "JQ Cross reference or how to replace one value with another part of the input"
    },
    {
        "tags": [
            "json",
            "bash",
            "awk",
            "environment-variables",
            "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": 1532024713,
                "post_id": 51422711,
                "comment_id": 89830087,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1532143092,
                "last_edit_date": 1532143092,
                "creation_date": 1532003568,
                "answer_id": 51422809,
                "question_id": 51422711,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you just want to pass the key as an `--arg`:\r\n\r\n    jq --arg key &quot;solr.baseuri&quot; &#39;.[$key]&#39; file.json\r\nTesting it out, using the minimal JSON that could be made from the line in your example:\r\n\r\n    $ cat file.json \r\n    { &quot;solr.baseuri&quot;:&quot;http://10.201.17.8:80&quot; }\r\n    $ jq --arg key &quot;solr.baseuri&quot; &#39;.[$key]&#39; file.json \r\n    &quot;http://10.201.17.8:80&quot;\r\n\r\nRather than piping to `grep`, you might want to consider using `jq` built-in functionality to parse the part of the string that you&#39;re interested in.\r\n\r\nTo extract the host to a variable, you could use `capture`:\r\n\r\n    $ value=$(jq --arg key solr.baseuri -r &#39;.[$key] | capture(&quot;.*://(?&lt;host&gt;[^:]+)&quot;) | .host&#39; file.json)\r\n    $ echo &quot;$value&quot;\r\n    10.201.17.8\r\nThis assumes that the property always is of the form `scheme://host`, optionally followed by `:port`.",
                "title": "how to parse bash variable for jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1532012802,
                "last_edit_date": 1532012802,
                "creation_date": 1532003771,
                "answer_id": 51422868,
                "question_id": 51422711,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your script has multiple problems. The quick and dirty answer is &quot;use double quotes&quot; but in addition, you need to fix your hideous syntax errors.\r\n\r\n    #!/bin/bash\r\n    # single quotes &#39;...&#39; not backticks `...`\r\n    key=&#39;solr.baseuri&#39;\r\n    # avoid useless cat\r\n    # prefer modern $(...) syntax over paleolithic `...`\r\n    # use double quotes around variable\r\n    value=$(jq &quot;.\\&quot;$key\\&quot;&quot; test.json | grep -oE &quot;\\b([0-9]{1,3}\\.){3}[0-9]{1,3}\\b&quot;)\r\n    \r\n    echo &quot;solr value is $value&quot;\r\n\r\nIt should not be hard to avoid the `grep` (and perhaps even also the `echo`) and use `jq` to extract just the IP address from the URL, either. (`\\b` is not valid in most `grep` versions anyway.)",
                "title": "how to parse bash variable for jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1532024335,
                "last_edit_date": 1532024335,
                "creation_date": 1532004977,
                "answer_id": 51423267,
                "question_id": 51422711,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do everything in jq alone.  You can probably do it better than the following, even:\r\n\r\n    #!/usr/bin/env bash\r\n\r\n    key=&quot;solr.baseuri&quot;\r\n    jq --arg key &quot;$key&quot; &#39;\r\n      .[$key] | split(&quot;/&quot;) | .[2] | split(&quot;:&quot;) | .[0]&#39; test.json\r\n\r\nThis uses the shell variable `$key` as an argument to jq. Jq then splits the resultant URL, first on forward slash, then on colon. The result should be the hostname (or in the case of your sample data, the IP address).\r\n\r\nNote that in your initial script, you had a quoting problem -- your variable assignment used backquotes, which are an obsolete mechanism to handle command substitution. Double or single quotes are used for strings. You probably already know that by now. ;-)",
                "title": "how to parse bash variable for jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1532143092,
        "creation_date": 1532003281,
        "question_id": 51422711,
        "body_markdown": "I have a test.json file which contains below property.\r\n\r\n    &quot;solr.baseuri&quot;:&quot;http://10.201.17.8:80&quot;\r\n\r\nWe are getting expected output for the below script if we parse the exact variable(solr.baseuri) name using jq command.\r\n\r\nShell script :\r\n\r\n    #!/bin/bash\r\n            \r\n    key=`solr.baseuri`\r\n    \r\n    value=`cat test.json |jq &#39;.&quot;solr.baseuri&quot;&#39; | grep -oE &quot;\\b([0-9]{1,3}\\.){3}[0-9]{1,3}\\b&quot;`\r\n    \r\n    echo &quot;solr value is $value&quot;\r\n\r\nOutput :\r\n\r\n    solr value is 10.201.17.8\r\n\r\n\r\n\r\nnot sure how to use the $key with jq command inside the script to display the value. trying with below command which is not working\r\n\r\n    value=`cat test.json |jq &#39;.&quot;${key}&quot;&#39; | grep -oE &quot;\\b([0-9]{1,3}\\.){3}[0-9]{1,3}\\b&quot;`\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51422711/how-to-parse-bash-variable-for-jq",
        "title": "how to parse bash variable for jq"
    },
    {
        "tags": [
            "json",
            "performance",
            "jq",
            "wal",
            "json-query"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1532023761,
                "creation_date": 1532023761,
                "answer_id": 51429307,
                "question_id": 51427332,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following helper function converts the incoming array into an object using `headers` as the keys:\r\n\r\n    def objectify(headers):\r\n      [headers, .] | transpose | map({(.[0]): .[1]}) | add;\r\n\r\nThe trick now is to use `range(0;length)` to generate `.sn`:\r\n\r\n      {xid} +\r\n      (.change\r\n       | range(0;length) as $i\r\n       | .[$i]\r\n       | .columnnames as $header\r\n       | {sn: ($i + 1),\r\n          kind,\r\n          data: (.columnvalues|objectify($header)) } )\r\n\r\n## Output\r\nFor the given log entry, the output would be:\r\n\r\n    {&quot;xid&quot;:1190,&quot;sn&quot;:1,&quot;kind&quot;:&quot;update&quot;,&quot;data&quot;:{&quot;id&quot;:401,&quot;name&quot;:&quot;Update AA&quot;,&quot;age&quot;:20}}\r\n    {&quot;xid&quot;:1190,&quot;sn&quot;:2,&quot;kind&quot;:&quot;update&quot;,&quot;data&quot;:{&quot;id&quot;:401,&quot;name&quot;:&quot;Update BB&quot;,&quot;age&quot;:20}}\r\n\r\n## Moral\r\nIf a solution looks too complicated, it probably is.\r\n\r\n",
                "title": "Optimize JSON denormalization using JQ - &quot;cartesian product&quot; from 1:N"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1532023761,
        "creation_date": 1532016415,
        "question_id": 51427332,
        "body_markdown": "I have a JSON database change log, output of `wal2json`. It looks like this:\r\n\r\n    {&quot;xid&quot;:1190,&quot;timestamp&quot;:&quot;2018-07-19 17:18:02.905354+02&quot;,&quot;change&quot;:[\r\n        {&quot;kind&quot;:&quot;update&quot;,&quot;table&quot;:&quot;mytable2&quot;,&quot;columnnames&quot;:[&quot;id&quot;,&quot;name&quot;,&quot;age&quot;],&quot;columnvalues&quot;:[401,&quot;Update AA&quot;,20],&quot;oldkeys&quot;:{&quot;keynames&quot;:[&quot;id&quot;],&quot;keyvalues&quot;:[401]}},\r\n        {&quot;kind&quot;:&quot;update&quot;,&quot;table&quot;:&quot;mytable2&quot;,&quot;columnnames&quot;:[&quot;id&quot;,&quot;name&quot;,&quot;age&quot;],&quot;columnvalues&quot;:[401,&quot;Update BB&quot;,20],&quot;oldkeys&quot;:{&quot;keynames&quot;:[&quot;id&quot;],&quot;keyvalues&quot;:[401]}}]}\r\n     ...\r\n\r\nEach top level entry (`xid`) is a transaction, each item in `change` is, well, a change. One row may change multiple times.\r\n\r\nTo import to an OLAP system with limited feature set,  I need to have the order explicitly stated. So I need to add a `sn` for each change in a transaction.  \r\nAlso, each change must be a top level entry - the OLAP can&#39;t iterate sub-items within one entry.\r\n\r\n    {&quot;xid&quot;:1190, &quot;sn&quot;:1, &quot;kind&quot;:&quot;update&quot;, &quot;data&quot;:{&quot;id&quot;:401,&quot;name&quot;:&quot;Update AA&quot;,&quot;age&quot;:20} }\r\n    {&quot;xid&quot;:1190, &quot;sn&quot;:2, &quot;kind&quot;:&quot;update&quot;, &quot;data&quot;:{&quot;id&quot;:401,&quot;name&quot;:&quot;Update BB&quot;,&quot;age&quot;:20} }\r\n    {&quot;xid&quot;:1191, &quot;sn&quot;:1, &quot;kind&quot;:&quot;insert&quot;, &quot;data&quot;:{&quot;id&quot;:625,&quot;name&quot;:&quot;Inserted&quot;,&quot;age&quot;:20} }\r\n    {&quot;xid&quot;:1191, &quot;sn&quot;:2, &quot;kind&quot;:&quot;delete&quot;, &quot;data&quot;:{&quot;id&quot;:625} }\r\n\r\n(The reason is that the OLAP has limited ability to transform the data during import, and also doesn&#39;t have the order as a parameter.)\r\n\r\nSo, I do this using `jq`:\r\n\r\n    function transformJsonDataStructure {\r\n        ## First let&#39;s reformat it to XML, then transform using XPATH, then back to JSON.\r\n    \r\n        ## Example input:\r\n        # {&quot;xid&quot;:1074,&quot;timestamp&quot;:&quot;2018-07-18 17:49:54.719475+02&quot;,&quot;change&quot;:[\r\n        #   {&quot;kind&quot;:&quot;update&quot;,&quot;table&quot;:&quot;mytable2&quot;,&quot;columnnames&quot;:[&quot;id&quot;,&quot;name&quot;,&quot;age&quot;],&quot;columnvalues&quot;:[401,&quot;Update AA&quot;,20],&quot;oldkeys&quot;:{&quot;keynames&quot;:[&quot;id&quot;],&quot;keyvalues&quot;:[401]}},\r\n        #   {&quot;kind&quot;:&quot;update&quot;,&quot;table&quot;:&quot;mytable2&quot;,&quot;columnnames&quot;:[&quot;id&quot;,&quot;name&quot;,&quot;age&quot;],&quot;columnvalues&quot;:[401,&quot;Update BB&quot;,20],&quot;oldkeys&quot;:{&quot;keynames&quot;:[&quot;id&quot;],&quot;keyvalues&quot;:[401]}}]}\r\n        cat &quot;$1&quot; | while read -r LINE ; do\r\n            XID=`echo &quot;$LINE&quot; | jq -c &#39;.xid&#39;`;\r\n            export SN=0;\r\n            #serr &quot;{xid: $XID, changes: $CHANGES}&quot;;\r\n            echo &quot;$LINE&quot; | jq -c &#39;.change[]&#39; | while read -r CHANGE ; do\r\n                SN=$((SN+=1))\r\n                KIND=`echo &quot;$CHANGE&quot; | jq -c --raw-output .kind`;\r\n                TABLE=`echo &quot;$CHANGE&quot; | jq -c --raw-output .table`;\r\n                DEST_FILE=&quot;$TARGET_PATH-$TABLE.json&quot;;\r\n                case &quot;$KIND&quot; in\r\n                    update|insert)\r\n                        MAP=$(convertTwoArraysToMap &quot;$(echo &quot;$CHANGE&quot; | jq -c &quot;.columnnames&quot;)&quot; &quot;$(echo &quot;$CHANGE&quot; | jq -c &quot;.columnvalues&quot;)&quot;) ;;\r\n                    delete)\r\n                        MAP=$(convertTwoArraysToMap &quot;$(echo &quot;$CHANGE&quot; | jq -c &quot;.oldkeys.keynames&quot;)&quot; &quot;$(echo &quot;$CHANGE&quot; | jq -c &quot;.oldkeys.keyvalues&quot;)&quot;) ;;\r\n                esac\r\n                #echo &quot;{\\&quot;xid\\&quot;:$XID, \\&quot;table\\&quot;:\\&quot;$TABLE\\&quot;, \\&quot;kind\\&quot;:\\&quot;$KIND\\&quot;, \\&quot;data\\&quot;:$MAP }&quot; &gt;&gt; &quot;$DEST_FILE&quot;; ;;\r\n                echo &quot;{\\&quot;xid\\&quot;:$XID, \\&quot;sn\\&quot;:$SN, \\&quot;kind\\&quot;:\\&quot;$KIND\\&quot;, \\&quot;data\\&quot;:$MAP }&quot; | tee --append &quot;$DEST_FILE&quot;;\r\n            done;\r\n        done;\r\n    \r\n        return;\r\n    }\r\n\r\nThe problem is the performance. I am calling `jq` few times per entry. This is quite slow, around 1000x times slower than without the transformation.\r\n\r\n**How can perform the transformation above using just one pass?** (`jq` is not a must, other tool can be used too, but should be in CentOS packages. I want to avoid coding an extra tool for that. \r\n\r\nFrom `man jq` it seems that it could be capable of processing the whole file (JSON entry per row) in one go. I could do it in XSLT but I can&#39;t wrap my head around `jq`. Especially the iteration of the `change` array and combining `columnnames` and `columnvalues` to a map.  \r\n\r\n * For the iteration, I think `map` or `map_values` could be used.\r\n * For the 2 arrays to map, I see the `from_entries` and `with_entries` functions, but can&#39;t get it work.\r\n\r\nAny `jq` master around to advise?",
        "link": "https://stackoverflow.com/questions/51427332/optimize-json-denormalization-using-jq-cartesian-product-from-1n",
        "title": "Optimize JSON denormalization using JQ - &quot;cartesian product&quot; from 1:N"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1532020942,
                "last_edit_date": 1532020942,
                "creation_date": 1532020369,
                "answer_id": 51428441,
                "question_id": 51427909,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You want save each object in the top-level list for later use while you are processing each `B` element.\r\n\r\n    $ jq -c &#39;.[] as $top | .[].B[] | [$top.A, (.B_array[] | join(&quot;, &quot;)), .C, .E, $top.F]&#39; tmp.json\r\n    [&quot;A1&quot;,&quot;B1, B2&quot;,10,&quot;E1&quot;,&quot;F1&quot;]\r\n    [&quot;A1&quot;,&quot;B3, B4&quot;,20,&quot;E2&quot;,&quot;F1&quot;]\r\n\r\nA variable assignment can be seen as a filter that passes its input through unchanged, but provides a name for the given expression. That is, `$top` is `.[]`, except the `.` refers to the input of the assignment filter, not the current input.",
                "title": "How to concatenate different type of multiple fields in JSON using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1532020942,
        "creation_date": 1532018343,
        "last_edit_date": 1532019164,
        "question_id": 51427909,
        "body_markdown": "I have a JSON file with the following format:\r\n\r\n    [\r\n      {\r\n        &quot;A&quot;: &quot;A1&quot;,\r\n        &quot;B&quot;: [\r\n          {\r\n            &quot;B_array&quot;: [\r\n              {\r\n                &quot;B_field1&quot;: &quot;B1&quot;,\r\n                &quot;B_field2&quot;: &quot;B2&quot;\r\n              }\r\n            ],\r\n            &quot;C&quot;: 10,\r\n            &quot;E&quot;: &quot;E1&quot;\r\n          },\r\n          {\r\n            &quot;B_array&quot;: [\r\n              {\r\n                &quot;B_field1&quot;: &quot;B3&quot;,\r\n                &quot;B_field2&quot;: &quot;B4&quot;\r\n              }\r\n            ],\r\n            &quot;C&quot;: 20,\r\n            &quot;E&quot;: &quot;E2&quot;\r\n          }\r\n        ],\r\n        &quot;F&quot;: &quot;F1&quot;\r\n      }\r\n     ]\r\n\r\nFrom here, what I want to achieve is that combining/concatenating fields so I can get the output like below:\r\n\r\n    [&quot;A1&quot; &quot;B1, B2&quot; 10 &quot;E1&quot; &quot;F1&quot;]\r\n    [&quot;A1&quot; &quot;B3, B4&quot; 20 &quot;E2&quot; &quot;F1&quot;]\r\n\r\n\r\nwhat I have done so far is:\r\n\r\n    map(.A + (.B[].C|tostring)+.B[].E+(.B[].B_array[] | join(&quot; | &quot;)+.F))\r\n\r\nBut what I am getting is that every possible combination such as:\r\n\r\n    [&quot;A1&quot; &quot;B1, B2&quot; 10 &quot;E1&quot; &quot;F1&quot;]\r\n    [&quot;A1&quot; &quot;B1, B2&quot; 10 &quot;E2&quot; &quot;F1&quot;]\r\n    [&quot;A1&quot; &quot;B3, B4&quot; 20 &quot;E2&quot; &quot;F1&quot;]\r\n    [&quot;A1&quot; &quot;B3, B4&quot; 20 &quot;E1&quot; &quot;F1&quot;]\r\n\r\nHow do I use the right jq query to get the result I expected above?\r\n\r\nThanks.\r\n",
        "link": "https://stackoverflow.com/questions/51427909/how-to-concatenate-different-type-of-multiple-fields-in-json-using-jq",
        "title": "How to concatenate different type of multiple fields in JSON using JQ?"
    },
    {
        "tags": [
            "python",
            "stream",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1532230787,
                "last_edit_date": 1532230787,
                "creation_date": 1532058604,
                "answer_id": 51434799,
                "question_id": 51432696,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I&#39;m trying to extract &quot;W&quot;&#39;s list.\r\n\r\nOK, so let&#39;s first deal with jq, and then with the python interface.\r\n\r\n## jq\r\n\r\n`.[]` yields all the items in the top-level array, and therefore\r\n`.[] | .W` will yield two items:\r\n\r\n* `null` (because the first item does not have .W), and\r\n* the desired list\r\n\r\nTo extract just &quot;W&quot;&#39;s list, you could use any of the following filters,\r\ndepending on your precise requirements:\r\n\r\n    .[] | select(has(&quot;W&quot;)) | .W\r\n\r\n    .[] | .W | select(.)\r\n\r\n    .[] | .W // empty\r\n\r\n    .[1].W\r\n\r\n\r\n# from jq import jq\r\n\r\nAs the documentation at https://pypi.org/project/pyjq/ says:\r\n\r\n &gt; If multiple_output is False (the default), then the first output is used\r\n\r\nFor example:\r\n\r\n    print jq(&#39;1,2&#39;).transform(data)\r\n\r\nyields just `1`.  \r\n\r\n## In summary\r\nDepending on the precise requirements, you can use any of the filters given above, for example:\r\n\r\n    jq(&#39;.[] | .W // empty&#39;).transform(data)\r\n\r\n## Moral\r\nIf there&#39;s a moral to this tale, it might be that, when in doubt, one should consider using jq (the command-line executable) or jqplay to make sure your jq filter is doing what you want.\r\n",
                "title": "Correctly parsing data with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1532230787,
        "creation_date": 1532040390,
        "last_edit_date": 1532058982,
        "question_id": 51432696,
        "body_markdown": "I have the following data:\r\n\r\n    [\r\n        {\r\n            &quot;M&quot;: [\r\n                {\r\n                    &quot;id&quot;: 1,\r\n                    &quot;nk&quot;: &quot;MATH$$SPRING$$INST1$$2&quot;,\r\n                    &quot;section&quot;: {\r\n                        &quot;nk&quot;: &quot;MATH$$SPRING$$INST1&quot;,\r\n                        &quot;course&quot;: 1,\r\n                        &quot;id&quot;: 1\r\n                    },\r\n                    &quot;location&quot;: {\r\n                        &quot;id&quot;: 1,\r\n                        &quot;nk&quot;: &quot;mcu$$101&quot;,\r\n                        &quot;campus&quot;: {\r\n                            &quot;id&quot;: 1,\r\n                            &quot;nk&quot;: &quot;mcu&quot;,\r\n                            &quot;name&quot;: &quot;Main Campus&quot;\r\n                        },\r\n                        &quot;address&quot;: &quot;1 st&quot;,\r\n                        &quot;building&quot;: &quot;1&quot;,\r\n                        &quot;room&quot;: &quot;101&quot;\r\n                    },\r\n                    &quot;day_of_week&quot;: 2,\r\n                    &quot;start_time&quot;: &quot;09:00:00&quot;,\r\n                    &quot;end_time&quot;: &quot;10:00:00&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: 3,\r\n                    &quot;nk&quot;: &quot;ENG$$SPRING$$INST2$$2&quot;,\r\n                    &quot;section&quot;: {\r\n                        &quot;nk&quot;: &quot;ENG$$SPRING$$INST2&quot;,\r\n                        &quot;course&quot;: 2,\r\n                        &quot;id&quot;: 4\r\n                    },\r\n                    &quot;location&quot;: {\r\n                        &quot;id&quot;: 2,\r\n                        &quot;nk&quot;: &quot;mcu$$201&quot;,\r\n                        &quot;campus&quot;: {\r\n                            &quot;id&quot;: 1,\r\n                            &quot;nk&quot;: &quot;mcu&quot;,\r\n                            &quot;name&quot;: &quot;Main Campus&quot;\r\n                        },\r\n                        &quot;address&quot;: &quot;1 st&quot;,\r\n                        &quot;building&quot;: &quot;1&quot;,\r\n                        &quot;room&quot;: &quot;201&quot;\r\n                    },\r\n                    &quot;day_of_week&quot;: 2,\r\n                    &quot;start_time&quot;: &quot;09:00:00&quot;,\r\n                    &quot;end_time&quot;: &quot;10:00:00&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: 4,\r\n                    &quot;nk&quot;: &quot;ENG$$SPRING$$INST2$$22&quot;,\r\n                    &quot;section&quot;: {\r\n                        &quot;nk&quot;: &quot;ENG$$SPRING$$INST2&quot;,\r\n                        &quot;course&quot;: 2,\r\n                        &quot;id&quot;: 4\r\n                    },\r\n                    &quot;location&quot;: {\r\n                        &quot;id&quot;: 2,\r\n                        &quot;nk&quot;: &quot;mcu$$201&quot;,\r\n                        &quot;campus&quot;: {\r\n                            &quot;id&quot;: 1,\r\n                            &quot;nk&quot;: &quot;mcu&quot;,\r\n                            &quot;name&quot;: &quot;Main Campus&quot;\r\n                        },\r\n                        &quot;address&quot;: &quot;1 st&quot;,\r\n                        &quot;building&quot;: &quot;1&quot;,\r\n                        &quot;room&quot;: &quot;201&quot;\r\n                    },\r\n                    &quot;day_of_week&quot;: 2,\r\n                    &quot;start_time&quot;: &quot;10:00:00&quot;,\r\n                    &quot;end_time&quot;: &quot;11:00:00&quot;\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;W&quot;: [\r\n                {\r\n                    &quot;id&quot;: 2,\r\n                    &quot;nk&quot;: &quot;MATH$$SPRING$$INST1$$4&quot;,\r\n                    &quot;section&quot;: {\r\n                        &quot;nk&quot;: &quot;MATH$$SPRING$$INST2&quot;,\r\n                        &quot;course&quot;: 1,\r\n                        &quot;id&quot;: 2\r\n                    },\r\n                    &quot;location&quot;: {\r\n                        &quot;id&quot;: 2,\r\n                        &quot;nk&quot;: &quot;mcu$$201&quot;,\r\n                        &quot;campus&quot;: {\r\n                            &quot;id&quot;: 1,\r\n                            &quot;nk&quot;: &quot;mcu&quot;,\r\n                            &quot;name&quot;: &quot;Main Campus&quot;\r\n                        },\r\n                        &quot;address&quot;: &quot;1 st&quot;,\r\n                        &quot;building&quot;: &quot;1&quot;,\r\n                        &quot;room&quot;: &quot;201&quot;\r\n                    },\r\n                    &quot;day_of_week&quot;: 4,\r\n                    &quot;start_time&quot;: &quot;08:00:00&quot;,\r\n                    &quot;end_time&quot;: &quot;10:00:00&quot;\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n\r\nI&#39;m trying to extract &quot;W&quot;&#39;s list.\r\n\r\nWhen i do: `jq(&#39;[.[].W][]&#39;).transform(data)` i get None, But when i do `jq(&#39;[.[].M][]&#39;).transform(data)` I get the desired result. Why im i experiencing this?\r\n",
        "link": "https://stackoverflow.com/questions/51432696/correctly-parsing-data-with-jq",
        "title": "Correctly parsing data with jq"
    },
    {
        "tags": [
            "json",
            "edit",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 32232,
                    "reputation": 12402,
                    "user_id": 89211,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/d8b4889359df45a8c8099ef16bd96be9?s=256&d=identicon&r=PG",
                    "display_name": "Relequestual",
                    "link": "https://stackoverflow.com/users/89211/relequestual"
                },
                "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": 1532086051,
                "post_id": 51440863,
                "comment_id": 89852829,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1532087030,
                "creation_date": 1532087030,
                "answer_id": 51441782,
                "question_id": 51440863,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This works for me:\r\n\r\n    map(del(.note, .age)) |\r\n    map( \r\n    \tif .phenotypes then \r\n          \t(.phenotypes |= map(del(.person_id)))\r\n    \telse\r\n    \t\t.\r\n    \tend \r\n    )\r\n\r\n[Working example](https://jqterm.com/#!/e68b43102a31ce9180a4ea1f006f6675?query=map%28del%28.note%2C%20.age%29%29%20%7C%0Amap%28%20%0A%09if%20.phenotypes%20then%20%0A%20%20%20%20%20%20%09%28.phenotypes%20%7C%3D%20map%28del%28.person_id%29%29%29%0A%09else%0A%09%09.%0A%09end%20%0A%29)",
                "title": "How do I modify a child object if it exists in array of objects using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1532184044,
        "creation_date": 1532083708,
        "last_edit_date": 1532184044,
        "question_id": 51440863,
        "body_markdown": "I&#39;m trying to use jq to modify json data at various levels of an API request or response to enable support for API versioning.\r\n\r\nHere&#39;s my (simplified) test JSON:\r\n\r\n    [\r\n      {\r\n        &quot;note&quot;: null,\r\n        &quot;patient_id&quot;: 1,\r\n        &quot;phenotypes&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;Breast carcinoma&quot;,\r\n            &quot;observation&quot;: &quot;present&quot;,\r\n            &quot;patient_id&quot;: 1,\r\n            &quot;person_id&quot;: 1\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;Breast carcinoma&quot;,\r\n            &quot;observation&quot;: &quot;present&quot;,\r\n            &quot;patient_id&quot;: 1,\r\n            &quot;person_id&quot;: 1\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;note&quot;: null,\r\n        &quot;patient_id&quot;: 2\r\n      },\r\n      {\r\n        &quot;note&quot;: null,\r\n        &quot;patient_id&quot;: 3,\r\n        &quot;phenotypes&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;Breast carcinoma&quot;,\r\n            &quot;observation&quot;: &quot;present&quot;,\r\n            &quot;patient_id&quot;: 3,\r\n            &quot;person_id&quot;: 3\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;Breast carcinoma&quot;,\r\n            &quot;observation&quot;: &quot;present&quot;,\r\n            &quot;patient_id&quot;: 3,\r\n            &quot;person_id&quot;: 3\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nI have an array of objects. Each object MAY have `&quot;phenotypes&quot;`, which I need to modify the content of, as well as removing `&quot;note&quot;` from the top level object.\r\n\r\nCurrently my jq is as follows:\r\n\r\n    [ map(del(.note, .age)) | .[] | select(.phenotypes != null) | .phenotypes |= map(del(.person_id)) ]\r\n\r\n\r\nThis almost works, but because of `select(.phenotypes != null)`, the second object in the array never makes it back after filtering.\r\n\r\nI have also tried using if-then-else (end), however I couldn&#39;t make it not error, and I can&#39;t find any examples or documentation that suggests it can be used for further expression.\r\n\r\nMy expected output is the following:\r\n\r\n    [\r\n      {\r\n        &quot;patient_id&quot;: 1,\r\n        &quot;phenotypes&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;Breast carcinoma&quot;,\r\n            &quot;observation&quot;: &quot;present&quot;,\r\n            &quot;patient_id&quot;: 1\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;Breast carcinoma&quot;,\r\n            &quot;observation&quot;: &quot;present&quot;,\r\n            &quot;patient_id&quot;: 1\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;patient_id&quot;: 2\r\n      },\r\n      {\r\n        &quot;patient_id&quot;: 3,\r\n        &quot;phenotypes&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;Breast carcinoma&quot;,\r\n            &quot;observation&quot;: &quot;present&quot;,\r\n            &quot;patient_id&quot;: 3\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;Breast carcinoma&quot;,\r\n            &quot;observation&quot;: &quot;present&quot;,\r\n            &quot;patient_id&quot;: 3\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\n`note` has been removed from root.\r\n`person_id` has been removed from `phenotypes`.",
        "link": "https://stackoverflow.com/questions/51440863/how-do-i-modify-a-child-object-if-it-exists-in-array-of-objects-using-jq",
        "title": "How do I modify a child object if it exists in array of objects using jq?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "addition",
            "element",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1532097807,
                "last_edit_date": 1532097807,
                "creation_date": 1532096335,
                "answer_id": 51444595,
                "question_id": 51441674,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "TIL about complex assignments in `jq`. This actually works:\r\n\r\n    (.children[] | select(.type==&quot;envApprovalTask&quot; and .role.name==&quot;Approver&quot;) | .propDefs) |= .+[{&quot;test&quot;:&quot;2&quot;}]\r\n\r\nThe only significant difference from your version is the parenthesised left side of the assignment.",
                "title": "Jq to add the element in json array conditionally and print the entire modified file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1532097807,
        "creation_date": 1532086618,
        "question_id": 51441674,
        "body_markdown": "I have a json file with the below format.\r\nI would like to add the element {&quot;test&quot; : &quot;2&quot;}in propDefs[] if the .children[].type==&quot;environmentApprovalTask&quot; and .children[].role.name== &quot;GCM approver&quot; and output that to the new file. I want the entire file with the modified content.The .children[] array may not have always 3 elements.\r\n\r\n\r\n\r\n\r\n    {\r\n      &quot;edges&quot;: [\r\n        {\r\n          &quot;to&quot;: &quot;de32e562319310b7b4fe3736e22009&quot;,\r\n          &quot;from&quot;: &quot;99d5f0b278f08721adba7741b782d8&quot;,\r\n          &quot;type&quot;: &quot;SUCCESS&quot;,\r\n          &quot;value&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;to&quot;: &quot;06916609ad7fd4127815be3f075c81&quot;,\r\n          &quot;from&quot;: &quot;de32e562319310b7b4fe3736e22009&quot;,\r\n          &quot;type&quot;: &quot;SUCCESS&quot;,\r\n          &quot;value&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;to&quot;: &quot;99d5f0b278f08721adba7741b782d8&quot;,\r\n          &quot;type&quot;: &quot;ALWAYS&quot;,\r\n          &quot;value&quot;: &quot;&quot;\r\n        }\r\n      ],\r\n      &quot;offsets&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;99d5f0b278f08721adba7741b782d8&quot;,\r\n          &quot;x&quot;: -91,\r\n          &quot;y&quot;: 100,\r\n          &quot;h&quot;: 70,\r\n          &quot;w&quot;: 290\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;06916609ad7fd4127815be3f075c81&quot;,\r\n          &quot;x&quot;: -5,\r\n          &quot;y&quot;: 420,\r\n          &quot;h&quot;: 80,\r\n          &quot;w&quot;: 120\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;de32e562319310b7b4fe3736e22009&quot;,\r\n          &quot;x&quot;: 69,\r\n          &quot;y&quot;: 240,\r\n          &quot;h&quot;: 70,\r\n          &quot;w&quot;: 240\r\n        }\r\n      ],\r\n      &quot;layoutMode&quot;: &quot;manual&quot;,\r\n      &quot;type&quot;: &quot;graph&quot;,\r\n      &quot;id&quot;: &quot;d5d9c4c4-0c5f-4642-872c-ac892039eaa4&quot;,\r\n      &quot;name&quot;: &quot;79e8b952-dd59-4cfd-9c0c-e6c08a81d4ca&quot;,\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;finish&quot;,\r\n          &quot;id&quot;: &quot;833e959c-6825-413d-afc4-7b74c0a87c3e&quot;,\r\n          &quot;name&quot;: &quot;06916609ad7fd4127815be3f075c81&quot;,\r\n          &quot;children&quot;: []\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;e976041d-af9d-48cf-b838-735bb5efd483&quot;,\r\n          &quot;type&quot;: &quot;envApprovalTask&quot;,\r\n          &quot;children&quot;: [],\r\n          &quot;name&quot;: &quot;de32e562319310b7b4fe3736e22009&quot;,\r\n          &quot;roleRestrictionData&quot;: {\r\n            &quot;contextType&quot;: &quot;ENVIRONMENT&quot;,\r\n            &quot;roleRestrictions&quot;: [\r\n              {\r\n                &quot;roleId&quot;: &quot;087175fb-5d38-42d1-b65a-2b6a6958bc21&quot;\r\n              }\r\n            ]\r\n          },\r\n          &quot;propDefs&quot;: [{&quot;test&quot;: &quot;1&quot;}],\r\n          &quot;templateName&quot;: &quot;ApprovalCreated&quot;,\r\n          &quot;commentRequired&quot;: false,\r\n          &quot;commentPrompt&quot;: &quot;&quot;,\r\n          &quot;role&quot;: {\r\n            &quot;id&quot;: &quot;087175fb-5d38-42d1-b65a-2b6a6958bc21&quot;,\r\n            &quot;name&quot;: &quot;Approver&quot;,\r\n            &quot;isDeletable&quot;: true\r\n          }\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;513fbc6a-3c4a-4a10-9eb0-7dc893c69413&quot;,\r\n          &quot;type&quot;: &quot;environmentApprovalTask&quot;,\r\n          &quot;children&quot;: [],\r\n          &quot;name&quot;: &quot;99d5f0b278f08721adba7741b782d8&quot;,\r\n          &quot;roleRestrictionData&quot;: {\r\n            &quot;contextType&quot;: &quot;ENVIRONMENT&quot;,\r\n            &quot;roleRestrictions&quot;: [\r\n              {\r\n                &quot;roleId&quot;: &quot;116b8cd5-e7e4-403d-9599-35fe25d3cba2&quot;\r\n              }\r\n            ]\r\n          },\r\n          &quot;propDefs&quot;: [],\r\n          &quot;templateName&quot;: &quot;ApprovalCreated&quot;,\r\n          &quot;commentRequired&quot;: false,\r\n          &quot;commentPrompt&quot;: &quot;&quot;,\r\n          &quot;role&quot;: {\r\n            &quot;id&quot;: &quot;116b8cd5-e7e4-403d-9599-35fe25d3cba2&quot;,\r\n            &quot;name&quot;: &quot;Manager Approver&quot;,\r\n            &quot;isDeletable&quot;: true\r\n          }\r\n        }\r\n      ]\r\n    }\r\nMy final attempt with the code \r\n\r\n    cat file.json |jq &#39;.|.children[]| select(.type==&quot;envApprovalTask&quot;)|select(.role.name==&quot;Approver&quot;) |.propDefs[.profDefs|length] |= .+ {&quot;test&quot; : &quot;2&quot;}&#39;\r\nThis only produces the modified element, didnt produce the entire file as output. Please help how can i get the desired output.",
        "link": "https://stackoverflow.com/questions/51441674/jq-to-add-the-element-in-json-array-conditionally-and-print-the-entire-modified",
        "title": "Jq to add the element in json array conditionally and print the entire modified file"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq",
            "gsub"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1532579537,
                "last_edit_date": 1532579537,
                "creation_date": 1532098199,
                "answer_id": 51445165,
                "question_id": 51441986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; can I replace comma in the field using jq-win ? \r\n\r\nYes.  For example, use `gsub`, pretty much as you’d use awk’s `gsub`, e.g.\r\n\r\n    gsub(&quot;,&quot;; &quot;|&quot;)\r\n\r\nIf you want more details, please provide more details as per [mcve].\r\n\r\n## Example\r\nWith the given JSON input, the jq program:\r\n\r\n    .[]\r\n    | .name |= gsub(&quot;,&quot;;&quot;;&quot;)\r\n    | [.[]]\r\n    | map(tostring)\r\n    | join(&quot;,&quot;)\r\n\r\nyields:\r\n\r\n    1083,AAAAA,8,\r\n    1084,bbbbb,7,\r\n    1088,CCCCCC,131,\r\n    1089,DDD;DDD,132,\r\n\r\n",
                "title": "replace comma in json file&#39;s field with jq-win"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1532847540,
        "creation_date": 1532087720,
        "last_edit_date": 1532847540,
        "question_id": 51441986,
        "body_markdown": "I have a problem in working JSON file. I launch curl in AutoIt sciript to download a json file from web and then convert it to csv format by jq-win\r\n\r\n    jq-win32 -r &quot;.[]&quot; -c class.json&gt;class.txt\r\n\r\nand the json is in the following format:\r\n\r\n    [\r\n    {\r\n    &quot;id&quot;:&quot;1083&quot;,\r\n    &quot;name&quot;:&quot;AAAAA&quot;,\r\n    &quot;channelNumber&quot;:8,\r\n    &quot;channelImage&quot;:&quot;&quot;},\r\n    {\r\n    &quot;id&quot;:&quot;1084&quot;,\r\n    &quot;name&quot;:&quot;bbbbb&quot;,\r\n    &quot;channelNumber&quot;:7,\r\n    &quot;channelImage&quot;:&quot;&quot;},\r\n    {\r\n    &quot;id&quot;:&quot;1088&quot;,\r\n    &quot;name&quot;:&quot;CCCCCC&quot;,\r\n    &quot;channelNumber&quot;:131,\r\n    &quot;channelImage&quot;:&quot;&quot;},\r\n    {\r\n    &quot;id&quot;:&quot;1089&quot;,\r\n    &quot;name&quot;:&quot;DDD,DDD&quot;,\r\n    &quot;channelNumber&quot;:132,\r\n    &quot;channelImage&quot;:&quot;&quot;},\r\n    ]\r\n\r\nafter jq-win, the file should become:\r\n\r\n    {&quot;id&quot;:&quot;1083&quot;,&quot;name&quot;:&quot;AAAAA&quot;,&quot;channelNumber&quot;:8,&quot;channelImage&quot;:&quot;&quot;}\r\n    {&quot;id&quot;:&quot;1084&quot;,&quot;name&quot;:&quot;bbbbb&quot;,&quot;channelNumber&quot;:7,&quot;channelImage&quot;:&quot;&quot;}\r\n    {&quot;id&quot;:&quot;1088&quot;,&quot;name&quot;:&quot;CCCCCC&quot;,&quot;channelNumber&quot;:131,&quot;channelImage&quot;:&quot;&quot;}\r\n    {&quot;id&quot;:&quot;1089&quot;,&quot;name&quot;:&quot;DDD,DDD&quot;,&quot;channelNumber&quot;:132,&quot;channelImage&quot;:&quot;&quot;}\r\n\r\nand then the csv file will be further process by the AutoIt script and become:\r\n\r\n    AAAAA,1083\r\n    bbbbb,1084\r\n    CCCCCC,1088\r\n    DDD,DDD,1089\r\n\r\nThe json has around 300 records and among them, 5~6 record has comma in it eg DDD,DDD\r\nso when I tried read in the csv file by _FileReadToArray, the comma in DDD,DDD cause trouble.\r\n\r\nMy question is: can I replace comma in the field using jq-win ? \r\n(I tried use fart.exe but it will replace all comma in json file which is not suitable for me.)\r\nThanks a lot.\r\n\r\nRegds\r\nLAM Chi-fung\r\n",
        "link": "https://stackoverflow.com/questions/51441986/replace-comma-in-json-files-field-with-jq-win",
        "title": "replace comma in json file&#39;s field with jq-win"
    },
    {
        "tags": [
            "json",
            "internationalization",
            "translation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1532113026,
                "last_edit_date": 1532113026,
                "creation_date": 1532101665,
                "answer_id": 51446188,
                "question_id": 51445949,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In brief:\r\n\r\n    $ jq -s -f patch.jq object.json array.json\r\n\r\nwhere patch.jq contains:\r\n\r\n    .[1] as $array\r\n    | .[0]\r\n    | .items |= reduce range(0;length) as $i (.; \r\n                  .[$i].name = $array[$i])\r\n\r\n\r\nIn long: there are many alternatives to the above but using the &quot;-s&quot; command-line option has the advantage that it works with all versions of jq, and doesn&#39;t require bash-magic.\r\n\r\n## Dictionaries\r\n\r\nRather than using an array as a dictionary, it might be better to use a dictionary, i.e. a JSON object. For example, in the present case, the dictionary could be constructed along the lines of:\r\n\r\n    {&quot;Item1&quot;: &quot;Item 1 translated&quot;, ...}\r\n\r\nOf course there are pros and cons to be considered, but if you&#39;re worried about the case in which keys are of mixed type (e.g. `&quot;1&quot;` and `1`), then you could consider using a dictionary of dictionaries, e.g. along the lines of:\r\n\r\n    { &quot;string&quot;: {&quot;1&quot;: &quot;one}, &quot;number&quot;: {&quot;1&quot;: 1} }",
                "title": "Modify/Patch json with another json using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1532113026,
        "creation_date": 1532100767,
        "question_id": 51445949,
        "body_markdown": "Given two json files like this:\r\n\r\n    {\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Item 1&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Item 2&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Item 3&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nand this:\r\n\r\n    [\r\n      &quot;Item 1 translated&quot;,\r\n      &quot;Item 2 translated&quot;,\r\n      &quot;Item 3 translated&quot;\r\n    ]\r\n\r\n— is it possible to apply the latter as a patch for the former? So that the final result would look like:\r\n\r\n    {\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Item 1 translated&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Item 2 translated&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Item 3 translated&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nA use case. Imagine a huge json file which needs to be localized. We could just export data to be translated in CSV, edit them in Spreadsheets and then export to json back. Then we could apply it as a patch for the original json.",
        "link": "https://stackoverflow.com/questions/51445949/modify-patch-json-with-another-json-using-jq",
        "title": "Modify/Patch json with another json using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1532119280,
                "creation_date": 1532119280,
                "answer_id": 51450079,
                "question_id": 51449999,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use a variable to remember `.channel` in the later stages of the pipeline.\r\n\r\n    $ jq &#39;.channel as $ch | .videos[].channel = $ch&#39; tmp.json\r\n    {\r\n      &quot;channel&quot;: &quot;mychannel&quot;,\r\n      &quot;videos&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;10&quot;,\r\n          &quot;url&quot;: &quot;youtube.com&quot;,\r\n          &quot;channel&quot;: &quot;mychannel&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;20&quot;,\r\n          &quot;url&quot;: &quot;youtube.com&quot;,\r\n          &quot;channel&quot;: &quot;mychannel&quot;\r\n        }\r\n      ]\r\n    }",
                "title": "Add the same element of array in a existing JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1532119280,
        "creation_date": 1532118925,
        "question_id": 51449999,
        "body_markdown": "I have a json file and I want to add some value from top in another place in json.\r\nI am trying to use jq command line.\r\n\r\n    {\r\n        &quot;channel&quot;: &quot;mychannel&quot;,\r\n        &quot;videos&quot;: [\r\n            {\r\n                &quot;id&quot;: &quot;10&quot;,\r\n                &quot;url&quot;: &quot;youtube.com&quot;\r\n            },\r\n            {\r\n                &quot;id&quot;: &quot;20&quot;, \r\n                &quot;url&quot;: &quot;youtube.com&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nThe output would be:\r\n\r\n    {\r\n        &quot;channel&quot;: &quot;mychannel&quot;,\r\n        &quot;videos&quot;: [\r\n            {\r\n                &quot;channel&quot;: &quot;mychannel&quot;,\r\n                &quot;id&quot;: &quot;10&quot;,\r\n                &quot;url&quot;: &quot;youtube.com&quot;\r\n            },\r\n            {\r\n                &quot;channel&quot;: &quot;mychannel&quot;,\r\n                &quot;id&quot;: &quot;20&quot;, \r\n                &quot;url&quot;: &quot;youtube.com&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nin my json the &quot;channel&quot; is static, same value always. I need a way to concatenate always in each video array.\r\n\r\nSomeone can help me?\r\n\r\njq .videos + channel",
        "link": "https://stackoverflow.com/questions/51449999/add-the-same-element-of-array-in-a-existing-json-using-jq",
        "title": "Add the same element of array in a existing JSON using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1532342749,
                "creation_date": 1532342749,
                "answer_id": 51476985,
                "question_id": 51476598,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following `jq` command:\r\n\r\n    jq -r &#39;.[]|&quot;\\(.server), \\(.keys[]|select(.name==&quot;user2&quot;).for_user)&quot;&#39;",
                "title": "How to output keys on different levels if value found in array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1532342749,
        "creation_date": 1532341552,
        "question_id": 51476598,
        "body_markdown": "Using jq, I would like to output multiple values on different levels of a JSON file based on whether they exist in an array.\r\n\r\nMy data looks like the following. It displays a number of hosts I examine regarding the people who have access to it:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;server&quot;: &quot;example_1&quot;,\r\n        &quot;version&quot;: &quot;Debian8&quot;,\r\n        &quot;keys&quot;: [\r\n          {\r\n            &quot;fingerprint&quot;: &quot;SHA256:fingerprint1&quot;,\r\n            &quot;for_user&quot;: &quot;root&quot;,\r\n            &quot;name&quot;: &quot;user1&quot;\r\n          },\r\n          {\r\n            &quot;fingerprint&quot;: &quot;SHA256:fingerprint2&quot;,\r\n            &quot;for_user&quot;: &quot;git&quot;,\r\n            &quot;name&quot;: &quot;user2&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;server&quot;: &quot;example_2&quot;,\r\n        &quot;version&quot;: &quot;Debian9&quot;,\r\n        &quot;keys&quot;: [\r\n          {\r\n            &quot;fingerprint&quot;: &quot;SHA256:fingerprint2&quot;,\r\n            &quot;for_user&quot;: &quot;root&quot;,\r\n            &quot;name&quot;: &quot;user2&quot;\r\n          },\r\n          {\r\n            &quot;fingerprint&quot;: &quot;SHA256:fingerprint2&quot;,\r\n            &quot;for_user&quot;: &quot;www&quot;,\r\n            &quot;name&quot;: &quot;user2&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;server&quot;: &quot;example_3&quot;,\r\n        &quot;version&quot;: &quot;CentOS&quot;,\r\n        &quot;keys&quot;: [\r\n          null\r\n        ]\r\n      }\r\n    ]\r\n\r\nI want to extract the value for `server` and the value of `for_user` any occurence where user2 is found as a name in `.keys[]`. Basically, the output could look like this:\r\n\r\n&lt;!-- language: lang-none --&gt;\r\n\r\n    example1, git\r\n    example2, root\r\n    example2, www\r\n\r\nWhat I can already do is displaying the first column, so the `.server` value:\r\n\r\n&lt;!-- language: lang-bash --&gt;\r\n\r\n    cat test.json | jq -r &#39;.[] | select(.keys[].name | index(&quot;user2&quot;)) | .server&#39;`\r\n\r\nHow could I also print a value in the selected array element?",
        "link": "https://stackoverflow.com/questions/51476598/how-to-output-keys-on-different-levels-if-value-found-in-array",
        "title": "How to output keys on different levels if value found in array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1532364683,
                "creation_date": 1532364683,
                "answer_id": 51483770,
                "question_id": 51477085,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "That&#39;s a really good effort made. Your idea is right, you&#39;ve made sure the `.instances[]` array is flattened, just use that logic to re-construct the JSON as you need as\r\n\r\n    jq &#39;{ &quot;@name&quot; : .site.&quot;@name&quot;, \r\n          &quot;@ssl&quot;  : .site.&quot;@ssl&quot;, \r\n          &quot;alerts&quot;: [.site.alerts[] as $in | $in.instances[] as $h | $in | del(.instances) as $in2 | $h * $in2 ]}&#39; json\r\n\r\n[jqplay.org - URL](https://jqplay.org/s/X9nYQDDGbG)\r\n\r\n",
                "title": "Flatten nested JSON array with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 8,
        "last_activity_date": 1532364683,
        "creation_date": 1532343070,
        "question_id": 51477085,
        "body_markdown": "I have a JSON in the following format:\r\n\r\n    {\r\n      &quot;@version&quot;: &quot;2.7.0&quot;,\r\n      &quot;site&quot;: {\r\n        &quot;@name&quot;: &quot;http://api:9999&quot;,\r\n        &quot;@ssl&quot;: &quot;false&quot;,\r\n        &quot;alerts&quot;: [\r\n          {\r\n            &quot;pluginid&quot;: &quot;10094&quot;,\r\n            &quot;desc&quot;: &quot;&lt;p&gt;Base64 encoded data was disclosed by the application/web server&lt;\\/p&gt;&quot;,\r\n            &quot;instances&quot;: [\r\n              {\r\n                &quot;uri&quot;: &quot;http://api:9999&quot;,\r\n                &quot;method&quot;: &quot;POST&quot;,\r\n                &quot;evidence&quot;: &quot;DxyPP_YQ6qdWA_Kw_ZLgYilIkXCz93Xs1CeJPvg&quot;\r\n              },\r\n              {\r\n                &quot;uri&quot;: &quot;http://api:9999&quot;,\r\n                &quot;method&quot;: &quot;POST&quot;,\r\n                &quot;evidence&quot;: &quot;eyJuYmYiOjE121lMWF1siSG9tZUFwcCJdfQ&quot;\r\n              }\r\n            ],\r\n            &quot;count&quot;: &quot;37&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nI want to flatten the inner array - `.site.alerts.instances` to get the following JSON:\r\n\r\n    {\r\n        &quot;@name&quot;: &quot;http://api:9999&quot;,\r\n        &quot;@ssl&quot;: &quot;false&quot;,\r\n        &quot;alerts&quot;: [\r\n          {\r\n            &quot;pluginid&quot;: &quot;10094&quot;,\r\n            &quot;desc&quot;: &quot;&lt;p&gt;Base64 encoded data was disclosed by the application/web server&lt;\\/p&gt;&quot;,\r\n            &quot;uri&quot;: &quot;http://api:9999&quot;,\r\n            &quot;method&quot;: &quot;POST&quot;,\r\n            &quot;evidence&quot;: &quot;DxyPP_YQ6qdWA_Kw_ZLgYilIkXCz93Xs1CeJPvg&quot;,\r\n            &quot;count&quot;: &quot;37&quot;\r\n          },\r\n          {\r\n            &quot;pluginid&quot;: &quot;10094&quot;,\r\n            &quot;desc&quot;: &quot;&lt;p&gt;Base64 encoded data was disclosed by the application/web server&lt;\\/p&gt;&quot;,\r\n            &quot;uri&quot;: &quot;http://api:9999&quot;,\r\n            &quot;method&quot;: &quot;POST&quot;,\r\n            &quot;evidence&quot;: &quot;eyJuYmYiOjE121lMWF1siSG9tZUFwcCJdfQ&quot;,\r\n            &quot;count&quot;: &quot;37&quot;\r\n          }\r\n        ]\r\n      }\r\n\r\nI was able to flatten the inner JSON array by using the following JQ pattern:\r\n\r\n    .site.alerts[] as $in | $in.instances[] as $h |  $in | del(.instances) as $in2 |  $h * $in2 \r\n\r\nThis gave me a very close result:\r\n\r\n    {\r\n      &quot;uri&quot;: &quot;http://api:9999&quot;,\r\n      &quot;method&quot;: &quot;POST&quot;,\r\n      &quot;evidence&quot;: &quot;DxyPP_YQ6qdWA_Kw_ZLgYilIkXCz93Xs1CeJPvg&quot;,\r\n      &quot;pluginid&quot;: &quot;10094&quot;,\r\n      &quot;desc&quot;: &quot;&lt;p&gt;Base64 encoded data was disclosed by the application/web server&lt;/p&gt;&quot;,\r\n      &quot;count&quot;: &quot;37&quot;\r\n    }\r\n    {\r\n      &quot;uri&quot;: &quot;http://api:9999&quot;,\r\n      &quot;method&quot;: &quot;POST&quot;,\r\n      &quot;evidence&quot;: &quot;eyJuYmYiOjE121lMWF1siSG9tZUFwcCJdfQ&quot;,\r\n      &quot;pluginid&quot;: &quot;10094&quot;,\r\n      &quot;desc&quot;: &quot;&lt;p&gt;Base64 encoded data was disclosed by the application/web server&lt;/p&gt;&quot;,\r\n      &quot;count&quot;: &quot;37&quot;\r\n    }\r\n\r\nBut not a perfect result. The objects are not in an array, and fields from the parent object, which are not part of the array (e.g. `.site.@name`) are not included.\r\n\r\nCan you help me improve the JQ pattern I created?\r\n\r\nThanks in advance!\r\n",
        "link": "https://stackoverflow.com/questions/51477085/flatten-nested-json-array-with-jq",
        "title": "Flatten nested JSON array with JQ"
    },
    {
        "tags": [
            "bash",
            "environment-variables",
            "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": 1532359007,
                "post_id": 51482065,
                "comment_id": 89933066,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2000482,
                    "reputation": 903,
                    "user_id": 1791660,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/523d71e4f3fc2caed588975caca6eb61?s=256&d=identicon&r=PG",
                    "display_name": "Rick Baker",
                    "link": "https://stackoverflow.com/users/1791660/rick-baker"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1532359248,
                "post_id": 51482065,
                "comment_id": 89933214,
                "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": 1532359293,
                "post_id": 51482065,
                "comment_id": 89933243,
                "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": 1532359759,
                "post_id": 51482065,
                "comment_id": 89933568,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1649261303,
                "last_edit_date": 1649261303,
                "creation_date": 1532359172,
                "answer_id": 51482231,
                "question_id": 51482065,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For all of the below, I&#39;m assuming that:\r\n\r\n    json=&#39;{&quot;params&quot;:[{ &quot;Name&quot;:&quot;KEY&quot;,&quot;Value&quot;:&quot;value with space&quot;}]}&#39;\r\n\r\n---\r\n\r\n### It can be done, but *ONLY IF YOU TRUST YOUR INPUT*.\r\n\r\nA solution that uses `eval` might look like:\r\n\r\n    eval &quot;$(jq -r &#39;.params[] | &quot;export \\(.Name | @sh)=\\(.Value | @sh)&quot;&#39; &lt;&lt;&lt;&quot;$json&quot;)&quot;\r\n\r\nThe `@sh` builtin in `jq` escapes content to be `eval`-safe in bash, and the `eval` invocation then ensures that the content goes through all parsing stages (so literal quotes in the data emitted by `jq` become syntactic).\r\n\r\nHowever, all solutions that allow arbitrary shell variables to be assigned have innate security problems, as the ability to set variables like `PATH`, `LD_LIBRARY_PATH`, `LD_PRELOAD` and the like can be leveraged into arbitrary code execution.\r\n\r\n---\r\n\r\n### Better form is to generate a NUL-delimited key/value list...\r\n\r\n    build_kv_nsv() {\r\n      jq -j &#39;.params[] |\r\n        ((.Name | gsub(&quot;\\u0000&quot;; &quot;&quot;)),\r\n         &quot;\\u0000&quot;,\r\n         (.Value | gsub(&quot;\\u0000&quot;; &quot;&quot;)),\r\n         &quot;\\u0000&quot;)&#39;\r\n    }\r\n\r\n### ...and either populate an associative array...\r\n\r\n    declare -A content_received=( )\r\n    while IFS= read -r -d &#39;&#39; name &amp;&amp; IFS= read -r -d &#39;&#39; value; do\r\n      content_received[$name]=$value\r\n    done &lt; &lt;(build_kv_nsv &lt;&lt;&lt;&quot;$json&quot;)\r\n\r\n    # print the value of the populated associative array\r\n    declare -p content_received\r\n\r\n### ...or to use a namespace that&#39;s prefixed to guarantee safety.\r\n\r\n    while IFS= read -r -d &#39;&#39; name &amp;&amp; IFS= read -r -d &#39;&#39; value; do\r\n      printf -v &quot;received_$name&quot; %s &quot;$value&quot; &amp;&amp; export &quot;received_$name&quot;\r\n    done &lt; &lt;(build_kv_nsv &lt;&lt;&lt;&quot;$json&quot;)\r\n\r\n    # print names and values of our variables that start with received_\r\n    declare -p &quot;${!received_@}&quot; &gt;&amp;2\r\n\r\n",
                "title": "exporting environment variables with spaces using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1532528181,
                "creation_date": 1532528181,
                "answer_id": 51521191,
                "question_id": 51482065,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the values are known not to contain (raw) newlines, and if you have access to `mapfile`, it may be worthwhile considering using it, e.g.\r\n \r\n\r\n    $ json=&#39;{&quot;params&quot;:[{ &quot;Name&quot;:&quot;KEY&quot;,&quot;Value&quot;:&quot;value with space&quot;}]}&#39;\r\n    $ mapfile -t KEY &lt; &lt;( jq -r &#39;.params[] | .Value&#39; &lt;&lt;&lt; &quot;$json&quot; )\r\n    $ echo N=${#KEY[@]}\r\n    N=1\r\n\r\nIf the values might contain (raw) newlines, then you&#39;d need a version of `mapfile` with the -d option, which could be used as illustrated below:\r\n\r\n    $ json=&#39;{&quot;params&quot;:[{ &quot;Name&quot;:&quot;KEY1&quot;,&quot;Value&quot;:&quot;value with space&quot;}, { &quot;Name&quot;:&quot;KEY2&quot;,&quot;Value&quot;:&quot;value with \\n newline&quot;}]}&#39;\r\n    $ mapfile -d $&#39;\\0&#39; KEY &lt; &lt;( jq -r -j &#39;.params[] | .Value + &quot;\\u0000&quot;&#39; &lt;&lt;&lt; &quot;$json&quot; )\r\n    $ echo N=${#KEY[@]}\r\n    N=2\r\n",
                "title": "exporting environment variables with spaces using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1649261303,
        "creation_date": 1532358632,
        "last_edit_date": 1532488309,
        "question_id": 51482065,
        "body_markdown": "So, I&#39;m trying to export an environment variable that comes from an api that returns json values.  Would like to use jq to just do a one liner, but if the values have spaces I cannot get it working\r\n\r\nTrying without surrounding the value in quotes\r\n\r\n    /app/src $ $(echo &#39;{&quot;params&quot;:[{ &quot;Name&quot;:&quot;KEY&quot;,&quot;Value&quot;:&quot;value with space&quot;}]}&#39; | jq\r\n     -r &#39;.params[] | &quot;export &quot; + .Name + &quot;=&quot; + .Value&#39;)\r\n    /app/src $ printenv KEY\r\n    value\r\n    /app/src $ \r\n\r\nNext, I try wrapping the value in quotes\r\n\r\n    /app/src $ $(echo &#39;{&quot;params&quot;:[{ &quot;Name&quot;:&quot;KEY&quot;,&quot;Value&quot;:&quot;value with space&quot;}]}&#39; | jq\r\n     -r &#39;.params[] | &quot;export &quot; + .Name + &quot;=\\&quot;&quot; + .Value + &quot;\\&quot;&quot;&#39;)\r\n    sh: export: space&quot;: bad variable name\r\n    /app/src $ \r\n\r\n",
        "link": "https://stackoverflow.com/questions/51482065/exporting-environment-variables-with-spaces-using-jq",
        "title": "exporting environment variables with spaces using jq"
    },
    {
        "tags": [
            "json",
            "object",
            "stream",
            "jq",
            "jsonstream"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1532418170,
                "last_edit_date": 1532418170,
                "creation_date": 1532416282,
                "answer_id": 51492578,
                "question_id": 51491317,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s assume you have jq 1.5 or later, and that your JSON objects are in one or more files.  Then for your first expected output you can simply write:\r\n\r\n\r\n    [inputs | .a | { (.b): .d} ] | add\r\n\r\nThis assumes you use the -n command-line option.  I&#39;m sure that once you see how simple the solution is, further explanation will be superfluous.\r\n\r\nFor your second expected output, you can just wrap the above line in:\r\n\r\n    {x: _}\r\n\r\nE.g.:\r\n \r\n    $ jq -ncf program.jq input.json\r\n    {&quot;x&quot;:{&quot;c&quot;:&quot;e&quot;,&quot;f&quot;:&quot;g&quot;}}\r\n\r\n**p.s.** Your approach using `reduce` is fine, but you&#39;d need to use the -s command-line option.\r\n\r\n**p.p.s.** Do you owe me another beer?\r\n",
                "title": "JQ How to merge multiple objects into one"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 8,
        "last_activity_date": 1532473152,
        "creation_date": 1532411388,
        "last_edit_date": 1532473152,
        "question_id": 51491317,
        "body_markdown": "Given the following input (which is a toned down version of the output with 100K+ objects of another complex query):\r\n\r\n    echo &#39;{ &quot;a&quot;: { &quot;b&quot;:&quot;c&quot;, &quot;d&quot;:&quot;e&quot; } }{ &quot;a&quot;: { &quot;b&quot;:&quot;f&quot;, &quot;d&quot;:&quot;g&quot; } }&#39; | jq &#39;.&#39;\r\n    {\r\n      &quot;a&quot;: {\r\n        &quot;b&quot;: &quot;c&quot;,\r\n        &quot;d&quot;: &quot;e&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;a&quot;: {\r\n        &quot;b&quot;: &quot;f&quot;,\r\n        &quot;d&quot;: &quot;g&quot;\r\n      }\r\n    }\r\n\r\ndesired output:\r\n\r\n    {\r\n       &quot;c&quot;: &quot;e&quot;,\r\n       &quot;f&quot;: &quot;g&quot;\r\n    }\r\n\r\nor (suits better for follow up usage):\r\n\r\n    {\r\n       x: {\r\n          &quot;c&quot;: &quot;e&quot;,\r\n          &quot;f&quot;: &quot;g&quot;\r\n       }\r\n    }\r\n\r\nI can&#39;t for the life of me figure out how to do it. My real problem of course is the multiple object input data, for which I really don&#39;t know whether it&#39;s valid JSON. Jq produces and accepts it, jshon does not. I tried various possibilities, but none of them produced what I need. I considered this the most likely candidate:\r\n\r\n    echo &#39;{ &quot;a&quot;: { &quot;b&quot;:&quot;c&quot;, &quot;d&quot;:&quot;e&quot; } }{ &quot;a&quot;: { &quot;b&quot;:&quot;f&quot;, &quot;d&quot;:&quot;g&quot; } }&#39; | jq &#39; . | { (.a.b): .a.d }&#39;\r\n    {\r\n       &quot;c&quot;: &quot;e&quot;\r\n    }\r\n    {\r\n       &quot;f&quot;: &quot;g&quot;\r\n    }\r\n\r\nBut alas. Other things I tried:\r\n\r\n    &#39; . | { x: { (.a.b): .a.d } }&#39;\r\n    &#39;{ x: {} | . | add }&#39;\r\n    &#39;{ x: {} | . | x += }&#39;\r\n    &#39;{ x: {} | x += . }&#39;\r\n    &#39;x: {} | .x += { (.a.b): .a.d }&#39;\r\n    &#39;{ x: {} } | .x += { (.a.b): .a.d }&#39;\r\n\r\nAnother one, close, but no sigar:\r\n\r\n    &#39;reduce { (.a.b): .a.d } as $item ({}; . + $item)&#39;\r\n    {\r\n      &quot;c&quot;: &quot;e&quot;\r\n    }\r\n    {\r\n      &quot;f&quot;: &quot;g&quot;\r\n    }\r\n\r\nWho cares to enlighten me?\r\n\r\nSo the full answer in the above use case, thanks to @peak, is\r\n\r\n    echo &#39;{ &quot;a&quot;: { &quot;b&quot;: &quot;c&quot;, &quot;d&quot;: &quot;e&quot; } }{ &quot;a&quot;: { &quot;b&quot;: &quot;f&quot;, &quot;d&quot;: &quot;g&quot; } }&#39; | jq -n &#39;{ x: [inputs | .a | { (.b): .d} ] | add }&#39;\r\n    {\r\n      &quot;x&quot;: {\r\n        &quot;c&quot;: &quot;e&quot;,\r\n        &quot;f&quot;: &quot;g&quot;\r\n      }\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51491317/jq-how-to-merge-multiple-objects-into-one",
        "title": "JQ How to merge multiple objects into one"
    },
    {
        "tags": [
            "key",
            "special-characters",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1714779351,
                "last_edit_date": 1714779351,
                "creation_date": 1532423745,
                "answer_id": 51494894,
                "question_id": 51494389,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The most robust alternative is to use the basic form:\r\n\r\n    .[KEY]\r\n\r\nwhere KEY is a JSON string, including the outer quotation marks. \r\n\r\nIn older versions of jq, however, you might have to pipeline this form:\r\n\r\n    jq &#39;.abc|.[&quot;@def-ghi&quot;]&#39;\r\n\r\n(The `.[_]` form can also be used for arrays, but of course _ would have to be an integer.)",
                "title": "Escape field name in jq that contains &#39;@&#39; and &#39;-&#39;?"
            },
            {
                "up_vote_count": 38,
                "is_accepted": true,
                "score": 38,
                "last_activity_date": 1686145169,
                "last_edit_date": 1686145169,
                "creation_date": 1532446249,
                "answer_id": 51502506,
                "question_id": 51494389,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to quote the key:\r\n\r\n    $ echo &#39;...&#39; | jq &#39;.abc.&quot;@def-ghi&quot;&#39;\r\n    &quot;value1&quot;",
                "title": "Escape field name in jq that contains &#39;@&#39; and &#39;-&#39;?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 24,
        "last_activity_date": 1714779351,
        "creation_date": 1532422328,
        "last_edit_date": 1532445796,
        "question_id": 51494389,
        "body_markdown": "Input JSON:\r\n\r\n    {\r\n      &quot;abc&quot;: {\r\n        &quot;@def-ghi&quot;: &quot;value1&quot;,\r\n        &quot;xyz&quot;: &quot;value2&quot;\r\n      }\r\n    }\r\n\r\nAnd I&#39;m trying to get value for field `@def-ghi`. \r\n\r\n\r\n\r\n\r\n    ➜ $?=0 ➤ echo &#39;{&quot;abc&quot;: {&quot;@def-ghi&quot;: &quot;value1&quot;, &quot;xyz&quot;: &quot;value2&quot;}}&#39; | jq &#39;.abc.xyz&#39;\r\n    &quot;value2&quot;\r\n    ➜ $?=0 ➤ echo &#39;{&quot;abc&quot;: {&quot;@def-ghi&quot;: &quot;value1&quot;, &quot;xyz&quot;: &quot;value2&quot;}}&#39; | jq &#39;.abc.@def-ghi&#39;\r\n    jq: error: syntax error, unexpected &#39;-&#39;, expecting QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .abc.@def-ghi\r\n    jq: 1 compile error\r\n    ➜ $?=3 ➤\r\n\r\nHow to escape the field name properly?",
        "link": "https://stackoverflow.com/questions/51494389/escape-field-name-in-jq-that-contains-and",
        "title": "Escape field name in jq that contains &#39;@&#39; and &#39;-&#39;?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "scope",
            "nested",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1532520296,
                "last_edit_date": 1532520296,
                "creation_date": 1532516371,
                "answer_id": 51517254,
                "question_id": 51515869,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The cartesian-product behavior is the result of including `.orders[]` at multiple places inside the object-construction expression.  Hoist it instead.  Assuming you want to select objects with `.batch_size` equal to &quot;2&quot;, you could write:\r\n\r\n    .operations[]\r\n    | select(.operationName==&quot;GetValue&quot;)\r\n    | .batch_size as $batch_size\r\n    | select($batch_size == &quot;2&quot;)\r\n    | .orders[]\r\n    | {key: .clientId,\r\n       place_validation_time: .validation_time.place,\r\n       execute_validation_time: .validation_time.execute,\r\n       batch_size: $batch_size}\r\n\r\n## Addendum\r\nIf you have other items of interest at the .batch_size level, you would probably want to use a filter more like this:\r\n\r\n    .operations[]\r\n    | select(.operationName==&quot;GetValue&quot;)\r\n    | . as $it\r\n    | select($it.batch_size == &quot;2&quot;)\r\n    | .orders[]\r\n    | {key: .clientId,\r\n       place_validation_time: .validation_time.place,\r\n       execute_validation_time: .validation_time.execute,\r\n       batch_size: $it.batch_size}\r\n\r\n\r\n",
                "title": "JQ to parse nested arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1532524801,
        "creation_date": 1532512152,
        "last_edit_date": 1532524801,
        "question_id": 51515869,
        "body_markdown": "I have an issue to get data from JSON:\r\n\r\n    {\r\n      &quot;operations&quot;: [\r\n        {\r\n          &quot;operationName&quot;: &quot;GetValue&quot;,\r\n          &quot;batch_size&quot;: &quot;2&quot;,\r\n          &quot;orders&quot;: [\r\n            {\r\n              &quot;clientId&quot;: &quot;7836&quot;,\r\n              &quot;validation_time&quot;: {\r\n                &quot;place&quot;: &quot;136&quot;,\r\n                &quot;execute&quot;: &quot;5379&quot;\r\n              }\r\n            },\r\n            {\r\n              &quot;clientId&quot;: &quot;7837&quot;,\r\n              &quot;validation_time&quot;: {\r\n                &quot;place&quot;: &quot;145&quot;,\r\n                &quot;execute&quot;: &quot;5401&quot;\r\n              }\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;operationName&quot;: &quot;GetValue&quot;,\r\n          &quot;batch_size&quot;: &quot;3&quot;,\r\n          &quot;orders&quot;: [\r\n            {\r\n              &quot;clientId&quot;: &quot;7838&quot;,\r\n              &quot;validation_time&quot;: {\r\n                &quot;place&quot;: &quot;122&quot;,\r\n                &quot;execute&quot;: &quot;5201&quot;\r\n              }\r\n            },\r\n            {\r\n              &quot;clientId&quot;: &quot;7839&quot;,\r\n              &quot;validation_time&quot;: {\r\n                &quot;place&quot;: &quot;122&quot;,\r\n                &quot;execute&quot;: &quot;5201&quot;\r\n              }\r\n            },\r\n            {\r\n              &quot;clientId&quot;: &quot;7840&quot;,\r\n              &quot;validation_time&quot;: {\r\n                &quot;place&quot;: &quot;122&quot;,\r\n                &quot;execute&quot;: &quot;5201&quot;\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nAs a result, I wanna get info per order including clientId as key, place_validation_time and execute_validation_time per order. I tried the following:\r\n\r\n    .operations[] | select(.operationName==&quot;GetValue&quot;) | {key: .orders[].clientId, place_validation_time: .orders[].validation_time.place, execute_validation_time: .orders[].validation_time.execute, batch_size: .batch_size}\r\n\r\nBut it has an unexpected result for me, it combined all clientId with all variations of validation_time.place and validation_time.execute, so instead of 1 object per order I&#39;ve got 4 (for batch_size=2) e.g.\r\nExpected:\r\n\r\n    {\r\n      &quot;key&quot;: &quot;7836&quot;,\r\n      &quot;place_validation_time&quot;: &quot;136&quot;,\r\n      &quot;execute_validation_time&quot;: &quot;5379&quot;,\r\n      &quot;batch_size&quot;: &quot;2&quot;\r\n    }\r\nActual I have:\r\n\r\n    {\r\n      &quot;key&quot;: &quot;7836&quot;,\r\n      &quot;place_validation_time&quot;: &quot;136&quot;,\r\n      &quot;execute_validation_time&quot;: &quot;5379&quot;,\r\n      &quot;batch_size&quot;: &quot;2&quot;\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;7836&quot;,\r\n      &quot;place_validation_time&quot;: &quot;136&quot;,\r\n      &quot;execute_validation_time&quot;: &quot;5401&quot;,\r\n      &quot;batch_size&quot;: &quot;2&quot;\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;7836&quot;,\r\n      &quot;place_validation_time&quot;: &quot;145&quot;,\r\n      &quot;execute_validation_time&quot;: &quot;5379&quot;,\r\n      &quot;batch_size&quot;: &quot;2&quot;\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;7836&quot;,\r\n      &quot;place_validation_time&quot;: &quot;145&quot;,\r\n      &quot;execute_validation_time&quot;: &quot;5401&quot;,\r\n      &quot;batch_size&quot;: &quot;2&quot;\r\n    }\r\n\r\nDoes anybody have ideas how to avoid it and get as a result 1 object per 1 order?\r\n",
        "link": "https://stackoverflow.com/questions/51515869/jq-to-parse-nested-arrays",
        "title": "JQ to parse nested arrays"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1532514324,
                "creation_date": 1532514324,
                "answer_id": 51516567,
                "question_id": 51516041,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need to look into a specific index, just use the `select()` expression do that for you, which will return the `@name` containing `dbUrl` and return its `@value`\r\n\r\n    jq --raw-output &#39;.project.property[] | select(.&quot;@name&quot;==&quot;dbUrl&quot;) | .&quot;@value&quot;&#39;\r\n\r\nSince the fields `@name` and `@value` have a special character `@` present, you need to access them inside quotes.\r\n\r\n[jqplay - URL](https://jqplay.org/s/eq8dsEpYee)\r\n",
                "title": "How to get the value of `@value` in a json array whose `@name` is `dbUrl` using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1532514970,
                "creation_date": 1532514970,
                "answer_id": 51516798,
                "question_id": 51516041,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want all the values of &quot;@value&quot; corresponding to &quot;@name&quot; being &quot;dbUrl&quot;:\r\n\r\n    .. | objects | select(.[&quot;@name&quot;] == &quot;dbUrl&quot;) | .[&quot;@value&quot;]\r\n\r\n\r\nHere I&#39;ve used the `.[&quot;KEYNAME&quot;]` form for accessing the value corresponding to &quot;KEYNAME&quot; as that is more robust than `.KEYNAME`.\r\n\r\n",
                "title": "How to get the value of `@value` in a json array whose `@name` is `dbUrl` using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1532514970,
        "creation_date": 1532512693,
        "question_id": 51516041,
        "body_markdown": "The following `test.json` file is converted from an xml file with [xq](https://github.com/kislyuk/yq):\r\n\r\n    {\r\n      &quot;project&quot;: {\r\n        &quot;@basedir&quot;: &quot;.&quot;,\r\n        &quot;property&quot;: [\r\n          {\r\n            &quot;@environment&quot;: &quot;env&quot;\r\n          },\r\n          {\r\n            &quot;@name&quot;: &quot;foo&quot;,\r\n            &quot;@value&quot;: &quot;bar&quot;\r\n          },\r\n          {\r\n            &quot;@name&quot;: &quot;aaa&quot;,\r\n            &quot;@value&quot;: &quot;bbb&quot;\r\n          },\r\n          {\r\n            &quot;@name&quot;: &quot;dbUrl&quot;,\r\n            &quot;@value&quot;: &quot;123.123.123.123&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nHow can I get `123.123.123.123` using `dbUrl` with [jq](https://stedolan.github.io/jq/)?\r\n\r\nPlease don&#39;t tell me to use `jq &#39;.project.property[3][&quot;@value&quot;]&#39; test.json` to get `123.123.123.123`. \r\n\r\nBecause `{&quot;@name&quot;: &quot;dbUrl&quot;, &quot;@value&quot;: &quot;123.123.123.123&quot;}` is not guaranteed to appear on the 4th position of `property`.\r\n\r\nFor example:\r\n\r\n    {\r\n      &quot;project&quot;: {\r\n        &quot;@basedir&quot;: &quot;.&quot;,\r\n        &quot;property&quot;: [\r\n          {\r\n            &quot;@environment&quot;: &quot;env&quot;\r\n          },\r\n          {\r\n            &quot;@name&quot;: &quot;foo&quot;,\r\n            &quot;@value&quot;: &quot;bar&quot;\r\n          },\r\n          {\r\n            &quot;@name&quot;: &quot;dbUrl&quot;,\r\n            &quot;@value&quot;: &quot;123.123.123.123&quot;\r\n          },\r\n          {\r\n            &quot;@name&quot;: &quot;aaa&quot;,\r\n            &quot;@value&quot;: &quot;bbb&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nIn this case, `jq &#39;.project.property[3][&quot;@value&quot;]&#39; test.json` doesn&#39;t return `123.123.123.123`. It returns `bbb`.",
        "link": "https://stackoverflow.com/questions/51516041/how-to-get-the-value-of-value-in-a-json-array-whose-name-is-dburl-using",
        "title": "How to get the value of `@value` in a json array whose `@name` is `dbUrl` using jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1532543333,
                "creation_date": 1532543333,
                "answer_id": 51525508,
                "question_id": 51525419,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to *extract* only the one block:\r\n\r\n    jq --arg id ami-77777777 &#39;.ImportImageTasks[] | select(.ImageId==$id)&#39;\r\n\r\nIf you want to *filter* the blocks, and return a document with the same form but all other `ImageImportTask` blocks removed:\r\n\r\n    jq --arg id ami-77777777 &#39;.ImportImageTasks |= [.[] | select(.ImageId==$id)]&#39;",
                "title": "How can I filter a block of data out of a big JSON output by value using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1532543333,
        "creation_date": 1532542961,
        "question_id": 51525419,
        "body_markdown": "When I run this command to get the status on an image import:\r\n\r\n    aws ec2 describe-import-image-tasks\r\n\r\nI&#39;m presented with the following example JSON, but these are all the images I&#39;ve imported:\r\n\r\n    {\r\n    &quot;ImportImageTasks&quot;: [\r\n        {\r\n            &quot;Architecture&quot;: &quot;x86_64&quot;,\r\n            &quot;ImageId&quot;: &quot;ami-99999999&quot;,\r\n            &quot;ImportTaskId&quot;: &quot;import-ami-00000000&quot;,\r\n            &quot;LicenseType&quot;: &quot;BYOL&quot;,\r\n            &quot;Platform&quot;: &quot;Linux&quot;,\r\n            &quot;Status&quot;: &quot;completed&quot;\r\n        },\r\n        {\r\n            &quot;Architecture&quot;: &quot;x86_64&quot;,\r\n            &quot;ImageId&quot;: &quot;ami-88888888&quot;,\r\n            &quot;ImportTaskId&quot;: &quot;import-ami-11111111&quot;,\r\n            &quot;LicenseType&quot;: &quot;BYOL&quot;,\r\n            &quot;Platform&quot;: &quot;Linux&quot;,\r\n            &quot;Status&quot;: &quot;completed&quot;\r\n        },\r\n        {\r\n            &quot;Architecture&quot;: &quot;x86_64&quot;,\r\n            &quot;ImageId&quot;: &quot;ami-77777777&quot;,\r\n            &quot;ImportTaskId&quot;: &quot;import-ami-22222222&quot;,\r\n            &quot;LicenseType&quot;: &quot;BYOL&quot;,\r\n            &quot;Platform&quot;: &quot;Linux&quot;,\r\n            &quot;Status&quot;: &quot;completed&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nI would only like the block that matches the ImageId I specify. Like so:\r\n\r\n    {\r\n        &quot;Architecture&quot;: &quot;x86_64&quot;,\r\n        &quot;ImageId&quot;: &quot;ami-77777777&quot;,\r\n        &quot;ImportTaskId&quot;: &quot;import-ami-22222222&quot;,\r\n        &quot;LicenseType&quot;: &quot;BYOL&quot;,\r\n        &quot;Platform&quot;: &quot;Linux&quot;,\r\n        &quot;Status&quot;: &quot;completed&quot;\r\n    }\r\n\r\n How can I do this with JQ?",
        "link": "https://stackoverflow.com/questions/51525419/how-can-i-filter-a-block-of-data-out-of-a-big-json-output-by-value-using-jq",
        "title": "How can I filter a block of data out of a big JSON output by value using JQ?"
    },
    {
        "tags": [
            "bash",
            "shell",
            "curl",
            "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": 1532579150,
                "post_id": 51530795,
                "comment_id": 90029775,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1469313,
                    "reputation": 6319,
                    "user_id": 1381266,
                    "user_type": "registered",
                    "accept_rate": 46,
                    "profile_image": "https://www.gravatar.com/avatar/7ac54c032c1dd24a5e6c737d06b83a03?s=256&d=identicon&r=PG",
                    "display_name": "Galet",
                    "link": "https://stackoverflow.com/users/1381266/galet"
                },
                "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": 1532582032,
                "post_id": 51530795,
                "comment_id": 90030505,
                "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": 1532582724,
                "post_id": 51530795,
                "comment_id": 90030745,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1532595496,
                "creation_date": 1532595496,
                "answer_id": 51534888,
                "question_id": 51530795,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What about:\r\n\r\n    if [ $status  = 200 ]; then\r\n      if [ -f $response ]; then\r\n        local name=$(cat $response | jq -r .name)\r\n        if [ $name = &quot;John&quot; ]; then\r\n          local address=$(cat $response | jq -r .address)\r\n          # Process response\r\n        else\r\n          # Error name is not John\r\n        fi\r\n      else\r\n        # Error no response file\r\n      fi\r\n    else\r\n       # Error status not 200\r\n    fi\r\n\r\nYou can add more condition - key &quot;name&quot; is present, &quot;address&quot; is present, ... If you dont&#39;t want to handle errors, just remove the else section",
                "title": "How to handle errors in parsing the curl response using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1532595496,
        "creation_date": 1532577607,
        "question_id": 51530795,
        "body_markdown": " \r\n\r\n       local response=response.json\r\n        local status=$(curl -s -w %{http_code} &quot;http://www.google.com&quot; -o $response)\r\n        \r\n        local name=$(cat $response | jq -r .name)\r\n        local address=$(cat $response | jq -r .address)\r\n        if [ $status  = 200 ] &amp;&amp; [ $name = &quot;John&quot; ]; then\r\n           # Process response\r\n        else\r\n           # Error\r\n        fi\r\n\r\nI am processing more requests using the above approach. All the requests fails with the above scenario\r\n\r\nIf there is a invalid URL, response.json is not available. I am getting error as below 2 times as I have parsed the $response 2 times\r\n\r\n    response.json not found, No such file or directory\r\n    response.json not found, No such file or directory\r\n\r\n\r\nHow can I handle these type of errors in a better way using the curl and jq?",
        "link": "https://stackoverflow.com/questions/51530795/how-to-handle-errors-in-parsing-the-curl-response-using-jq",
        "title": "How to handle errors in parsing the curl response using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1532631727,
                "post_id": 51545594,
                "comment_id": 90059437,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1532633999,
                "last_edit_date": 1532633999,
                "creation_date": 1532631652,
                "answer_id": 51545864,
                "question_id": 51545594,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### If you want the dots to be treated as nesting separators\r\n\r\nThis means letting JQ parse your `changeField` content as code; be certain it&#39;s from a trusted source. (By contrast, `changeValue` is purely passed as data out-of-band from code, preventing injection attacks no matter its contents).\r\n\r\n    inputJson=&#39;{&quot;one&quot;: {&quot;aaa&quot;: &quot;old-val&quot;}}&#39;\r\n    changeField=.one.aaa\r\n    changeValue=new-val\r\n    \r\n    jq --arg changeValue &quot;$changeValue&quot; &quot;$changeField&quot;&#39;=$changeValue&#39; &lt;&lt;&lt;&quot;$inputJson&quot;\r\n\r\n...properly emits:\r\n\r\n    {\r\n      &quot;one&quot;: {\r\n        &quot;aaa&quot;: &quot;new-val&quot;\r\n      }\r\n    }\r\n\r\n---\r\n\r\n### If you want the dots to be literal\r\n\r\n    inputJson=&#39;{&quot;.one.aaa&quot;: &quot;old-val&quot;}&#39;\r\n    changeField=.one.aaa\r\n    changeVal=new-val\r\n    jq --arg changeField &quot;$changeField&quot; \\\r\n       --arg changeValue &quot;$changeValue&quot; \\\r\n       &#39;.[$changeField]=$changeValue&#39; &lt;&lt;&lt;&quot;$inputJson&quot;\r\n\r\n...properly emits:\r\n\r\n    {\r\n      &quot;.one.aaa&quot;: &quot;new-val&quot;\r\n    }\r\n\r\n---\r\n\r\nNote that when we passed an argument in through `jq --arg`, we used single quotes in the later query referencing it to make the reference a *literal* string to the shell, and thus syntactic to `jq`.\r\n\r\nBy contrast, when we wanted data (not the reference to it) to be syntactic to `jq`, we passed the variable&#39;s expansion in double quotes at the shell layer so it was expanded before `jq` parsed it as code.\r\n",
                "title": "Taking name of field to update (not just value) from variable in calling JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1532633999,
        "creation_date": 1532630478,
        "last_edit_date": 1532632651,
        "question_id": 51545594,
        "body_markdown": "I need to support variables all around to push changes to JSON\r\n\r\n    changeField=.one.aaa\r\n    changeValue=new-val\r\n\r\nThis works:\r\n\r\n    jq --arg changeValue $changeValue &quot;.one.aaa = \\&quot;$changeValue\\&quot;&quot; some.json\r\n\r\nThis does not:\r\n\r\n    jq --arg changeField $changeField --arg changeValue $changeValue &quot;$changeField = \\&quot;$changeValue\\&quot;&quot; some.json\r\n\r\nI&#39;ve tried every combination of `[{(` Google shows me, but nothing is working. What am I missing here?\r\n",
        "link": "https://stackoverflow.com/questions/51545594/taking-name-of-field-to-update-not-just-value-from-variable-in-calling-jq",
        "title": "Taking name of field to update (not just value) from variable in calling JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1532697297,
                "post_id": 51558701,
                "comment_id": 90084314,
                "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": 1532698482,
                "post_id": 51558701,
                "comment_id": 90085009,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user5971350"
                },
                "reply_to_user": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1532710434,
                "post_id": 51558701,
                "comment_id": 90091601,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1532729792,
                "post_id": 51558701,
                "comment_id": 90099132,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1533232928,
                "last_edit_date": 1533232928,
                "creation_date": 1532713413,
                "answer_id": 51563052,
                "question_id": 51558701,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following produces the output as originally requested:\r\n\r\n    (.wireless[].name) as $name\r\n    | .address[]\r\n    | select(.interface == $name)\r\n    | { wireless: {name: $name, address}}\r\n\r\nHowever the above filter could potentially produce more than one result, so you might want to make modifications accordingly.\r\n\r\n## Revised revised requirements\r\n\r\nIf your jq has `INDEX/2` (which was only made available AFTER jq 1.5 was released), you can simply use it to create a lookup table:\r\n\r\n    (INDEX(.address[]; .interface)) as $dict\r\n    | {name,\r\n       version,\r\n       wireless: (.wireless\r\n                  | map(. + {address: ($dict[.name]|.address) }) ) }\r\n\r\nOr (depending perhaps on the exact requirements):\r\n\r\n    (INDEX(.address[]; .interface)) as $dict\r\n    | del(.address)\r\n    | .wireless |= map(. + {address: ($dict[.name]|.address) })\r\n\r\nIf your jq does not have `INDEX/2`, then you could easily adapt the above (using `reduce`), or even more easily snarf the def of `INDEX/2` from https://github.com/stedolan/jq/blob/master/src/builtin.jq\r\n\r\n",
                "title": "jq - Find a JSON object based on one of its values and get another value from it"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1533304057,
        "creation_date": 1532697102,
        "last_edit_date": 1533304057,
        "question_id": 51558701,
        "body_markdown": "I&#39;ve started using jq just very recently and I would like to know if something like this is even possible.\r\n\r\nExample:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;device&quot;,\r\n      &quot;version&quot;: &quot;1.0.0&quot;,\r\n      &quot;address&quot;: [\r\n        {\r\n          &quot;address&quot;: &quot;10.1.2.3&quot;,\r\n          &quot;interface&quot;: &quot;wlan1_wifi&quot;\r\n        },\r\n        {\r\n          &quot;address&quot;: &quot;10.1.2.5&quot;,\r\n          &quot;interface&quot;: &quot;wlan2_link&quot;\r\n        },\r\n        {\r\n          &quot;address&quot;: &quot;10.1.2.4&quot;,\r\n          &quot;interface&quot;: &quot;ether1&quot;\r\n        }\r\n      ],\r\n      &quot;wireless&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;wlan1_wifi&quot;,\r\n          &quot;type&quot;: &quot;5Ghz&quot;,\r\n          &quot;ssid&quot;: &quot;wifi&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;wlan2_link&quot;,\r\n          &quot;type&quot;: &quot;2Ghz&quot;,\r\n          &quot;ssid&quot;: &quot;link&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nFirstly let&#39;s transform the example to this json object:\r\n\r\n    cat json | jq &#39;. | {&quot;name&quot;: .&quot;name&quot;, &quot;version&quot;: .&quot;version&quot;, &quot;wireless&quot;: [.&quot;wireless&quot;[] | {&quot;name&quot;: .&quot;name&quot;, &quot;type&quot;: .&quot;type&quot;, &quot;ssid&quot;: .&quot;ssid&quot;}]}&#39;\r\n    {\r\n      &quot;name&quot;: &quot;device&quot;,\r\n      &quot;version&quot;: &quot;1.0.0&quot;,\r\n      &quot;wireless&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;wlan1_wifi&quot;,\r\n          &quot;type&quot;: &quot;5Ghz&quot;,\r\n          &quot;ssid&quot;: &quot;wifi&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;wlan2_link&quot;,\r\n          &quot;type&quot;: &quot;2Ghz&quot;,\r\n          &quot;ssid&quot;: &quot;link&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nNow there&#39;s a problem. I need to assign an address to the `&quot;wireless&quot;` array. The address is stored in `&quot;address&quot;` array.\r\n\r\n**So the question: is there a way of finding the right json object in `&quot;address&quot;` based on `&quot;name&quot;` (in wireless array) and &quot;`interface&quot;` (in address array) for every json object in `&quot;wireless&quot;` array and then assigning `&quot;address&quot;` to it?**\r\n\r\nThe final result should look like this:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;device&quot;,\r\n      &quot;version&quot;: &quot;1.0.0&quot;,\r\n      &quot;wireless&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;wlan1_wifi&quot;,\r\n          &quot;type&quot;: &quot;5Ghz&quot;,\r\n          &quot;ssid&quot;: &quot;wifi&quot;,\r\n          &quot;address&quot;: &quot;10.1.2.3&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;wlan2_link&quot;,\r\n          &quot;type&quot;: &quot;2Ghz&quot;,\r\n          &quot;ssid&quot;: &quot;link&quot;,\r\n          &quot;address&quot;: &quot;10.1.2.5&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n**Answer:**\r\nHere&#39;s my answer based on the &lt;a href=&quot;https://stackoverflow.com/a/51563052/5971350&quot;&gt;answer&lt;/a&gt; from @peak. Instead of copying the content of `.wireless` and then using `map`, I&#39;m  cherry picking the keys that I want to include only. This also allows me to position &quot;address&quot; how ever I want.\r\n\r\n    (INDEX(.address[]; .interface)) as $dict \r\n    | {name: .name, version: .version, \r\n    wireless: [.wireless[] | {name, address: ($dict[.name]|.address), type, ssid}]}\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51558701/jq-find-a-json-object-based-on-one-of-its-values-and-get-another-value-from-it",
        "title": "jq - Find a JSON object based on one of its values and get another value from it"
    },
    {
        "tags": [
            "json",
            "sorting",
            "unix",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 914842,
                    "reputation": 27155,
                    "user_id": 1135424,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/rvwBS.jpg?s=256",
                    "display_name": "nbari",
                    "link": "https://stackoverflow.com/users/1135424/nbari"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1532757270,
                "post_id": 51562538,
                "comment_id": 90103197,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1532714031,
                "creation_date": 1532714031,
                "answer_id": 51563184,
                "question_id": 51562538,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input, the filter\r\n\r\n    ( {c}, {a} )\r\n    | to_entries[]\r\n    | &quot;\\(.key) \\(.value)&quot;\r\n\r\nproduces the desired output (you will probably want to use the -r command-line option).\r\n\r\nIf the ordering of keys you want is specified by an array,\r\n$a, then you could write:\r\n\r\n    . as $in\r\n    | $a[]\r\n    | &quot;\\(.) \\($in[.])&quot;\r\n\r\nEtc.",
                "title": "jq: print only specific keys and values in order"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1532785132,
        "creation_date": 1532711020,
        "last_edit_date": 1532785132,
        "question_id": 51562538,
        "body_markdown": "Say I have the following JSON:\r\n\r\n`{&quot;a&quot;: 1, &quot;b&quot;: 2&quot;, &quot;c&quot;: 3}`\r\n\r\nUsing `jq` and maybe Unix, I want to get the following output:\r\n\r\n\r\n    c 3\r\n    a 1\r\n\r\nTwo things going - first, I am printing only two keys and values, and I am ordering in the way I want.\r\n\r\nI know how to print keys and values, and even only some, but I can&#39;t seem to order them in the way I want (not alphabetical or algorithmic sort).\r\n\r\n    ",
        "link": "https://stackoverflow.com/questions/51562538/jq-print-only-specific-keys-and-values-in-order",
        "title": "jq: print only specific keys and values in order"
    },
    {
        "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": 1,
                "creation_date": 1532722649,
                "post_id": 51564898,
                "comment_id": 90096873,
                "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": 1532722882,
                "post_id": 51564898,
                "comment_id": 90096950,
                "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": 1532722898,
                "post_id": 51564898,
                "comment_id": 90096956,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1532722543,
                "last_edit_date": 1532722543,
                "creation_date": 1532722440,
                "answer_id": 51564957,
                "question_id": 51564898,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You may use this script:\r\n\r\n    #!/bin/bash\r\n    \r\n    input=&#39;[{&quot;field&quot;:&quot;fieldA&quot;,&quot;bucket&quot;:[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]},{&quot;field&quot;:&quot;fieldB&quot;,&quot;bucket&quot;:[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;]}]&#39;\r\n    \r\n    output=&quot;$(jq -r &#39;.[]|{field, bucketText: .bucket|join(&quot;, &quot;)}|join(&quot; found in bucket: &quot;)&#39; &lt;&lt;&lt; &quot;$input&quot;)&quot;\r\n    \r\n    printf &quot;%s\\n&quot; &quot;$output&quot;\r\n\r\n**Output:**\r\n\r\n    fieldA found in bucket: a, b, c\r\n    fieldB found in bucket: a, b, c, d\r\n\r\n**Suggested changes:**\r\n\r\n- No need to escape double quote inside single quoted `jq` commands\r\n- Recommended to use lowercase variables instead of all uppercase\r\n- Avoid pipeline and use here-string in `jq` command to avoid unnecessary sub-shell creation",
                "title": "Escape jq query and save output in a bash variable"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1532722543,
        "creation_date": 1532722136,
        "question_id": 51564898,
        "body_markdown": "I am trying to save the output of the following command in a bash variable in a script. But no matter how hard i try, i am unable to escape the quotes correctly.\r\n\r\nHere is the command whose output i want to save in a variable.\r\n\r\n\t$ echo &#39;[{&quot;field&quot;:&quot;fieldA&quot;,&quot;bucket&quot;:[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]},{&quot;field&quot;:&quot;fieldB&quot;,&quot;bucket&quot;:[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;]}]&#39; | jq -r &#39;.[]|{field, bucketText: .bucket|join(&quot;, &quot;)}|join(&quot; found in bucket: &quot;)&#39;\r\n\tfieldA found in bucket: a, b, c\r\n\tfieldB found in bucket: a, b, c, d\r\n\r\n\r\nAnd here is my attempt in my script file\r\n\r\n\r\n\r\n\t#!/bin/bash\r\n\r\n\tINPUT=&#39;[{&quot;field&quot;:&quot;fieldA&quot;,&quot;bucket&quot;:[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]},{&quot;field&quot;:&quot;fieldB&quot;,&quot;bucket&quot;:[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;]}]&#39;\r\n\r\n\tOUTPUT_LINES=&quot;$(echo ${INPUT} | jq -r &#39;.[]|{field, bucketText: .bucket|join(\\&quot;, \\&quot;)}|join(\\&quot; found in bucket: \\&quot;)&#39;)&quot;\r\n\r\n\tprintf &quot;%s\\n&quot; &quot;${OUTPUT_LINES}&quot;",
        "link": "https://stackoverflow.com/questions/51564898/escape-jq-query-and-save-output-in-a-bash-variable",
        "title": "Escape jq query and save output in a bash variable"
    },
    {
        "tags": [
            "json",
            "nested",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1532743516,
                "creation_date": 1532743516,
                "answer_id": 51567437,
                "question_id": 51566939,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your sample JSON as input, the following invocation:\r\n\r\n    jq &#39;{id, name: .attributes.name }&#39; input.json\r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;152471393&quot;,\r\n      &quot;name&quot;: &quot;Crazy&quot;\r\n    }\r\n\r\nThe filter above is short for:\r\n\r\n    {&quot;id&quot; : .id, &quot;name&quot;: .attributes.name }\r\n\r\nIn any case, the keys must be appropriately specified.\r\n\r\nFor future reference, when asking questions on stackoverflow.com, please adhere to the  http://stackoverflow.com/help/mcve guidelines as much as possible. \r\n\r\n",
                "title": "JQ newbie trouble selecting nested keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1532804531,
        "creation_date": 1532736727,
        "last_edit_date": 1532804531,
        "question_id": 51566939,
        "body_markdown": "Hi I am new to JQ and Json. I am using \r\n\r\n$ jq --version\r\njq-1.5\r\n\r\n\r\nI am having a heck of a time trying to figure out how to select the values for id, attributes.name, attributes.albumName, and attributes.artistName\r\n\r\nI am using the terminal app on a mac. I am running into some sort strange parsing problem\r\n\r\n    $ jq &#39;.results.songs.data[0] | {id, attributes.name } &#39; t\r\n    jq: error: syntax error, unexpected FIELD, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .results.songs.data[0] | {id, attributes.name }                                         \r\n    jq: 1 compile error\r\n    $ \r\n\r\nThis example shows the structure of the data I am trying to filter looks like\r\n\r\n        $ jq &#39;.results.songs.data[0] | {id, attributes } &#39; t\r\n    {\r\n      &quot;id&quot;: &quot;152471393&quot;,\r\n      &quot;attributes&quot;: {\r\n        &quot;previews&quot;: [\r\n          {\r\n            &quot;url&quot;: &quot;https://audio-ssl.itunes.apple.com/apple-assets-us-std-000001/AudioPreview71/v4/7d/c5/68/7dc56849-29b8-bd90-2bb1-51750e479569/mzaf_4742389090778091050.plus.aac.p.m4a&quot;\r\n          }\r\n        ],\r\n        &quot;artwork&quot;: {\r\n          &quot;width&quot;: 1449,\r\n          &quot;height&quot;: 1449,\r\n          &quot;url&quot;: &quot;https://is5-ssl.mzstatic.com/image/thumb/Music/v4/7d/01/56/7d0156be-12cd-8724-a0ca-727b1013a81d/source/{w}x{h}bb.jpeg&quot;,\r\n          &quot;bgColor&quot;: &quot;ddcfc4&quot;,\r\n          &quot;textColor1&quot;: &quot;010100&quot;,\r\n          &quot;textColor2&quot;: &quot;422f10&quot;,\r\n          &quot;textColor3&quot;: &quot;2d2a27&quot;,\r\n          &quot;textColor4&quot;: &quot;614f34&quot;\r\n        },\r\n        &quot;artistName&quot;: &quot;Gnarls Barkley&quot;,\r\n        &quot;url&quot;: &quot;https://itunes.apple.com/us/album/crazy/152471339?i=152471393&quot;,\r\n        &quot;discNumber&quot;: 1,\r\n        &quot;genreNames&quot;: [\r\n          &quot;Alternative&quot;,\r\n          &quot;Music&quot;,\r\n          &quot;R&amp;B/Soul&quot;,\r\n          &quot;Rock&quot;,\r\n          &quot;Soul&quot;,\r\n          &quot;Hip-Hop/Rap&quot;,\r\n          &quot;Rap&quot;,\r\n          &quot;Hip-Hop&quot;,\r\n          &quot;Adult Alternative&quot;,\r\n          &quot;Neo-Soul&quot;,\r\n          &quot;Alternative Rap&quot;,\r\n          &quot;Underground Rap&quot;\r\n        ],\r\n        &quot;durationInMillis&quot;: 178387,\r\n        &quot;releaseDate&quot;: &quot;2006-03-13&quot;,\r\n        &quot;name&quot;: &quot;Crazy&quot;,\r\n        &quot;isrc&quot;: &quot;USAT20611041&quot;,\r\n        &quot;albumName&quot;: &quot;St. Elsewhere&quot;,\r\n        &quot;playParams&quot;: {\r\n          &quot;id&quot;: &quot;152471393&quot;,\r\n          &quot;kind&quot;: &quot;song&quot;\r\n        },\r\n        &quot;trackNumber&quot;: 2\r\n      }\r\n    }\r\n\r\n\r\nThanks\r\n\r\nAndy\r\n",
        "link": "https://stackoverflow.com/questions/51566939/jq-newbie-trouble-selecting-nested-keys",
        "title": "JQ newbie trouble selecting nested keys"
    },
    {
        "tags": [
            "variables",
            "scope",
            "global-variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1532893529,
                "last_edit_date": 1532893529,
                "creation_date": 1532882852,
                "answer_id": 51582484,
                "question_id": 51582008,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In jq, the scoping of variables is defined lexically. With `f` defined as `$a`, `f` can only be evaluated as `$a` if `$a` is &quot;visible&quot; to `f`.  This can be achieved, for example, using one of the command-line options such as —arg or —argjson.\r\n\r\nIt can also be achieved as illustrated by:\r\n\r\n    jq -n &#39;2 as $a | def f: $a; f&#39;\r\n\r\nNote also that lexical scoping works with sub-functions as well:\r\n\r\n    def f($a): def g: $a; g;\r\n    f(1)\r\n\r\nyields:\r\n\r\n    1",
                "title": "Do jq&#39;s variable bindings work through functions?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1532895358,
        "creation_date": 1532879400,
        "last_edit_date": 1532895358,
        "question_id": 51582008,
        "body_markdown": "I have the following script for [jq][1]:\r\n\r\n    $ jq -n &#39;def f: $a; 1 as $a | $a&#39;\r\n    1\r\n\r\nSince `f` is not used, this outputs `1` as expected.  However:\r\n\r\n    $ jq -n &#39;def f: $a; 1 as $a | f&#39;\r\n    jq: error: a/0 is not defined at &lt;top-level&gt;, line 1:\r\n    def f: $a; 1 as $a | f\r\n    jq: 1 compile error\r\n\r\nIs it not possible to use variable bindings through functions?\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/\r\n",
        "link": "https://stackoverflow.com/questions/51582008/do-jqs-variable-bindings-work-through-functions",
        "title": "Do jq&#39;s variable bindings work through functions?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3568038,
                    "reputation": 637,
                    "user_id": 2979081,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/qyP3y.png?s=256",
                    "display_name": "Theofanis",
                    "link": "https://stackoverflow.com/users/2979081/theofanis"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1532958694,
                "post_id": 51595356,
                "comment_id": 90156867,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 3568038,
                    "reputation": 637,
                    "user_id": 2979081,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/qyP3y.png?s=256",
                    "display_name": "Theofanis",
                    "link": "https://stackoverflow.com/users/2979081/theofanis"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1532970569,
                "post_id": 51595356,
                "comment_id": 90164062,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1532959536,
                "last_edit_date": 1532959536,
                "creation_date": 1532959081,
                "answer_id": 51595661,
                "question_id": 51595356,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unwind your situation a bit:\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    $ jq --arg args &#39;&quot;abc&quot;,&quot;efg&quot;&#39; &#39;.[&quot;filename&quot;] += [$args]&#39; &lt;&lt;&lt; &#39;{&quot;filename&quot;:[]}&#39;\r\n    {\r\n      &quot;filename&quot;: [\r\n        &quot;\\&quot;abc\\&quot;,\\&quot;efg\\&quot;&quot;\r\n      ]\r\n    }\r\n\r\nHere, we are effectively assigning `args` to a string in the `jq` engine:\r\n\r\n&lt;!-- language: javascript --&gt;\r\n\r\n    args = &quot;\\&quot;abc\\&quot;,\\&quot;efg\\&quot;&quot;\r\n\r\nIf you want set `args` to a list/array, then you&#39;ll need to take another approach.\r\n\r\n---\r\n\r\nYou could either format a JSON argument and use `--argjson`:\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    $ jq --argjson args &#39;[&quot;abc&quot;,&quot;efg&quot;]&#39; &#39;.[&quot;filename&quot;] += $args&#39; &lt;&lt;&lt; &#39;{&quot;filename&quot;:[]}&#39;\r\n    {\r\n      &quot;filename&quot;: [\r\n        &quot;abc&quot;,\r\n        &quot;efg&quot;\r\n      ]\r\n    }\r\n\r\n---\r\n\r\nOr you could make `update_list` into an array, and loop:\r\n\r\n&lt;!-- language: bash --&gt;\r\n\r\n    update_list=()\r\n    update_list+=(&quot;abc&quot;)\r\n    update_list+=(&quot;efg&quot;)\r\n    \r\n    echo &#39;{&quot;filename&quot;:[]}&#39; &gt; test\r\n    \r\n    for i in &quot;${update_list[@]}&quot;; do\r\n        jq --arg update_item &quot;${i}&quot; &#39;.[&quot;filename&quot;] += [ $update_item ]&#39; &lt; test \\\r\n            | sponge test\r\n    done\r\n    \r\n&lt;!-- language: none --&gt;\r\n\r\n    $ cat test\r\n    {\r\n      &quot;filename&quot;: [\r\n        &quot;abc&quot;,\r\n        &quot;efg&quot;\r\n      ]\r\n    }\r\n\r\n",
                "title": "adding item to json using bash variable with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1532997479,
                "last_edit_date": 1532997479,
                "creation_date": 1532982943,
                "answer_id": 51601921,
                "question_id": 51595356,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the original question, `update_list` is a comma-separated listing of quoted strings, and the following solution would work if these strings are also JSON strings:\r\n\r\n    jq --arg args &quot;$update_list&quot; &#39;\r\n      .[&quot;filename&quot;] += ($args|split(&quot;,&quot;)|map(fromjson))&#39;\r\n\r\n## update_list variants\r\nIf `update_list` can be made available as a JSON array, then @Attie&#39;s first solution would be the way to go. \r\n\r\nHowever if `update_list` is a bash array, the solution involving one call to jq per array element is unnecessarily (and might be embarrassingly) inefficient; the suggested solution might also create problems because the update is not atomic.  There are far better alternatives.  For example, the [jq FAQ][1] mentions a technique which, when applied to the present problem, yields the following solution:\r\n\r\n    jq --argjson args &quot;$(printf &#39;%s\\n&#39; &quot;${update_list[@]}&quot; | jq -nR &#39;[inputs]&#39;)&quot; &#39;\r\n     .[&quot;filename&quot;] += $args&#39; \r\n\r\nOr for robustness, one could use NUL as the delimiter:\r\n\r\n    jq --argjson args &quot;$(printf &#39;%s\\0&#39; &quot;${update_list[@]}&quot; | jq -sR &#39;split(&quot;\\u0000&quot;)&#39;)&quot; &#39;\r\n     .[&quot;filename&quot;] += $args&#39;\r\n\r\nSee also https://stackoverflow.com/questions/49184557/jq-convert-bash-array-to-json-array-and-insert-to-file\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "adding item to json using bash variable with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1532997479,
        "creation_date": 1532958150,
        "last_edit_date": 1532970132,
        "question_id": 51595356,
        "body_markdown": "I am trying to use bash to create a string variable that will be used in jq to add new elements to the json file. But it&#39;s escaping my double quote. See below for &quot;wrong output&quot; produced. I am expecting the output shown below &quot;expected output&quot;. What is the correct way to add more fields to filename with bash variable?\r\n\r\nMy input json file (input.json):\r\n\r\n    {\r\n      &quot;##_Comment1&quot;: &quot;Inputs&quot;,\r\n      &quot;filename&quot;: [\r\n        &quot;file1&quot;,\r\n        &quot;file2&quot;,\r\n        &quot;file3&quot;,\r\n        &quot;file4&quot;\r\n      ]\r\n    }\r\n\r\nMy bash script:\r\n\r\n    #!/bin/bash\r\n    update_list=&#39;&quot;abc&quot;,&quot;efg&quot;&#39;\r\n    \r\n    cat input.json | jq --arg args &quot;$update_list&quot; &#39;.[&quot;filename&quot;] += [$args]&#39;\r\n\r\nwrong output:\r\n\r\n    {\r\n      &quot;##_Comment1&quot;: &quot;Inputs&quot;,\r\n      &quot;filename&quot;: [\r\n        &quot;file1&quot;,\r\n        &quot;file2&quot;,\r\n        &quot;file3&quot;,\r\n        &quot;file4&quot;,\r\n        &quot;\\&quot;abc\\&quot;,\\&quot;efg\\&quot;&quot;\r\n      ]\r\n    }\r\n\r\n\r\ncorrect output:\r\n\r\n    {\r\n      &quot;##_Comment1&quot;: &quot;Inputs&quot;,\r\n      &quot;filename&quot;: [\r\n        &quot;file1&quot;,\r\n        &quot;file2&quot;,\r\n        &quot;file3&quot;,\r\n        &quot;file4&quot;,\r\n        &quot;abc&quot;,\r\n        &quot;efg&quot;\r\n      ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51595356/adding-item-to-json-using-bash-variable-with-jq",
        "title": "adding item to json using bash variable with jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 14063913,
                    "reputation": 27,
                    "user_id": 10159248,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c9b285e0b38a54e3522ebf68149dd7d6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "paoloschi",
                    "link": "https://stackoverflow.com/users/10159248/paoloschi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1533029606,
                "post_id": 51609844,
                "comment_id": 90184814,
                "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": 1533035477,
                "post_id": 51609844,
                "comment_id": 90188689,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14063913,
                    "reputation": 27,
                    "user_id": 10159248,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c9b285e0b38a54e3522ebf68149dd7d6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "paoloschi",
                    "link": "https://stackoverflow.com/users/10159248/paoloschi"
                },
                "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": 1533044345,
                "post_id": 51609844,
                "comment_id": 90194791,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1533053255,
                "creation_date": 1533053255,
                "answer_id": 51617720,
                "question_id": 51609844,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After modifying your db.json and new.json to make them valid JSON, and adding the following filter to a file (update.jq):\r\n\r\n    reduce range(0;length) as $i (.;\r\n      .[$i].foo += $new[$i].foo )\r\n\r\nthe following invocation:\r\n\r\n    jq --argfile new new.json -f update.jq db.json\r\n\r\nproduces:\r\n\r\n    [\r\n      {\r\n        &quot;foo&quot;: {\r\n          &quot;key_1&quot;: &quot;value_1.1&quot;,\r\n          &quot;key_2&quot;: &quot;value_1.2&quot;,\r\n          &quot;key_n&quot;: &quot;value_N.3&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;foo&quot;: {\r\n          &quot;key_1&quot;: &quot;value_2.1&quot;,\r\n          &quot;key_2&quot;: &quot;value_2.2&quot;,\r\n          &quot;key_n&quot;: &quot;value_N.3&quot;\r\n        }\r\n      }\r\n    ]",
                "title": "How add a new {key:value} per array element merging others identically structured JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1533053898,
        "creation_date": 1533028852,
        "last_edit_date": 1533053898,
        "question_id": 51609844,
        "body_markdown": "The current JSON database, the file `db.json`, is structured as:\r\n\r\n    [\r\n      {\r\n        &quot;foo&quot;: {\r\n          &quot;key_1&quot;: &quot;value_1.1&quot;,\r\n          &quot;key_2&quot;: &quot;value_2.1&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;foo&quot;: {\r\n          &quot;key_1&quot;: &quot;value_1.2&quot;,\r\n          &quot;key_2&quot;: &quot;value_2.2&quot;\r\n        }\r\n      },\r\n      ...\r\n    ]\r\n\r\nSo simply. The number of total elements in the array can vary.\r\nI want to join the key that lies in several identically structured documents, the file `new.json`:\r\n\r\n    [\r\n      {\r\n        &quot;foo&quot;: {\r\n          &quot;key_n&quot;: &quot;value_1.N&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;foo&quot;: {\r\n          &quot;key_n&quot;: &quot;value_2.N&quot;\r\n        }\r\n      },\r\n      ...\r\n    ]\r\n\r\nwhere the array in each JSON to be added certainly has the same number of elements present in the current database and where each &quot;entry&quot; element:  \r\n- it certainly contains no more than one single key.   \r\n- with certainty the key and its string value is always present.  \r\n- with certainty the key has a unique name compared to the keys already present in the database.  \r\n\r\nTherefore, after each jq execution, the expected result will be the addition to the database of the new key in the corresponding array element: \r\n\r\n    [\r\n      {\r\n        &quot;foo&quot;: {\r\n          &quot;key_1&quot;: &quot;value_1.1&quot;,\r\n          &quot;key_2&quot;: &quot;value_1.2&quot;,\r\n          &quot;key_n&quot;: &quot;value_1.N&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;foo&quot;: {\r\n          &quot;key_1&quot;: &quot;value_2.1&quot;,\r\n          &quot;key_2&quot;: &quot;value_2.2&quot;,\r\n          &quot;key_n&quot;: &quot;value_2.N&quot;\r\n        }\r\n      },\r\n      ...\r\n    ]\r\n\r\n\r\nI use linux and want to do this with jq from a bash script.\r\nMy linux distribution provides jq 1.5 stable release (16 Aug 2015).\r\n  \r\nI have the feeling of asking something of trivial already extensively covered but I assure you: for two days now I have been applying the answers found in other very similar questions and I have not succeeded...\r\n\r\nI can insert a new key with this technique which I found in many other _stack overflow_ responses about merging:\r\n  \r\n    jq -s --argfile db db.json &#39;map(reduce . as $new ({}; $db[] * $new[]))&#39; new.json\r\n\r\nbut in this way only the last element remains in my `db.json` file..    \r\n\r\n    [\r\n      {\r\n        &quot;foo&quot;: {\r\n          &quot;key_1&quot;: &quot;value_2.1&quot;,\r\n          &quot;key_2&quot;: &quot;value_2.2&quot;,\r\n          &quot;key_n&quot;: &quot;value_2.N&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\nwhile with the `+` operator:\r\n \r\n    jq -s --argfile db db.json &#39;reduce . as $new ({}; $db + $new)&#39; new.json \r\n\r\nthe merging of the elements, as expected, is not achieved..\r\n\r\n    [\r\n      {\r\n        &quot;foo&quot;: {\r\n          &quot;key_1&quot;: &quot;value_1.1&quot;,\r\n          &quot;key_2&quot;: &quot;value_1.2&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;foo&quot;: {\r\n          &quot;key_1&quot;: &quot;value_2.1&quot;,\r\n          &quot;key_2&quot;: &quot;value_2.2&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;foo&quot;: {\r\n          &quot;key_n&quot;: &quot;value_1.N&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;foo&quot;: {\r\n          &quot;key_n&quot;: &quot;value_2.N&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\n\r\n__RESULT UPDATE__  \r\nuhu, it seems that this command that I&#39;ve just now tried does all the work correctly:\r\n\r\n    jq -s --argfile db db.json &#39;map($db[] * .[]) | unique_by(.foo)&#39; new.json\r\n\r\n`unique_by(.foo)` removes all recursion duplicates that I would have using the `*` operator only..  \r\nDoes this seem to you a consistent technique to solve my question?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51609844/how-add-a-new-keyvalue-per-array-element-merging-others-identically-structure",
        "title": "How add a new {key:value} per array element merging others identically structured JSON with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1533051216,
                "post_id": 51616832,
                "comment_id": 90199679,
                "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": 4,
                "creation_date": 1533054508,
                "post_id": 51616832,
                "comment_id": 90201658,
                "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": 1533054547,
                "post_id": 51616832,
                "comment_id": 90201676,
                "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": 3,
                "creation_date": 1533054695,
                "post_id": 51616832,
                "comment_id": 90201761,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3058116,
                    "reputation": 269,
                    "user_id": 2591350,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://graph.facebook.com/650453706/picture?type=large",
                    "display_name": "Oren Ashkenazy",
                    "link": "https://stackoverflow.com/users/2591350/oren-ashkenazy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1533062155,
                "post_id": 51616832,
                "comment_id": 90205445,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1533068378,
                "last_edit_date": 1533068378,
                "creation_date": 1533052476,
                "answer_id": 51617502,
                "question_id": 51616832,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[EDIT: This response has been revised in accordance with clarification of the question.]\r\n\r\nUse: \r\n\r\n    echo &quot;$output&quot;\r\n\r\nIf your `bash` has `mapfile`, it might also be worthwhile considering creating `output` as a bash array:\r\n\r\n    mapfile -t output &lt; &lt;(jq  &#39;.[] | &quot;\\(.name) \\(.status)&quot;&#39; &lt;&lt;&lt; &quot;$input&quot; )\r\n    printf &quot;%s\\n&quot; &quot;${output[@]}&quot;\r\n\r\n",
                "title": "How to split iterations to new lines in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1533088002,
        "creation_date": 1533050400,
        "last_edit_date": 1533088002,
        "question_id": 51616832,
        "body_markdown": "[NOTE: The question has been clarified in accordance with the comments, some of which might therefore be outdated.]\r\n\r\nI&#39;m using jq to parse the following JSON:\r\n\r\n    [{\r\n    \t&quot;type&quot;: &quot;A&quot;,\r\n    \t&quot;id&quot;: &quot;A&quot;,\r\n    \t&quot;name&quot;: &quot;A&quot;,\r\n    \t&quot;message&quot;: &quot;OK&quot;,\r\n    \t&quot;updateDate&quot;: &quot;2018-07-31T10:55:14.813Z&quot;,\r\n    \t&quot;createDate&quot;: &quot;2018-07-31T08:01:32.164Z&quot;,\r\n    \t&quot;status&quot;: &quot;ACTIVE&quot;\r\n    }, {\r\n    \t&quot;type&quot;: &quot;B&quot;,\r\n    \t&quot;id&quot;: &quot;B&quot;,\r\n    \t&quot;name&quot;: &quot;B&quot;,\r\n    \t&quot;message&quot;: &quot;OK&quot;,\r\n    \t&quot;updateDate&quot;: &quot;2018-07-31T10:55:16.803Z&quot;,\r\n    \t&quot;createDate&quot;: &quot;2018-07-31T08:01:34.171Z&quot;,\r\n    \t&quot;status&quot;: &quot;ACTIVE&quot;\r\n    }, {\r\n    \t&quot;type&quot;: &quot;C&quot;,\r\n    \t&quot;id&quot;: &quot;C&quot;,\r\n    \t&quot;name&quot;: &quot;C&quot;,\r\n    \t&quot;message&quot;: &quot;OK&quot;,\r\n    \t&quot;updateDate&quot;: &quot;2018-07-31T10:55:18.607Z&quot;,\r\n    \t&quot;createDate&quot;: &quot;2018-07-31T08:01:37.181Z&quot;,\r\n    \t&quot;status&quot;: &quot;ACTIVE&quot;\r\n    }, {\r\n    \t&quot;type&quot;: &quot;D&quot;,\r\n    \t&quot;id&quot;: &quot;D&quot;,\r\n    \t&quot;name&quot;: &quot;D&quot;,\r\n    \t&quot;message&quot;: &quot;OK&quot;,\r\n    \t&quot;updateDate&quot;: &quot;2018-07-31T10:55:20.877Z&quot;,\r\n    \t&quot;createDate&quot;: &quot;2018-07-31T08:01:38.185Z&quot;,\r\n    \t&quot;status&quot;: &quot;ACTIVE&quot;\r\n    }, {\r\n    \t&quot;type&quot;: &quot;E&quot;,\r\n    \t&quot;id&quot;: &quot;E&quot;,\r\n    \t&quot;name&quot;: &quot;E&quot;,\r\n    \t&quot;message&quot;: &quot;OK&quot;,\r\n    \t&quot;updateDate&quot;: &quot;2018-07-31T10:55:18.615Z&quot;,\r\n    \t&quot;createDate&quot;: &quot;2018-07-31T08:01:44.207Z&quot;,\r\n    \t&quot;status&quot;: &quot;ACTIVE&quot;\r\n    }, {\r\n    \t&quot;type&quot;: &quot;F&quot;,\r\n    \t&quot;id&quot;: &quot;F&quot;,\r\n    \t&quot;name&quot;: &quot;F&quot;,\r\n    \t&quot;message&quot;: &quot;OK&quot;,\r\n    \t&quot;updateDate&quot;: &quot;2018-07-31T10:55:19.131Z&quot;,\r\n    \t&quot;createDate&quot;: &quot;2018-07-31T08:01:44.207Z&quot;,\r\n    \t&quot;status&quot;: &quot;ACTIVE&quot;\r\n    }, {\r\n    \t&quot;type&quot;: &quot;G&quot;,\r\n    \t&quot;id&quot;: &quot;G&quot;,\r\n    \t&quot;name&quot;: &quot;G&quot;,\r\n    \t&quot;message&quot;: &quot;OK&quot;,\r\n    \t&quot;updateDate&quot;: &quot;2018-07-31T10:55:18.326Z&quot;,\r\n    \t&quot;createDate&quot;: &quot;2018-07-31T08:01:46.212Z&quot;,\r\n    \t&quot;status&quot;: &quot;ACTIVE&quot;\r\n    }]\r\n\r\nTo display the name and the status I use the following commands, where `$input` holds the above JSON:\r\n\r\n    output=$(jq &#39;.[] | &quot;\\(.name) \\(.status)&quot;&#39; &lt;&lt;&lt; &quot;$input&quot;)\r\n    echo $output\r\n\r\nThis produces:\r\n\r\n    &quot;A: ACTIVE&quot; &quot;B: ACTIVE&quot; &quot;C: ACTIVE&quot; &quot;D: ACTIVE&quot; &quot;E: ACTIVE&quot; &quot;F: ACTIVE&quot; &quot;G: ACTIVE&quot;\r\n\r\nHow do I ensure each iteration produces one new line, like so:\r\n\r\n          &quot;A: ACTIVE&quot;\r\n          &quot;B: ACTIVE&quot;\r\n          &quot;C: ACTIVE&quot; \r\n          &quot;D: ACTIVE\r\n          &quot;E: ACTIVE&quot;\r\n          &quot;F: ACTIVE&quot;\r\n          &quot;G: ACTIVE&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/51616832/how-to-split-iterations-to-new-lines-in-jq",
        "title": "How to split iterations to new lines in jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1533062409,
                "post_id": 51619317,
                "comment_id": 90205572,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1533063700,
                "creation_date": 1533063700,
                "answer_id": 51620331,
                "question_id": 51619317,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `field1`, I doubt you are getting anything in the output, since there is no key/field with the given name. If you simply change your command to `jq -s &#39;unique_by(.caller_id)&#39;` it will give you desired result containing unique &amp; sorted objects based on `caller_id` key. It will ensure in result you have atleast &amp; atmost one object for each `caller_id`.\r\n\r\nNOTE: Same as what @Jeff Mercado has explained in the comments.",
                "title": "jq to remove one of the duplicated objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1533073237,
                "last_edit_date": 1533073237,
                "creation_date": 1533072517,
                "answer_id": 51622341,
                "question_id": 51619317,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the file consists of a sequence (stream) of JSON objects, then a very simple way to produce a stream of the distinct objects would be to use the invocation:\r\n\r\n    jq -s `unique[]`\r\n\r\nA similar alternative would be:\r\n\r\n    jq -n `[inputs] | unique[]`\r\n\r\nFor large files, however, the above will probably be too inefficient, both with respect to RAM and run-time. Note that both `unique` and `unique_by` entail a sort.\r\n\r\nA far better alternative would be to take advantage of the fact that the input is a stream, and to avoid the built-in `unique` and `unique_by` filters.  This can be done with the assistance of the following filters, which are not yet built-in but likely to become so:\r\n\r\n    # emit a dictionary\r\n    def set(s): reduce s as $x ({}; .[$x | (type[0:1] + tostring)] = $x);\r\n    \r\n    # distinct entities in the stream s\r\n    def distinct(s): set(s)[];\r\n\r\nWe now have only to add:\r\n\r\n    distinct(inputs)\r\n\r\nto achieve the objective, provided jq is invoked with the -n command-line option.\r\n\r\nThis approach will also preserve the original ordering.\r\n\r\n## If the input is an array ...\r\nIf the input is an array, then using `distinct` as defined above still has the advantage of not requiring a sort.  For arrays that are too large to fit comfortably in memory, it would be advisable to use jq&#39;s streaming parser to create a stream.  \r\n\r\nOne possibility would be to proceed in two steps (`jq --stream .... | jq -n ...`), but it might be better to do everything in one step (`jq -cn --stream ...`), using the following &quot;main&quot; program:\r\n\r\n    distinct(fromstream(inputs \r\n                        | (.[0] |= .[1:] )\r\n                        | select(. != [[]]))) ",
                "title": "jq to remove one of the duplicated objects"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1533073237,
        "creation_date": 1533059585,
        "last_edit_date": 1533062615,
        "question_id": 51619317,
        "body_markdown": "I have a json file like this:\r\n\r\n    {&quot;caller_id&quot;:&quot;123321&quot;,&quot;cust_name&quot;:&quot;abc&quot;}\r\n    {&quot;caller_id&quot;:&quot;123443&quot;,&quot;cust_name&quot;:&quot;def&quot;}\r\n    {&quot;caller_id&quot;:&quot;123321&quot;,&quot;cust_name&quot;:&quot;abc&quot;}\r\n    {&quot;caller_id&quot;:&quot;234432&quot;,&quot;cust_name&quot;:&quot;ghi&quot;}\r\n    {&quot;caller_id&quot;:&quot;123321&quot;,&quot;cust_name&quot;:&quot;abc&quot;}\r\n    ....\r\n\r\nI tried: \r\n\r\n    jq -s &#39;unique_by(.field1)&#39; \r\n\r\nbut this will remove all the duplicated items, I,m looking to keep just one of the duplicated items, to get the file like this:\r\n\r\n    {&quot;caller_id&quot;:&quot;123321&quot;,&quot;cust_name&quot;:&quot;abc&quot;}\r\n    {&quot;caller_id&quot;:&quot;123443&quot;,&quot;cust_name&quot;:&quot;def&quot;}\r\n    {&quot;caller_id&quot;:&quot;234432&quot;,&quot;cust_name&quot;:&quot;ghi&quot;}\r\n    ....\r\n",
        "link": "https://stackoverflow.com/questions/51619317/jq-to-remove-one-of-the-duplicated-objects",
        "title": "jq to remove one of the duplicated objects"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3774125,
                    "reputation": 13334,
                    "user_id": 3135417,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d3b6f2aa3ec6d5dce4cbeb074db6d9ab?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Abdou",
                    "link": "https://stackoverflow.com/users/3135417/abdou"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1533061569,
                "post_id": 51619475,
                "comment_id": 90205213,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3774125,
                    "reputation": 13334,
                    "user_id": 3135417,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d3b6f2aa3ec6d5dce4cbeb074db6d9ab?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Abdou",
                    "link": "https://stackoverflow.com/users/3135417/abdou"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1533061996,
                "post_id": 51619475,
                "comment_id": 90205385,
                "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": 1533062687,
                "post_id": 51619475,
                "comment_id": 90205701,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1533062327,
                "creation_date": 1533062327,
                "answer_id": 51620016,
                "question_id": 51619475,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I see @Abdou has already given solution to this, just adding in another minified version to achieve the desired solution.\r\n\r\n&gt;jq --compact-output &#39;[.files[].name]&#39;",
                "title": "How can extract the filename from the below JSON data"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1533062327,
        "creation_date": 1533060193,
        "last_edit_date": 1533060828,
        "question_id": 51619475,
        "body_markdown": "I am new to `jq` and not sure how to go about extracting just the filenames from the below JSON file. \r\n\r\n    {\r\n      &quot;files&quot; : [ {\r\n        &quot;name&quot; : &quot;filename1.gz&quot;,\r\n        &quot;StartDate&quot; : &quot;2018-07-09T11:00:00-04:00&quot;,\r\n        &quot;EndDate&quot; : &quot;2018-07-09T12:00:00-04:00&quot;\r\n      }, {\r\n        &quot;name&quot; : &quot;filename2.gz&quot;,\r\n        &quot;StartDate&quot; : &quot;2018-07-09T10:00:00-04:00&quot;,\r\n        &quot;EndDate&quot; : &quot;2018-07-09T11:00:00-04:00&quot;\r\n      }, {\r\n        &quot;name&quot; : &quot;filename3.gz&quot;,\r\n        &quot;StartDate&quot; : &quot;2018-07-09T09:00:00-04:00&quot;,\r\n        &quot;EndDate&quot; : &quot;2018-07-09T10:00:00-04:00&quot;\r\n     }, {\r\n        &quot;name&quot; : &quot;filename4.gz&quot;,\r\n        &quot;StartDate&quot; : &quot;2018-07-09T07:00:00-04:00&quot;,\r\n        &quot;EndDate&quot; : &quot;2018-07-09T08:00:00-04:00&quot;\r\n      } ]\r\n    }\r\n\r\nexpected output:\r\n\r\n    [filename1.gz,filename2.gz,filename3.gz,filename4.gz]",
        "link": "https://stackoverflow.com/questions/51619475/how-can-extract-the-filename-from-the-below-json-data",
        "title": "How can extract the filename from the below JSON data"
    },
    {
        "tags": [
            "hadoop",
            "hadoop-yarn",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1533180779,
                "last_edit_date": 1533180779,
                "creation_date": 1533104228,
                "answer_id": 51626511,
                "question_id": 51626001,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; does anyone see a more effective way to write the JQ part\r\n\r\nFor efficiency, it would be better to make the selection before the sort.  Your filter can also be slightly simplified:\r\n\r\n      .apps.app \r\n      | map(select(.state == &quot;RUNNING&quot;))\r\n      | sort_by(.allocatedMB + .allocatedVCores * 10000) \r\n      | reverse[] \r\n      | {name, allocatedMB, allocatedVCores, user, id, trackingUrl}\r\n\r\n",
                "title": "Ranking yarn&#39;s running application by size"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1533180779,
        "creation_date": 1533102039,
        "last_edit_date": 1533102356,
        "question_id": 51626001,
        "body_markdown": "I came up with a way to list yarn&#39;s running applications by size. Because size is divided into Allocated MB and Allocated VCores I decided to assume a VCore is about 10000 MB.\r\n\r\n    # Uses httpie and jq, or you could use curl with -H Content-Type:application/json\r\n    http http://yarn-web-ui-url:port/ws/v1/cluster/apps|jq &#39;\r\n      .apps.app \r\n      | sort_by(.allocatedMB + .allocatedVCores * 10000) \r\n      | reverse \r\n      | .[] \r\n      | select(.state == &quot;RUNNING&quot;) \r\n      | {name, allocatedMB, allocatedVCores, user, id, trackingUrl}&#39; | \r\n      less\r\n\r\nBut is there some way to do this in the UI directly? And if not does anyone see a more effective way to write the JQ part.",
        "link": "https://stackoverflow.com/questions/51626001/ranking-yarns-running-application-by-size",
        "title": "Ranking yarn&#39;s running application by size"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2119809,
                    "reputation": 55131,
                    "user_id": 1883316,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/9yAAh.jpg?s=256",
                    "display_name": "Tim Roberts",
                    "link": "https://stackoverflow.com/users/1883316/tim-roberts"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1680115032,
                "post_id": 51628133,
                "comment_id": 133844406,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1533110602,
                "creation_date": 1533110602,
                "answer_id": 51628264,
                "question_id": 51628133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have to escape end of line in JSON:\r\n\r\n    {\r\n      &quot;words&quot; : &quot;one two\\nthree four five&quot;\r\n    }",
                "title": "Parse error when text is split on multi lines: &quot;control characters from U+0000 through U+001F must be escaped&quot;"
            },
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1533110613,
                "creation_date": 1533110613,
                "answer_id": 51628267,
                "question_id": 51628133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "That&#39;s because the JSON format is invalid. It should look like this:\r\n\r\n    {\r\n        &quot;words&quot; : &quot;one two \\nthree four five&quot;\r\n    }",
                "title": "Parse error when text is split on multi lines: &quot;control characters from U+0000 through U+001F must be escaped&quot;"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1533129466,
                "creation_date": 1533129466,
                "answer_id": 51634347,
                "question_id": 51628133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To convert the text with the multi-line string to valid JSON, you could use `any-json` (https://www.npmjs.com/package/any-json), and pipe that into jq:\r\n\r\n    $ any-json --input-format=cson split-string.txt\r\n    {\r\n        &quot;words&quot;: &quot;one two three four five&quot;\r\n    }\r\n    $ any-json --input-format=cson split-string.txt | jq length\r\n    1\r\n\r\nFor more on handling almost-JSON texts, see the jq FAQ: https://github.com/stedolan/jq/wiki/FAQ#processing-not-quite-valid-json\r\n",
                "title": "Parse error when text is split on multi lines: &quot;control characters from U+0000 through U+001F must be escaped&quot;"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1590881508,
                "creation_date": 1590881508,
                "answer_id": 62109900,
                "question_id": 51628133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; The parse error points to the `&quot;` at the end of the third line.\r\n\r\nThe way `jq` flags this error may be counterintuitive, but the error in the JSON *precedes* the indicated quote-mark.\r\n\r\nIf the error is non-obvious, **it may be that an end-quote is missing on the prior key or value**.  In this case, the value that matches the criteria `U+0000 through U+001F` could be `U+000A`, which is the [line feed](https://en.wikipedia.org/wiki/Newline) character in [ASCII](https://en.wikipedia.org/wiki/ASCII).\r\n\r\nIn the case of this question, the line feed was inserted intentionally.  But, unescaped, this is [invalid JSON](https://stackoverflow.com/a/27516892/86967).",
                "title": "Parse error when text is split on multi lines: &quot;control characters from U+0000 through U+001F must be escaped&quot;"
            },
            {
                "up_vote_count": 11,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1680192692,
                "last_edit_date": 1680192692,
                "creation_date": 1680114883,
                "answer_id": 75880925,
                "question_id": 51628133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "That&#39;s not valid JSON; JSON strings don&#39;t contain literal newlines. But you can do:\r\n``` sh\r\njq -Rnr &#39;[inputs] | join(&quot;\\\\n&quot;) | fromjson | .choices[0].message.content&#39; sample.json\r\n```",
                "title": "Parse error when text is split on multi lines: &quot;control characters from U+0000 through U+001F must be escaped&quot;"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1680407816,
                "creation_date": 1680407816,
                "answer_id": 75910046,
                "question_id": 51628133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "this is another option for user @randombits\r\n\r\n    cat sample.json | jq -R &#39;.&#39; | jq -s &#39;.&#39; | jq -r &#39;join(&quot;&quot;)&#39; | jq -r &#39;.choices[0].message.content&#39;",
                "title": "Parse error when text is split on multi lines: &quot;control characters from U+0000 through U+001F must be escaped&quot;"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1745426934,
                "creation_date": 1745426934,
                "answer_id": 79589102,
                "question_id": 51628133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just ran into this myself and the fix was just adding `#!/bin/bash` to the top of my script, no sophisticated `jq` needed at all (though I was glad to learn about it!)",
                "title": "Parse error when text is split on multi lines: &quot;control characters from U+0000 through U+001F must be escaped&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 7,
        "score": 18,
        "last_activity_date": 1745426934,
        "creation_date": 1533110126,
        "last_edit_date": 1680190200,
        "question_id": 51628133,
        "body_markdown": "I&#39;m getting a &quot;parse error&quot; when I split a text line on multiple lines and show the JSON file on screen with the command `jq . words.json`. \r\n\r\nThe JSON file with the text value on a single line looks like this\r\n\r\n    {\r\n        &quot;words&quot; : &quot;one two three four five&quot;\r\n    }\r\n\r\nThe command `jq . words.json` works fine and shows the JSON file on screen.\r\n\r\nBut when I split the value &quot;one two three four five&quot; on two lines and run the same command I get a parse error\r\n\r\n    {\r\n        &quot;words&quot; : &quot;one two   \r\n        three four five&quot;\r\n                       ^\r\n    }  \r\n                     \r\n\r\n\r\n&gt; parse error: Invalid string: control characters from U+0000 through\r\n&gt; U+001F must be escaped at line 3, column 20\r\n\r\nThe parse error points to the `&quot;` character at the end of the third line.\r\n\r\nHow can I solve this? \r\n",
        "link": "https://stackoverflow.com/questions/51628133/parse-error-when-text-is-split-on-multi-lines-control-characters-from-u0000-t",
        "title": "Parse error when text is split on multi lines: &quot;control characters from U+0000 through U+001F must be escaped&quot;"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1533121046,
                "creation_date": 1533121046,
                "answer_id": 51631572,
                "question_id": 51631441,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have an obvious typo in the field name that you are trying to use `vodafoneid` is not `somedomainid`. But in general to access a field having special characters like `:` in their names, do a proper quoting of the field as below.\r\n\r\n    jq --raw-output &#39;.links.&quot;urn:somedomainid:follow&quot;.href&#39;\r\n\r\n[jqplay.org - URL](https://jqplay.org/s/AhaMCazi9o)\r\n",
                "title": "Extract URL from JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1533121414,
        "creation_date": 1533120663,
        "last_edit_date": 1533120797,
        "question_id": 51631441,
        "body_markdown": "I have the following json output available and i need to extract the value of href which is the https URL using jq processor.\r\n\r\nI have tried using \r\n\r\n    jq -r .links.urn:vodafoneid:follow.hrefs\r\n\r\nHowever this does not work ?\r\n\r\nJSON Output:\r\n\r\n    {  \r\n       &quot;links&quot;:{  \r\n          &quot;urn:somedomainid:follow&quot;:{  \r\n             &quot;href&quot;:&quot;https://abc.somedomain.com/ula/login?service=IDGW&amp;channel=WEB&amp;usecaseid=a0b51311-d14b-4733-9e6b-ba5f5deec05f&amp;opco=DE&amp;nonce=89e31cde-fecc-41e1-91d6-1f9f84f9c136&amp;acr_values=explicit&amp;scopes=phone_number&amp;returnUrl=https%3A%2F%2Fidgw.somedomain.com%2Fauthorize%23state%3Da0b51311-d14b-4733-9e6b-ba5f5deec05f&quot;,\r\n             &quot;type&quot;:&quot;text/html&quot;\r\n          }\r\n       },\r\n       &quot;context&quot;:&quot;FOLLOW&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/51631441/extract-url-from-json-using-jq",
        "title": "Extract URL from JSON using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "edit",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1533229828,
                "post_id": 51658522,
                "comment_id": 90281453,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1533231076,
                "last_edit_date": 1533231076,
                "creation_date": 1533229733,
                "answer_id": 51658930,
                "question_id": 51658522,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq --arg match &quot;VAL2CHANGE&quot; \\\r\n       --arg replace &quot;VALHASBEENCHANGED&quot; \\\r\n      &#39;.Par |= map(if .Value == $match then (.Value=$replace) else . end)&#39; \\\r\n      &lt;in.json\r\n\r\nTo more comprehensively replace a string anywhere it may be in a nested data structure, you can use the `walk` function -- which will be in the standard library in jq 1.6, but can be manually pulled in in 1.5:\r\n\r\n    jq --arg match &quot;VAL2CHANGE&quot; \\\r\n       --arg replace &quot;VALHASBEENCHANGED&quot; &#39;\r\n\r\n    # taken from jq 1.6; will not be needed here after that version is released.\r\n    # Apply f to composite entities recursively, and to atoms\r\n    def walk(f):\r\n      . as $in\r\n      | if type == &quot;object&quot; then\r\n          reduce keys_unsorted[] as $key\r\n            ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n      elif type == &quot;array&quot; then map( walk(f) ) | f\r\n      else f\r\n      end;\r\n\r\n    walk(if . == $match then $replace else . end)&#39; &lt;in.json\r\n",
                "title": "Change entry in a JSON list that matches a condition without discarding rest of document"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1533262358,
                "last_edit_date": 1533262358,
                "creation_date": 1533249760,
                "answer_id": 51663092,
                "question_id": 51658522,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re just replacing based on the values, you could stream the file and replace the values as you rebuild the result.\r\n\r\n    $ jq --arg change &#39;VAL2CHANGE&#39; --arg value &#39;VALHASBEENCHANGED&#39; -n --stream &#39;\r\n    fromstream(inputs | if length == 2 and .[1] == $change then .[1] = $value else . end)\r\n    &#39; input.json",
                "title": "Change entry in a JSON list that matches a condition without discarding rest of document"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1533533882,
        "creation_date": 1533228012,
        "last_edit_date": 1533533882,
        "question_id": 51658522,
        "body_markdown": "I am trying to open a file, look through the file and change a value based on the value and pass this either to a file or var.\r\nBelow is an example of the JSON\r\n\r\n    {\r\n         &quot;Par&quot;: [\r\n             {\r\n                 &quot;Key&quot;: &quot;12345L&quot;,\r\n                 &quot;Value&quot;: &quot;https://100.100.100.100:100&quot;,\r\n                 &quot;UseLastValue&quot;: true\r\n             },\r\n             {\r\n                 &quot;Key&quot;: &quot;12345S&quot;,\r\n                 &quot;Value&quot;: &quot;VAL2CHANGE&quot;,\r\n                 &quot;UseLastValue&quot;: true\r\n             },\r\n             {\r\n                 &quot;Key&quot;: &quot;12345T&quot;,\r\n                 &quot;Value&quot;: &quot;HAPPY-HELLO&quot;,\r\n                 &quot;UseLastValue&quot;: true\r\n             }\r\n         ],\r\n          &quot;CANCOPY&quot;: false,\r\n          &quot;LOGFILE&quot;: [&quot;HELPLOG&quot;]\r\n     }\r\n\r\ni have been using jq and i have been successful in isolating the object group and change the value.\r\n\r\n     cat jsonfile,json | jq &#39;.Par | map(select(.Value==&quot;VAL2CHANGE&quot;)) | .[] | .Value=&quot;VALHASBEENCHANGED&quot;&#39;\r\n\r\nThis gives\r\n\r\n             {\r\n                 &quot;Key&quot;: &quot;12345S&quot;,\r\n                 &quot;Value&quot;: &quot;VALHASBEENCHANGED&quot;,\r\n                 &quot;UseLastValue&quot;: true\r\n             }\r\n\r\nWhat id like to achieve is to retain the full JSON output with the changed value\r\n\r\n    {\r\n         &quot;Par&quot;: [\r\n             {\r\n                 &quot;Key&quot;: &quot;12345L&quot;,\r\n                 &quot;Value&quot;: &quot;https://100.100.100.100:100&quot;,\r\n                 &quot;UseLastValue&quot;: true\r\n             },\r\n             {\r\n                 &quot;Key&quot;: &quot;12345S&quot;,\r\n                 &quot;Value&quot;: &quot;VALHASBEENCHANGED&quot;,\r\n                 &quot;UseLastValue&quot;: true\r\n             },\r\n             {\r\n                 &quot;Key&quot;: &quot;12345T&quot;,\r\n                 &quot;Value&quot;: &quot;HAPPY-HELLO&quot;,\r\n                 &quot;UseLastValue&quot;: true\r\n             }\r\n         ],\r\n          &quot;CANCOPY&quot;: false,\r\n          &quot;LOGFILE&quot;: [&quot;HELPLOG&quot;]\r\n     }\r\n\r\nI.E. \r\n\r\n    jq &#39;.Par | map(select(.Value==&quot;VAL2CHANGE&quot;)) | .[] | .Value=&quot;VALHASBEENCHANGED&quot;&#39; (NOW PUT IT BACK IN FILE)\r\n\r\nOR\r\n\r\nopen file, look in file, file value to be changed and change this and output this to a file or to screen\r\n\r\nTo add, the json file will only contain the value im looking for once as im creating this. If any other values need changing i will name differently.\r\n",
        "link": "https://stackoverflow.com/questions/51658522/change-entry-in-a-json-list-that-matches-a-condition-without-discarding-rest-of",
        "title": "Change entry in a JSON list that matches a condition without discarding rest of document"
    },
    {
        "tags": [
            "python",
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1533287568,
                "last_edit_date": 1533287568,
                "creation_date": 1533286848,
                "answer_id": 51668961,
                "question_id": 51668189,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The requirements are not entirely clear to me, but the following should be sufficient to get you on your way.\r\n\r\nPlease note that the following assumes that raw newlines appear in neither ID nor VALUES.\r\n\r\nNotice also that in the following, the first and last elements of each of the ID and VALUES arrays are the same.  This is to exercise one of the requirements.\r\n\r\n    #!/bin/bash\r\n    ID=(1 2 3 4 1)\r\n    VALUES=(&quot;/path1&quot; &quot;/path2&quot; &quot;/path3&quot; &quot;/path4&quot; &quot;/path1&quot;)\r\n    \r\n    ID=$(printf &quot;%s\\n&quot; &quot;${ID[@]}&quot;)\r\n    VALUES=$(printf &quot;%s\\n&quot; &quot;${VALUES[@]}&quot;)\r\n    \r\n    jq -n --arg id &quot;$ID&quot; --arg values &quot;$VALUES&quot; &#39;\r\n      # emit a dictionary\r\n      def set(s): reduce s as $x ({};\r\n        .[$x | (type[0:1] + tostring)] = $x);\r\n     \r\n      # distinct entities in the stream s\r\n      def distinct(s): set(s)[];\r\n    \r\n      [$id, $values]\r\n      | map( split(&quot;\\n&quot;))\r\n      | [distinct(transpose[])]\r\n      | map( {Id: .[0], Path: .[1]} )\r\n    &#39;\r\n\r\nWe use `set/1` and `distinct/1` rather than `unique` mainly to ensure that the ordering is retained as the requirements specify, but also to avoid the `sort` that `unique` entails.\r\n\r\n\r\n## Output:\r\n\r\n    [\r\n      {\r\n        &quot;Id&quot;: &quot;1&quot;,\r\n        &quot;Path&quot;: &quot;/path1&quot;\r\n      },\r\n      {\r\n        &quot;Id&quot;: &quot;2&quot;,\r\n        &quot;Path&quot;: &quot;/path2&quot;\r\n      },\r\n      {\r\n        &quot;Id&quot;: &quot;3&quot;,\r\n        &quot;Path&quot;: &quot;/path3&quot;\r\n      },\r\n      {\r\n        &quot;Id&quot;: &quot;4&quot;,\r\n        &quot;Path&quot;: &quot;/path4&quot;\r\n      }\r\n    ]",
                "title": "Check and copy values from bash array to json array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1533287568,
        "creation_date": 1533284219,
        "question_id": 51668189,
        "body_markdown": "I have two bash arrays.\r\n\r\nID=(1 2 3 4...)\r\nVALUES=(&quot;/path1&quot; &quot;/path2&quot; &quot;/path3&quot; &quot;/path4&quot;...)\r\n\r\nAnd I want to add the corresponding values to a JSON array\r\n\r\n    [\r\n    {\r\n      &quot;Id&quot;: &quot;1&quot;,\r\n      &quot;Path&quot;: &quot;/path1&quot;\r\n    },\r\n    {\r\n      &quot;Id&quot;: &quot;2&quot;,\r\n      &quot;Path&quot;: &quot;/path2&quot;\r\n    }\r\n    ...\r\n    ]\r\n\r\nBefore adding the values, I want to check if the element already exists and skip if it does. How can I go about implementing this in a bash script (or python, if that&#39;s better)",
        "link": "https://stackoverflow.com/questions/51668189/check-and-copy-values-from-bash-array-to-json-array",
        "title": "Check and copy values from bash array to json array"
    }
]