[
    {
        "tags": [
            "json",
            "linux",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 45374,
                    "reputation": 6840,
                    "user_id": 133717,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/775be355a9cf9928ee5a124dd12eaba1?s=256&d=identicon&r=PG",
                    "display_name": "NDM",
                    "link": "https://stackoverflow.com/users/133717/ndm"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1442489961,
                "post_id": 32629301,
                "comment_id": 53107894,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6488101,
                    "reputation": 331,
                    "user_id": 5022996,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/83d3cc4b590b12e0690ef9e950f4e0cb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ranjit Singh",
                    "link": "https://stackoverflow.com/users/5022996/ranjit-singh"
                },
                "reply_to_user": {
                    "account_id": 45374,
                    "reputation": 6840,
                    "user_id": 133717,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/775be355a9cf9928ee5a124dd12eaba1?s=256&d=identicon&r=PG",
                    "display_name": "NDM",
                    "link": "https://stackoverflow.com/users/133717/ndm"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1442490208,
                "post_id": 32629301,
                "comment_id": 53108054,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 45374,
                    "reputation": 6840,
                    "user_id": 133717,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/775be355a9cf9928ee5a124dd12eaba1?s=256&d=identicon&r=PG",
                    "display_name": "NDM",
                    "link": "https://stackoverflow.com/users/133717/ndm"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1442490323,
                "post_id": 32629301,
                "comment_id": 53108109,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1442492572,
                "post_id": 32629301,
                "comment_id": 53109433,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6488101,
                    "reputation": 331,
                    "user_id": 5022996,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/83d3cc4b590b12e0690ef9e950f4e0cb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ranjit Singh",
                    "link": "https://stackoverflow.com/users/5022996/ranjit-singh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1442493722,
                "post_id": 32629301,
                "comment_id": 53110148,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 15,
                "is_accepted": true,
                "score": 15,
                "last_activity_date": 1442502900,
                "last_edit_date": 1442502900,
                "creation_date": 1442502580,
                "answer_id": 32633865,
                "question_id": 32629301,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "*fromjson* is your friend:\r\n\r\n    $ jq &#39;.categoriesListArr | fromjson&#39; detail.json\r\n\r\nOr, if you want to retain the original structure:\r\n\r\n    $ jq &#39;.categoriesListArr |= fromjson&#39; detail.json\r\n\r\n",
                "title": "get json object from stringify object using jq filter in shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 9,
        "last_activity_date": 1442502900,
        "creation_date": 1442489534,
        "last_edit_date": 1442492481,
        "question_id": 32629301,
        "body_markdown": "i am wring the shell script as i am new. my query is \r\ni have json object like\r\n\r\n    {\r\n       &quot;logo&quot;: {&quot;name&quot;:&quot;logo.png&quot;,&quot;type&quot;:&quot;image\\/jpeg&quot;,&quot;tmp_name&quot;:&quot;C:\\\\xampp\\\\tmp\\\\php8B97.tmp&quot;,&quot;error&quot;:0,&quot;size&quot;:110290},\r\n       &quot;template&quot;:&quot;template1&quot;,\r\n       &quot;firstname&quot;:&quot;a&quot;,\r\n       &quot;lastname&quot;:&quot;a&quot;,\r\n       &quot;username&quot;:&quot;a&quot;,\r\n       &quot;password&quot;:&quot;aa&quot;,\r\n       &quot;email&quot;:&quot;a&quot;,\r\n       &quot;categoriesListArr&quot;:&quot;{\\&quot;Women\\&quot;:[\\&quot;All footwear\\&quot;,\\&quot;All footwear\\&quot;,\\&quot;All Clothing\\&quot;,\\&quot;All Clothing\\&quot;,\\&quot;All Watches\\&quot;,\\&quot;All Watches\\&quot;,\\&quot;All Sunglasses\\&quot;,\\&quot;All Sunglasses\\&quot;],\\&quot;Men\\&quot;:[\\&quot;All Mens Accessories\\&quot;,\\&quot;All Bags,Belts And wallets\\&quot;,\\&quot;All Fragrances\\&quot;,\\&quot;All Grooming and wellness\\&quot;]}&quot;,\r\n       &quot;aboutUs&quot;:&quot;aa&quot;,\r\n       &quot;contactUs&quot;:&quot;78787878878787&quot;,\r\n       &quot;deliveryInfo&quot;:&quot;aa&quot;,\r\n       &quot;privacyPolicy&quot;:&quot;aa&quot;,\r\n       &quot;t&amp;d&quot;:&quot;aa&quot;\r\n    }\r\n\r\ni extracted the categoriesListArr using jq filter as follows:\r\n \r\n    categories=`cat detail.json| jq &#39;.categoriesListArr&#39;`\r\n\r\ndetail.json is the name of the file.\r\nnow categories is stringify object...i need to parse it and convert it into json object. \r\n\r\n    &quot;{\\&quot;Women\\&quot;:[\\&quot;All footwear\\&quot;,\\&quot;All footwear\\&quot;,\\&quot;All Clothing\\&quot;,\\&quot;All Clothing\\&quot;,\\&quot;All Watches\\&quot;,\\&quot;All Watches\\&quot;,\\&quot;All Sunglasses\\&quot;,\\&quot;All Sunglasses\\&quot;],\\&quot;Men\\&quot;:[\\&quot;All Mens Accessories\\&quot;,\\&quot;All Bags,Belts And wallets\\&quot;,\\&quot;All Fragrances\\&quot;,\\&quot;All Grooming and wellness\\&quot;]}&quot;\r\n\r\nhow i can convert it using jq filter\r\n",
        "link": "https://stackoverflow.com/questions/32629301/get-json-object-from-stringify-object-using-jq-filter-in-shell-script",
        "title": "get json object from stringify object using jq filter in shell script"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1442738761,
                "last_edit_date": 1442738761,
                "creation_date": 1442737931,
                "answer_id": 32677378,
                "question_id": 32675229,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using `from_entries`, this worked for me:\r\n\r\n    $ jq &#39;.employees[] | {number: .number, tags: .tags | from_entries} | select(.tags.management==&quot;no&quot;) | {number: .number, name: .tags.name, login: .tags.login}&#39; input\r\n\r\n... and the output is:\r\n\r\n    {\r\n      &quot;number&quot;: &quot;102&quot;,\r\n      &quot;name&quot;: &quot;jane blogs&quot;,\r\n      &quot;login&quot;: &quot;jane&quot;\r\n    }\r\n    {\r\n      &quot;number&quot;: &quot;103&quot;,\r\n      &quot;name&quot;: &quot;john doe&quot;,\r\n      &quot;login&quot;: &quot;john&quot;\r\n    }\r\n\r\nThere may be a better way to achieve what I wanted, so I&#39;ll leave the question open for a while if someone wants to offer a better solution.\r\n",
                "title": "Using jq, how can I limit values based on a key"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1442980641,
                "creation_date": 1442980641,
                "answer_id": 32730698,
                "question_id": 32675229,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following is a slightly more succinct solution:\r\n\r\n    .employees[]\r\n    | .tags |= from_entries\r\n    | select(.tags.management == &quot;no&quot;)\r\n    | {number, &quot;name&quot;: .tags.name, &quot;login&quot;: .tags.login}\r\n\r\n\r\n\r\n    ",
                "title": "Using jq, how can I limit values based on a key"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503687390,
                "creation_date": 1503687390,
                "answer_id": 45887876,
                "question_id": 32675229,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another solution which uses [from_entries](https://github.com/stedolan/jq/blob/master/src/builtin.jq#L24)\r\n\r\n      .employees[]\r\n    | {number} + (.tags | from_entries)\r\n    | if .management == &quot;no&quot; then {number, name, login} else empty end",
                "title": "Using jq, how can I limit values based on a key"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1503687390,
        "creation_date": 1442716988,
        "question_id": 32675229,
        "body_markdown": "For an input file that looks like this:\r\n\r\n    {\r\n      &quot;employees&quot;: [\r\n        {\r\n          &quot;number&quot;: &quot;101&quot;,\r\n          &quot;tags&quot;: [\r\n            {\r\n              &quot;value&quot;: &quot;yes&quot;,\r\n              &quot;key&quot;: &quot;management&quot;\r\n            },\r\n            {\r\n              &quot;value&quot;: &quot;joe&quot;,\r\n              &quot;key&quot;: &quot;login&quot;\r\n            },\r\n            {\r\n              &quot;value&quot;: &quot;joe blogs&quot;,\r\n              &quot;key&quot;: &quot;name&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;number&quot;: &quot;102&quot;,\r\n          &quot;tags&quot;: [\r\n            {\r\n              &quot;value&quot;: &quot;no&quot;,\r\n              &quot;key&quot;: &quot;management&quot;\r\n            },\r\n            {\r\n              &quot;value&quot;: &quot;jane&quot;,\r\n              &quot;key&quot;: &quot;login&quot;\r\n            },\r\n            {\r\n              &quot;value&quot;: &quot;jane doe&quot;,\r\n              &quot;key&quot;: &quot;name&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;number&quot;: &quot;103&quot;,\r\n          &quot;tags&quot;: [\r\n            {\r\n              &quot;value&quot;: &quot;no&quot;,\r\n              &quot;key&quot;: &quot;management&quot;\r\n            },\r\n            {\r\n              &quot;value&quot;: &quot;john&quot;,\r\n              &quot;key&quot;: &quot;login&quot;\r\n            },\r\n            {\r\n              &quot;value&quot;: &quot;john doe&quot;,\r\n              &quot;key&quot;: &quot;name&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n... I&#39;d like to get details for all non-management employees so that the desired output looks like this:\r\n\r\n    {\r\n      &quot;number&quot;: &quot;102&quot;,\r\n      &quot;name&quot;: &quot;jane doe&quot;,\r\n      &quot;login&quot;: &quot;jane&quot;\r\n    }\r\n    {\r\n      &quot;number&quot;: &quot;103&quot;,\r\n      &quot;name&quot;: &quot;john doe&quot;,\r\n      &quot;login&quot;: &quot;john&quot;\r\n    }\r\n\r\nI can&#39;t figure out how to limit results based on a key without selecting that key (in this case &quot;management&quot;)",
        "link": "https://stackoverflow.com/questions/32675229/using-jq-how-can-i-limit-values-based-on-a-key",
        "title": "Using jq, how can I limit values based on a key"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1442904655,
                "creation_date": 1442904655,
                "answer_id": 32710225,
                "question_id": 32710114,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It&#39;s not really clear what you are asking.  If `$categories` contains your JSON data then you need to pipe it to `jq` somehow.  With Bash, you could use a here string:\r\n\r\n    jq keys &lt;&lt;&lt;&quot;$categories&quot;\r\n\r\nor more traditionally (and portably), a pipe:\r\n\r\n    printf &#39;%s\\n&#39; &quot;$categories&quot; | jq keys\r\n\r\nTo capture the value of the keys into a variable, use a command substitution:\r\n\r\n    keys=$(jq &#39;keys&#39; &lt;&lt;&lt;&quot;$categories&quot;)\r\n\r\n(or `` `backticks` `` like in your attempt; but the modern notation is much preferable);\r\n\r\nor better yet, obtain this value in the same way you assigned `categories` in the first place.",
                "title": "Shell script to get key value pair from JSON object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1442904664,
        "creation_date": 1442904248,
        "last_edit_date": 1442904664,
        "question_id": 32710114,
        "body_markdown": "I have a *JSON* object like \r\n\r\n     {\r\n      &quot;Men&quot;: [\r\n        &quot;All Clothing&quot;,\r\n        &quot;All Clothing&quot;,\r\n        &quot;All footwear&quot;,\r\n        &quot;All footwear&quot;,\r\n        &quot;All Watches&quot;,\r\n        &quot;All Watches&quot;,\r\n        &quot;All Sunglasses&quot;,\r\n        &quot;All Sunglasses&quot;\r\n      ],\r\n      &quot;Electronics&quot;: [\r\n        &quot;Mobiles&quot;,\r\n        &quot;Tablets&quot;,\r\n        &quot;Wearable Smart Devices&quot;,\r\n        &quot;Mobile Accessories&quot;,\r\n        &quot;Headphones and headsets&quot;,\r\n        &quot;Tablet Accessories&quot;,\r\n        &quot;Computer Accessories&quot;,\r\n        &quot;Televisions&quot;,\r\n        &quot;Large Appliances&quot;,\r\n        &quot;Small Appliances&quot;,\r\n        &quot;Kitchen Appliances&quot;,\r\n        &quot;Personal Care&quot;,\r\n        &quot;Audio and video&quot;,\r\n        &quot;Laptop&quot;\r\n      ],\r\n      &quot;Women&quot;: [\r\n        &quot;Ethnic wear&quot;,\r\n        &quot;Western wear&quot;,\r\n        &quot;Lingerie &amp; Sleep Wear&quot;,\r\n        &quot;All Bags, Belts &amp; Wallets&quot;,\r\n        &quot;All jewellery&quot;,\r\n        &quot;All Perfumes&quot;,\r\n        &quot;Spectacle Frames&quot;,\r\n        &quot;Beauty &amp; Personal Care&quot;,\r\n        &quot;The International Beauty Shop&quot;\r\n      ]\r\n    }\r\n\r\nI want to get key value pair from this object.m using jq filter but it doesnot work.\r\n\r\n    keys=`jq &#39;keys&#39; $categories`\r\n\r\n$categories is the name of variable of json object. suggestions are welcome.\r\n",
        "link": "https://stackoverflow.com/questions/32710114/shell-script-to-get-key-value-pair-from-json-object",
        "title": "Shell script to get key value pair from JSON object"
    },
    {
        "tags": [
            "json",
            "newline",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5734928,
                    "reputation": 584,
                    "user_id": 4529404,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6efe312e52d6e6cb41cb791c30811151?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dreua",
                    "link": "https://stackoverflow.com/users/4529404/dreua"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1684842488,
                "post_id": 32715008,
                "comment_id": 134573368,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 96,
                "is_accepted": false,
                "score": 96,
                "last_activity_date": 1442938224,
                "creation_date": 1442938224,
                "answer_id": 32721737,
                "question_id": 32715008,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Sure! Using the `-r` option, jq will print string contents directly to the terminal instead of as JSON escaped strings.\r\n\r\n    jq -r &#39;.stack_trace&#39;",
                "title": "JQ how to print newline and not newline character from json value"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1493713172,
                "last_edit_date": 1493713172,
                "creation_date": 1442979613,
                "answer_id": 32730564,
                "question_id": 32715008,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The input as originally given isn&#39;t quite valid JSON, and it&#39;s not clear precisely what the desired output is, but the following might be of interest.  It is written for the current version of jq (version 1.5) but could easily be adapted for jq 1.4:\r\n\r\n    def json2qjson:\r\n      def pp: if type == &quot;string&quot; then &quot;\\&quot;\\(.)\\&quot;&quot;  else . end;\r\n      . as $in\r\n      | foreach keys[] as $k (null; null; &quot;\\&quot;\\($k)\\&quot;: \\($in[$k] | pp)&quot; ) ;\r\n  \r\n\r\n    def data: {\r\n      &quot;@timestamp&quot;: &quot;2015-09-22T10:54:35.449+02:00&quot;,\r\n      &quot;@version&quot;: 1,\r\n      &quot;HOSTNAME&quot;: &quot;server1.example&quot;,\r\n      &quot;level&quot;: &quot;WARN&quot;,\r\n      &quot;level_value&quot;: 30000,\r\n      &quot;logger_name&quot;: &quot;server1.example.adapter&quot;,\r\n      &quot;message&quot;: &quot;message&quot;,\r\n      &quot;stack_trace&quot;: &quot;ERROR LALALLA\\nERROR INFO NANANAN\\nSOME MORE ERROR INFO\\nBABABABABABBA BABABABA ABABBABAA BABABABAB\\n&quot;\r\n    };\r\n\r\n    data | json2qjson\r\n\r\nOutput:\r\n\r\n    $ jq -rnf json2qjson.jq\r\n    &quot;@timestamp&quot;: &quot;2015-09-22T10:54:35.449+02:00&quot;\r\n    &quot;@version&quot;: 1\r\n    &quot;HOSTNAME&quot;: &quot;server1.example&quot;\r\n    &quot;level&quot;: &quot;WARN&quot;\r\n    &quot;level_value&quot;: 30000\r\n    &quot;logger_name&quot;: &quot;server1.example.adapter&quot;\r\n    &quot;message&quot;: &quot;message&quot;\r\n    &quot;stack_trace&quot;: &quot;ERROR LALALLA\r\n    ERROR INFO NANANAN\r\n    SOME MORE ERROR INFO\r\n    BABABABABABBA BABABABA ABABBABAA BABABABAB\r\n    &quot;\r\n",
                "title": "JQ how to print newline and not newline character from json value"
            },
            {
                "up_vote_count": 23,
                "is_accepted": false,
                "score": 23,
                "last_activity_date": 1748994120,
                "last_edit_date": 1748994120,
                "creation_date": 1458953363,
                "answer_id": 36230352,
                "question_id": 32715008,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unless you&#39;re constraint to use `jq` *only*, you can &quot;fix&quot; (or actually &quot;un-json-ify&quot;) `jq` output with `sed`:\r\n\r\n&lt;!-- language-all: shell --&gt;\r\n    cat the-input | jq . | sed &#39;s/\\\\n/\\n/g&#39;\r\n\r\nIf you happen to have tabs in the input as well (`\\t` in JSON), then:\r\n\r\n    cat the-input | jq . | sed &#39;s/\\\\n/\\n/g; s/\\\\t/\\t/g&#39;\r\n\r\nThis would be especially handy if your `stack_trace` was generated by Java (you didn&#39;t tell what is the source of the logs), as the Java stacktrace lines begin with `&lt;tab&gt;at&lt;space&gt;`.\r\n\r\nWarning: naturally, this is not *correct*, in a sense that JSON input containing `\\\\n` will result in a &quot;&lt;slash&gt;&lt;newline&gt;&quot; output, however it should result in &quot;&lt;slash&gt;n&quot; output. While not correct, it&#39;s certainly sufficient for peeking at the data by humans. The `sed` patterns can be further improved to take care for this (at the cost of readability).",
                "title": "JQ how to print newline and not newline character from json value"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 52,
        "last_activity_date": 1748994120,
        "creation_date": 1442919187,
        "last_edit_date": 1633338473,
        "question_id": 32715008,
        "body_markdown": "I have some logs that output information in JSON. This is for collection to elasticsearch.\r\n\r\nSome testers and operations people want to be able to read logs on the servers.\r\n\r\nHere is some example JSON:\r\n\r\n    {\r\n    &quot;@timestamp&quot;: &quot;2015-09-22T10:54:35.449+02:00&quot;,\r\n    &quot;@version&quot;: 1,\r\n    &quot;HOSTNAME&quot;: &quot;server1.example&quot;,\r\n    &quot;level&quot;: &quot;WARN&quot;,\r\n    &quot;level_value&quot;: 30000,\r\n    &quot;logger_name&quot;: &quot;server1.example.adapter&quot;,\r\n    &quot;message&quot;: &quot;message&quot;\r\n    &quot;stack_trace&quot;: &quot;ERROR LALALLA\\nERROR INFO NANANAN\\nSOME MORE ERROR INFO\\nBABABABABABBA BABABABA ABABBABAA BABABABAB\\n&quot;\r\n    }\r\n\r\n\r\n\r\n\r\nAnd so on.\r\n\r\nIs it possible to make Jq print newline instead of the \\n character sequence as seen in the value of `.stack_trace`?",
        "link": "https://stackoverflow.com/questions/32715008/jq-how-to-print-newline-and-not-newline-character-from-json-value",
        "title": "JQ how to print newline and not newline character from json value"
    },
    {
        "tags": [
            "json",
            "node.js",
            "jq",
            "fs",
            "jsonlines"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1032283,
                    "reputation": 16530,
                    "user_id": 1040371,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0b7fb38ae0407a97f5a342ebbcc288f7?s=256&d=identicon&r=PG",
                    "display_name": "rjz",
                    "link": "https://stackoverflow.com/users/1040371/rjz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1443049223,
                "post_id": 32750745,
                "comment_id": 53342239,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1360946,
                    "reputation": 361,
                    "user_id": 1298339,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/854ea8c1ee332fa284eee37dfc75528a?s=256&d=identicon&r=PG",
                    "display_name": "kisonay",
                    "link": "https://stackoverflow.com/users/1298339/kisonay"
                },
                "reply_to_user": {
                    "account_id": 1032283,
                    "reputation": 16530,
                    "user_id": 1040371,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0b7fb38ae0407a97f5a342ebbcc288f7?s=256&d=identicon&r=PG",
                    "display_name": "rjz",
                    "link": "https://stackoverflow.com/users/1040371/rjz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1443053163,
                "post_id": 32750745,
                "comment_id": 53343325,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 18,
                "is_accepted": true,
                "score": 18,
                "last_activity_date": 1443060046,
                "last_edit_date": 1443060046,
                "creation_date": 1443058774,
                "answer_id": 32752044,
                "question_id": 32750745,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One way to convert a JSON array to a stream of newline-delimited JSON entities is to use jq with the -c option, e.g.\r\n\r\n    $ jq -c &quot;.[]&quot;\r\n\r\nInput:\r\n\r\n    [[1,2], 3, {&quot;4&quot;:5}]\r\n\r\nOutput:\r\n\r\n    [1,2]\r\n    3\r\n    {&quot;4&quot;:5}\r\n\r\nSee https://stedolan.github.io/jq",
                "title": "Converting comma delimited JSON to a newline delimited node"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1591767438,
                "creation_date": 1591767438,
                "answer_id": 62296574,
                "question_id": 32750745,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In node.js you can use the `node-jq` package to do what @peak has shown above.\r\n\r\n```\r\nvar stream = require(&#39;stream&#39;);\r\nvar fs = require(&#39;fs&#39;);\r\nconst jq = require(&#39;node-jq&#39;);\r\n\r\nvar fileName = &#39;YOUR_FILE_NAME&#39;; //e.g abc.json\r\nvar bucketName = &#39;YOUR_BUCKET NAME&#39;; // e.g gs://def\r\nvar dataStream = new stream.PassThrough();\r\n\r\n\r\nasync function formatJson() {\r\n\r\n    jq.run(&#39;.[]&#39;, fileName, {output: &#39;compact&#39;})\r\n    .then((output) =&gt; {\r\n        dataStream.push(output)\r\n        dataStream.push(null)\r\n        console.log(dataStream)    \r\n    })\r\n    .catch((err) =&gt; {\r\n        console.log(err)\r\n    })\r\n}\r\n\r\nformatJson()\r\n```\r\n\r\nI am not an experienced node person, so apologies if the code is clumsy but it works.",
                "title": "Converting comma delimited JSON to a newline delimited node"
            },
            {
                "up_vote_count": 17,
                "is_accepted": false,
                "score": 17,
                "last_activity_date": 1601122594,
                "creation_date": 1601122594,
                "answer_id": 64077574,
                "question_id": 32750745,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For anybody who is looking to a solution on how to **convert json array of objects to nd-json**. Here is the solution:\r\n\r\nInput:\r\n\r\n    const arrObj = [{\r\n      id: 1,\r\n      name: &#39;joe&#39;\r\n    }, {\r\n      id: 2,\r\n      name: &#39;ben&#39;\r\n    }, {\r\n      id: 3,\r\n      name: &#39;jake&#39;\r\n    }, {\r\n      id: 4,\r\n      name: &#39;marsh&#39;\r\n    }];\r\n    \r\n    // stringify the object and join with \\n\r\n    const ndJson = arrObj.map(JSON.stringify).join(&#39;\\n&#39;);\r\n    \r\n    console.log(ndJson);\r\n\r\nOutput:\r\n\r\n    {&quot;id&quot;:1,&quot;name&quot;:&quot;joe&quot;}\r\n    {&quot;id&quot;:2,&quot;name&quot;:&quot;ben&quot;}\r\n    {&quot;id&quot;:3,&quot;name&quot;:&quot;jake&quot;}\r\n    {&quot;id&quot;:4,&quot;name&quot;:&quot;marsh&quot;}\r\n\r\nExample **Usecase**: When importing **bulk request** from a json file to **elasticsearch**.\r\n\r\nHappy Coding :)\r\n",
                "title": "Converting comma delimited JSON to a newline delimited node"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 5,
        "last_activity_date": 1601122594,
        "creation_date": 1443048670,
        "last_edit_date": 1511302447,
        "question_id": 32750745,
        "body_markdown": "I have a JSON file which I am reading with node, modifying and saving it as a json file.\r\n\r\nI&#39;m looking to save the new json as newline delimited vs being in an array.\r\n\r\nI came across https://github.com/CrowdProcess/newline-json but don&#39;t fully understand streams. If i have the following stream setup, how can I pipe it though the parser and stringifier?\r\n\r\n    fileStream = fs.createReadStream(&#39;source.json&#39;)\r\n    writeStream = fs.createWriteStream(&#39;output.txt&#39;);\r\n\r\n    var Parser = require(&#39;newline-json&#39;).Parser;\r\n    var Stringifier = require(&#39;newline-json&#39;).Stringifier;\r\n\r\n    var parser = new Parser();\r\n    var stringifier = new Stringifier();\r\n\r\nBut running the following only outputs a blank file.\r\n\r\n    fileStream.pipe(parser).pipe(stringifier).pipe(writeStream)\r\n\r\nwhat am I missing about streams?",
        "link": "https://stackoverflow.com/questions/32750745/converting-comma-delimited-json-to-a-newline-delimited-node",
        "title": "Converting comma delimited JSON to a newline delimited node"
    },
    {
        "tags": [
            "arrays",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1443421679,
                "last_edit_date": 1443421679,
                "creation_date": 1443365356,
                "answer_id": 32809161,
                "question_id": 32809062,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To understand why you get an array of 4 elements, look at the output of the sub-shell:\r\n\r\n    cat jsonfile.json | jq &#39;.file&#39; | jq -r &#39;keys&#39;\r\n\r\nThis produces:\r\n\r\n&gt;     [\r\n&gt;       &quot;a&quot;,\r\n&gt;       &quot;b&quot;\r\n&gt;     ]\r\n\r\nEach line there becomes an element of the array -&gt; 4 lines.\r\n\r\nTry this instead:\r\n\r\n    jq -r &#39;.file | keys | .[]&#39; jsonfile.json\r\n\r\nOutput:\r\n\r\n&gt;     a\r\n&gt;     b\r\n\r\nI also simplified your original expression. (Thanks @JeffMercado!)",
                "title": "Why jq array returns length is greater than actual no of array items"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1443421679,
        "creation_date": 1443364702,
        "last_edit_date": 1443365728,
        "question_id": 32809062,
        "body_markdown": "i have a json file\r\n\r\n    {\r\n      &quot;file&quot; : {\r\n          &quot;a&quot; : 1,\r\n          &quot;b&quot; : 2\r\n        }\r\n    }\r\n\r\nI am using `jq` to count number of keys file value have in this json object.\r\n\r\nthen using on bash \r\n\r\n    arr=($(cat jsonfile.json | jq &#39;.file&#39; | jq -r &#39;keys&#39;))\r\n    echo ${#arr[@]}\r\n\r\nhere i get output 4 whereas there is only 2 keys a,b\r\n\r\nWhy is that so, and how do i get arr only have two elements `a` and `b`.?\r\n",
        "link": "https://stackoverflow.com/questions/32809062/why-jq-array-returns-length-is-greater-than-actual-no-of-array-items",
        "title": "Why jq array returns length is greater than actual no of array items"
    },
    {
        "tags": [
            "python",
            "raspberry-pi",
            "cron",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 405638,
                    "reputation": 12587,
                    "user_id": 774651,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/bdc1822747d4ffccf9c79364f734e363?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Lol4t0",
                    "link": "https://stackoverflow.com/users/774651/lol4t0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1443510947,
                "post_id": 32837827,
                "comment_id": 53510787,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1443534697,
                "creation_date": 1443534697,
                "answer_id": 32845777,
                "question_id": 32837827,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One solution would be to &quot;hardwire&quot; the pathname of jq into your call to jq.\r\n\r\nAs for why the call to os.open was but is no longer working, evidently the location of jq is no longer on the PATH at the time of the call.  Presumably this means either that the location of jq has changed, or that something has changed regarding when or how PATH is set. ",
                "title": "jq not loaded at boot (Raspbian)"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1443534697,
        "creation_date": 1443510725,
        "question_id": 32837827,
        "body_markdown": "I have a python script which uses this curl command:\r\n\r\n    stream = os.popen(&quot;curl -s &#39;http://someip/json.htm?type=devices&amp;rid=7&#39;| jq -r .result[].Data&quot;)\r\n\r\nWhen i loaded this script at the boot of my raspberrypi by the fowwlong cron\r\n    \r\n    @reboot /usr/bin/screen -dmSL elec /home/pi/domoticz/scripts/python/elec.py\r\n\r\nEverything was fine. But since few days, i have this error:\r\n\r\n    sh: 1: jq: not found\r\nIf I stop the script and restart it everything is ok.\r\n\r\nEveryone has an idea to solve that?",
        "link": "https://stackoverflow.com/questions/32837827/jq-not-loaded-at-boot-raspbian",
        "title": "jq not loaded at boot (Raspbian)"
    },
    {
        "tags": [
            "json",
            "jq",
            "har"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1443628113,
                "post_id": 32870341,
                "comment_id": 53572587,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1443631403,
                "creation_date": 1443631403,
                "answer_id": 32871503,
                "question_id": 32870341,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could use a filter like this:\r\n\r\n    [ &quot;url&quot;, &quot;content-type&quot;, &quot;content-encoding&quot; ],\r\n    (.log.entries[] | [\r\n        .request.url,\r\n        ((.response.headers[] | select(.name == &quot;Content-Type&quot;).value) // &quot;&quot;),\r\n        ((.response.headers[] | select(.name == &quot;Content-Encoding&quot;).value) // &quot;&quot;)\r\n    ])\r\n    | @csv\r\n\r\nThe key here is that for the content type and encoding, you need to perform a search for those headers separately if you want to control the order they appear.  Then from there, you just need to format it in such a way it could be output as csv.",
                "title": "Parsing HAR file to get a table of HTTP header values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1443631403,
        "creation_date": 1443627753,
        "last_edit_date": 1443628079,
        "question_id": 32870341,
        "body_markdown": "I am parsing a HAR file (chrome devtools generated) using jq. My objective is to get a &quot;table&quot; (or csv output could be nice also) with a list of the values of specific HTTP headers returned by the server, per request URL.\r\n\r\nTo get a list of all request URLs, I can do:\r\n\r\n    cat har.json | jq &#39;.log.entries[].request.url&#39;\r\n\r\nNow I would like, for each request, a column with all the URLs and the next columns with the corresponding Content-Encoding and Content-Type HTTP header values returned in the response/headers section.\r\n\r\nI managed to get the HTTP headers values with the following command:\r\n\r\n    cat har.json | jq &#39;.log.entries[].response.headers[] | select(.name==&quot;Content-Encoding&quot; or .name==&quot;Content-Type&quot;) | .value&#39;\r\n\r\nNow I would like to mix the URL and the header values. How can I do that?\r\n\r\nThere is a difficulty here because the headers may not be returned in the same order by the HTTP server.",
        "link": "https://stackoverflow.com/questions/32870341/parsing-har-file-to-get-a-table-of-http-header-values",
        "title": "Parsing HAR file to get a table of HTTP header values"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "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": 1443750465,
                "post_id": 32897445,
                "comment_id": 53627499,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1513338159,
                "last_edit_date": 1513338159,
                "creation_date": 1443751844,
                "answer_id": 32899538,
                "question_id": 32897445,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your proposed solution is fine, but if you don&#39;t mind converting the arrays of Key-Value pairs into objects, then the following can be used:\r\n\r\n    map( .Tags |= from_entries ) | group_by(.Tags.Name) \r\n\r\n\r\nThis at least makes the &quot;group_by&quot; easy to understand; furthermore, it would be easy to convert the .Tags objects back to key-value pairs (with lower-case &quot;key&quot; and &quot;value&quot;):\r\n\r\n\r\n    map( .Tags |= from_entries ) | group_by(.Tags.Name)\r\n    | map(map( .Tags |= to_entries))\r\n\r\n### Key/Value capitalization\r\n\r\nOne way to recover the capitalized Key/Value tags would be to tweak the above as follows:\r\n\r\n    def KV: map( {Key: .key, Value: .value} );\r\n    \r\n    map( .Tags |= from_entries ) | group_by(.Tags.Name)\r\n    | map(map( .Tags |= (to_entries | KV)))\r\n\r\n\r\n",
                "title": "jq group by property in array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1513338159,
        "creation_date": 1443736346,
        "last_edit_date": 1443795657,
        "question_id": 32897445,
        "body_markdown": "I have an input json document as so: \r\n\r\n    [\r\n      {\r\n        &quot;Name&quot;: &quot;one&quot;,\r\n        &quot;Tags&quot;: [\r\n          {\r\n            &quot;Key&quot;: &quot;Name&quot;,\r\n            &quot;Value&quot;: &quot;important&quot;\r\n          },\r\n          {\r\n            &quot;Key&quot;: &quot;OtherTag&quot;,\r\n            &quot;Value&quot;: &quot;irrelevant&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;Name&quot;: &quot;two&quot;,\r\n        &quot;Tags&quot;: [\r\n          {\r\n            &quot;Key&quot;: &quot;OtherTag&quot;,\r\n            &quot;Value&quot;: &quot;irrelevant2&quot;\r\n          },\r\n          {\r\n            &quot;Key&quot;: &quot;Name&quot;,\r\n            &quot;Value&quot;: &quot;important&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;Name&quot;: &quot;three&quot;,\r\n        &quot;Tags&quot;: [\r\n          {\r\n            &quot;Key&quot;: &quot;Name&quot;,\r\n            &quot;Value&quot;: &quot;important2&quot;\r\n          },\r\n          {\r\n            &quot;Key&quot;: &quot;OtherTag&quot;,\r\n            &quot;Value&quot;: &quot;irrelevant3&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nI want to use `jq` to group the three records by tag Value where the Key = &quot;Name&quot;. The result would be two arrays, one with two records in it and one with one. The array with two records would have two because both records share the same tag with a value of &quot;important&quot;. Here is what the result would look like:\r\n\r\n    [\r\n      [\r\n        {\r\n          &quot;Name&quot;: &quot;one&quot;,\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Key&quot;: &quot;Name&quot;,\r\n              &quot;Value&quot;: &quot;important&quot;\r\n            },\r\n            {\r\n              &quot;Key&quot;: &quot;OtherTag&quot;,\r\n              &quot;Value&quot;: &quot;irrelevant&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;two&quot;,\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Key&quot;: &quot;OtherTag&quot;,\r\n              &quot;Value&quot;: &quot;irrelevant2&quot;\r\n            },\r\n            {\r\n              &quot;Key&quot;: &quot;Name&quot;,\r\n              &quot;Value&quot;: &quot;important&quot;\r\n            }\r\n          ]\r\n        },\r\n      ],\r\n      [\r\n        {\r\n          &quot;Name&quot;: &quot;three&quot;,\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Key&quot;: &quot;Name&quot;,\r\n              &quot;Value&quot;: &quot;important2&quot;\r\n            },\r\n            {\r\n              &quot;Key&quot;: &quot;OtherTag&quot;,\r\n              &quot;Value&quot;: &quot;irrelevant3&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    ]\r\n\r\nI just can&#39;t figure out how to do this with `jq`. Does anyone have any ideas?",
        "link": "https://stackoverflow.com/questions/32897445/jq-group-by-property-in-array",
        "title": "jq group by property in array"
    },
    {
        "tags": [
            "jq",
            "chocolatey"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1443803546,
                "creation_date": 1443803546,
                "answer_id": 32911748,
                "question_id": 32911446,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Resolved it after reading details from the following pull-request.\r\n\r\nhttps://github.com/stedolan/jq/issues/959\r\n\r\nThe solution is to pass -version 1.5 to the install command. The following works just fine.\r\n\r\n    choco install jq --force -version 1.5",
                "title": "Error installing JQ on windows"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1443877826,
                "creation_date": 1443877826,
                "answer_id": 32922971,
                "question_id": 32911446,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "During the moderation process, even if there is a newer version of the application hosted on chocolatey.org, doing `choco install &lt;package name&gt;` will only give you the latest moderated package.\r\n\r\nHowever, if you are willing to accept the potential for a problematic package, you can always force the installation of an unmoderated package by specifying the version number in the install command, as you have done.\r\n\r\nIn this case, the unmoderated package actually fixed an issue with the moderated one, so it was safe to proceed with, but just take care when doing this, and only do it on a case by case basis, in the knowledge that an unmoderated package may actually change, based on comments which are raised during the moderation process.",
                "title": "Error installing JQ on windows"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1443877826,
        "creation_date": 1443802398,
        "question_id": 32911446,
        "body_markdown": "I have been trying to install jq using chocoletey\r\n\r\nHowever, when I run the following command, it fails. \r\n\r\n    choco install jq\r\n\r\nReading the log file, I see that it is pointing the Powershell script is pointing at a ULR that doesn&#39;t exist any more\r\n\r\n&gt; Attempt to get headers for\r\n&gt; http://stedolan.github.io/jq/download/win64/jq.exe failed.\r\n\r\nI tried update the powershell script but choco install still not working for me. Can anyone help me out please.",
        "link": "https://stackoverflow.com/questions/32911446/error-installing-jq-on-windows",
        "title": "Error installing JQ on windows"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4624068,
                    "reputation": 54457,
                    "user_id": 3748349,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ArUlH.png?s=256",
                    "display_name": "Hans Z.",
                    "link": "https://stackoverflow.com/users/3748349/hans-z"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1443947738,
                "post_id": 32931471,
                "comment_id": 53688832,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1443956665,
                "creation_date": 1443956665,
                "answer_id": 32932761,
                "question_id": 32931471,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use the alternative operator, `//`.\r\n\r\n`jq -r &#39;.Tags[] | select(.Key == &quot;Name&quot;) | .Value // &quot;N/A&quot;&#39;`",
                "title": "jq: missing JSON object detection"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1443987158,
                "creation_date": 1443987158,
                "answer_id": 32937536,
                "question_id": 32931471,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is the perfect solution from David Tolnay:\r\n\r\nhttps://github.com/stedolan/jq/issues/976\r\n\r\nQuoting it here:\r\n\r\nTry this:\r\n\r\n    jq -r &#39;.Tags | from_entries | .Name // &quot;N/A&quot;&#39;\r\n\r\nThis converts the list of key/value pairs to a map using from_entries, then picks out the &quot;Name&quot; in the map. Then it uses the &quot;alternative operator&quot; // to produce &quot;N/A&quot; if Name was not in the map.\r\n\r\nThis requires jq 1.5 in order to understand capitalized &quot;Key&quot; and &quot;Value&quot; in from_entries. If you are stuck on jq 1.4 or older, you need to explicitly convert them to lowercase:\r\n\r\n    jq -r &#39;.Tags | map({key:.Key, value:.Value}) | from_entries | .Name // &quot;N/A&quot;&#39;\r\n",
                "title": "jq: missing JSON object detection"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1443987158,
        "creation_date": 1443946888,
        "last_edit_date": 1443983921,
        "question_id": 32931471,
        "body_markdown": "My JSON data:\r\n\r\n    {\r\n      &quot;Tags&quot;: [\r\n               {  &quot;Key&quot;: &quot;Team&quot;,     &quot;Value&quot;: &quot;AA&quot; },\r\n               {  &quot;Key&quot;: &quot;Division&quot;, &quot;Value&quot;: &quot;BB&quot; },\r\n               {  &quot;Key&quot;: &quot;Name&quot;,     &quot;Value&quot;: &quot;CC&quot; }\r\n            ]\r\n    }\r\n\r\nI&#39;d like to display value of Name (&quot;CC&quot; in example above).\r\nIf this value is missing &quot;N/A&quot; should be displayed.\r\nWhat I&#39;m looking for is pure jq replacement of this jq and bash mix:\r\n\r\n    a=$( cat json | jq -r &#39;.Tags[] | select( .Key==&quot;Name&quot; ) | .Value&#39; );\r\n    if [ -z $a ]; then a=&quot;N/A&quot;; fi\r\n    echo $a\r\n\r\n",
        "link": "https://stackoverflow.com/questions/32931471/jq-missing-json-object-detection",
        "title": "jq: missing JSON object detection"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3320880,
                    "reputation": 3285,
                    "user_id": 2792096,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0d987dde42de8829bf5a04107ed5c75f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Alexander Obersht",
                    "link": "https://stackoverflow.com/users/2792096/alexander-obersht"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1443969909,
                "post_id": 32934683,
                "comment_id": 53694791,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2691224,
                    "reputation": 1086,
                    "user_id": 2324541,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FXspR.jpg?s=256",
                    "display_name": "vvs",
                    "link": "https://stackoverflow.com/users/2324541/vvs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1443970252,
                "post_id": 32934683,
                "comment_id": 53694892,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1928076,
                    "reputation": 425,
                    "user_id": 1738082,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/8RfjO.jpg?s=256",
                    "display_name": "jsphdnl",
                    "link": "https://stackoverflow.com/users/1738082/jsphdnl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1443970448,
                "post_id": 32934683,
                "comment_id": 53694962,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1443974419,
                "post_id": 32934683,
                "comment_id": 53696192,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1443988269,
                "last_edit_date": 1443988269,
                "creation_date": 1443974403,
                "answer_id": 32935440,
                "question_id": 32934683,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The shell is interpreting it as several arguments. Either quote the expansion (as in `-d &quot;$VAL&quot;`) or pipe it instead of saving it to a variable `jq &#39;...&#39; | curl ...`",
                "title": "Converting json string in a shell variable to string literal"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1443988269,
        "creation_date": 1443969716,
        "last_edit_date": 1443970430,
        "question_id": 32934683,
        "body_markdown": "I have a shell variable which contains json as follows \r\n\r\n  {\r\n    &quot;test&quot; :&quot;test&quot;,\r\n     &quot;temp&quot;:&quot;temp&quot;\r\n  }\r\n\r\nThis is a part of json that I got when parsed from jq, which is a json parser tool.But when I pass this to curl as a part of post request body, it is getting converted to\r\n\r\n       &#39;{&#39; \r\n         &#39;&quot;test&quot;&#39; &#39;:&#39; &#39;test,&#39;\r\n          &#39;&quot;temp&quot;&#39; &#39;:&#39; &#39;temp&#39;\r\n       &#39;}&#39;\r\n\r\nBut I want it as\r\n\r\n       &#39;{\r\n          &quot;test&quot; : &quot;test&quot;,\r\n          &quot;temp&quot; : &quot;temp&quot;\r\n        }&#39;\r\n\r\n    VAL=$(echo &quot;$RET&quot; | jq &quot;.pending[$j].value&quot;)\r\n\r\n  VAL is the variable that will contain the json\r\n  I need to pass this VAL as request body to curl\r\n  \r\n\r\n    curl -X POST -H &quot;$CONTENT_HEADER&quot; -H &quot;$AUTH_HEADER&quot; http://localhost:8080/testApi -d $VAL\r\n\r\n",
        "link": "https://stackoverflow.com/questions/32934683/converting-json-string-in-a-shell-variable-to-string-literal",
        "title": "Converting json string in a shell variable to string literal"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1443995860,
                "creation_date": 1443995860,
                "answer_id": 32938839,
                "question_id": 32936439,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If your input really is irredeemably a stream, and if you cannot use the slurp option, then the simplest would probably be to use jq 1.5&#39;s `inputs` filter, along the lines of:\r\n```\r\njq -n &#39;[inputs]&#39;\r\n```\r\n\r\nIf you don&#39;t use the -n option, then the first JSON entity won&#39;t be seen by `inputs`.  If you cannot use the -n option, then use `[., inputs]`",
                "title": "Stream to array convertor without slurp"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1501799372,
                "creation_date": 1501799372,
                "answer_id": 45495533,
                "question_id": 32936439,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I think all you need is to use the jq array constructor syntax.  I.e. enclose whatever complex expression you have that generates the stream in a pair of `[ ]`\r\n\r\nHere is an example.  For the sake of argument I&#39;ll use a function in place of whatever complex expression you have.  e.g.\r\n\r\n    def some_complex_expression:\r\n      {  &quot;Key&quot;: &quot;Team&quot;,     &quot;Value&quot;: &quot;AA&quot; },\r\n      {  &quot;Key&quot;: &quot;Division&quot;, &quot;Value&quot;: &quot;BB&quot; }\r\n    ;\r\n\r\nIf we just execute this expression    \r\n\r\n    some_complex_expression\r\n\r\nthe result is a stream of two objects as we expect:\r\n\r\n    {\r\n      &quot;Key&quot;: &quot;Team&quot;,\r\n      &quot;Value&quot;: &quot;AA&quot;\r\n    }\r\n    {\r\n      &quot;Key&quot;: &quot;Division&quot;,\r\n      &quot;Value&quot;: &quot;BB&quot;\r\n    }\r\n\r\nBut if we enclose the expression in `[ ]`\r\n\r\n    [ some_complex_expression ]\r\n\r\nthe result is a single array containing the objects from the stream\r\n\r\n    [\r\n      {\r\n        &quot;Key&quot;: &quot;Team&quot;,\r\n        &quot;Value&quot;: &quot;AA&quot;\r\n      },\r\n      {\r\n        &quot;Key&quot;: &quot;Division&quot;,\r\n        &quot;Value&quot;: &quot;BB&quot;\r\n      }\r\n    ]\r\n",
                "title": "Stream to array convertor without slurp"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1501799372,
        "creation_date": 1443980785,
        "last_edit_date": 1444016385,
        "question_id": 32936439,
        "body_markdown": "My JSON input:\r\n\r\n      {  &quot;Key&quot;: &quot;Team&quot;,     &quot;Value&quot;: &quot;AA&quot; }\r\n      {  &quot;Key&quot;: &quot;Division&quot;, &quot;Value&quot;: &quot;BB&quot; }\r\n\r\nDesired output:\r\n\r\n    [\r\n      {  &quot;Key&quot;: &quot;Team&quot;,     &quot;Value&quot;: &quot;AA&quot; },\r\n      {  &quot;Key&quot;: &quot;Division&quot;, &quot;Value&quot;: &quot;BB&quot; }\r\n    ]\r\n\r\nI cannot use the `--slurp` option because I&#39;m in a middle of complex jq code.\r\n\r\nThe mentioned input is a result of my function and I need to convert it to an array for further processing.\r\n\r\nThe solution recommended in FAQ: https://github.com/stedolan/jq/wiki/FAQ#general-questions\r\n\r\n    cat json | jq &#39;reduce . as $i ([]; . + [$i])&#39;\r\n\r\nproduces something different:\r\n\r\n    [\r\n      {  &quot;Key&quot;: &quot;Team&quot;,     &quot;Value&quot;: &quot;AA&quot; }\r\n    ]\r\n    [\r\n      {  &quot;Key&quot;: &quot;Division&quot;, &quot;Value&quot;: &quot;BB&quot; }\r\n    ]\r\n",
        "link": "https://stackoverflow.com/questions/32936439/stream-to-array-convertor-without-slurp",
        "title": "Stream to array convertor without slurp"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 6,
                "creation_date": 1564343253,
                "post_id": 32960857,
                "comment_id": 100989523,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 164754,
                    "reputation": 1544,
                    "user_id": 387719,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a4e134d8db4dcb849b2fad7b63ad1363?s=256&d=identicon&r=PG",
                    "display_name": "opyh",
                    "link": "https://stackoverflow.com/users/387719/opyh"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1631953216,
                "post_id": 32960857,
                "comment_id": 122366559,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 330,
                "is_accepted": false,
                "score": 329,
                "last_activity_date": 1444120318,
                "creation_date": 1444120318,
                "answer_id": 32965227,
                "question_id": 32960857,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First, obtain an array containing all the different object property names in your object array input. Those will be the columns of your CSV:\r\n\r\n    (map(keys) | add | unique) as $cols\r\n\r\nThen, for each object in the object array input, map the column names you obtained to the corresponding properties in the object. Those will be the rows of your CSV.\r\n\r\n    map(. as $row | $cols | map($row[.])) as $rows\r\n\r\nFinally, put the column names before the rows, as a header for the CSV, and pass the resulting row stream to the `@csv` filter.\r\n\r\n    $cols, $rows[] | @csv\r\n\r\nAll together now. Remember to use the `-r` flag to get the result as a raw string:\r\n\r\n    jq -r &#39;(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @csv&#39;",
                "title": "How to convert arbitrary simple JSON to CSV using jq?"
            },
            {
                "up_vote_count": 196,
                "is_accepted": false,
                "score": 196,
                "last_activity_date": 1510874810,
                "last_edit_date": 1633592092,
                "creation_date": 1444126589,
                "answer_id": 32967407,
                "question_id": 32960857,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## The Skinny\r\n\r\n    jq -r &#39;(.[0] | keys_unsorted) as $keys | $keys, map([.[ $keys[] ]])[] | @csv&#39;\r\n\r\nor:\r\n\r\n    jq -r &#39;(.[0] | keys_unsorted) as $keys | ([$keys] + map([.[ $keys[] ]])) [] | @csv&#39;\r\n\r\n\r\n## The Details\r\n\r\n### Aside\r\n\r\nDescribing the details is tricky because jq is stream-oriented, meaning it operates on a sequence of JSON data, rather than a single value. The input JSON stream gets converted to some internal type which is passed through the filters, then encoded in an output stream at program&#39;s end. The internal type isn&#39;t modeled by JSON, and doesn&#39;t exist as a named type. It&#39;s most easily demonstrated by examining the output of a bare index (`.[]`) or the comma operator (examining it directly could be done with a debugger, but that would be in terms of jq&#39;s internal data types, rather than the conceptual data types behind JSON).\r\n\r\n&lt;blockquote&gt;&lt;pre&gt;\r\n$ jq -c &#39;.[]&#39; &amp;lt;&amp;lt;&amp;lt;&#39;[&quot;a&quot;, &quot;b&quot;]&#39;\r\n&quot;a&quot;\r\n&quot;b&quot;\r\n$ jq -cn &#39;&quot;a&quot;, &quot;b&quot;&#39;\r\n&quot;a&quot;\r\n&quot;b&quot;\r\n&lt;/pre&gt;&lt;/blockquote&gt;\r\n\r\nNote that the output isn&#39;t an array (which would be `[&quot;a&quot;, &quot;b&quot;]`). Compact output (the `-c` option) shows that each array element (or argument to the `,` filter) becomes a separate object in the output (each is on a separate line).\r\n\r\nA stream is like a [JSON-seq][1], but uses newlines rather than [RS][2] as an output separator when encoded. Consequently, this internal type is referred to by the generic term &quot;sequence&quot; in this answer, with &quot;stream&quot; being reserved for the encoded input and output.\r\n\r\n### Constructing the Filter\r\n\r\nThe first object&#39;s keys can be extracted with:\r\n\r\n    .[0] | keys_unsorted\r\n\r\nKeys will generally be kept in their original order, but preserving the exact order isn&#39;t guaranteed. Consequently, they will need to be used to index the objects to get the values in the same order. This will also prevent values being in the wrong columns if some objects have a different key order.\r\n\r\nTo both output the keys as the first row and make them available for indexing, they&#39;re stored in a variable. The next stage of the pipeline then references this variable and uses the comma operator to prepend the header to the output stream.\r\n\r\n    (.[0] | keys_unsorted) as $keys | $keys, ...\r\n\r\nThe expression after the comma is a little involved. The index operator on an object can take a sequence of strings (e.g. `&quot;name&quot;, &quot;value&quot;`), returning a sequence of property values for those strings. `$keys` is an array, not a sequence, so `[]` is applied to convert it to a sequence,\r\n\r\n    $keys[]\r\n\r\nwhich can then be passed to `.[]`\r\n\r\n    .[ $keys[] ]\r\n\r\nThis, too, produces a sequence, so the array constructor is used to convert it to an array.\r\n\r\n    [.[ $keys[] ]]\r\n\r\nThis expression is to be applied to a single object. `map()` is used to apply it to all objects in the outer array:\r\n\r\n    map([.[ $keys[] ]])\r\n\r\nLastly for this stage, this is converted to a sequence so each item becomes a separate row in the output.\r\n\r\n    map([.[ $keys[] ]])[]\r\n\r\nWhy bundle the sequence into an array within the `map` only to unbundle it outside? `map` produces an array; `.[ $keys[] ]` produces a sequence. Applying `map` to the sequence from `.[ $keys[] ]` would produce an array of sequences of values, but since sequences aren&#39;t a JSON type, so you instead get a flattened array containing all the values.\r\n\r\n    [&quot;NSW&quot;,&quot;AU&quot;,&quot;state&quot;,&quot;New South Wales&quot;,&quot;AB&quot;,&quot;CA&quot;,&quot;province&quot;,&quot;Alberta&quot;,&quot;ABD&quot;,&quot;GB&quot;,&quot;council area&quot;,&quot;Aberdeenshire&quot;,&quot;AK&quot;,&quot;US&quot;,&quot;state&quot;,&quot;Alaska&quot;]\r\n\r\nThe values from each object need to be kept separate, so that they become separate rows in the final output.\r\n\r\nFinally, the sequence is passed through `@csv` formatter.\r\n\r\n### Alternate\r\n\r\nThe items can be separated late, rather than early. Instead of using the comma operator to get a sequence (passing a sequence as the right operand), the header sequence (`$keys`) can be wrapped in an array, and `+` used to append the array of values. This still needs to be converted to a sequence before being passed to `@csv`.\r\n\r\n\r\n  [1]: https://www.rfc-editor.org/rfc/rfc7464\r\n  [2]: https://en.wikipedia.org/wiki/C0_and_C1_control_codes#Field_separators",
                "title": "How to convert arbitrary simple JSON to CSV using jq?"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1444153697,
                "creation_date": 1444153697,
                "answer_id": 32976330,
                "question_id": 32960857,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I created a function that outputs an array of objects or arrays to csv with headers.  The columns would be in the order of the headers.\r\n\r\n    def to_csv($headers):\r\n        def _object_to_csv:\r\n            ($headers | @csv),\r\n            (.[] | [.[$headers[]]] | @csv);\r\n        def _array_to_csv:\r\n            ($headers | @csv),\r\n            (.[][:$headers|length] | @csv);\r\n        if .[0]|type == &quot;object&quot;\r\n            then _object_to_csv\r\n            else _array_to_csv\r\n        end;\r\n\r\nSo you could use it like so:\r\n\r\n    to_csv([ &quot;code&quot;, &quot;name&quot;, &quot;level&quot;, &quot;country&quot; ])",
                "title": "How to convert arbitrary simple JSON to CSV using jq?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1670933187,
                "last_edit_date": 1670933187,
                "creation_date": 1450161658,
                "answer_id": 34282594,
                "question_id": 32960857,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This variant of Santiago&#39;s program is also safe but ensures that the key names in\r\nthe first object are used as the first column headers, in the same order as they\r\nappear in that object:\r\n\r\n    def tocsv:\r\n      if length == 0 then empty\r\n      else\r\n        (.[0] | keys_unsorted) as $firstkeys\r\n        | (map(keys) | add | unique) as $allkeys\r\n        | ($firstkeys + ($allkeys - $firstkeys)) as $cols\r\n        | ($cols, (.[] as $row | $cols | map($row[.])))\r\n        | @csv\r\n      end ;\r\n    \r\n    tocsv\r\n    ",
                "title": "How to convert arbitrary simple JSON to CSV using jq?"
            },
            {
                "up_vote_count": 19,
                "is_accepted": false,
                "score": 18,
                "last_activity_date": 1602993575,
                "last_edit_date": 1602993575,
                "creation_date": 1494972147,
                "answer_id": 44012345,
                "question_id": 32960857,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following filter is slightly different in that it will ensure every value is converted to a string. (jq 1.5+)\r\n\r\n```shell\r\n# For an array of many objects\r\njq -f filter.jq [file]\r\n\r\n# For many objects (not within array)\r\njq -s -f filter.jq [file]\r\n```\r\n\r\n**Filter: `filter.jq`**\r\n\r\n    def tocsv:\r\n        (map(keys)\r\n            |add\r\n            |unique\r\n            |sort\r\n        ) as $cols\r\n        |map(. as $row\r\n            |$cols\r\n            |map($row[.]|tostring)\r\n        ) as $rows\r\n        |$cols,$rows[]\r\n        | @csv;\r\n    \r\n    tocsv\r\n",
                "title": "How to convert arbitrary simple JSON to CSV using jq?"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1661190192,
                "creation_date": 1661190192,
                "answer_id": 73449085,
                "question_id": 32960857,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple way is to just use string concatenation. If your input is a proper array:\r\n\r\n```\r\n# filename.txt\r\n[\r\n  {&quot;field1&quot;:&quot;value1&quot;, &quot;field2&quot;:&quot;value2&quot;},\r\n  {&quot;field1&quot;:&quot;value1&quot;, &quot;field2&quot;:&quot;value2&quot;},\r\n  {&quot;field1&quot;:&quot;value1&quot;, &quot;field2&quot;:&quot;value2&quot;}\r\n]\r\n```\r\n\r\nthen index with `.[]`:\r\n\r\n```\r\ncat filename.txt | jq -r &#39;.[] | .field1 + &quot;, &quot; + .field2&#39;\r\n```\r\n\r\nor if it&#39;s just line by line objects:\r\n\r\n```\r\n# filename.txt\r\n{&quot;field1&quot;:&quot;value1&quot;, &quot;field2&quot;:&quot;value2&quot;}\r\n{&quot;field1&quot;:&quot;value1&quot;, &quot;field2&quot;:&quot;value2&quot;}\r\n{&quot;field1&quot;:&quot;value1&quot;, &quot;field2&quot;:&quot;value2&quot;}\r\n```\r\n\r\njust do this:\r\n\r\n```\r\ncat filename.txt | jq -r &#39;.field1 + &quot;, &quot; + .field2&#39;\r\n```\r\n",
                "title": "How to convert arbitrary simple JSON to CSV using jq?"
            },
            {
                "up_vote_count": 38,
                "is_accepted": false,
                "score": 37,
                "last_activity_date": 1662959513,
                "creation_date": 1662959513,
                "answer_id": 73684729,
                "question_id": 32960857,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    $cat test.json\r\n    [\r\n        {&quot;code&quot;: &quot;NSW&quot;, &quot;name&quot;: &quot;New South Wales&quot;, &quot;level&quot;:&quot;state&quot;, &quot;country&quot;: &quot;AU&quot;},\r\n        {&quot;code&quot;: &quot;AB&quot;, &quot;name&quot;: &quot;Alberta&quot;, &quot;level&quot;:&quot;province&quot;, &quot;country&quot;: &quot;CA&quot;},\r\n        {&quot;code&quot;: &quot;ABD&quot;, &quot;name&quot;: &quot;Aberdeenshire&quot;, &quot;level&quot;:&quot;council area&quot;, &quot;country&quot;: &quot;GB&quot;},\r\n        {&quot;code&quot;: &quot;AK&quot;, &quot;name&quot;: &quot;Alaska&quot;, &quot;level&quot;:&quot;state&quot;, &quot;country&quot;: &quot;US&quot;}\r\n    ]\r\n\r\n\r\n    $ jq -r &#39;[&quot;Code&quot;, &quot;Name&quot;, &quot;Level&quot;, &quot;Country&quot;], (.[] | [.code, .name, .level, .country]) | @tsv &#39; test.json\r\n    Code\tName\tLevel\tCountry\r\n    NSW\tNew South Wales\tstate\tAU\r\n    AB\tAlberta\tprovince\tCA\r\n    ABD\tAberdeenshire\tcouncil area\tGB\r\n    AK\tAlaska\tstate\tUS\r\n\r\n\r\n    $ jq -r &#39;[&quot;Code&quot;, &quot;Name&quot;, &quot;Level&quot;, &quot;Country&quot;], (.[] | [.code, .name, .level, .country]) | @csv &#39; test.json\r\n    &quot;Code&quot;,&quot;Name&quot;,&quot;Level&quot;,&quot;Country&quot;\r\n    &quot;NSW&quot;,&quot;New South Wales&quot;,&quot;state&quot;,&quot;AU&quot;\r\n    &quot;AB&quot;,&quot;Alberta&quot;,&quot;province&quot;,&quot;CA&quot;\r\n    &quot;ABD&quot;,&quot;Aberdeenshire&quot;,&quot;council area&quot;,&quot;GB&quot;\r\n    &quot;AK&quot;,&quot;Alaska&quot;,&quot;state&quot;,&quot;US&quot;",
                "title": "How to convert arbitrary simple JSON to CSV using jq?"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1672969748,
                "creation_date": 1672969748,
                "answer_id": 75026152,
                "question_id": 32960857,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re open to using other Unix tools, [`csvkit`](https://csvkit.readthedocs.io/en/latest/) has an `in2csv` tool:\r\n\r\n```bash\r\nin2csv example.json\r\n```\r\n\r\nUsing your sample data:\r\n\r\n```bash\r\n&gt; in2csv example.json\r\ncode,name,level,country\r\nNSW,New South Wales,state,AU\r\nAB,Alberta,province,CA\r\nABD,Aberdeenshire,council area,GB\r\nAK,Alaska,state,US \r\n```\r\n\r\nI like the pipe approach for piping directly from `jq`:\r\n\r\n```bash\r\ncat example.json | in2csv -f json -\r\n```",
                "title": "How to convert arbitrary simple JSON to CSV using jq?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1689715455,
                "creation_date": 1689715455,
                "answer_id": 76716634,
                "question_id": 32960857,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a compact solution:\r\n```jq\r\n(map(keys)|add|unique)as$k|$k,(.[]|[.[$k[]]])|@csv\r\n```\r\n\r\n- `(map(keys) | add | unique) as $k` sets `$k` to all unique keys found in the array of objects\r\n- `.[$k[]]` returns the object index for all keys in `$k`\r\n- `(.[] | [ ... ])` returns an array of values for each object.",
                "title": "How to convert arbitrary simple JSON to CSV using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 9,
        "score": 247,
        "last_activity_date": 1689715455,
        "creation_date": 1444099072,
        "last_edit_date": 1547855920,
        "question_id": 32960857,
        "body_markdown": "Using [jq][1], how can arbitrary JSON encoding an array of shallow objects be converted to CSV?\r\n\r\nThere are plenty of Q&amp;As on this site that cover specific data models which hard-code the fields, but answers to this question should work given any JSON, with the only restriction that it&#39;s an array of objects with scalar properties (no deep/complex/sub-objects, as flattening these is another question). The result should contain a header row giving the field names. Preference will be given to answers that preserve the field order of the first object, but it&#39;s not a requirement. Results may enclose all cells with double-quotes, or only enclose those that require quoting (e.g. &#39;a,b&#39;).\r\n\r\n## Examples\r\n\r\n1. Input:\r\n\r\n        [\r\n            {&quot;code&quot;: &quot;NSW&quot;, &quot;name&quot;: &quot;New South Wales&quot;, &quot;level&quot;:&quot;state&quot;, &quot;country&quot;: &quot;AU&quot;},\r\n            {&quot;code&quot;: &quot;AB&quot;, &quot;name&quot;: &quot;Alberta&quot;, &quot;level&quot;:&quot;province&quot;, &quot;country&quot;: &quot;CA&quot;},\r\n            {&quot;code&quot;: &quot;ABD&quot;, &quot;name&quot;: &quot;Aberdeenshire&quot;, &quot;level&quot;:&quot;council area&quot;, &quot;country&quot;: &quot;GB&quot;},\r\n            {&quot;code&quot;: &quot;AK&quot;, &quot;name&quot;: &quot;Alaska&quot;, &quot;level&quot;:&quot;state&quot;, &quot;country&quot;: &quot;US&quot;}\r\n        ]\r\n\r\n    Possible output:\r\n\r\n        code,name,level,country\r\n        NSW,New South Wales,state,AU\r\n        AB,Alberta,province,CA\r\n        ABD,Aberdeenshire,council area,GB\r\n        AK,Alaska,state,US\r\n\r\n    Possible output:\r\n\r\n        &quot;code&quot;,&quot;name&quot;,&quot;level&quot;,&quot;country&quot;\r\n        &quot;NSW&quot;,&quot;New South Wales&quot;,&quot;state&quot;,&quot;AU&quot;\r\n        &quot;AB&quot;,&quot;Alberta&quot;,&quot;province&quot;,&quot;CA&quot;\r\n        &quot;ABD&quot;,&quot;Aberdeenshire&quot;,&quot;council area&quot;,&quot;GB&quot;\r\n        &quot;AK&quot;,&quot;Alaska&quot;,&quot;state&quot;,&quot;US&quot;\r\n\r\n2. Input:\r\n\r\n        [\r\n            {&quot;name&quot;: &quot;bang&quot;, &quot;value&quot;: &quot;!&quot;, &quot;level&quot;: 0},\r\n            {&quot;name&quot;: &quot;letters&quot;, &quot;value&quot;: &quot;a,b,c&quot;, &quot;level&quot;: 0},\r\n            {&quot;name&quot;: &quot;letters&quot;, &quot;value&quot;: &quot;x,y,z&quot;, &quot;level&quot;: 1},\r\n            {&quot;name&quot;: &quot;bang&quot;, &quot;value&quot;: &quot;\\&quot;!\\&quot;&quot;, &quot;level&quot;: 1}\r\n        ]\r\n\r\n    Possible output:\r\n\r\n        name,value,level\r\n        bang,!,0\r\n        letters,&quot;a,b,c&quot;,0\r\n        letters,&quot;x,y,z&quot;,1\r\n        bang,&quot;&quot;&quot;!&quot;&quot;&quot;,0\r\n\r\n    Possible output:\r\n\r\n        &quot;name&quot;,&quot;value&quot;,&quot;level&quot;\r\n        &quot;bang&quot;,&quot;!&quot;,&quot;0&quot;\r\n        &quot;letters&quot;,&quot;a,b,c&quot;,&quot;0&quot;\r\n        &quot;letters&quot;,&quot;x,y,z&quot;,&quot;1&quot;\r\n        &quot;bang&quot;,&quot;&quot;&quot;!&quot;&quot;&quot;,&quot;1&quot;\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/32960857/how-to-convert-arbitrary-simple-json-to-csv-using-jq",
        "title": "How to convert arbitrary simple JSON to CSV using jq?"
    },
    {
        "tags": [
            "javascript",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3579873,
                    "reputation": 21809,
                    "user_id": 2988337,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/tWpqC.jpg?s=256",
                    "display_name": "taxicala",
                    "link": "https://stackoverflow.com/users/2988337/taxicala"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1444321614,
                "post_id": 33021152,
                "comment_id": 53865138,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1206451,
                    "reputation": 171716,
                    "user_id": 1175966,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8d3d9dfbd040f9cbc1a6b82f0da2b345?s=256&d=identicon&r=PG",
                    "display_name": "charlietfl",
                    "link": "https://stackoverflow.com/users/1175966/charlietfl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1444321828,
                "post_id": 33021152,
                "comment_id": 53865249,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4125277,
                    "reputation": 81,
                    "user_id": 3384602,
                    "user_type": "registered",
                    "accept_rate": 9,
                    "profile_image": "https://www.gravatar.com/avatar/6512588299439cb6ca55f08d4613d411?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Swami",
                    "link": "https://stackoverflow.com/users/3384602/swami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1444322281,
                "post_id": 33021152,
                "comment_id": 53865483,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666128083,
                "post_id": 33021152,
                "comment_id": 130861450,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1444324492,
                "creation_date": 1444324492,
                "answer_id": 33022093,
                "question_id": 33021152,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try below one\r\n\r\n    #!/bin/bash\r\n    json=&quot;{&quot;\r\n    for f in &lt;path of directory&gt;/*.txt\r\n    do\r\n    filename=$(basename &quot;$f&quot;)\r\n    filename=&quot;${filename%.*}&quot;  \r\n    json=$json&#39;&quot;&#39;$filename&#39;&quot;&#39;&quot;: [&quot;\r\n    while IFS= read -r line; do\r\n    echo $filename\r\n    json=$json&#39;&quot;&#39;$line&#39;&quot;,&#39;\r\n    done &lt; $f  \r\n    json=&quot;${json%?}&quot;\r\n    json=$json&quot;],&quot;\r\n    done\r\n    json=&quot;${json%?}&quot;\r\n    json=$json&quot;}&quot;\r\n    echo $json",
                "title": "Create JSON file from multiple txt files"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1444342090,
                "creation_date": 1444342090,
                "answer_id": 33026754,
                "question_id": 33021152,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "jq can be used to read in multiple files using the `--slurpfile` option.  The files however _must_ be an actual json file.  Since your files aren&#39;t in a json format, you need to convert them.\r\n\r\n    $ jq -R &#39;.&#39; key1.txt &gt; /tmp/key1.json &amp;&amp; \\\r\n      jq -R &#39;.&#39; key2.txt &gt; /tmp/key2.json &amp;&amp; \\\r\n      jq --slurpfile key1 /tmp/key1.json \\\r\n         --slurpfile key2 /tmp/key2.json \\\r\n         -n &#39;{ key1: $key1, key2: $key2 }&#39;\r\n\r\nOtherwise, if you don&#39;t want to deal with temporary files, you could use a subshell to create the json arrays and pass them in using `--argjson`.\r\n\r\n    $ jq --argjson key1 &quot;$(jq -R &#39;.&#39; key1.txt | jq -s &#39;.&#39;)&quot; \\\r\n         --argjson key2 &quot;$(jq -R &#39;.&#39; key2.txt | jq -s &#39;.&#39;)&quot; \\\r\n         -n &#39;{ key1: $key1, key2: $key2 }&#39;",
                "title": "Create JSON file from multiple txt files"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666130120,
                "last_edit_date": 1666130120,
                "creation_date": 1666128422,
                "answer_id": 74117648,
                "question_id": 33021152,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use a loop to build an array of entries and then merge the loop output with a final jq invocation.\r\n\r\n```sh\r\nfor f in *.txt; do\r\n  &lt;&quot;$f&quot; jq -nR --arg key &quot;${f%.txt}&quot; &#39;{$key,value:[inputs]}&#39;;\r\ndone | jq -s &#39;from_entries&#39;\r\n```\r\n\r\nNote that this question&amp;answer is very similar to https://stackoverflow.com/questions/74055447/how-to-update-a-json-file-by-the-contents-read-from-other-files-using-jq/74056106 and https://stackoverflow.com/questions/74095381/construct-json-through-jq-tool-in-shell-script-loop/74095461.",
                "title": "Create JSON file from multiple txt files"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": -4,
        "last_activity_date": 1666130120,
        "creation_date": 1444321455,
        "question_id": 33021152,
        "body_markdown": "I have the following problem:\r\n\r\n*I want a JSON files with the keys, {&quot;key1&quot;,&quot;key2&quot;} each having several values and are written in a txt file. The txt file for each key looks like this:\r\n\r\n    key1.txt:\r\n    val1\r\n    val2\r\n    val3\r\n    ..\r\n\r\nand similar structure for key2.txt. Using these I want to create a json file that has the following structure:\r\n\r\n    {\r\n        key1:\r\n        [ &quot;val1&quot;\r\n          &quot;val2&quot;\r\n           ...\r\n        ]\r\n    \r\n        key2:\r\n        [ &quot;val1&quot;\r\n          &quot;val2&quot;\r\n           ...\r\n        ]\r\n    }\r\n\r\nI hope the question is clear. I prefer using bash to do this, if possible.",
        "link": "https://stackoverflow.com/questions/33021152/create-json-file-from-multiple-txt-files",
        "title": "Create JSON file from multiple txt files"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 551,
                "is_accepted": false,
                "score": 551,
                "last_activity_date": 1722242749,
                "last_edit_date": 1722242749,
                "creation_date": 1444511608,
                "answer_id": 33059058,
                "question_id": 33057420,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` supports the normal [Boolean operators and/or/not](https://jqlang.github.io/jq/manual/#and-or-not), so it would look like:\r\n\r\n    .[] | select((.processedBarsVolume &lt;= 5) and .processedBars &gt; 0)\r\n\r\n",
                "title": "JQ: Select multiple conditions"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1731883898,
                "last_edit_date": 1731883898,
                "creation_date": 1656056251,
                "answer_id": 72740529,
                "question_id": 33057420,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I had to wrap the piping to `startswith` with parentheses in order to make this work.\r\n\r\n&lt;!-- language: shell --&gt;\r\n    jq -n &#39;env | with_entries(select ((.key|startswith(&quot;CI_&quot;)) or .key == &quot;DOCKER_CONTAINER_VERSION_TAG&quot;))&#39;",
                "title": "JQ: Select multiple conditions"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 297,
        "last_activity_date": 1731883898,
        "creation_date": 1444501092,
        "last_edit_date": 1504595459,
        "question_id": 33057420,
        "body_markdown": "I have a json and at the moment using select to get only the data which match one condition, I need to filter based on more conditions.\r\n\r\nFor e.g:\r\n\r\n\r\n\r\n    .[] | select((.processedBarsVolume &lt;= 5) &amp;&amp; .processedBars &gt; 0)\r\n\r\nHow I can do this ?\r\n",
        "link": "https://stackoverflow.com/questions/33057420/jq-select-multiple-conditions",
        "title": "JQ: Select multiple conditions"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 39,
                "is_accepted": true,
                "score": 39,
                "last_activity_date": 1444645060,
                "creation_date": 1444645060,
                "answer_id": 33078666,
                "question_id": 33075323,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Comma is an operator in `jq`: \r\n\r\n&gt; Even the comma operator is a generator, generating first the values\r\n&gt; generated by the expression to the left of the comma, then for each of\r\n&gt; those, the values generate by the expression on the right of the\r\n&gt; comma.\r\n\r\nChanging multiple elements can be done by piping from one filter/assignment in to the next as follows:\r\n\r\n    jq --arg ts &quot;$TS&quot; &#39;.Date = $ts | .Marker.Date = $ts | .InfoFromTerminator.Timestamp = $ts&#39;\r\n",
                "title": "How to make multiple assignment of field values in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1709156812,
                "creation_date": 1709156812,
                "answer_id": 78077788,
                "question_id": 33075323,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also use comma to assign a collection of properties to the same value:\r\n\r\n    jq --arg ts &quot;$TS&quot; &#39;(.StartDate, .EndDate) = $ts&#39;\r\n\r\nThis takes the list of path references on the left-hand side and updates them all to the new value.  This can be useful when the right-hand expression is more than a simple variable.\r\n\r\nExample:\r\n\r\n    $ jq &#39;(.a, .b) = &quot;new value&quot;&#39; &lt;&lt;&lt; &#39;{&quot;a&quot;: &quot;a&quot;, &quot;b&quot;: &quot;b&quot;, &quot;c&quot;: &quot;c&quot;}&#39;\r\n    {\r\n      &quot;a&quot;: &quot;new value&quot;,\r\n      &quot;b&quot;: &quot;new value&quot;,\r\n      &quot;c&quot;: &quot;c&quot;\r\n    }\r\n\r\n",
                "title": "How to make multiple assignment of field values in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 23,
        "last_activity_date": 1709156812,
        "creation_date": 1444634367,
        "question_id": 33075323,
        "body_markdown": "I have jq command like this:\r\n\r\n    jq --arg ts &quot;$TS&quot; &#39;.Date = $ts, .Marker.Date = $ts, .InfoFromTerminator.Timestamp = $ts&#39;\r\n\r\nbut it appears to only replace the last item keeping the previous two as is. How do I rewrite the query to replace for all 3 parameters?",
        "link": "https://stackoverflow.com/questions/33075323/how-to-make-multiple-assignment-of-field-values-in-jq",
        "title": "How to make multiple assignment of field values in jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1444659690,
                "creation_date": 1444659690,
                "answer_id": 33083531,
                "question_id": 33080405,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can&#39;t really use `to_entries` here, that creates an object out of an array of key/value objects. You&#39;re trying to map a key/value object to another object. Just map it directly.\r\n\r\n    map({ (.key): .value.sub })",
                "title": "JQ: Print Key and Attribute Value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1444659690,
        "creation_date": 1444650604,
        "last_edit_date": 1444650695,
        "question_id": 33080405,
        "body_markdown": "I&#39;ve been trying to print a key and attribute value so given this JSON\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;foo&quot;,\r\n        &quot;value&quot;: { &quot;sub&quot; : false}\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;bar&quot;,\r\n        &quot;value&quot;: { &quot;sub&quot; : true}\r\n      }\r\n    ]\r\n\r\nI want to return something like this:\r\n\r\n    [\r\n      {\r\n        &quot;foo&quot;: &quot;false&quot;\r\n      },\r\n      {\r\n        &quot;bar&quot;: &quot;true&quot;\r\n      }\r\n    ]\r\n\r\nI&#39;m using to_entries to do this but when I feed the JSON into JQ though I can&#39;t seem to access it correctly? I get an error:  \r\n\r\n&gt; jq: error (at &lt;stdin&gt;:9): Cannot index array with string &quot;key&quot;\r\n\r\n[This test case][1] simplifies the behaviour\r\n\r\n\r\n  [1]: https://jqplay.org/jq?q=to_entries&amp;j=%7B%22a%22%3A%201%2C%20%22b%22%3A%202%7D",
        "link": "https://stackoverflow.com/questions/33080405/jq-print-key-and-attribute-value",
        "title": "JQ: Print Key and Attribute Value"
    },
    {
        "tags": [
            "json",
            "debugging",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1444692420,
                "creation_date": 1444692420,
                "answer_id": 33091780,
                "question_id": 33091762,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "cut the file into more lines with\r\n\r\n    cat nodes.json|cut -f 1- -d} --output-delimiter=$&#39;}\\n&#39;&gt;/tmp/a.json\r\n\r\nand analyse `/tmp/a.json` with, then you get an error with line nr:\r\n\r\n&gt;parse error: Invalid literal at line 5995, column 47\r\n\r\nuse `less -N /tmp/a.json` to find that line  ",
                "title": "Debug a large json file that is in one line"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1445265986,
                "creation_date": 1445265986,
                "answer_id": 33217423,
                "question_id": 33091762,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I see you are on a shell prompt. So you could try perl, because your operating system has it pre-installed, presumably.\r\n\r\n    cat nodes.json | json_xs -f json -t json-pretty\r\n\r\nThis tells the json_xs command line program to parse the file and prettify it.\r\n\r\nIf you don&#39;t have json_xs installed, you could try json_pp (pp is for pure-perl).\r\n\r\nIf you have neither, you must install the JSON::XS perl module with this command:\r\n\r\n    sudo cpanm JSON::XS\r\n    [sudo] password for knb: \r\n    --&gt; Working on JSON::XS\r\n    Fetching http://www.cpan.org/authors/id/M/ML/MLEHMANN/JSON-XS-3.01.tar.gz ... OK\r\n    Configuring JSON-XS-3.01 ... OK\r\n    Building and testing JSON-XS-3.01 ... OK\r\n    Successfully installed JSON-XS-3.01 (upgraded from 2.34)\r\n    1 distribution installed\r\n\r\nThis installs JSON::XS and a few helper scripts, among them json_xs and json_pp. \r\n\r\nThen you can run this simple one-liner:\r\n\r\n    cat dat.json | json_xs -f json -t json-pretty\r\n\r\nAfter misplacing a parenthesis to force a nesting-error somewhere in the valid json file dat.json I got this:\r\n\r\n    cat dat.json | json_xs -f json -t json-pretty\r\n    &#39;&quot;&#39; expected, at character offset 1331 (before &quot;{&quot;A_DESC&quot;:&quot;density i...&quot;) at /usr/local/bin/json_xs line 181, &lt;STDIN&gt; line 1.\r\n\r\nMaybe this is more informative than the jq output. \r\n",
                "title": "Debug a large json file that is in one line"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1445265986,
        "creation_date": 1444692260,
        "last_edit_date": 1444733987,
        "question_id": 33091762,
        "body_markdown": "I have a 2MB json file that is only **all in one line** and now I get an error using `jq`:\r\n\r\n    $ jq .&lt;nodes.json\r\n\r\n    parse error: Invalid literal at line 1, column 377140\r\n\r\nHow do I debug this on the console? To look at the mentioned column, I tried this:\r\n\r\n    head -c 377139 nodes.json|tail -c 1000\r\n\r\nBut I cannot find any error with a wrong `t` there, so it seems it is not the correct way to reach the position in the file.\r\n\r\nHow can I debug such a one-liner?",
        "link": "https://stackoverflow.com/questions/33091762/debug-a-large-json-file-that-is-in-one-line",
        "title": "Debug a large json file that is in one line"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1444761678,
                "last_edit_date": 1444761678,
                "creation_date": 1444753337,
                "answer_id": 33107799,
                "question_id": 33107524,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Once you format is like your question, you can use `itertools.groupby` to group by the opening bracket, join the lines with str.join and use json.loads to get a dict, then it is simply a matter of accessing by key and writing the updated data to a tempfile. Finally using `shutil.move` to replace the original file, if you want a brand new file just change the `NamedTemporaryFile` to using `open`: \r\n\r\n    from tempfile import NamedTemporaryFile\r\n    from shutil import move\r\n    from itertools import groupby\r\n    \r\n    import json\r\n    \r\n    with open(&quot;in.txt&quot;) as f, NamedTemporaryFile(&quot;w&quot;, dir=&quot;.&quot;,delete=False) as out:\r\n        for k, v in groupby(f, key=lambda x: x.lstrip().startswith(&quot;{&quot;)):\r\n            if not k:\r\n                d = json.loads(&quot;{&quot; + &quot;&quot;.join(v))\r\n                v = d[&quot;metatag.eprints.citation&quot;]\r\n                d[&quot;metatag.eprints.citation&quot;] = v[:v.find(&quot;)&quot;)+1]\r\n                json.dump(d, out)\r\n                out.write(&quot;\\n&quot;)\r\n    move(out.name,&quot;in.txt&quot;)\r\n\r\nin.txt before:\r\n\r\n    {\r\n        &quot;url&quot;:&quot;http://example.com/10618/&quot;,\r\n        &quot;metatag.eprints.publication&quot;:&quot;Journal of Corporate Real Estate&quot;,\r\n        &quot;metatag.eprints.title&quot;:&quot;Corporate Real Estate Strategy&quot;,\r\n        &quot;metatag.eprints.citation&quot;:&quot;Adair, P, McGrogan, WS, and Webb, JR (2006) Corporate Real Estate Strategy. Journal of Corporate Real Estate&quot;}\r\n    {\r\n        &quot;url&quot;:&quot;http://example.com/23552/&quot;,\r\n        &quot;metatag.eprints.publication&quot;:&quot;European Journal of Cardio-Thoracic Surgery&quot;,\r\n        &quot;metatag.eprints.title&quot;:&quot;Long-term survival from coronary endarterectomies in coronary artery disease&quot;,\r\n        &quot;metatag.eprints.citation&quot;:&quot;Aaron, P, Jones, K, Pallin, C, and Nash, R (2012) Long-term survival from coronary endarterectomies in coronary artery disease. European Journal of Cardio-Thoracic Surgery&quot;}\r\n        \r\nin.txt after:\r\n\r\n    {&quot;url&quot;: &quot;http://example.com/10618/&quot;, &quot;metatag.eprints.publication&quot;: &quot;Journal of Corporate Real Estate&quot;, &quot;metatag.eprints.citation&quot;: &quot;Adair, P, McGrogan, WS, and Webb, JR (2006)&quot;, &quot;metatag.eprints.title&quot;: &quot;Corporate Real Estate Strategy&quot;}\r\n    {&quot;url&quot;: &quot;http://example.com/23552/&quot;, &quot;metatag.eprints.publication&quot;: &quot;European Journal of Cardio-Thoracic Surgery&quot;, &quot;metatag.eprints.citation&quot;: &quot;Aaron, P, Jones, K, Pallin, C, and Nash, R (2012)&quot;, &quot;metatag.eprints.title&quot;: &quot;Long-term survival from coronary endarterectomies in coronary artery disease&quot;}\r\n\r\n\r\nIf you have to edit it at a later date you can simply loop over the file and `json.loads` each line to get a dict, update with the key again and write to the file. Having one per line will make your life much easier.\r\n\r\nIf you can have an opening paren before the date you can use a regex to search for the specific substring, 4 digits between parens:\r\n\r\n\r\n    r = re.compile(&quot;\\(\\d{4}\\)&quot;)\r\n    for k, v in groupby(f, key=lambda x: x.lstrip().startswith(&quot;{&quot;)):\r\n        if not k:\r\n            d = json.loads(&quot;{&quot; + &quot;&quot;.join(v))\r\n            v = d[&quot;metatag.eprints.citation&quot;]\r\n            d[&quot;metatag.eprints.citation&quot;] = v[:next(r.finditer(v)).end()]\r\n            json.dump(d, out)\r\n            out.write(&quot;\\n&quot;)\r\n\r\nIf you are getting an empty file then your data must actually be one dict per line so it is just a matter of iterating over the file object and applying the same logic:\r\n\r\n\r\n    with open(&quot;in.txt&quot;) as f, NamedTemporaryFile(&quot;w&quot;, dir=&quot;.&quot;,delete=False) as out:\r\n        for line in f:\r\n                d = json.loads(line)\r\n                v = d[&quot;metatag.eprints.citation&quot;]\r\n                d[&quot;metatag.eprints.citation&quot;] = v[:v.find(&quot;)&quot;)+1]\r\n                json.dump(d, out)\r\n                out.write(&quot;\\n&quot;)\r\n    move(out.name,&quot;in.txt&quot;)\r\n\r\n\r\n",
                "title": "jq or python script to delete text after date in json field"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1444756655,
                "creation_date": 1444756655,
                "answer_id": 33108747,
                "question_id": 33107524,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`jq &#39;.[&quot;metatag.eprints.citation&quot;] |= match(&quot;.*?\\\\\\)&quot;).string // .&#39;`\r\n\r\nNeeds jq 1.5. What this does is set the value of `metatag.eprints.citation` to the result of matching itself to the regex `.*?\\)`, which will match everything before the first closing parenthesis. If there was no closing parenthesis for whatever reason, we use the alternative operator `//` to set the value back to whatever it was.",
                "title": "jq or python script to delete text after date in json field"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1444761678,
        "creation_date": 1444752438,
        "question_id": 33107524,
        "body_markdown": "I have a json file with hundreds of entries such as:\r\n\r\n    {\r\n        &quot;url&quot;:&quot;http://example.com/10618/&quot;,\r\n        &quot;metatag.eprints.publication&quot;:&quot;Journal of Corporate Real Estate&quot;,\r\n        &quot;metatag.eprints.title&quot;:&quot;Corporate Real Estate Strategy&quot;,\r\n        &quot;metatag.eprints.citation&quot;:&quot;Adair, P, McGrogan, WS, and Webb, JR (2006) Corporate Real Estate Strategy. Journal of Corporate Real Estate&quot;}\r\n    {\r\n        &quot;url&quot;:&quot;http://example.com/23552/&quot;,\r\n        &quot;metatag.eprints.publication&quot;:&quot;European Journal of Cardio-Thoracic Surgery&quot;,\r\n        &quot;metatag.eprints.title&quot;:&quot;Long-term survival from coronary endarterectomies in coronary artery disease&quot;,\r\n        &quot;metatag.eprints.citation&quot;:&quot;Aaron, P, Jones, K, Pallin, C, and Nash, R (2012) Long-term survival from coronary endarterectomies in coronary artery disease. European Journal of Cardio-Thoracic Surgery&quot;}\r\n\r\nCould anybody help write a jq or python script which, for every block, would alter the &quot;metatag.eprints.citation&quot; so that all text after the date is deleted?\r\n\r\nSo the above blocks would become:\r\n\r\n    {\r\n        &quot;url&quot;:&quot;http://example.com/10618/&quot;,\r\n        &quot;metatag.eprints.publication&quot;:&quot;Journal of Corporate Real Estate&quot;,\r\n        &quot;metatag.eprints.title&quot;:&quot;Corporate Real Estate Strategy&quot;,\r\n        &quot;metatag.eprints.citation&quot;:&quot;Adair, P, McGrogan, WS, and Webb, JR (2006)&quot;}\r\n    {\r\n        &quot;url&quot;:&quot;http://example.com/23552/&quot;,\r\n        &quot;metatag.eprints.publication&quot;:&quot;European Journal of Cardio-Thoracic Surgery&quot;,\r\n        &quot;metatag.eprints.title&quot;:&quot;Long-term survival from coronary endarterectomies in coronary artery disease&quot;,\r\n        &quot;metatag.eprints.citation&quot;:&quot;Aaron, P, Jones, K, Pallin, C, and Nash, R (2012)&quot;}\r\n\r\n",
        "link": "https://stackoverflow.com/questions/33107524/jq-or-python-script-to-delete-text-after-date-in-json-field",
        "title": "jq or python script to delete text after date in json field"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1444943893,
                "last_edit_date": 1444943893,
                "creation_date": 1444835794,
                "answer_id": 33129246,
                "question_id": 33128365,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First you need to identify the objects you want to update. Since you want to set the null datasources of the panels to `&quot;mydb&quot;`, you could do this:\r\n\r\n    $ jq &#39;.rows[].panels[].datasource //= &quot;mydb&quot;&#39; input.json\r\n\r\nIf you want to update any `datasource` property on any object at any level, you could use `..` to recursively search for them.\r\n\r\n    $ jq &#39;(.. | select(objects | has(&quot;datasource&quot;))).datasource //= &quot;mydb&quot;&#39; input.json",
                "title": "How can I replace a null value in a json document by a specific value with jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1445571955,
                "creation_date": 1445571955,
                "answer_id": 33294555,
                "question_id": 33128365,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For the record, it is also quite easy to change all key values that are null (no matter where they occur) to some other value.  Versions of jq &gt; 1.5 include a jq-defined filter, walk/1, which can be used (e.g. by copying and pasting) in other versions of jq as well.  \r\n\r\nFor example, to change all key values that are null to 0 using walk/1:\r\n\r\n    walk(if type == &quot;object&quot; then with_entries(.value //= 0) else . end)\r\n\r\n\r\nHere is the jq-provided definition of walk/1:\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",
                "title": "How can I replace a null value in a json document by a specific value with jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503690830,
                "creation_date": 1503690830,
                "answer_id": 45888570,
                "question_id": 33128365,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **tostream**, **reduce** and **setpath** to set any leaf `datasource` attribute whose value is `null` to `&quot;mydb&quot;`.\r\n\r\n    reduce (tostream|select(length==2)) as [$p,$v] (\r\n      .\r\n    ; if $p[-1] == &quot;datasource&quot; and $v == null then setpath($p; &quot;mydb&quot;) else . end\r\n    )",
                "title": "How can I replace a null value in a json document by a specific value with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1503690830,
        "creation_date": 1444833489,
        "last_edit_date": 1444835871,
        "question_id": 33128365,
        "body_markdown": "I have a json file that contains `null`s as values for some keys, which I would like to replace with some specific value.\r\n\r\nGiven this input:\r\n\r\n    {\r\n      &quot;id&quot;: null,\r\n      &quot;rows&quot;: [\r\n        {\r\n          &quot;panels&quot;: [\r\n            {\r\n              &quot;title&quot;: &quot;Panel1&quot;,\r\n              &quot;datasource&quot;: null\r\n            },\r\n            {\r\n              &quot;title&quot;: &quot;Panel2&quot;,\r\n              &quot;datasource&quot;: null\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nI would like to have\r\n\r\n    {\r\n      &quot;id&quot;: null,\r\n      &quot;rows&quot;: [\r\n        {\r\n          &quot;panels&quot;: [\r\n            {\r\n              &quot;title&quot;: &quot;Panel1&quot;,\r\n              &quot;datasource&quot;: &quot;mydb&quot;\r\n            },\r\n            {\r\n              &quot;title&quot;: &quot;Panel2&quot;,\r\n              &quot;datasource&quot;: &quot;mydb&quot;\r\n            }\r\n            ]\r\n         }\r\n      ]\r\n    }\r\n\r\nWhat I currently use is\r\n\r\n    sed &#39;s/&quot;datasource&quot;: null/&quot;datasource&quot;: &quot;mydb&quot;/&#39;\r\n\r\nThis produces the output I need, but I keep thinking that it is a shame to use `sed` for this job, when there are tools like `jq` that can work on JSON in a much better way.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/33128365/how-can-i-replace-a-null-value-in-a-json-document-by-a-specific-value-with-jq",
        "title": "How can I replace a null value in a json document by a specific value with jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1444920359,
                "creation_date": 1444920359,
                "answer_id": 33151607,
                "question_id": 33148557,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This should work.  You wouldn&#39;t want to use a `group_by` here, you would do that if you were trying to go from more to less, we&#39;re going the other way.\r\n\r\nYou&#39;re combining the different versions with the corresponding severity.  Here&#39;s how you could do that.\r\n\r\n    map(.fields | (.versions[] | { id, name }) + { value: .severity.value })\r\n",
                "title": "denormalizing JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1444920359,
        "creation_date": 1444911986,
        "question_id": 33148557,
        "body_markdown": "I have JSON that looks like this:\r\n\r\n        [\r\n          {\r\n            &quot;fields&quot;: {\r\n              &quot;versions&quot;: [\r\n                {\r\n                  &quot;id&quot;: &quot;36143&quot;,\r\n                  &quot;name&quot;: &quot;ST card&quot;\r\n                },\r\n                {\r\n                  &quot;id&quot;: &quot;36144&quot;,\r\n                  &quot;description&quot;: &quot;Acceptance test card&quot;,\r\n                  &quot;name&quot;: &quot;AT card&quot;\r\n                }\r\n              ],\r\n              &quot;severity&quot;: {\r\n                &quot;value&quot;: &quot;B-Serious&quot;,\r\n                &quot;id&quot;: &quot;14231&quot;\r\n              }\r\n            }\r\n          },\r\n          {\r\n            &quot;fields&quot;: {\r\n              &quot;versions&quot;: [\r\n                {\r\n                  &quot;id&quot;: &quot;36145&quot;,\r\n                  &quot;name&quot;: &quot;ST card&quot;\r\n                }\r\n              ],\r\n              &quot;severity&quot;: {\r\n                &quot;value&quot;: &quot;C-Limited&quot;,\r\n                &quot;id&quot;: &quot;14235&quot;\r\n              }\r\n            }\r\n          }\r\n        ]\r\n\r\nI want to convert it with jq to this:\r\n\r\n        [\r\n          {\r\n            &quot;id&quot;: &quot;36143&quot;,\r\n            &quot;name&quot;: &quot;ST card&quot;\r\n            &quot;value&quot;: &quot;B-Serious&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;36144&quot;,\r\n            &quot;name&quot;: &quot;AT card&quot;\r\n            &quot;value&quot;: &quot;B-Serious&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;36145&quot;,\r\n            &quot;name&quot;: &quot;ST card&quot;\r\n            &quot;value&quot;: &quot;C-Limited&quot;\r\n          }\r\n        ]\r\n\r\nNote that the first object has 2 versions, and the same severity. I have tried jq&#39;s group_by and map functions but haven&#39;t been too successful. Please help :)",
        "link": "https://stackoverflow.com/questions/33148557/denormalizing-json-with-jq",
        "title": "denormalizing JSON with jq"
    },
    {
        "tags": [
            "json",
            "ubuntu",
            "ubuntu-10.04",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1589784,
                    "reputation": 5942,
                    "user_id": 1601580,
                    "user_type": "registered",
                    "accept_rate": 47,
                    "profile_image": "https://i.sstatic.net/2B6rV.png?s=256",
                    "display_name": "Charlie Parker",
                    "link": "https://stackoverflow.com/users/1601580/charlie-parker"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676666522,
                "post_id": 33184780,
                "comment_id": 133190637,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1445082998,
                "creation_date": 1445082998,
                "answer_id": 33186329,
                "question_id": 33184780,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Download &amp; build from source as described in https://stedolan.github.io/jq/download/, last section called &quot;From source on Linux, OS X, Cygwin, and other POSIX-like operating systems&quot;.",
                "title": "Install jq JSON processor on Ubuntu 10.04"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1487148082,
                "last_edit_date": 1487148082,
                "creation_date": 1447076024,
                "answer_id": 33610297,
                "question_id": 33184780,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I think you&#39;re missing the repo: \r\nhttp://installion.co.uk/ubuntu/vivid/universe/j/jq/install/index.html",
                "title": "Install jq JSON processor on Ubuntu 10.04"
            },
            {
                "up_vote_count": 195,
                "is_accepted": true,
                "score": 195,
                "last_activity_date": 1612973198,
                "last_edit_date": 1612973198,
                "creation_date": 1497447844,
                "answer_id": 44546590,
                "question_id": 33184780,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is possible to perform `sudo apt-get install jq` however you need to inform the system where to find jq.\r\n\r\nℹ️ **Note**: Ubuntu 14+ users can skip to step 3! &#127881;\r\n\r\n# Install\r\n1. Open your sources file in a text editor:\r\n\r\n        sudo vim /etc/apt/sources.list\r\n\r\n2. Add the following line to the end of that file (note `deb` is not a command, [more info][1]):\r\n\r\n    &gt;deb http://us.archive.ubuntu.com/ubuntu vivid main universe\r\n\r\n\r\n3. Then re-index apt-get so that it can find `jq`:\r\n\r\n        sudo apt-get update\r\n\r\n\r\n4. Then do the normal install and you should be the proud new user of `jq`!\r\n\r\n        sudo apt-get install jq\r\n\r\n# Test\r\nTest it works! Try this to see it pretty print some example json\r\n\r\n    echo &#39;{ &quot;name&quot;:&quot;John&quot;, &quot;age&quot;:31, &quot;city&quot;:&quot;New York&quot; }&#39; | jq .\r\nThe result should appear like so in your terminal:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;John&quot;,\r\n      &quot;age&quot;: 31,\r\n      &quot;city&quot;: &quot;New York&quot;\r\n    }\r\n\r\n  [1]: https://askubuntu.com/questions/233064/why-am-i-getting-command-deb-not-found/233069\r\n\r\n\r\n",
                "title": "Install jq JSON processor on Ubuntu 10.04"
            },
            {
                "up_vote_count": 48,
                "is_accepted": false,
                "score": 48,
                "last_activity_date": 1557304480,
                "last_edit_date": 1557304480,
                "creation_date": 1557304172,
                "answer_id": 56036560,
                "question_id": 33184780,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since Ubuntu 16.04LTS [xenial][1] you do not need to modify `/etc/apt/sources.list`, just run \r\n\r\n    sudo apt-get install jq\r\n\r\n`jq 1.5` is in the official [Debian][2] and [Ubuntu][3] repositories.\r\n\r\n\r\n  [1]: https://packages.ubuntu.com/xenial/jq\r\n  [2]: https://packages.debian.org/search?keywords=jq\r\n  [3]: https://packages.ubuntu.com/search?keywords=jq",
                "title": "Install jq JSON processor on Ubuntu 10.04"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1676668237,
                "creation_date": 1676668237,
                "answer_id": 75489241,
                "question_id": 33184780,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t have sudo permission do this:\r\n\r\n```\r\n#!/usr/bin/env bash\r\n\r\n# conda activate jq_install_env\r\n\r\n# - Install jq without sudo\r\n# Clone the jq repository from GitHub\r\ncd $HOME\r\ngit clone https://github.com/stedolan/jq.git $HOME/jq\r\ncd $HOME/jq\r\ngit submodule update --init\r\n\r\n# Compile jq from source\r\ncd $HOME/jq\r\nautoreconf -fi\r\n./configure --with-oniguruma=builtin --disable-maintainer-mode --prefix=$HOME/.local\r\nmake -j8 &amp;&amp; make check\r\nmake install\r\nls $HOME/.local\r\nls $HOME/.local/bin\r\n\r\n# Add the directory where the jq binary file is located to your PATH environment variable\r\necho &#39;PATH=$PATH:~/.local/bin/&#39; &gt;&gt; $HOME/.bashrc.lfs\r\nexport PATH=$PATH:~/.local/bin/\r\necho $PATH | tr &#39;:&#39; &#39;\\n&#39;\r\n\r\n# Reload your shell configuration file to update your PATH environment variable\r\nsource $HOME/.bashrc.lfs\r\n\r\n# Verify that jq is installed and working\r\njq --version\r\n```\r\n\r\nreference: https://suzyahyah.github.io/misc/2020/03/31/jq-without-sudo.html\r\n\r\nin case link dies:\r\n```\r\nLanding Page...\r\nAboutCategoriesAdvisors\r\nRecipe for building jq from source without admin(sudo) rights\r\nMar 31, 2020\r\n\r\nThis took me some time to install. Just putting it out there in case it helps someone.\r\nGet the latest jq from github\r\n\r\ngit clone https://github.com/stedolan/jq.git\r\n\r\nUpdate submodules (onigurama)\r\n\r\ngit submodule update --init\r\n\r\nCopy missing auxiliary files\r\n\r\nautoreconf -fi\r\n\r\nInstall into {YOUR_HOME_DIR} with onigurama (regex library)\r\n\r\n./configure --with-oniguruma=builtin --disable-maintainer-mode --prefix={YOUR_HOME_DIR}.local\r\n\r\nCheck that we have all the dependencies downloaded and install\r\n\r\nmake -j8 &amp;&amp; make check\r\n\r\nmake install\r\n\r\nFinally, add this to your ~/.bashrc and to call jq from anywhere. Remember to &gt;source ~/.bashrc and you should be good to go.\r\n\r\nexport PATH=$PATH:~/.local/bin/\r\n\r\n&#171; The Sigmoid in Regression, Neural Network Activation and LSTM GatesA minimum keystroke (py)Debugger for Lazy ML/DS people who don&#39;t IDE &#187;\r\nQuality means doing it right when no one is looking - Henry Ford\r\n suzyahyah\r\n suzyahyah\r\nThe best time to plant a tree was 20 years ago. The second best time is now. - Japanese proverb\r\n\r\nSince October 2017\r\n```",
                "title": "Install jq JSON processor on Ubuntu 10.04"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1747909325,
                "creation_date": 1747909325,
                "answer_id": 79633534,
                "question_id": 33184780,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I was trying to install `jq` on a fresh Ubuntu 24.04 (Noble) system using:\r\n\r\n```\r\nsudo apt install jq\r\n```\r\n\r\nBut I got the issue:\r\n\r\n```\r\nReading package lists... Done\r\nBuilding dependency tree... Done\r\nReading state information... Done\r\n\r\nNo apt package &quot;jq&quot;, but there is a snap with that name.\r\nTry &quot;snap install jq&quot;\r\n\r\nE: Unable to locate package jq\r\n```\r\n\r\nTo fix it, I ran:\r\n\r\n```\r\nsudo apt-get update\r\n```\r\n\r\nIt fetched all the latest package lists from the Ubuntu mirrors. After that, I tried installing `jq` again:\r\n\r\n```\r\nsudo apt install jq\r\n```\r\n\r\nThis time it worked:\r\n\r\n```\r\nReading package lists... Done\r\nBuilding dependency tree... Done\r\nReading state information... Done\r\nThe following additional packages will be installed:\r\n  libjq1 libonig5\r\nThe following NEW packages will be installed:\r\n  jq libjq1 libonig5\r\n0 upgraded, 3 newly installed, 0 to remove and 24 not upgraded.\r\nNeed to get 378 kB of archives.\r\nAfter this operation, 1125 kB of additional disk space will be used.\r\nDo you want to continue? [Y/n] Y\r\n```\r\n\r\nThe installation completed successfully after I ran `apt-get update`. I didn’t have to modify `/etc/apt/sources.list` or do anything else.",
                "title": "Install jq JSON processor on Ubuntu 10.04"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 111,
        "last_activity_date": 1747909325,
        "creation_date": 1445072683,
        "question_id": 33184780,
        "body_markdown": "Is there a way to install jq JSON processor on Ubuntu 10.04?\r\n\r\nI Tried the usual `sudo apt-get install jq` but got the error `E: Couldn&#39;t find package jq`",
        "link": "https://stackoverflow.com/questions/33184780/install-jq-json-processor-on-ubuntu-10-04",
        "title": "Install jq JSON processor on Ubuntu 10.04"
    },
    {
        "tags": [
            "shell",
            "pipe",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 399,
                "is_accepted": true,
                "score": 397,
                "last_activity_date": 1445377103,
                "creation_date": 1445377103,
                "answer_id": 33247259,
                "question_id": 33247228,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to supply a filter as an argument. To pass the JSON through unmodified other than the pretty printing `jq` provides by default, use the identity filter `.`:\r\n\r\n    curl -s https://api.github.com/users/octocat/repos | jq &#39;.&#39; | cat",
                "title": "How to use `jq` in a shell pipeline?"
            },
            {
                "up_vote_count": 21,
                "is_accepted": false,
                "score": 17,
                "last_activity_date": 1491337544,
                "creation_date": 1491337544,
                "answer_id": 43217051,
                "question_id": 33247228,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One use case I have found myself doing frequently as well is *&quot;How do I construct JSON data to supply into other shell commands, for example `curl`?&quot;* The way I do this is by using the `--null-input/-n` option:\r\n\r\n&gt; Don’t read any input at all! Instead, the filter is run once using `null` as the input. This is useful when using `jq` as a simple calculator or to construct JSON data from scratch.\r\n\r\nAnd an example passing it into `curl`:\r\n\r\n    jq -n &#39;{key: &quot;value&quot;}&#39; | curl -d @- \\\r\n      --url &#39;https://some.url.com&#39; \\\r\n      -H &#39;Content-Type: application/json&#39; \\\r\n      -H &#39;Accept: application/json&#39;\r\n",
                "title": "How to use `jq` in a shell pipeline?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 244,
        "last_activity_date": 1621620685,
        "creation_date": 1445376951,
        "last_edit_date": 1621620685,
        "question_id": 33247228,
        "body_markdown": "I can&#39;t seem to get `jq` to behave &quot;normally&quot; in a shell pipeline.  For example:\r\n\r\n    $ curl -s https://api.github.com/users/octocat/repos | jq | cat\r\n\r\nresults in `jq` simply printing out its help text*.  The same thing happens if I try to redirect `jq`&#39;s output to a file:\r\n\r\n    $ curl -s https://api.github.com/users/octocat/repos | jq &gt; /tmp/stuff.json\r\n\r\nIs `jq` deliberately bailing out if it determines that it&#39;s not being run from a tty?  How can I prevent this behavior so that I can use `jq` in a pipeline?\r\n\r\nEdit: it looks like this is no longer an issue in recent versions of `jq`. I have `jq-1.6` now and the examples above work as expected.\r\n\r\n---\r\n\r\n\\* &lt;sub&gt;(I realize this example contains a [useless use of cat](http://porkmail.org/era/unix/award.html); it&#39;s for illustration purposes only)&lt;/sub&gt;",
        "link": "https://stackoverflow.com/questions/33247228/how-to-use-jq-in-a-shell-pipeline",
        "title": "How to use `jq` in a shell pipeline?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1445455458,
                "post_id": 33265654,
                "comment_id": 54336279,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 532293,
                    "reputation": 251,
                    "user_id": 903355,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/150bd91ca863ecfb162a3ff315425c06?s=256&d=identicon&r=PG",
                    "display_name": "Tom",
                    "link": "https://stackoverflow.com/users/903355/tom"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1445519257,
                "post_id": 33265654,
                "comment_id": 54363868,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1445546278,
                "post_id": 33265654,
                "comment_id": 54380710,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 532293,
                    "reputation": 251,
                    "user_id": 903355,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/150bd91ca863ecfb162a3ff315425c06?s=256&d=identicon&r=PG",
                    "display_name": "Tom",
                    "link": "https://stackoverflow.com/users/903355/tom"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1445604745,
                "post_id": 33265654,
                "comment_id": 54404357,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1445451338,
                "creation_date": 1445451338,
                "answer_id": 33266437,
                "question_id": 33265654,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can update the elements in the array whilst keeping the other elements as is like this:\r\n\r\n    &#39;.rooms[] |=  {suite_type, price_range_start: .price_range[0],\r\n      price_range_end: .price_range[1]} + {available,\r\n      square_foot_start:.square_feet[0], square_foot_end:.square_feet[1],\r\n      deposit:.deposit[0], bathrooms:.bathrooms[0]}&#39;",
                "title": "JQ Array to new fields"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503690029,
                "creation_date": 1503690029,
                "answer_id": 45888409,
                "question_id": 33265654,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses functions.\r\n\r\n    def common_columns:\r\n       &quot;phone_number&quot;, &quot;city&quot;, &quot;updated&quot;, &quot;name&quot;, &quot;address&quot;, &quot;zip_code&quot;, &quot;url&quot;, &quot;last_visited&quot;\r\n    ;\r\n    def common:\r\n       .phone_number, .city, .updated, .name, .address, .zip_code, .url, .last_visited\r\n    ;\r\n    def room_columns(n):\r\n         range(n)\r\n       | (\r\n          &quot;available_\\(.)&quot;, &quot;bathrooms_\\(.)&quot;, &quot;suite_type_\\(.)&quot;,\r\n          &quot;square_feet_start_\\(.)&quot;, &quot;square_feet_end_\\(.)&quot;, &quot;deposit_\\(.)&quot;,\r\n          &quot;price_range_start_\\(.)&quot;, &quot;price_range_end_\\(.)&quot;\r\n         )\r\n    ;\r\n    def rooms(n):\r\n         . as $r\r\n       | range(n)\r\n       | $r.rooms[.]\r\n       | (\r\n           .available, .bathrooms[0], .suite_type,\r\n           .square_feet[0,1], .deposit[0], .price_range[0,1]\r\n         )\r\n    ;\r\n\r\n      [ common_columns, room_columns(6) ]\r\n    , [ common,         rooms(6) ]\r\n    | @csv\r\n\r\nYou can change the `6` to however many sets of room columns you need.",
                "title": "JQ Array to new fields"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1504629057,
        "creation_date": 1445448607,
        "last_edit_date": 1504629057,
        "question_id": 33265654,
        "body_markdown": "I have a sample json data like:\r\n   \r\n    {\r\n      &quot;phone_number&quot;: &quot;780-414-2085&quot;,\r\n      &quot;city&quot;: &quot;Edmonton&quot;,\r\n      &quot;updated&quot;: &quot;2015-10-19T00:03:10&quot;,\r\n      &quot;name&quot;: &quot;Sir William Place &quot;,\r\n      &quot;url&quot;: &quot;http://www.bwalk.com/en-CA/Rent/Details/Alberta/Edmonton/Sir-William-Place&quot;,\r\n      &quot;last_visited&quot;: &quot;2015-10-19T00:03:10&quot;,\r\n      &quot;rooms&quot;: [{\r\n        &quot;available&quot;: &quot;Available&quot;,\r\n        &quot;bathrooms&quot;: [&quot;1&quot;],\r\n        &quot;suite_type&quot;: &quot;1 Bedroom&quot;,\r\n        &quot;square_feet&quot;: [&quot;594&quot;, &quot;649&quot;],\r\n        &quot;deposit&quot;: [&quot;$499&quot;],\r\n        &quot;price_range&quot;: [&quot;$1059&quot;, &quot;$1209&quot;]\r\n      }, {\r\n        &quot;available&quot;: &quot;Available&quot;,\r\n        &quot;bathrooms&quot;: [&quot;1&quot;],\r\n        &quot;suite_type&quot;: &quot;1 Bedroom + Den&quot;,\r\n        &quot;square_feet&quot;: [&quot;771&quot;],\r\n        &quot;deposit&quot;: [&quot;$499&quot;],\r\n        &quot;price_range&quot;: [&quot;$1169&quot;, &quot;$1249&quot;]\r\n      }, {\r\n        &quot;available&quot;: &quot;Available&quot;,\r\n        &quot;bathrooms&quot;: [&quot;1&quot;, &quot;2&quot;],\r\n        &quot;suite_type&quot;: &quot;2 Bedroom&quot;,\r\n        &quot;square_feet&quot;: [&quot;894&quot;, &quot;970&quot;],\r\n        &quot;deposit&quot;: [&quot;$499&quot;],\r\n        &quot;price_range&quot;: [&quot;$1344&quot;, &quot;$1494&quot;]\r\n      }, {\r\n        &quot;available&quot;: &quot;Available&quot;,\r\n        &quot;bathrooms&quot;: [&quot;2&quot;],\r\n        &quot;deal&quot;: [&quot;October FREE and $299 Security Deposit on 12 month leases &quot;],\r\n    &quot;suite_type&quot;: &quot;2 Bedroom Bi-level&quot;,\r\n    &quot;square_feet&quot;: [&quot;894&quot;],\r\n    &quot;deposit&quot;: [&quot;$499&quot;],\r\n    &quot;price_range&quot;: [&quot;$1344&quot;, &quot;$1394&quot;]\r\n      }, {\r\n        &quot;available&quot;: &quot;Waiting List&quot;,\r\n        &quot;bathrooms&quot;: [&quot;1&quot;],\r\n        &quot;suite_type&quot;: &quot;Bachelor&quot;,\r\n        &quot;square_feet&quot;: [&quot;540&quot;],\r\n        &quot;deposit&quot;: [&quot;$499&quot;],\r\n        &quot;price_range&quot;: [&quot;$1004&quot;, &quot;$1054&quot;]\r\n      }],\r\n      &quot;address&quot;: &quot;8830-85 St., Edmonton, Alberta, T6C 3C3&quot;,\r\n      &quot;zip_code&quot;: &quot;T6C 3C3&quot;\r\n    }\r\n\r\nAnd I am running a jq expression like:\r\n\r\n    &#39;{phone_number, city, updated, name, address, zip_code, url, last_visited} + (.rooms[] | {suite_type, price_range_start: .price_range[0], price_range_end: .price_range[1]} + {available, square_foot_start:.square_feet[0], square_foot_end:.square_feet[1], deposit:.deposit[0], bathrooms:.bathrooms[0]})&#39;\r\n\r\nThis gives me an ok output but repeats the same names because I just list the rooms array. I want to be able to set each item in the rooms array to something like room1, room2, room3 etc. But also to keep it in one entry, so for example with the sample here it ends up 5 entries because there is 5 rooms and name for instance gets repeated 5 times because the way I have it set now. I think I need to map the rooms to something but not sure how to do that.\r\n\r\nCan someone advise on how to do this?",
        "link": "https://stackoverflow.com/questions/33265654/jq-array-to-new-fields",
        "title": "JQ Array to new fields"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1445537627,
                "creation_date": 1445537627,
                "answer_id": 33287864,
                "question_id": 33286778,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s how you can build that up:\r\n\r\n    { &quot;top-level-key&quot;: .toplevel_key } + ([\r\n        range(.list|length) as $i\r\n            | .list[$i]\r\n            | to_entries[]\r\n            | .key = &quot;list_\\($i)_\\(.key)&quot;\r\n        ] | from_entries)\r\n\r\nThis will map for every corresponding list entry.\r\n\r\n    {\r\n      &quot;top-level-key&quot;: &quot;top value 1&quot;,\r\n      &quot;list_0_key1&quot;: &quot;value 1&quot;,\r\n      &quot;list_0_key2&quot;: &quot;value 2&quot;,\r\n      &quot;list_1_key1&quot;: &quot;value 3&quot;,\r\n      &quot;list_1_key2&quot;: &quot;value 4&quot;\r\n    }\r\n    {\r\n      &quot;top-level-key&quot;: &quot;top value 2&quot;,\r\n      &quot;list_0_key1&quot;: &quot;value 5&quot;,\r\n      &quot;list_0_key2&quot;: &quot;value 6&quot;\r\n    }\r\n\r\nIf you need to pad it out, you&#39;ll have to slurp up the results to determine how much is actually needed and add the padding.  But I&#39;d leave it as this for now.\r\n",
                "title": "How to use JQ to unroll a list of objects into denormalized objects?"
            },
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1445724726,
                "last_edit_date": 1445724726,
                "creation_date": 1445546175,
                "answer_id": 33290267,
                "question_id": 33286778,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As long as you know the names of the specific keys, Jeff&#39;s answer is great. Here&#39;s an answer that doesn&#39;t hardcode the specific key names, that is, it works with objects of any structure and levels of nesting:\r\n\r\n    [leaf_paths as $path | {\r\n        &quot;key&quot;: $path | map(tostring) | join(&quot;_&quot;),\r\n        &quot;value&quot;: getpath($path)\r\n    }] | from_entries\r\n\r\nAn explanation: `paths` is a builtin function that outputs an array representing the position of each element of the input you pass to it, recursively: the elements in said array are the ordered key names and indexes that lead to the requested array element. `leaf_paths` is a version of it that only gets the paths to the &quot;leaf&quot; elements, that is, elements that do not contain other elements.\r\n\r\nTo clarify, given the input `[[1, 2]]`, `paths` will output `[0], [0, 0], [0, 1]` (that is, the paths to `[1, 2]`, `1` and `2`, respectively) while `leaf_paths` will only output `[0, 0], [0, 1]`.\r\n\r\nThat&#39;s the hardest part. After that, we get each of the paths as `$path` (of the form `[&quot;list&quot;, 1, &quot;key2&quot;]`) convert each of its elements to its string representation with `map(tostring)` (which gives us `[&quot;list&quot;, &quot;1&quot;, &quot;key2&quot;]`) and `join` them with underscores. We keep this as the key of the &quot;entry&quot; in the object we want to create: as value, we get the value of the original object at the `$path` given.\r\n\r\nLastly, we use `from_entries` to turn an array of key-value pairs into a JSON object. This will give us an output similar to the one on Jeff&#39;s answer: that is, one in which only keys with values appear.\r\n\r\nHowever, your original question requested values appearing on any of the input objects to appear in all of the outputs, with the corresponding values set to empty strings when missing on the input. Here&#39;s a jq program that does this: as Jeff says in his answer, you need to slurp (`-s`) all the input values for it to be possible:\r\n\r\n    (map(leaf_paths) | unique) as $paths |\r\n    map([$paths[] as $path | {\r\n        &quot;key&quot;: $path | map(tostring) | join(&quot;_&quot;),\r\n        &quot;value&quot;: (getpath($path) // &quot;&quot;)\r\n    }] | from_entries)[]\r\n\r\nYou&#39;ll notice that it&#39;s pretty similar to the first program: the main difference is that we get all unique paths in the slurped object as `$paths`, and for each object we go through those instead of going through the paths of that object. We also use the alternative operator (`//`) to set missing values to empty strings.\r\n\r\nHope this helps!",
                "title": "How to use JQ to unroll a list of objects into denormalized objects?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1630594085,
                "creation_date": 1630594085,
                "answer_id": 69032546,
                "question_id": 33286778,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to join the toplevel_key with the list as a string on seperate lines you can use the following:\r\n\r\n    jq -r &#39;&quot;\\(.toplevel_key) - &quot; as $i | [.list | to_entries[] | &quot;\\(.value | .key1), \\(.value | .key2)&quot;] | join(&quot;, &quot;) as $j | $i + $j&#39; toplevel.json\r\n\r\nThis will provide the below result:\r\n\r\n    top value 1 - value 1, value 2, value 3, value 4\r\n    top value 2 - value 5, value 6\r\n\r\n\r\n",
                "title": "How to use JQ to unroll a list of objects into denormalized objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1630594085,
        "creation_date": 1445534022,
        "last_edit_date": 1504596950,
        "question_id": 33286778,
        "body_markdown": "I have the following JSON lines example:\r\n\r\n    {&quot;toplevel_key&quot;: &quot;top value 1&quot;, &quot;list&quot;: [{&quot;key1&quot;: &quot;value 1&quot;, &quot;key2&quot;: &quot;value 2&quot;},{&quot;key1&quot;: &quot;value 3&quot;, &quot;key2&quot;: &quot;value 4&quot;}]}\r\n    {&quot;toplevel_key&quot;: &quot;top value 2&quot;, &quot;list&quot;: [{&quot;key1&quot;: &quot;value 5&quot;, &quot;key2&quot;: &quot;value 6&quot;}]}\r\n\r\nI want convert it using JQ, unrolling the list to a fixed number of &quot;columns&quot;, ending up with a list of flat JSON objects, with the following format:\r\n\r\n    {\r\n        &quot;top-level-key&quot;: &quot;top value 1&quot;,\r\n        &quot;list_0_key1&quot;: &quot;value 1&quot;,\r\n        &quot;list_0_key2&quot;: &quot;value 2&quot;,\r\n        &quot;list_1_key1&quot;: &quot;value 3&quot;,\r\n        &quot;list_1_key2&quot;: &quot;value 4&quot;,\r\n    }\r\n    {\r\n        &quot;top-level-key&quot;: &quot;top value 2&quot;,\r\n        &quot;list_0_key1&quot;: &quot;value 4&quot;,\r\n        &quot;list_0_key2&quot;: &quot;value 5&quot;,\r\n        &quot;list_1_key1&quot;: &quot;&quot;,\r\n        &quot;list_1_key2&quot;: &quot;&quot;,\r\n    }\r\n\r\n&lt;sub&gt;Note: I actually want them one per line, formatted here for legibility.&lt;/sub&gt;\r\n\r\nThe only way I was able to get the output I want was by writing out all the columns in my JQ expression:\r\n\r\n    $ cat example.jsonl | jq -c &#39;{toplevel_key, list_0_key1: .list[0].key1, list_0_key2: .list[0].key2, list_1_key1: .list[1].key1, list_1_key2: .list[1].key2}&#39;\r\n\r\n\r\nThis gets me the result that I want, but I have to write manually ALL the fixed &quot;columns&quot; (and in production it will be a lot more than that).\r\n\r\nI know I could use a script to generate that JQ code, but I&#39;m **NOT** interested in a solution like that -- it won&#39;t solve my problem, because this is for an application that accepts only JQ.\r\n\r\nIs there a way to do it in pure JQ?\r\n\r\nThis is what I was able to get so far:\r\n\r\n    $ cat example.jsonl | jq -c &#39;(.list | to_entries | map({(&quot;list_&quot; + (.key | tostring)): .value})) | add&#39;\r\n    {&quot;list_0&quot;:{&quot;key1&quot;:&quot;value 1&quot;,&quot;key2&quot;:&quot;value 2&quot;},&quot;list_1&quot;:{&quot;key1&quot;:&quot;value 3&quot;,&quot;key2&quot;:&quot;value 4&quot;}}\r\n    {&quot;list_0&quot;:{&quot;key1&quot;:&quot;value 5&quot;,&quot;key2&quot;:&quot;value 6&quot;}}",
        "link": "https://stackoverflow.com/questions/33286778/how-to-use-jq-to-unroll-a-list-of-objects-into-denormalized-objects",
        "title": "How to use JQ to unroll a list of objects into denormalized objects?"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1445883826,
                "post_id": 33352930,
                "comment_id": 54501475,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 455809,
                    "reputation": 13559,
                    "user_id": 854207,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/R6DhK.jpg?s=256",
                    "display_name": "paul",
                    "link": "https://stackoverflow.com/users/854207/paul"
                },
                "reply_to_user": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1445885754,
                "post_id": 33352930,
                "comment_id": 54502591,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1445885806,
                "post_id": 33352930,
                "comment_id": 54502620,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1196850,
                    "reputation": 2366,
                    "user_id": 1168382,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://i.sstatic.net/pNZu4.jpg?s=256",
                    "display_name": "Dimitry K",
                    "link": "https://stackoverflow.com/users/1168382/dimitry-k"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1585252905,
                "post_id": 33352930,
                "comment_id": 107703308,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1115659,
                    "reputation": 2488,
                    "user_id": 1105047,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/a6a367675e861a9a1cd83edb359e648b?s=256&d=identicon&r=PG",
                    "display_name": "richie",
                    "link": "https://stackoverflow.com/users/1105047/richie"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668786398,
                "post_id": 33352930,
                "comment_id": 131498116,
                "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": 1752523849,
                "post_id": 33352930,
                "comment_id": 140589216,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1445885917,
                "last_edit_date": 1445885917,
                "creation_date": 1445884062,
                "answer_id": 33353029,
                "question_id": 33352930,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Remove them; JSON does not support comments.\r\n\r\n(JSON is defined [here](http://www.ecma-international.org/publications/files/ECMA-ST/ECMA-404.pdf); you can see a briefer description of the grammar [here](http://json.org).)",
                "title": "JQ issues with comments on Json file"
            },
            {
                "up_vote_count": 17,
                "is_accepted": true,
                "score": 17,
                "last_activity_date": 1724471707,
                "last_edit_date": 1724471707,
                "creation_date": 1445909729,
                "answer_id": 33358551,
                "question_id": 33352930,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JSON and thus jq do not support comments (in the usual sense) in JSON input. The jq FAQ lists a number of tools that can be used to remove comments, including jsonlint, json5, and any-json. I&#39;d recommend one that can act as a filter.\r\n\r\n\r\nFor NDJSON with #-style comments on separate lines, you could use jq by filtering out the #-style comments as follows:\r\n```\r\njq -Rcn &#39;\r\n  def iterate(f): def r: f | (., r); r;\r\n  iterate(try (inputs|fromjson) catch infinite)\r\n  | select(isinfinite|not)&#39;\r\n```\r\n\r\n(This also works with gojq and jaq, the Go and Rust implementation of jq.)\r\n\r\nSee https://github.com/stedolan/jq/wiki/FAQ#processing-not-quite-valid-json for links and further details.  \r\n——\r\n\r\n\r\nIt might be worth pointing out that jq can be used to process JSON with `#`-style comments, at least if the JSON is not too large to be processed as a jq program. For example, you could use jq with the -f option to read a JSON file as a jq program.",
                "title": "JQ issues with comments on Json file"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1477471410,
                "creation_date": 1477471410,
                "answer_id": 40257598,
                "question_id": 33352930,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I found https://github.com/sindresorhus/strip-json-comments-cli which allows you to do:\r\n\r\n    cat my_json_with_comments.json | strip-json-comments | jq  .\r\n",
                "title": "JQ issues with comments on Json file"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1652447639,
                "last_edit_date": 1652447639,
                "creation_date": 1628766330,
                "answer_id": 68756245,
                "question_id": 33352930,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Can be stripped out using sed, eg to remove lines beginning with &#39;//&#39;:\r\n\r\n    cat test.json | sed &#39;s/^ *\\/\\/.*//&#39; | jq &lt;&gt;commands&gt;\r\n\r\nsed is a pass-through/stream editor, in this case it&#39;s substituting nothing ( // ) for lines that begin with &#39;//&#39;; &#39;//&#39; must be escaped with a backslash character since the &#39;/&#39; is used by sed as a delimiter.\r\n",
                "title": "JQ issues with comments on Json file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -3,
                "last_activity_date": 1668760188,
                "creation_date": 1668760188,
                "answer_id": 74486823,
                "question_id": 33352930,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With this sed, you can remove:\r\n1. Empty lines\r\n2. Comments, even in the format `&quot;key&quot;: &quot;value&quot; //my comment`\r\n\r\nEventually, json will be output, which can be processed without problems using jq\r\n\r\n```sed &#39;/^[[:blank:]]*#/d;s/\\/\\/.*//&#39; my.json | jq &#39;.&lt;your_block&gt;&#39;```\r\n\r\nreference: https://unix.stackexchange.com/a/157619",
                "title": "JQ issues with comments on Json file"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1709064140,
                "last_edit_date": 1709064140,
                "creation_date": 1700130018,
                "answer_id": 77493974,
                "question_id": 33352930,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For C/C++ style comments you can use the C preprocessor to strip comment (`-E`) and not insert line markers (`-P`) like so:\r\n\r\n```\r\n cpp -P -E &lt;FILENAME&gt; | jq .\r\n```\r\n\r\nNote: JSON doesn&#39;t support comments, JSONC does.",
                "title": "JQ issues with comments on Json file"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1727004151,
                "creation_date": 1727004151,
                "answer_id": 79011511,
                "question_id": 33352930,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## You can do this very easily with &quot;shell&quot; and &quot;node&quot;.\r\n\r\n```jsonc\r\n// x.jsonc\r\n{\r\n  &quot;ts&quot;: 1724637960, // (int) epoch time\r\n}\r\n```\r\n\r\n```sh\r\nalias jsonc2json=&quot;bash -c -- &#39;node -e \\&quot;console.log(JSON.stringify(\\$(cat \\$1)))\\&quot;&#39;&quot;\r\n```\r\n\r\n## Examples\r\n\r\n```sh\r\ncat x.jsonc | jsonc2json\r\n```\r\n-&gt;\r\n```txt\r\n{&quot;ts&quot;:1724637960}\r\n```\r\n\r\n### Or\r\n\r\n```sh\r\ncat x.jsonc | jsonc2json | jq\r\n```\r\n-&gt;\r\n```txt\r\n{\r\n  &quot;ts&quot;: 1724637960\r\n}\r\n```",
                "title": "JQ issues with comments on Json file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1752522387,
                "creation_date": 1752522387,
                "answer_id": 79701300,
                "question_id": 33352930,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another great tool for this is **`fx`** (&lt;https://fx.wtf&gt;). It&#39;s designed for interactive processing of JSON on the command line and is more forgiving of things like comments by default. You can pipe your JSONC (JSON with comments) file directly to it.\r\n\r\nIf you need to enforce strict JSON validation, `fx` also includes a `--strict` flag.\r\n\r\n```\r\n# This will work with comments\r\ncat my_json_with_comments.json | fx .\r\n\r\n# This will fail if there are comments, enforcing strict JSON\r\ncat my_json_with_comments.json | fx --strict .\r\n```",
                "title": "JQ issues with comments on Json file"
            }
        ],
        "is_answered": true,
        "answer_count": 8,
        "score": 21,
        "last_activity_date": 1752522387,
        "creation_date": 1445883740,
        "last_edit_date": 1532715649,
        "question_id": 33352930,
        "body_markdown": "I&#39;m using JQ https://stedolan.github.io/jq/ to work in bash with my json and when I read the json is throwing me an error \r\n \r\n       parse error: Invalid numeric literal at line 2, column 5=\r\n\r\nSince my json has some comments\r\n\r\n      // comment\r\n      &quot;spawn&quot;: {}\r\n\r\nI&#39;ve been seen looking the options and I cannot find any option to fix the problem. Any idea how to solve it?",
        "link": "https://stackoverflow.com/questions/33352930/jq-issues-with-comments-on-json-file",
        "title": "JQ issues with comments on Json file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1445967349,
                "last_edit_date": 1445967349,
                "creation_date": 1445930102,
                "answer_id": 33361907,
                "question_id": 33359437,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use the raw input (`-R`) command line option to read the input in as a string.  Then you can build your json result.  You&#39;ll want to slurp it too (`-s`) for multiline text files.\r\n\r\n    $ jq -Rs &#39;{ html: . }&#39; index.html\r\n\r\nHowever, this only works for text files.  If you have binary files, you would have to encode them first.  You could use `base64` to do so.\r\n\r\n    $ base64 -w0 image.jpg | jq -R &#39;{ jpg: . }&#39;",
                "title": "Read files into JSON"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1445967785,
                "last_edit_date": 1445967785,
                "creation_date": 1445967439,
                "answer_id": 33374854,
                "question_id": 33359437,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This ought to work for you (requires jq 1.5):\r\n\r\n&lt;!--language: lang-sh --&gt;\r\n\r\n    jq --null-input --raw-input \\\r\n      &#39;reduce inputs as $line ({}; .[input_filename] += [$line]) | map_values(join(&quot;\\n&quot;))&#39; \\\r\n      index.html style.css main.js\r\n\r\nHere&#39;s the filter on its own. It&#39;s pretty simple:\r\n\r\n&lt;!--language: lang-jq --&gt;\r\n\r\n    reduce inputs as $line ({}; .[input_filename] += [$line])\r\n    | map_values(join(&quot;\\n&quot;))\r\n\r\nExample:\r\n\r\n&lt;!-- language: lang-none --&gt;\r\n\r\n    $ cat test1.txt\r\n    foo\r\n    bar\r\n    baz\r\n    \r\n    $ cat test2.txt\r\n    qux\r\n    quux\r\n    quuux\r\n    \r\n    $ jq --null-input --raw-input \\\r\n      &#39;reduce inputs as $line ({}; .[input_filename] += [$line]) | map_values(join(&quot;\\n&quot;))&#39; \\\r\n      test1.txt test2.txt\r\n    {\r\n      &quot;test1.txt&quot;: &quot;foo\\nbar\\nbaz&quot;,\r\n      &quot;test2.txt&quot;: &quot;qux\\nquux\\nquuux&quot;\r\n    }\r\n\r\nP.S. If you don&#39;t mind a trailing newline you could do this instead:\r\n\r\n&lt;!--language: lang-jq --&gt;\r\n\r\n    reduce inputs as $line ({}; .[input_filename] += &quot;\\($line)\\n&quot;)",
                "title": "Read files into JSON"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1446197415,
                "last_edit_date": 1446197415,
                "creation_date": 1445979261,
                "answer_id": 33378293,
                "question_id": 33359437,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One way to handle multiple text files is illustrated by the following:\r\n\r\n    (jq -Rs . a.txt ; jq -sR . b.txt) | jq -s\r\n    [\r\n      &quot;1\\n2\\n&quot;,\r\n      &quot;3\\n4\\n&quot;\r\n    ]\r\n\r\nSo in your case you would do something like this:\r\n\r\n    (jq -Rs &#39;{ html: . }&#39; index.html; \\\r\n     jq -Rs &#39;{ javascript: . }&#39; main.js; \\\r\n     jq -Rs &#39;{ css: . }&#39; style.css) |\\\r\n     jq -s add\r\n\r\nThat is, convert each text file to a JSON string separately, and then pipe these strings to jq. This has the advantage of not requiring jq 1.5, but if you do have jq 1.5, then a solution using the filter ```inputs``` might be preferable.",
                "title": "Read files into JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 6,
        "last_activity_date": 1446197415,
        "creation_date": 1445916186,
        "question_id": 33359437,
        "body_markdown": "I want to read in several files (index.html, style.css, main.js) to create a JSON payload for upload.\r\n\r\nI know with nodejs, I can begin to create what I want like so:\r\n\r\n    var fs = require(&#39;fs&#39;);\r\n    fs.readFile(&#39;index.html&#39;, &#39;utf8&#39;, function (err, data) {\r\n      if (err) throw err;\r\n      out = JSON.stringify({&quot;html&quot;: data});\r\n      console.log(out);\r\n    });\r\n\r\nThough how do I do that with [jq](https://github.com/stedolan/jq)?",
        "link": "https://stackoverflow.com/questions/33359437/read-files-into-json",
        "title": "Read files into JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4548841,
                    "reputation": 347,
                    "user_id": 3694539,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/8e6184300fd804e16be6194ec866bff7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "David Martin",
                    "link": "https://stackoverflow.com/users/3694539/david-martin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1446053622,
                "post_id": 33397134,
                "comment_id": 54586977,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1446062742,
                "post_id": 33397134,
                "comment_id": 54592501,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3783612,
                    "reputation": 4060,
                    "user_id": 3142963,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/529614ad1e8ddc33b5c934d499171732?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nwk",
                    "link": "https://stackoverflow.com/users/3142963/nwk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1446063609,
                "post_id": 33397134,
                "comment_id": 54592977,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1446065011,
                "creation_date": 1446065011,
                "answer_id": 33401263,
                "question_id": 33397134,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This was my solution.\r\n\r\n    cat 99 | jq -r &#39;.&quot;current-user&quot; as $foo | .users[] | select(.name == $foo).user&#39;\r\n    {\r\n      &quot;username&quot;: &quot;tester02&quot;\r\n    }\r\n\r\n",
                "title": "jq parsing json input with variables"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501870209,
                "creation_date": 1501870209,
                "answer_id": 45513089,
                "question_id": 33397134,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The **select** solution is good.  Here is an alternative that uses **foreach**.\r\n\r\n    foreach .users[] as $u (\r\n         .&quot;current-user&quot;\r\n       ; .\r\n       ; if . == $u.name then $u.user.username else empty end\r\n    )",
                "title": "jq parsing json input with variables"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1501870315,
        "creation_date": 1446051653,
        "last_edit_date": 1501870315,
        "question_id": 33397134,
        "body_markdown": "I have this input:\r\n\r\n    {\r\n      &quot;users&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;tester-01&quot;,\r\n          &quot;user&quot;: {\r\n            &quot;username&quot;: &quot;tester01&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;tester-02&quot;,\r\n          &quot;user&quot;: {\r\n            &quot;username&quot;: &quot;tester02&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;current-user&quot;: &quot;tester-02&quot;\r\n    }\r\n\r\nUsing jq (1.5), I want to print the username that matches current-user.\r\n\r\nCan anyone share how this would be done or tips to get me started?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/33397134/jq-parsing-json-input-with-variables",
        "title": "jq parsing json input with variables"
    },
    {
        "tags": [
            "mongodb",
            "search",
            "replace",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1446225573,
                "post_id": 33440952,
                "comment_id": 54671242,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1446230292,
                "creation_date": 1446230292,
                "answer_id": 33442821,
                "question_id": 33440952,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Search for the processes that has the versions you want to update, then update them.\r\n\r\n    (.processes[] | select(.version == &quot;3.0.7&quot;)).version = &quot;3.0.6&quot;",
                "title": "search and replace with &#39;jq&#39; JSON shell tool"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1446295151,
                "creation_date": 1446295151,
                "answer_id": 33451675,
                "question_id": 33440952,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Now that you&#39;ve extracted the values you need, it&#39;s just a matter of assigning them a new value. \r\n\r\n    $ cat automationConfig | jq &#39;.processes[].version = &quot;3.0.6&quot;&#39;",
                "title": "search and replace with &#39;jq&#39; JSON shell tool"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1446295151,
        "creation_date": 1446223506,
        "question_id": 33440952,
        "body_markdown": "Here extract from JSON output. The JSON document automationConfig is MongoDB Ops Manager, a commercial product for management of `mongod`.\r\n\r\n    $ cat automationConfig |  jq &#39;.processes[]&#39;\r\n    {\r\n      &quot;args2_6&quot;: {\r\n        &quot;net&quot;: {\r\n          &quot;port&quot;: 28200\r\n        },\r\n        &quot;operationProfiling&quot;: {},\r\n        &quot;replication&quot;: {\r\n          &quot;replSetName&quot;: &quot;wooomtest-cache-dbspace&quot;\r\n        },\r\n        &quot;storage&quot;: {\r\n          &quot;dbPath&quot;: &quot;/data/wooomtest-cache-dbspace/wooomtest-cache-dbspace_0&quot;,\r\n          &quot;engine&quot;: &quot;wiredTiger&quot;\r\n        },\r\n        &quot;systemLog&quot;: {\r\n          &quot;destination&quot;: &quot;file&quot;,\r\n          &quot;path&quot;: &quot;/data/wooomtest-cache-dbspace/wooomtest-cache-dbspace_0/mongodb.log&quot;\r\n        }\r\n      },\r\n      &quot;authSchemaVersion&quot;: 5,\r\n      &quot;disabled&quot;: false,\r\n      &quot;hostname&quot;: &quot;node-z5-wooomtest-ca-sc-wooom-stack4-prd-1.sc-wooom-stack4-prd.local&quot;,\r\n      &quot;logRotate&quot;: {\r\n        &quot;sizeThresholdMB&quot;: 1000,\r\n        &quot;timeThresholdHrs&quot;: 24\r\n      },\r\n      &quot;name&quot;: &quot;wooomtest-cache-dbspace_0&quot;,\r\n      &quot;processType&quot;: &quot;mongod&quot;,\r\n      &quot;version&quot;: &quot;3.0.7&quot;\r\n    }\r\n    {\r\n      &quot;args2_6&quot;: {\r\n        &quot;net&quot;: {\r\n          &quot;port&quot;: 28200\r\n        },\r\n        &quot;operationProfiling&quot;: {},\r\n        &quot;replication&quot;: {\r\n          &quot;replSetName&quot;: &quot;wooomtest-cache-dbspace&quot;\r\n        },\r\n        &quot;storage&quot;: {\r\n          &quot;dbPath&quot;: &quot;/data/wooomtest-cache-dbspace/wooomtest-cache-dbspace_1&quot;,\r\n          &quot;engine&quot;: &quot;wiredTiger&quot;\r\n        },\r\n        &quot;systemLog&quot;: {\r\n          &quot;destination&quot;: &quot;file&quot;,\r\n          &quot;path&quot;: &quot;/data/wooomtest-cache-dbspace/wooomtest-cache-dbspace_1/mongodb.log&quot;\r\n        }\r\n      },\r\n      &quot;authSchemaVersion&quot;: 5,\r\n      &quot;disabled&quot;: false,\r\n      &quot;hostname&quot;: &quot;node-z5-wooomtest-ca-sc-wooom-stack4-prd-2.sc-wooom-stack4-prd.local&quot;,\r\n      &quot;logRotate&quot;: {\r\n        &quot;sizeThresholdMB&quot;: 1000,\r\n        &quot;timeThresholdHrs&quot;: 24\r\n      },\r\n      &quot;name&quot;: &quot;wooomtest-cache-dbspace_1&quot;,\r\n      &quot;processType&quot;: &quot;mongod&quot;,\r\n      &quot;version&quot;: &quot;3.0.7&quot;\r\n    }\r\n    {\r\n      &quot;args2_6&quot;: {\r\n        &quot;net&quot;: {\r\n          &quot;port&quot;: 28200\r\n        },\r\n        &quot;operationProfiling&quot;: {},\r\n        &quot;replication&quot;: {\r\n          &quot;replSetName&quot;: &quot;wooomtest-cache-dbspace&quot;\r\n        },\r\n        &quot;storage&quot;: {\r\n          &quot;dbPath&quot;: &quot;/data/wooomtest-cache-dbspace/wooomtest-cache-dbspace_2&quot;,\r\n          &quot;engine&quot;: &quot;wiredTiger&quot;\r\n        },\r\n        &quot;systemLog&quot;: {\r\n          &quot;destination&quot;: &quot;file&quot;,\r\n          &quot;path&quot;: &quot;/data/wooomtest-cache-dbspace/wooomtest-cache-dbspace_2/mongodb.log&quot;\r\n        }\r\n      },\r\n      &quot;authSchemaVersion&quot;: 5,\r\n      &quot;disabled&quot;: false,\r\n      &quot;hostname&quot;: &quot;node-z5-wooomtest-ca-sc-wooom-stack4-prd-3.sc-wooom-stack4-prd.local&quot;,\r\n      &quot;logRotate&quot;: {\r\n        &quot;sizeThresholdMB&quot;: 1000,\r\n        &quot;timeThresholdHrs&quot;: 24\r\n      },\r\n      &quot;name&quot;: &quot;wooomtest-cache-dbspace_2&quot;,\r\n      &quot;processType&quot;: &quot;mongod&quot;,\r\n      &quot;version&quot;: &quot;3.0.7&quot;\r\n    }\r\n    {\r\n      &quot;args2_6&quot;: {\r\n        &quot;net&quot;: {\r\n          &quot;port&quot;: 28000\r\n        },\r\n        &quot;operationProfiling&quot;: {},\r\n        &quot;replication&quot;: {\r\n          &quot;replSetName&quot;: &quot;wooomtest-identity-dbspace&quot;\r\n        },\r\n        &quot;storage&quot;: {\r\n          &quot;dbPath&quot;: &quot;/data/wooomtest-identity-dbspace/wooomtest-identity-dbspace_3&quot;,\r\n          &quot;engine&quot;: &quot;wiredTiger&quot;\r\n        },\r\n        &quot;systemLog&quot;: {\r\n          &quot;destination&quot;: &quot;file&quot;,\r\n          &quot;path&quot;: &quot;/data/wooomtest-identity-dbspace/wooomtest-identity-dbspace_3/mongodb.log&quot;\r\n        }\r\n      },\r\n      &quot;authSchemaVersion&quot;: 5,\r\n      &quot;disabled&quot;: false,\r\n      &quot;hostname&quot;: &quot;node-z5-wooomtest-id-sc-wooom-stack4-prd-1.sc-wooom-stack4-prd.local&quot;,\r\n      &quot;logRotate&quot;: {\r\n        &quot;sizeThresholdMB&quot;: 1000,\r\n        &quot;timeThresholdHrs&quot;: 24\r\n      },\r\n      &quot;name&quot;: &quot;wooomtest-identity-dbspace_3&quot;,\r\n      &quot;processType&quot;: &quot;mongod&quot;,\r\n      &quot;version&quot;: &quot;3.0.7&quot;\r\n    }\r\n    {\r\n      &quot;args2_6&quot;: {\r\n        &quot;net&quot;: {\r\n          &quot;port&quot;: 28000\r\n        },\r\n        &quot;operationProfiling&quot;: {},\r\n        &quot;replication&quot;: {\r\n          &quot;replSetName&quot;: &quot;wooomtest-identity-dbspace&quot;\r\n        },\r\n        &quot;storage&quot;: {\r\n          &quot;dbPath&quot;: &quot;/data/wooomtest-identity-dbspace/wooomtest-identity-dbspace_4&quot;,\r\n          &quot;engine&quot;: &quot;wiredTiger&quot;\r\n        },\r\n        &quot;systemLog&quot;: {\r\n          &quot;destination&quot;: &quot;file&quot;,\r\n          &quot;path&quot;: &quot;/data/wooomtest-identity-dbspace/wooomtest-identity-dbspace_4/mongodb.log&quot;\r\n        }\r\n      },\r\n      &quot;authSchemaVersion&quot;: 5,\r\n      &quot;disabled&quot;: false,\r\n      &quot;hostname&quot;: &quot;node-z5-wooomtest-id-sc-wooom-stack4-prd-2.sc-wooom-stack4-prd.local&quot;,\r\n      &quot;logRotate&quot;: {\r\n        &quot;sizeThresholdMB&quot;: 1000,\r\n        &quot;timeThresholdHrs&quot;: 24\r\n      },\r\n      &quot;name&quot;: &quot;wooomtest-identity-dbspace_4&quot;,\r\n      &quot;processType&quot;: &quot;mongod&quot;,\r\n      &quot;version&quot;: &quot;3.0.7&quot;\r\n    }\r\n    {\r\n      &quot;args2_6&quot;: {\r\n        &quot;net&quot;: {\r\n          &quot;port&quot;: 28000\r\n        },\r\n        &quot;operationProfiling&quot;: {},\r\n        &quot;replication&quot;: {\r\n          &quot;replSetName&quot;: &quot;wooomtest-identity-dbspace&quot;\r\n        },\r\n        &quot;storage&quot;: {\r\n          &quot;dbPath&quot;: &quot;/data/wooomtest-identity-dbspace/wooomtest-identity-dbspace_5&quot;,\r\n          &quot;engine&quot;: &quot;wiredTiger&quot;\r\n        },\r\n        &quot;systemLog&quot;: {\r\n          &quot;destination&quot;: &quot;file&quot;,\r\n          &quot;path&quot;: &quot;/data/wooomtest-identity-dbspace/wooomtest-identity-dbspace_5/mongodb.log&quot;\r\n        }\r\n      },\r\n      &quot;authSchemaVersion&quot;: 5,\r\n      &quot;disabled&quot;: false,\r\n      &quot;hostname&quot;: &quot;node-z5-wooomtest-id-sc-wooom-stack4-prd-3.sc-wooom-stack4-prd.local&quot;,\r\n      &quot;logRotate&quot;: {\r\n        &quot;sizeThresholdMB&quot;: 1000,\r\n        &quot;timeThresholdHrs&quot;: 24\r\n      },\r\n      &quot;name&quot;: &quot;wooomtest-identity-dbspace_5&quot;,\r\n      &quot;processType&quot;: &quot;mongod&quot;,\r\n      &quot;version&quot;: &quot;3.0.7&quot;\r\n    }\r\n    {\r\n      &quot;args2_6&quot;: {\r\n        &quot;net&quot;: {\r\n          &quot;port&quot;: 28300\r\n        },\r\n        &quot;operationProfiling&quot;: {},\r\n        &quot;replication&quot;: {\r\n          &quot;replSetName&quot;: &quot;wooomtest-library-dbspace&quot;\r\n        },\r\n        &quot;storage&quot;: {\r\n          &quot;dbPath&quot;: &quot;/data/wooomtest-library-dbspace/wooomtest-library-dbspace_6&quot;,\r\n          &quot;engine&quot;: &quot;wiredTiger&quot;\r\n        },\r\n        &quot;systemLog&quot;: {\r\n          &quot;destination&quot;: &quot;file&quot;,\r\n          &quot;path&quot;: &quot;/data/wooomtest-library-dbspace/wooomtest-library-dbspace_6/mongodb.log&quot;\r\n        }\r\n      },\r\n      &quot;authSchemaVersion&quot;: 5,\r\n      &quot;disabled&quot;: false,\r\n      &quot;hostname&quot;: &quot;node-z5-wooomtest-lib-sc-wooom-stack4-prd-1.sc-wooom-stack4-prd.local&quot;,\r\n      &quot;logRotate&quot;: {\r\n        &quot;sizeThresholdMB&quot;: 1000,\r\n        &quot;timeThresholdHrs&quot;: 24\r\n      },\r\n      &quot;name&quot;: &quot;wooomtest-library-dbspace_6&quot;,\r\n      &quot;processType&quot;: &quot;mongod&quot;,\r\n      &quot;version&quot;: &quot;3.0.7&quot;\r\n    }\r\n    {\r\n      &quot;args2_6&quot;: {\r\n        &quot;net&quot;: {\r\n          &quot;port&quot;: 28300\r\n        },\r\n        &quot;operationProfiling&quot;: {},\r\n        &quot;replication&quot;: {\r\n          &quot;replSetName&quot;: &quot;wooomtest-library-dbspace&quot;\r\n        },\r\n        &quot;storage&quot;: {\r\n          &quot;dbPath&quot;: &quot;/data/wooomtest-library-dbspace/wooomtest-library-dbspace_7&quot;,\r\n          &quot;engine&quot;: &quot;wiredTiger&quot;\r\n        },\r\n        &quot;systemLog&quot;: {\r\n          &quot;destination&quot;: &quot;file&quot;,\r\n          &quot;path&quot;: &quot;/data/wooomtest-library-dbspace/wooomtest-library-dbspace_7/mongodb.log&quot;\r\n        }\r\n      },\r\n      &quot;authSchemaVersion&quot;: 5,\r\n      &quot;disabled&quot;: false,\r\n      &quot;hostname&quot;: &quot;node-z5-wooomtest-lib-sc-wooom-stack4-prd-2.sc-wooom-stack4-prd.local&quot;,\r\n      &quot;logRotate&quot;: {\r\n        &quot;sizeThresholdMB&quot;: 1000,\r\n        &quot;timeThresholdHrs&quot;: 24\r\n      },\r\n      &quot;name&quot;: &quot;wooomtest-library-dbspace_7&quot;,\r\n      &quot;processType&quot;: &quot;mongod&quot;,\r\n      &quot;version&quot;: &quot;3.0.7&quot;\r\n    }\r\n    {\r\n      &quot;args2_6&quot;: {\r\n        &quot;net&quot;: {\r\n          &quot;port&quot;: 28300\r\n        },\r\n        &quot;operationProfiling&quot;: {},\r\n        &quot;replication&quot;: {\r\n          &quot;replSetName&quot;: &quot;wooomtest-library-dbspace&quot;\r\n        },\r\n        &quot;storage&quot;: {\r\n          &quot;dbPath&quot;: &quot;/data/wooomtest-library-dbspace/wooomtest-library-dbspace_8&quot;,\r\n          &quot;engine&quot;: &quot;wiredTiger&quot;\r\n        },\r\n        &quot;systemLog&quot;: {\r\n          &quot;destination&quot;: &quot;file&quot;,\r\n          &quot;path&quot;: &quot;/data/wooomtest-library-dbspace/wooomtest-library-dbspace_8/mongodb.log&quot;\r\n        }\r\n      },\r\n      &quot;authSchemaVersion&quot;: 5,\r\n      &quot;disabled&quot;: false,\r\n      &quot;hostname&quot;: &quot;node-z5-wooomtest-lib-sc-wooom-stack4-prd-3.sc-wooom-stack4-prd.local&quot;,\r\n      &quot;logRotate&quot;: {\r\n        &quot;sizeThresholdMB&quot;: 1000,\r\n        &quot;timeThresholdHrs&quot;: 24\r\n      },\r\n      &quot;name&quot;: &quot;wooomtest-library-dbspace_8&quot;,\r\n      &quot;processType&quot;: &quot;mongod&quot;,\r\n      &quot;version&quot;: &quot;3.0.7&quot;\r\n    }\r\n    {\r\n      &quot;args2_6&quot;: {\r\n        &quot;net&quot;: {\r\n          &quot;port&quot;: 28100\r\n        },\r\n        &quot;operationProfiling&quot;: {},\r\n        &quot;replication&quot;: {\r\n          &quot;replSetName&quot;: &quot;wooomtest-storage-dbspace&quot;\r\n        },\r\n        &quot;storage&quot;: {\r\n          &quot;dbPath&quot;: &quot;/data/wooomtest-storage-dbspace/wooomtest-storage-dbspace_9&quot;,\r\n          &quot;engine&quot;: &quot;wiredTiger&quot;\r\n        },\r\n        &quot;systemLog&quot;: {\r\n          &quot;destination&quot;: &quot;file&quot;,\r\n          &quot;path&quot;: &quot;/data/wooomtest-storage-dbspace/wooomtest-storage-dbspace_9/mongodb.log&quot;\r\n        }\r\n      },\r\n      &quot;authSchemaVersion&quot;: 5,\r\n      &quot;disabled&quot;: false,\r\n      &quot;hostname&quot;: &quot;node-z5-wooomtest-st-sc-wooom-stack4-prd-1.sc-wooom-stack4-prd.local&quot;,\r\n      &quot;logRotate&quot;: {\r\n        &quot;sizeThresholdMB&quot;: 1000,\r\n        &quot;timeThresholdHrs&quot;: 24\r\n      },\r\n      &quot;name&quot;: &quot;wooomtest-storage-dbspace_9&quot;,\r\n      &quot;processType&quot;: &quot;mongod&quot;,\r\n      &quot;version&quot;: &quot;3.0.7&quot;\r\n    }\r\n    {\r\n      &quot;args2_6&quot;: {\r\n        &quot;net&quot;: {\r\n          &quot;port&quot;: 28100\r\n        },\r\n        &quot;operationProfiling&quot;: {},\r\n        &quot;replication&quot;: {\r\n          &quot;replSetName&quot;: &quot;wooomtest-storage-dbspace&quot;\r\n        },\r\n        &quot;storage&quot;: {\r\n          &quot;dbPath&quot;: &quot;/data/wooomtest-storage-dbspace/wooomtest-storage-dbspace_10&quot;,\r\n          &quot;engine&quot;: &quot;wiredTiger&quot;\r\n        },\r\n        &quot;systemLog&quot;: {\r\n          &quot;destination&quot;: &quot;file&quot;,\r\n          &quot;path&quot;: &quot;/data/wooomtest-storage-dbspace/wooomtest-storage-dbspace_10/mongodb.log&quot;\r\n        }\r\n      },\r\n      &quot;authSchemaVersion&quot;: 5,\r\n      &quot;disabled&quot;: false,\r\n      &quot;hostname&quot;: &quot;node-z5-wooomtest-st-sc-wooom-stack4-prd-2.sc-wooom-stack4-prd.local&quot;,\r\n      &quot;logRotate&quot;: {\r\n        &quot;sizeThresholdMB&quot;: 1000,\r\n        &quot;timeThresholdHrs&quot;: 24\r\n      },\r\n      &quot;name&quot;: &quot;wooomtest-storage-dbspace_10&quot;,\r\n      &quot;processType&quot;: &quot;mongod&quot;,\r\n      &quot;version&quot;: &quot;3.0.7&quot;\r\n    }\r\n    {\r\n      &quot;args2_6&quot;: {\r\n        &quot;net&quot;: {\r\n          &quot;port&quot;: 28100\r\n        },\r\n        &quot;operationProfiling&quot;: {},\r\n        &quot;replication&quot;: {\r\n          &quot;replSetName&quot;: &quot;wooomtest-storage-dbspace&quot;\r\n        },\r\n        &quot;storage&quot;: {\r\n          &quot;dbPath&quot;: &quot;/data/wooomtest-storage-dbspace/wooomtest-storage-dbspace_11&quot;,\r\n          &quot;engine&quot;: &quot;wiredTiger&quot;\r\n        },\r\n        &quot;systemLog&quot;: {\r\n          &quot;destination&quot;: &quot;file&quot;,\r\n          &quot;path&quot;: &quot;/data/wooomtest-storage-dbspace/wooomtest-storage-dbspace_11/mongodb.log&quot;\r\n        }\r\n      },\r\n      &quot;authSchemaVersion&quot;: 5,\r\n      &quot;disabled&quot;: false,\r\n      &quot;hostname&quot;: &quot;node-z5-wooomtest-st-sc-wooom-stack4-prd-3.sc-wooom-stack4-prd.local&quot;,\r\n      &quot;logRotate&quot;: {\r\n        &quot;sizeThresholdMB&quot;: 1000,\r\n        &quot;timeThresholdHrs&quot;: 24\r\n      },\r\n      &quot;name&quot;: &quot;wooomtest-storage-dbspace_11&quot;,\r\n      &quot;processType&quot;: &quot;mongod&quot;,\r\n      &quot;version&quot;: &quot;3.0.7&quot;\r\n    }\r\n    {\r\n      &quot;args2_6&quot;: {\r\n        &quot;net&quot;: {\r\n          &quot;port&quot;: 28400\r\n        },\r\n        &quot;operationProfiling&quot;: {},\r\n        &quot;replication&quot;: {\r\n          &quot;replSetName&quot;: &quot;wooomtest-support-dbspace&quot;\r\n        },\r\n        &quot;storage&quot;: {\r\n          &quot;dbPath&quot;: &quot;/data/wooomtest-support-dbspace/wooomtest-support-dbspace_12&quot;,\r\n          &quot;engine&quot;: &quot;wiredTiger&quot;\r\n        },\r\n        &quot;systemLog&quot;: {\r\n          &quot;destination&quot;: &quot;file&quot;,\r\n          &quot;path&quot;: &quot;/data/wooomtest-support-dbspace/wooomtest-support-dbspace_12/mongodb.log&quot;\r\n        }\r\n      },\r\n      &quot;authSchemaVersion&quot;: 5,\r\n      &quot;hostname&quot;: &quot;node-z5-wooomtest-sup-sc-wooom-stack4-prd-1.sc-wooom-stack4-prd.local&quot;,\r\n      &quot;logRotate&quot;: {\r\n        &quot;sizeThresholdMB&quot;: 1000,\r\n        &quot;timeThresholdHrs&quot;: 24\r\n      },\r\n      &quot;name&quot;: &quot;wooomtest-support-dbspace_12&quot;,\r\n      &quot;processType&quot;: &quot;mongod&quot;,\r\n      &quot;version&quot;: &quot;3.0.7&quot;\r\n    }\r\n    {\r\n      &quot;args2_6&quot;: {\r\n        &quot;net&quot;: {\r\n          &quot;port&quot;: 28400\r\n        },\r\n        &quot;operationProfiling&quot;: {},\r\n        &quot;replication&quot;: {\r\n          &quot;replSetName&quot;: &quot;wooomtest-support-dbspace&quot;\r\n        },\r\n        &quot;storage&quot;: {\r\n          &quot;dbPath&quot;: &quot;/data/wooomtest-support-dbspace/wooomtest-support-dbspace_13&quot;,\r\n          &quot;engine&quot;: &quot;wiredTiger&quot;\r\n        },\r\n        &quot;systemLog&quot;: {\r\n          &quot;destination&quot;: &quot;file&quot;,\r\n          &quot;path&quot;: &quot;/data/wooomtest-support-dbspace/wooomtest-support-dbspace_13/mongodb.log&quot;\r\n        }\r\n      },\r\n      &quot;authSchemaVersion&quot;: 5,\r\n      &quot;hostname&quot;: &quot;node-z5-wooomtest-sup-sc-wooom-stack4-prd-2.sc-wooom-stack4-prd.local&quot;,\r\n      &quot;logRotate&quot;: {\r\n        &quot;sizeThresholdMB&quot;: 1000,\r\n        &quot;timeThresholdHrs&quot;: 24\r\n      },\r\n      &quot;name&quot;: &quot;wooomtest-support-dbspace_13&quot;,\r\n      &quot;processType&quot;: &quot;mongod&quot;,\r\n      &quot;version&quot;: &quot;3.0.7&quot;\r\n    }\r\n    {\r\n      &quot;args2_6&quot;: {\r\n        &quot;net&quot;: {\r\n          &quot;port&quot;: 28400\r\n        },\r\n        &quot;operationProfiling&quot;: {},\r\n        &quot;replication&quot;: {\r\n          &quot;replSetName&quot;: &quot;wooomtest-support-dbspace&quot;\r\n        },\r\n        &quot;storage&quot;: {\r\n          &quot;dbPath&quot;: &quot;/data/wooomtest-support-dbspace/wooomtest-support-dbspace_14&quot;,\r\n          &quot;engine&quot;: &quot;wiredTiger&quot;\r\n        },\r\n        &quot;systemLog&quot;: {\r\n          &quot;destination&quot;: &quot;file&quot;,\r\n          &quot;path&quot;: &quot;/data/wooomtest-support-dbspace/wooomtest-support-dbspace_14/mongodb.log&quot;\r\n        }\r\n      },\r\n      &quot;authSchemaVersion&quot;: 5,\r\n      &quot;hostname&quot;: &quot;node-z5-wooomtest-sup-sc-wooom-stack4-prd-3.sc-wooom-stack4-prd.local&quot;,\r\n      &quot;logRotate&quot;: {\r\n        &quot;sizeThresholdMB&quot;: 1000,\r\n        &quot;timeThresholdHrs&quot;: 24\r\n      },\r\n      &quot;name&quot;: &quot;wooomtest-support-dbspace_14&quot;,\r\n      &quot;processType&quot;: &quot;mongod&quot;,\r\n      &quot;version&quot;: &quot;3.0.7&quot;\r\n    }\r\n\r\nI was able to extract only version\r\n\r\n    $ cat automationConfig |  jq &#39;.processes[] .version&#39; \r\n    &quot;3.0.7&quot;\r\n    &quot;3.0.7&quot;\r\n    &quot;3.0.7&quot;\r\n    &quot;3.0.7&quot;\r\n    &quot;3.0.7&quot;\r\n    &quot;3.0.7&quot;\r\n    &quot;3.0.7&quot;\r\n    &quot;3.0.7&quot;\r\n    &quot;3.0.7&quot;\r\n    &quot;3.0.7&quot;\r\n    &quot;3.0.7&quot;\r\n    &quot;3.0.7&quot;\r\n    &quot;3.0.7&quot;\r\n    &quot;3.0.7&quot;\r\n    &quot;3.0.7&quot;\r\n\r\nNow I wish to replace the number &quot;3.0.7&quot; with &quot;3.0.6&quot; using shell tool `jq`. \r\n\r\nI am following this [docs.mongodb.com][1], but wish to do downgrade (not upgrade).\r\n\r\n\r\n  [1]: https://docs.opsmanager.mongodb.com/master/tutorial/update-mongodb-version-of-deployment-via-api/",
        "link": "https://stackoverflow.com/questions/33440952/search-and-replace-with-jq-json-shell-tool",
        "title": "search and replace with &#39;jq&#39; JSON shell tool"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1446653889,
                "last_edit_date": 1446653889,
                "creation_date": 1446646969,
                "answer_id": 33524293,
                "question_id": 33520220,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    def swapper:\r\n      . as $in\r\n      | reduce keys[] as $key\r\n          ( {}; . + ( $in[$key] as $o\r\n                      | ($o|keys[0]) as $innerkey\r\n                      | { ($innerkey): { ($key): $o[$innerkey] } } ) ) ;\r\n\r\nExample:\r\n\r\n    { &quot;a&quot;: {&quot;b&quot;: 0}, &quot;c&quot;: {&quot;d&quot;: 1}} | swapper\r\nproduces:\r\n\r\n    {&quot;b&quot;:{&quot;a&quot;:0},&quot;d&quot;:{&quot;c&quot;:1}}\r\n",
                "title": "Swap keys in nested objects using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1446653864,
                "creation_date": 1446653864,
                "answer_id": 33526800,
                "question_id": 33520220,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s an alternative using `with_entries`:\r\n\r\n    with_entries(.key as $parent\r\n      | (.value|keys[0]) as $child\r\n      | {\r\n            key: $child,\r\n            value: { ($parent): .value[$child] }\r\n        }\r\n    )",
                "title": "Swap keys in nested objects using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501805556,
                "last_edit_date": 1501805556,
                "creation_date": 1501805071,
                "answer_id": 45496350,
                "question_id": 33520220,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses jq streams and variables:\r\n\r\n    [\r\n      . as $d\r\n    | keys[]\r\n    | $d[.] as $v\r\n    | ($v|keys[]) as $vkeys\r\n    | {\r\n        ($vkeys): {\r\n           (.): ($vkeys|$v[.])\r\n        }\r\n      }\r\n    ] | add\r\n\r\nIt is easy to lose track of what is what at the end so to see more clearly what&#39;s going on here is a slightly expanded version with additional comments and variables.\r\n\r\n    [\r\n      . as $d                    # $d:     {&quot;a&quot;:{&quot;b&quot;:0},&quot;c&quot;:{&quot;d&quot;: 1}}\r\n    | keys[] | . as $k           # $k:     &quot;a&quot;, &quot;c&quot;\r\n    | $d[$k] as $v               # $v:     {&quot;b&quot;: 0}, {&quot;d&quot;: 1}\r\n    | ($v|keys[]) as $vkeys      # $vkeys: &quot;b&quot;, &quot;d&quot;\r\n    | ($vkeys|$v[.]) as $vv      # $vv:    0, 1\r\n    | {\r\n        ($vkeys): {              # &quot;b&quot;: {     &quot;d&quot;: {\r\n           ($k): $vv             #   &quot;a&quot;: 0      &quot;c&quot;: 1\r\n        }                        # }        , }\r\n      }\r\n    ] | add\r\n",
                "title": "Swap keys in nested objects using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1501805556,
        "creation_date": 1446635157,
        "last_edit_date": 1446653946,
        "question_id": 33520220,
        "body_markdown": "Using [jq][1], how can I transform:\r\n\r\n    { &quot;a&quot;: {&quot;b&quot;: 0}, &quot;c&quot;: {&quot;d&quot;: 1}}\r\n\r\ninto:\r\n\r\n    {&quot;b&quot;: {&quot;a&quot;: 0}, &quot;d&quot;: {&quot;c&quot;: 1}}\r\n\r\nwithout knowing the name of the keys in the source?\r\n\r\n(I know that this can lose data in the general case, but not with my data)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/33520220/swap-keys-in-nested-objects-using-jq",
        "title": "Swap keys in nested objects using JQ"
    },
    {
        "tags": [
            "javascript",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1446675806,
                "last_edit_date": 1446675806,
                "creation_date": 1446655711,
                "answer_id": 33527427,
                "question_id": 33525267,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following adds the &quot;id&quot; property as requested:\r\n\r\n    .objects.delegaciones.geometries[] |= (.id = .properties.id)\r\n",
                "title": "Using jq to assign property of child to parent dictionary"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1446675806,
        "creation_date": 1446649834,
        "last_edit_date": 1446650518,
        "question_id": 33525267,
        "body_markdown": "I have a TopoJSON file with several geometries. It looks like so:\r\n\r\n    {\r\n      &quot;type&quot;: &quot;Topology&quot;,\r\n      &quot;objects&quot;: {\r\n        &quot;delegaciones&quot;: {\r\n          &quot;geometries&quot;: [\r\n            {\r\n              &quot;properties&quot;: {\r\n                &quot;name&quot;: &quot;Tlalpan&quot;,\r\n                &quot;municip&quot;: &quot;012&quot;,\r\n                &quot;id&quot;: &quot;09012&quot;,\r\n                &quot;state&quot;: &quot;09&quot;\r\n              }\r\n    ...\r\n\r\nI want to be able to take the `id` field from `properties`, and assign it to the parent, so that the result is:\r\n\r\n    {\r\n      &quot;type&quot;: &quot;Topology&quot;,\r\n      &quot;objects&quot;: {\r\n        &quot;delegaciones&quot;: {\r\n          &quot;geometries&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;09012&quot;,\r\n              &quot;properties&quot;: {\r\n                &quot;name&quot;: &quot;Tlalpan&quot;,\r\n                &quot;municip&quot;: &quot;012&quot;,\r\n                &quot;id&quot;: &quot;09012&quot;, // &lt;-- It&#39;s okay if it&#39;s removed or not\r\n                &quot;state&quot;: &quot;09&quot;\r\n              }\r\n    ...\r\n\r\nI tried the following assignment on jq, but it&#39;s not correct:\r\n\r\n    jq &#39;.objects.delegaciones.geometries[].id = .objects.delegaciones.geometries[].properties.id&#39; topo_df.json \r\n\r\nAnyone know how I can make jq iterate elements one by one? Or how I can make this work?",
        "link": "https://stackoverflow.com/questions/33525267/using-jq-to-assign-property-of-child-to-parent-dictionary",
        "title": "Using jq to assign property of child to parent dictionary"
    },
    {
        "tags": [
            "json",
            "matlab",
            "csv",
            "elasticsearch",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1514754,
                    "reputation": 11080,
                    "user_id": 1416035,
                    "user_type": "registered",
                    "accept_rate": 66,
                    "profile_image": "https://i.sstatic.net/7ue1e.png?s=256",
                    "display_name": "Sten Petrov",
                    "link": "https://stackoverflow.com/users/1416035/sten-petrov"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1446687482,
                "post_id": 33535186,
                "comment_id": 54851821,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3016061,
                    "reputation": 115,
                    "user_id": 2558204,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d1c931444daf5c15d78b93706478124d?s=256&d=identicon&r=PG",
                    "display_name": "bjg",
                    "link": "https://stackoverflow.com/users/2558204/bjg"
                },
                "reply_to_user": {
                    "account_id": 1514754,
                    "reputation": 11080,
                    "user_id": 1416035,
                    "user_type": "registered",
                    "accept_rate": 66,
                    "profile_image": "https://i.sstatic.net/7ue1e.png?s=256",
                    "display_name": "Sten Petrov",
                    "link": "https://stackoverflow.com/users/1416035/sten-petrov"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1448051719,
                "post_id": 33535186,
                "comment_id": 55436547,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1446745852,
                "last_edit_date": 1446745852,
                "creation_date": 1446697241,
                "answer_id": 33536644,
                "question_id": 33535186,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following, I believe, does what you said you want, but I don&#39;t fully understand the connection between your input files and the output that you included.  Hopefully this will at least put you on the right track.\r\n\r\nThe program assumes all your data will fit into memory.  It uses JSON objects as dictionaries for fast lookup and so should be quite performant.\r\n\r\nThe approach taken here separates the csv-to-json conversion from the aggregation, as there may be better ways to do the former.  (See for example [the jq Cookbook entry on convert-a-csv-file-with-headers-to-json][1].)\r\n\r\nThe first file (scsv2json.jq) is for converting simple CSV to JSON.  The second file (aggregate.jq) does the aggregation.  With these in place:\r\n\r\n```\r\n$ (jq -R -s -f scsv2json.jq file1.csv ;\\\r\n   jq -R -s -f scsv2json.jq file2.csv) |\\\r\n   jq -s -c -f aggregate.jq\r\n[{&quot;id&quot;:&quot;1&quot;,\r\n  &quot;file1&quot;:{&quot;age&quot;:&quot;49&quot;,&quot;gender&quot;:&quot;M&quot;,&quot;wave&quot;:&quot;1&quot;},\r\n  &quot;file2&quot;:{&quot;time&quot;:&quot;4/21/2095&quot;,&quot;event1&quot;:&quot;T21&quot;}},\r\n {&quot;id&quot;:&quot;2&quot;,\r\n   &quot;file1&quot;:{&quot;age&quot;:&quot;72&quot;,&quot;gender&quot;:&quot;F&quot;,&quot;wave&quot;:&quot;0&quot;},\r\n   &quot;file2&quot;:{&quot;time&quot;:&quot;5/17/2094&quot;,&quot;event1&quot;:&quot;V39&quot;}}]\r\n``` \r\n\r\nNotice that the &quot;id&quot; has been removed from the inner objects in the output.\r\n\r\naggregate.jq:\r\n\r\n    # Input: an array of objects, each with an &quot;id&quot; field\r\n    # such that (tostring|.id) is an index.\r\n    # Output: a dictionary keyed by the id field.\r\n    def todictionary:\r\n      reduce .[] as $row ( {}; . + { ($row.id | tostring): $row } );\r\n\r\n    def aggregate:\r\n      .[0] as $file1\r\n      | .[1] as $file2\r\n      | ($file1 | todictionary) as $d1\r\n      | ($file2 | todictionary) as $d2\r\n      | ( [$file1[].id] + [$file2[].id] | unique ) as $keys\r\n      | reduce ($keys[] | tostring) as $k\r\n          ( [];\r\n            . + [{&quot;id&quot;: $k, \r\n                  &quot;file1&quot;: ($d1[$k] | del(.id)),\r\n                  &quot;file2&quot;: ($d2[$k] | del(.id)) }] );\r\n\r\n    aggregate\r\n\r\nscsv2json.jq\r\n\r\n    def objectify(headers):\r\n      . as $in\r\n      | reduce range(0; headers|length) as $i\r\n          ({}; .[headers[$i]] = ($in[$i]) );\r\n\r\n    def csv2table:\r\n      def trim: sub(&quot;^ +&quot;;&quot;&quot;) |  sub(&quot; +$&quot;;&quot;&quot;);\r\n      split(&quot;\\n&quot;) | map( split(&quot;,&quot;) | map(trim) );\r\n\r\n    def csv2json:\r\n      csv2table\r\n      | .[0] as $headers\r\n      | reduce (.[1:][] | select(length &gt; 0) ) as $row\r\n          ( []; . + [ $row|objectify($headers) ]);\r\n\r\n    csv2json\r\n\r\n\r\nThe above assumes that a version of jq with regex support is being used.  If your jq does not have regex support, simply omit the trimming.\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/Cookbook#convert-a-csv-file-with-headers-to-json",
                "title": "Can jq perform aggregation across files"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1446767408,
                "creation_date": 1446767408,
                "answer_id": 33557002,
                "question_id": 33535186,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a less memory-intensive approach.  It only requires that file1\r\nbe kept in memory: the second file is processed one line at a time.\r\n\r\nInvocation is like so:  \r\n  \r\n    $ jq -n -R --argfile file1 &lt;(jq -R -s -f scsv2json.jq file1.csv)\\\r\n         -f aggregate.jq file2.csv\r\n\r\nwhere scsv2json.jq is as shown in the previous post. It is not repeated here mainly because (as pointed out elsewhere) some other program for converting CSV to JSON in the same manner may be appropriate.\r\n\r\naggregate.jq:\r\n    \r\n    def objectify(headers):\r\n      . as $in\r\n      | reduce range(0; headers|length) as $i\r\n          ({}; .[headers[$i]] = ($in[$i]) );\r\n    \r\n    def csv2table:\r\n      def trim: sub(&quot;^ +&quot;;&quot;&quot;) |  sub(&quot; +$&quot;;&quot;&quot;);\r\n      split(&quot;\\n&quot;) | map( split(&quot;,&quot;) | map(trim) );\r\n    \r\n    # Input: an array of objects, each with an &quot;id&quot; field\r\n    # such that (tostring|.id) is an index.\r\n    # Output: a dictionary keyed by the id field.\r\n    def todictionary:\r\n      reduce .[] as $row ( {}; . + { ($row.id | tostring): $row } );\r\n    \r\n    # input: {&quot;id&quot;: ID } + OBJECT2\r\n    # dict: {ID: OBJECT1, ...}\r\n    # output: {id: ID, &quot;file1&quot;: OBJECT1, &quot;file2&quot;: OBJECT2}\r\n    def aggregate(dict):\r\n      .id as $id\r\n      | (dict[$id] | del(.id)) as $o1\r\n      | {&quot;id&quot;: $id,\r\n         &quot;file1&quot;: $o1,\r\n         &quot;file2&quot;:  del(.id) };\r\n    \r\n    # $file1 is the JSON version of file1.csv -- an array of objects\r\n    (input | csv2table[0]) as $headers\r\n    | inputs\r\n    | csv2table[0]\r\n    | objectify($headers) \r\n    | ($file1 | todictionary) as $d1\r\n    | aggregate($d1)\r\n    ",
                "title": "Can jq perform aggregation across files"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1447042380,
                "last_edit_date": 1447042380,
                "creation_date": 1446830186,
                "answer_id": 33572138,
                "question_id": 33535186,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is an approach for which the jq memory requirements are trivially small.  It assumes that you&#39;ve been able to merge all your .csv files into one stream (or file) of JSON arrays of the form:\r\n\r\n    [id, sourceFile, baggage]\r\n\r\nwhere the value of id is in sorted order.  The stream might look like this:\r\n\r\n     [1,&quot;file1&quot;, {&quot;a&quot;:1}]\r\n     [1,&quot;file2&quot;, {&quot;b&quot;:1}]\r\n     [1,&quot;file3&quot;, {&quot;c&quot;:1}]\r\n     [2,&quot;file1&quot;, {&quot;d&quot;:1}]\r\n     [2,&quot;file2&quot;, {&quot;e&quot;:1}]\r\n     [3,&quot;file1&quot;, {&quot;f&quot;:1}]\r\n\r\nThis preliminary step requires a global sort and thus you may need to select a sort utility carefully.\r\n\r\nThere can be as many file sources as you like; there is no need for each array to fit on one line; and the id values need not be integers -- they could, for example, be strings instead.\r\n\r\nLet&#39;s assume the above is in a file named combined.json and that aggregate.jq has the contents shown below.  Then the invocation:\r\n\r\n    $ jq -c -n -f aggregate.jq combined.json\r\n\r\nwould produce:\r\n\r\n    {&quot;id&quot;:1,&quot;file1&quot;:{&quot;a&quot;:1},&quot;file2&quot;:{&quot;b&quot;:1},&quot;file3&quot;:{&quot;c&quot;:1}}\r\n    {&quot;id&quot;:2,&quot;file1&quot;:{&quot;d&quot;:1},&quot;file2&quot;:{&quot;e&quot;:1}}\r\n    {&quot;id&quot;:3,&quot;file1&quot;:{&quot;f&quot;:1}}\r\n\r\nCORRECTED: aggregate.jq:\r\n\r\n    foreach (inputs,null) as $row\r\n      # At each iteration, if .emit then emit it\r\n      ( {&quot;emit&quot;: null, &quot;current&quot;: null};\r\n\r\n        if $row == null\r\n        then {emit: .current, current: null}          # signal EOF\r\n        else  {id: $row[0], ($row[1]) : $row[2] } as $this\r\n        | if .current == null\r\n          then {emit: null, current: $this}\r\n          elif $row[0] == .current.id\r\n          then .emit = null | .current += $this\r\n          else {emit: .current, current: $this}\r\n\t      end\r\n        end;\r\n        if .emit then .emit else empty end\r\n      )\r\n",
                "title": "Can jq perform aggregation across files"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1448051683,
                "creation_date": 1448051683,
                "answer_id": 33835625,
                "question_id": 33535186,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As suggested in one of the comments I ended up using SQL to export JSON in the format I required.  Another [thread][1] helped tremendously.  In the end I choose to output a given SQL table to its own JSON file instead of combining them (the file size was becoming unmanageable).  This is the code structure to do that such that you produce the command line for the Bulk API and the JSON data line:\r\n\r\n    create or replace function format_data_line(command text, data_str text)\r\n    returns setof text language plpgsql as $$\r\n    begin\r\n        return next command;\r\n        return next             \r\n            replace(\r\n                regexp_replace(data_str,\r\n                    &#39;(\\d\\d\\d\\d-\\d\\d-\\d\\d)T&#39;, &#39;\\1 &#39;, &#39;g&#39;),\r\n                e&#39; \\n &#39;, &#39;&#39;);\r\n    end $$;\r\n    \r\n    COPY (\r\n        with f_1 as(\r\n           SELECT id, json_agg(fileX.*) AS tag\r\n           FROM forum.file3\r\n           GROUP BY id\r\n        )\r\n        SELECT \r\n            format_data_line(\r\n                format(&#39;{&quot;update&quot;:{&quot;_index&quot;:&quot;forum2&quot;,&quot;_type&quot;:&quot;subject&quot;,&quot;_id&quot;:%s}}&#39;,a.id),\r\n                format(&#39;{&quot;doc&quot;:{&quot;id&quot;:%s,&quot;fileX&quot;:%s}}&#39;, \r\n                    a.id, a.tag))\r\n        FROM f_1 a \r\n    ) TO &#39;/path/to/json/fileX.json&#39;;\r\n\r\nImporting the larger files with the Bulk API also turned out to be problematic (out of memory Java errors) so a script was needed to only send subsets of the data to Curl (for indexing in Elasticsearch) at a given time.  The basic structure for that script is:\r\n\r\n    #!/bin/bash\r\n    \r\n    FILE=$1\r\n    INC=100\r\n    numline=`wc -l $FILE | awk &#39;{print $1}&#39;`\r\n    rm -f output/$FILE.txt\r\n    for i in `seq 1 $INC $numline`; do\r\n        TIME=`date +%H:%M:%S`\r\n        echo &quot;[$TIME] Processing lines from $i to $((i + INC -1))&quot;\r\n    \trm -f intermediates/interm_file_$i.json\r\n        sed -n $i,$((i +INC - 1))p $FILE &gt;&gt; intermediates/interm_file_$i.json\r\n        curl -s -XPOST localhost:9200/_bulk --data-binary @intermediates/interm_file_$i.json &gt;&gt; output/$FILE.txt\r\n    done\r\n\r\nAn &quot;intermediates&quot; directory should be created beneath the script files directory.  The script can be saved as &quot;ESscript&quot; and run on the command line with:\r\n\r\n    ./ESscript fileX.json\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/33662850/formatting-postgres-json-output-for-nested-elasticsearch-structure",
                "title": "Can jq perform aggregation across files"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1448051683,
        "creation_date": 1446687101,
        "question_id": 33535186,
        "body_markdown": "I&#39;m trying to identify a program/software which will allow me to efficiently take a number of large CSV files (totaling 40+ GB) and output a JSON file with the specific format I need for import into Elasticsearch (ES).  \r\n\r\nCan jq efficiently take data like this:\r\n\r\n    file1:\r\n    id,age,gender,wave\r\n    1,49,M,1\r\n    2,72,F,0\r\n\r\n    file2:\r\n    id,time,event1\r\n    1,4/20/2095,V39\r\n    1,4/21/2095,T21\r\n    2,5/17/2094,V39\r\n\r\naggregate it by id (such that all the JSON documents from CSV rows in multiple files fall under a single id entry), outputting something like this:\r\n\r\n    {&quot;index&quot;:{&quot;_index&quot;:&quot;forum_mat&quot;,&quot;_type&quot;:&quot;subject&quot;,&quot;_id&quot;:&quot;1&quot;}}\r\n    {&quot;id&quot;:&quot;1&quot;,&quot;file1&quot;:[{&quot;filen&quot;:&quot;file1&quot;,&quot;id&quot;:&quot;1&quot;,&quot;age&quot;:&quot;49&quot;,&quot;gender&quot;:&quot;M&quot;,&quot;wave&quot;:&quot;1&quot;}],&quot;file2&quot;:[{&quot;filen&quot;:&quot;file2&quot;,&quot;id&quot;:&quot;1&quot;,&quot;time&quot;:&quot;4/20/2095&quot;,&quot;event1&quot;:&quot;V39&quot;},{&quot;filen&quot;:&quot;file2&quot;,&quot;id&quot;:&quot;1&quot;,&quot;time&quot;:&quot;4/21/2095&quot;,&quot;event1&quot;:&quot;T21&quot;}]}\r\n    {&quot;index&quot;:{&quot;_index&quot;:&quot;forum_mat&quot;,&quot;_type&quot;:&quot;subject&quot;,&quot;_id&quot;:&quot;2&quot;}}\r\n    {&quot;id&quot;:&quot;2&quot;,&quot;file1&quot;:[{&quot;filen&quot;:&quot;file1&quot;,&quot;id&quot;:&quot;2&quot;,&quot;age&quot;:&quot;72&quot;,&quot;gender&quot;:&quot;F&quot;,&quot;wave&quot;:&quot;0&quot;}],&quot;file2&quot;:[{&quot;filen&quot;:&quot;file2&quot;,&quot;id&quot;:&quot;2&quot;,&quot;time&quot;:&quot;5/17/2094&quot;,&quot;event1&quot;:&quot;V39&quot;}]}\r\n\r\nI wrote a script in Matlab but as I was worried about it is much to slow.  I might take months to crunch all 40+GB of data.  I was [informed][1] that Logstash (which is the preferred data input tool for ES) isn&#39;t good at this type of aggregation.  \r\n\r\n\r\n  [1]: https://discuss.elastic.co/t/logstash-mutate-filter-rename-exception-in-filterworker-exception-indexerror-string-not-matched/33438/4",
        "link": "https://stackoverflow.com/questions/33535186/can-jq-perform-aggregation-across-files",
        "title": "Can jq perform aggregation across files"
    },
    {
        "tags": [
            "json",
            "bash",
            "sh",
            "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": 1446755879,
                "post_id": 33554246,
                "comment_id": 54888126,
                "content_license": "CC BY-SA 3.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": 1446756182,
                "post_id": 33554246,
                "comment_id": 54888304,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user742030"
                },
                "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": 1446756697,
                "post_id": 33554246,
                "comment_id": 54888610,
                "content_license": "CC BY-SA 3.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": 1446756699,
                "post_id": 33554246,
                "comment_id": 54888612,
                "content_license": "CC BY-SA 3.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": 1446756944,
                "post_id": 33554246,
                "comment_id": 54888780,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1446757961,
                "last_edit_date": 1446757961,
                "creation_date": 1446756083,
                "answer_id": 33554378,
                "question_id": 33554246,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For your existing sample data, the following suffices:\r\n\r\n    jq --arg mod &quot;acme&quot; \\\r\n       --arg resolved &quot;some_url&quot; \\\r\n      &#39;.dependencies[$mod].resolved=$resolved&#39; \\\r\n      &lt;in.json &gt;out.json\r\n\r\n...to filter on the `from`, by contrast:\r\n\r\n    jq --arg new_url &quot;http://new.url/&quot; \\\r\n       --arg target &quot;acme@1.2.3&quot; \\\r\n      &#39;.dependencies=(.dependencies\r\n                      | to_entries\r\n                      | map(if(.value.from == $target)\r\n                            then .value.resolved=$new_url\r\n                            else . end)\r\n                      | from_entries)&#39; \\\r\n      &lt;in.json &gt;out.json\r\n",
                "title": "Modify Nested JSON with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1446765199,
                "creation_date": 1446765199,
                "answer_id": 33556603,
                "question_id": 33554246,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you know the name of the dependency you want to update, you could just index into it.\r\n\r\n    $ jq --arg dep &quot;$dep&quot; --arg resolved &quot;$resolved&quot; \\\r\n        &#39;.dependencies[$dep].resolved = $resolved&#39; \\\r\n        OLD.json &gt; NEW.json\r\n\r\nOtherwise, to modify a dependency based on the name (or other property), search for the dependency and update.\r\n\r\n    $ jq --arg version &quot;$version&quot; --arg resolved &quot;$resolved&quot; \\\r\n        &#39;(.dependencies[] | select(.version == $version)).resolved = $resolved&#39; \\\r\n        OLD.json &gt; NEW.json",
                "title": "Modify Nested JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1446765199,
        "creation_date": 1446755631,
        "last_edit_date": 1495541713,
        "question_id": 33554246,
        "body_markdown": "I&#39;m trying to modify nested JSON objects using the `jq &lt;map&gt;` function in a bash/shell script; something similar to [this blog entry][1] but attempting to adapt the examples here to nested objects.\r\n\r\nThe returned JSON to be modified as follows:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;vendor-module&quot;,\r\n      &quot;dependencies&quot;: {\r\n        &quot;abc&quot;: {\r\n          &quot;from&quot;: &quot;abc@2.4.0&quot;,\r\n          &quot;resolved&quot;: &quot;https://some.special.url&quot;,\r\n          &quot;version&quot;: &quot;2.4.0&quot;\r\n        },\r\n        &quot;acme&quot;: {\r\n          &quot;from&quot;: &quot;acme@1.2.3&quot;,\r\n          &quot;resolved&quot;: &quot;&lt;CHANGE_THIS&gt;&quot;,\r\n          &quot;version&quot;: &quot;1.2.3&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nThis would be my attempt:\r\n\r\n\r\n    modules=&quot;`node -pe &#39;JSON.parse(process.argv[1]).dependencies.$dependency&#39; \\\r\n      &quot;$(cat $wrapped)&quot;`&quot;\r\n    version=&quot;1.2.3&quot;\r\n    resolved=&quot;some_url&quot;\r\n    \r\n    cat OLD.json | \r\n      jq &#39;to_entries | \r\n           map(if .dependencies[0].$module[0].from == &quot;$module@$version&quot;\r\n              then . + {&quot;resolved&quot;}={&quot;$resolved&quot;}\r\n              else . \r\n              end\r\n             ) | \r\n          from_entries&#39; &gt; NEW.json\r\n\r\nObviously this doesn&#39;t work.  When I run the script the `NEW.json` is created but without modifications or returned errors. If I don&#39;t target a nested object (e.g., `&quot;name&quot;: &quot;vendor-module&quot;`), The script works as expected. I am sure there is a way to do it using native bash and jq..?? Any help (with the proper escaping) will be greatly appreciated.\r\n\r\n**UPDATE:**\r\n\r\nThnx from the help of [Charles Duffy&#39;s answer][2], and his suggestion of using `sponge`, The solution that works well for me is:\r\n\r\n    jq --arg mod &quot;acme&quot; --arg resolved &quot;Some URL&quot; \\\r\n       &#39;.dependencies[$mod].resolved |= $resolved&#39; \\\r\n       OLD.json | sponge OLD.json\r\n\r\n\r\n\r\n\r\n  [1]: http://engineering.monsanto.com/2015/05/22/jq-change-json/\r\n  [2]: https://stackoverflow.com/a/33554378/742030",
        "link": "https://stackoverflow.com/questions/33554246/modify-nested-json-with-jq",
        "title": "Modify Nested JSON with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1709244572,
                "last_edit_date": 1709244572,
                "creation_date": 1446786148,
                "answer_id": 33559836,
                "question_id": 33558674,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "walk/1 is included in recent (post-1.5) releases of jq.  Its definition is also available below.\r\n\r\nHere&#39;s how it can be used to achieve your objective as I understand it:\r\n\r\n    walk(if type == &quot;array&quot; and length &gt; 1 then [.[0]] else . end)\r\n\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",
                "title": "recursive reduce arrays using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1446821086,
                "creation_date": 1446821086,
                "answer_id": 33569342,
                "question_id": 33558674,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "peak&#39;s answer is great. This problem can also be solved using recursion, but it is not obvious how to make it work.\r\n\r\nThe na&#239;ve solution I came up with was `(.. | arrays) |= .[0]`, but that doesn&#39;t work because the recursion is done from the outside, which means that on nested cases we end up trying to get .[0] from values who are no longer arrays.\r\n\r\nThis can be solved by doing post-order traversal, as explained [in this GitHub issue][postorder]. \r\n\r\nWith `post_recurse`, it&#39;s just a matter of replacing `..` with `post_recurse` in the na&#239;ve solution above. The full solution:\r\n\r\n    def post_recurse(f): def r: (f | select(. != null) | r), .; r; def post_recurse: post_recurse(.[]?); (post_recurse | arrays) |= .[0]\r\n\r\n  [postorder]: https://github.com/stedolan/jq/issues/893",
                "title": "recursive reduce arrays using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501872449,
                "creation_date": 1501872449,
                "answer_id": 45513651,
                "question_id": 33558674,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using **tostream** which converts the input object\r\ninto a stream of paths, filters out any paths with nonzero array indices\r\nand converts the result back to an object using **reduce** and **setpath**.   All the recursion is internal to **tostream**.\r\n\r\n    [\r\n      tostream\r\n\r\n    | if   length != 2 then empty\r\n      elif ([.[0][]|numbers|.!=0]|any) then empty\r\n      else .\r\n      end\r\n    ]\r\n\r\n    | reduce .[] as $p (\r\n        {};     \r\n        setpath($p[0]; $p[1])\r\n      )",
                "title": "recursive reduce arrays using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1709244572,
        "creation_date": 1446778358,
        "question_id": 33558674,
        "body_markdown": "How can I recursive find all arrays in object and reduce them to first item ? \r\n\r\nI tried to detect array using `if .[0]? == &quot;&quot; then .[0] else . end` but it not output anything if current object is not array.\r\n\r\ninput:\r\n\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: [\r\n        1,\r\n        2,\r\n        3\r\n      ],\r\n      &quot;c&quot;: [\r\n        {\r\n          &quot;a&quot;: 1,\r\n          &quot;b&quot;: [\r\n            1,\r\n            2,\r\n            3\r\n          ],\r\n          &quot;c&quot;: {\r\n            &quot;a&quot;: 1,\r\n            &quot;b&quot;: [\r\n              1,\r\n              2,\r\n              3\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;a&quot;: 1,\r\n          &quot;b&quot;: [\r\n            1,\r\n            2,\r\n            3\r\n          ],\r\n          &quot;c&quot;: {\r\n            &quot;a&quot;: 1,\r\n            &quot;b&quot;: [\r\n              1,\r\n              2,\r\n              3\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;a&quot;: 1,\r\n          &quot;b&quot;: [\r\n            1,\r\n            2,\r\n            3\r\n          ],\r\n          &quot;c&quot;: {\r\n            &quot;a&quot;: 1,\r\n            &quot;b&quot;: [\r\n              1,\r\n              2,\r\n              3\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\noutput: \r\n\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: [\r\n        1\r\n      ],\r\n      &quot;c&quot;: [\r\n        {\r\n          &quot;a&quot;: 1,\r\n          &quot;b&quot;: [\r\n            1\r\n          ],\r\n          &quot;c&quot;: {\r\n            &quot;a&quot;: 1,\r\n            &quot;b&quot;: [\r\n              1\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/33558674/recursive-reduce-arrays-using-jq",
        "title": "recursive reduce arrays using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1446832774,
                "creation_date": 1446832774,
                "answer_id": 33572853,
                "question_id": 33572755,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to create an actual object to add to the first object.  Change the `if` expression to:\r\n\r\n    {partner_attributions: (if (.partner_attributions | length) &gt; 0 then &quot;yes&quot; else &quot;no&quot; end)}",
                "title": "JQ If then Else"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1446845101,
                "creation_date": 1446845101,
                "answer_id": 33575965,
                "question_id": 33572755,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Better yet perhaps:\r\n\r\n    .partner_attributions |= (if length &gt; 0 then &quot;yes&quot; else &quot;no&quot; end)\r\n\r\nThis just updates the one field without modifying anything else.",
                "title": "JQ If then Else"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1446845101,
        "creation_date": 1446832376,
        "last_edit_date": 1446832685,
        "question_id": 33572755,
        "body_markdown": "How would I do an if then else on the value of a field? Such as my data I am working with looks like:\r\n\r\n   \r\n      {&quot;_key&quot;: &quot;USCA3DC_8f4521822c099c3e&quot;,\r\n      &quot;partner_attributions&quot;: [&quot;This business is a Yelp advertiser.&quot;],\r\n      &quot;showcase_photos&quot;: [\r\n    [&quot;Mathnasium of Westwood - Westwood, CA, United States. Nice and       caring instructors&quot;, &quot;http://s3-media1.fl.yelpcdn.com/bphoto/KeKAhvy2HHY4KGpvA24VaA/ls.jpg&quot;],\r\n    [&quot;Mathnasium of Westwood - Westwood, CA, United States. Prize box and estimation jar!&quot;, &quot;http://s3-media3.fl.yelpcdn.com/bphoto/lJWHHCAVaUMfeFD7GDKtHw/ls.jpg&quot;],\r\n    [&quot;Mathnasium of Westwood - Westwood, CA, United States. New table setup!!!!&quot;, &quot;http://s3-media2.fl.yelpcdn.com/bphoto/kVYJrYqDRHPOH4F2uTuFVg/ls.jpg&quot;],\r\n    [&quot;Mathnasium of Westwood - Westwood, CA, United States. Halloween party&quot;, &quot;http://s3-media3.fl.yelpcdn.com/bphoto/wKm5KjF0V8MsPTVSuofPEQ/180s.jpg&quot;],\r\n    [&quot;Mathnasium of Westwood - Westwood, CA, United States&quot;, &quot;http://s3-media4.fl.yelpcdn.com/bphoto/r2981msJm0c1ocU09blb1A/180s.jpg&quot;],\r\n    [&quot;Mathnasium of Westwood - Westwood, CA, United States&quot;, &quot;http://s3-media3.fl.yelpcdn.com/bphoto/r2Vgo18YKeUojDvjQMRF_A/180s.jpg&quot;]\r\n      ],\r\n      &quot;review_count&quot;: &quot;24&quot;,\r\n      &quot;yelp_id&quot;: &quot;t7WyXcABE3xj20G-UqXalA&quot;,\r\n      &quot;rating_value&quot;: &quot;5.0&quot;,\r\n      &quot;coordinates&quot;: {\r\n    &quot;latitude&quot;: &quot;34.042568&quot;,\r\n    &quot;longitude&quot;: &quot;-118.431038&quot;\r\n      }\r\n    }\r\n\r\nThis is just a small sample of it, however I am using this expression to parse it:\r\n\r\n    {_key, last_visited, name, phone, price_range, rating_value, review_count, updated, url, website, yelp_id} + (if (.partner_attributions | length) &gt; 0 then .partner_attributions == &quot;yes&quot; else  .partner_attributions == &quot;no&quot; end) + ([leaf_paths as $path | {&quot;key&quot;: $path | map(tostring) | join(&quot;_&quot;),&quot;value&quot;: getpath($path)}] | from_entries)\r\n\r\nWhat I want to do is have an If then else for the Partner_attributions field that if there is something there make it a yes and if it is null make it No. I have tried a few things with no success, seems simple enough but having trouble trying to figure it out.\r\n\r\nCan someone help?",
        "link": "https://stackoverflow.com/questions/33572755/jq-if-then-else",
        "title": "JQ If then Else"
    },
    {
        "tags": [
            "linux",
            "bash",
            "shell",
            "ubuntu",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3807187,
                    "reputation": 17515,
                    "user_id": 3159253,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/b1ad0885304cb976f949d5bd5c3c2c9c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3159253",
                    "link": "https://stackoverflow.com/users/3159253/user3159253"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1447130737,
                "post_id": 33622925,
                "comment_id": 55020239,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2719694,
                    "reputation": 605,
                    "user_id": 2346256,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/ac35ba417edca03157038daf69700edb?s=256&d=identicon&r=PG",
                    "display_name": "ayniam",
                    "link": "https://stackoverflow.com/users/2346256/ayniam"
                },
                "reply_to_user": {
                    "account_id": 3807187,
                    "reputation": 17515,
                    "user_id": 3159253,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/b1ad0885304cb976f949d5bd5c3c2c9c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3159253",
                    "link": "https://stackoverflow.com/users/3159253/user3159253"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1447130800,
                "post_id": 33622925,
                "comment_id": 55020251,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1447141096,
                "post_id": 33622925,
                "comment_id": 55023692,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1447138629,
                "last_edit_date": 1495541744,
                "creation_date": 1447138629,
                "answer_id": 33624473,
                "question_id": 33622925,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First up your JSON example seems slightly malformed - the push_psservice line has a comma after it but this is most likely a typo.\r\n\r\nYou might find it easier to turn your object&#39;s fields into an array using jq&#39;s to_entries (see https://stackoverflow.com/a/24254365/4513656 ) e.g.:\r\n\r\n    to_entries | .[0].key\r\n    to_entries | .[0].value.version\r\n\r\nTry this on https://jqplay.org/ .",
                "title": "Iterate over a json using shell"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1447139260,
                "creation_date": 1447139260,
                "answer_id": 33624594,
                "question_id": 33622925,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "## input.json\r\n\r\n    {\r\n         &quot;atest_engine&quot;: { &quot;version&quot;: &quot;96&quot; }, \r\n         &quot;a_kdfvm&quot;: { &quot;version&quot;: &quot;68&quot; }, \r\n         &quot;aseft_api&quot;: { &quot;version&quot;: &quot;&quot; },\r\n         &quot;push_psservice&quot;: { &quot;version&quot;: &quot;68&quot; }\r\n    }\r\n\r\n## command\r\n\r\n    jq -r &#39;to_entries[] | &quot;\\(.key)\\t\\(.value.version)&quot;&#39; input.json |\r\n      while read name version\r\n      do\r\n        echo &quot;name:&quot; $name\r\n        echo &quot;version:&quot; $version\r\n      done\r\n\r\n## result\r\n\r\n    name: atest_engine\r\n    version: 96\r\n    name: a_kdfvm\r\n    version: 68\r\n    name: aseft_api\r\n    version:\r\n    name: push_psservice\r\n    version: 68\r\n\r\n",
                "title": "Iterate over a json using shell"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1447139260,
        "creation_date": 1447130018,
        "last_edit_date": 1447136408,
        "question_id": 33622925,
        "body_markdown": "I have a json in the following format. I want to iterate over this json file\r\n\r\n   \r\n\r\n     {\r\n         &quot;atest_engine&quot;: { &quot;version&quot;: &quot;96&quot; }, \r\n         &quot;a_kdfvm&quot;: { &quot;version&quot;: &quot;68&quot; }, \r\n         &quot;aseft_api&quot;: { &quot;version&quot;: &quot;&quot; },\r\n         &quot;push_psservice&quot;: { &quot;version&quot;: &quot;68&quot; },\r\n       }\r\n\r\nI tried jq utility and my script is as follows.\r\n\r\n    count=$( jq &#39;. | length&#39; test.json )\r\n    echo $count\r\n    for((i=0;i&lt;$count;i++)) \r\n    do \r\n     name=$(cat test.json | jq &#39;.|keys[&#39;${i}&#39;]&#39;)\r\n     version=$(cat test.json | jq &#39;.|keys[&#39;${i}&#39;].version&#39;)\r\n     echo $name\r\n     echo $version\r\n    done\r\n\r\n   \r\nI am getting count and name properly but not able to fetch version information. How can I get it. I am new to scripting and any help in this regard is greatly appreciated.Thanks in Advance.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/33622925/iterate-over-a-json-using-shell",
        "title": "Iterate over a json using shell"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 30,
                "is_accepted": true,
                "score": 30,
                "last_activity_date": 1710181450,
                "last_edit_date": 1710181450,
                "creation_date": 1447161501,
                "answer_id": 33630944,
                "question_id": 33627427,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `map_values` instead of `map` to map the values of a JSON object while preserving the keys:\r\n\r\n&lt;!-- language-all: shell --&gt;\r\n    jq &#39;.p | map_values(keys)&#39;\r\n\r\nOn jq versions lower than 1.5, `map_values` is not defined: instead, you can use `[]|=`:\r\n\r\n    jq &#39;.p | . []|= keys&#39;",
                "title": "jq: Getting two levels of keys"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1501879803,
                "creation_date": 1501879803,
                "answer_id": 45515311,
                "question_id": 33627427,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **reduce** and **setpath**\r\n\r\n      .p\r\n    | reduce keys[] as $k (\r\n         .\r\n       ; setpath([$k]; .[$k] | keys)\r\n    )",
                "title": "jq: Getting two levels of keys"
            },
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 15,
                "last_activity_date": 1710181486,
                "last_edit_date": 1710181486,
                "creation_date": 1609199984,
                "answer_id": 65485614,
                "question_id": 33627427,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## In general\r\n\r\n### Top level keys:\r\n\r\n`curl -s https://crates.io/api/v1/crates/atty | jq &#39;. |= keys&#39;`\r\n\r\n&lt;!-- language: json --&gt;\r\n    [\r\n      &quot;categories&quot;,\r\n      &quot;crate&quot;,\r\n      &quot;keywords&quot;,\r\n      &quot;versions&quot;\r\n    ]\r\n\r\n## Two levels of keys:\r\n\r\n`curl -s https://crates.io/api/v1/crates/atty | jq &#39;.| map_values(keys)&#39;`\r\n\r\n&lt;!-- language: json --&gt;\r\n    {\r\n      &quot;crate&quot;: [\r\n        &quot;badges&quot;,\r\n        &quot;categories&quot;,\r\n        &quot;created_at&quot;,\r\n        &quot;description&quot;,\r\n        &quot;documentation&quot;,\r\n        &quot;downloads&quot;,\r\n        &quot;exact_match&quot;,\r\n        &quot;homepage&quot;,\r\n        &quot;id&quot;,\r\n        &quot;keywords&quot;,\r\n        &quot;links&quot;,\r\n        &quot;max_version&quot;,\r\n        &quot;name&quot;,\r\n        &quot;newest_version&quot;,\r\n        &quot;recent_downloads&quot;,\r\n        &quot;repository&quot;,\r\n        &quot;updated_at&quot;,\r\n        &quot;versions&quot;\r\n      ],\r\n      &quot;versions&quot;: [\r\n        0,\r\n        1,\r\n        2,\r\n        3,\r\n        4,\r\n        5,\r\n        6,\r\n        7,\r\n        8,\r\n        9,\r\n        10,\r\n        11,\r\n        12,\r\n        13,\r\n        14,\r\n        15,\r\n        16\r\n      ],\r\n      &quot;keywords&quot;: [\r\n        0,\r\n        1,\r\n        2\r\n      ],\r\n      &quot;categories&quot;: []\r\n    }\r\n\r\n\r\n## Method versions \r\n\r\n&lt;!-- language: shell --&gt;\r\n    topLevelJsonKeys() {\r\n     curl -s $1 | jq &#39;. |= keys&#39;\r\n      # EXAMPLE: \r\n      # topLevelJsonKeys https://crates.io/api/v1/crates/atty\r\n    }\r\n\r\n    topLevelJsonKeys2() {\r\n      curl -s $1 | jq &#39;.| map_values(keys)&#39;\r\n      # EXAMPLE: \r\n      # topLevelJsonKeys2 https://crates.io/api/v1/crates/atty\r\n    }\r\n",
                "title": "jq: Getting two levels of keys"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 32,
        "last_activity_date": 1710181486,
        "creation_date": 1447149924,
        "last_edit_date": 1710181282,
        "question_id": 33627427,
        "body_markdown": "I have some json data that looks like:\r\n\r\n    {\r\n      &quot;p&quot;: {\r\n        &quot;d&quot;: {\r\n          &quot;a&quot; : {\r\n            &quot;r&quot;: &quot;foo&quot;,\r\n            &quot;g&quot;: 1\r\n          },\r\n          &quot;b&quot;: {\r\n            &quot;r&quot;: &quot;bar&quot;,\r\n            &quot;g&quot;: 2\r\n          }\r\n        },\r\n        &quot;c&quot;: {\r\n          &quot;e&quot;: {\r\n            &quot;r&quot;: &quot;baz&quot;,\r\n            &quot;g&quot;: 1\r\n          }\r\n        },\r\n        ...\r\n      }\r\n    }\r\n\r\nI want something like:\r\n\r\n&lt;!-- language: json --&gt;\r\n    {\r\n      &quot;d&quot;: [ \r\n        &quot;a&quot;,\r\n        &quot;b&quot;\r\n      ],\r\n      &quot;c&quot;: [\r\n        &quot;e&quot;\r\n      ]\r\n    }\r\n\r\nI can get the list of keys on the first level under &quot;p&quot; with `jq &#39;.p|keys&#39;`, and the structure and keys on the second level with `jq &#39;.p|map(.|keys)&#39;`, but I can&#39;t figure out how to combine it.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/33627427/jq-getting-two-levels-of-keys",
        "title": "jq: Getting two levels of keys"
    },
    {
        "tags": [
            "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": 0,
                "creation_date": 1447263522,
                "post_id": 33656260,
                "comment_id": 55086159,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2786859,
                    "reputation": 25,
                    "user_id": 4145819,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/g2PMI.jpg?s=256",
                    "display_name": "Elias51",
                    "link": "https://stackoverflow.com/users/4145819/elias51"
                },
                "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": 1447263715,
                "post_id": 33656260,
                "comment_id": 55086278,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1447268225,
                "last_edit_date": 1447268225,
                "creation_date": 1447263613,
                "answer_id": 33656518,
                "question_id": 33656260,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could also use delpaths/1.  For example:\r\n\r\n    $ jq -n &#39;{&quot;a&quot;:1, &quot;b&quot;: 1} | delpaths([[&quot;a&quot;]])&#39;\r\n    {\r\n      &quot;b&quot;: 1\r\n    }\r\n\r\nThat is, modifying your program so that the last line reads like this:\r\n\r\n\r\n    (post_recurse | objects) |= delpaths([[ $delete ]] )\r\n\r\nyou would invoke jq like so:\r\n\r\n    $ jq --arg delete &quot;META_BASIC_INFO&quot; -f delete.jq input.json\r\n\r\n(One cannot use `--arg module ...` as &quot;$module&quot; has some kind of reserved status.)\r\n",
                "title": "Passing Multiple Objects to jq for Recursive Filter Operation"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1447300583,
                "last_edit_date": 1447300583,
                "creation_date": 1447271599,
                "answer_id": 33658747,
                "question_id": 33656260,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It seems the name `module` is a keyword in 1.5 so `$module` will result in a syntax error. You should use a different name.  There are other builtins to do recursion for you, consider using them instead of churning out your own.\r\n\r\n    $ jq &#39;(.. | objects | select(has($a))) |= del(.[$a])&#39; --arg a &quot;META_BASIC_INFO&quot; Test.json",
                "title": "Passing Multiple Objects to jq for Recursive Filter Operation"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1447345573,
                "last_edit_date": 1447345573,
                "creation_date": 1447302130,
                "answer_id": 33664390,
                "question_id": 33656260,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a &quot;one-line&quot; solution using walk/1:\r\n\r\n    jq --arg d &quot;META_BASIC_INFO&quot; &#39;walk(if type == &quot;object&quot; then del(.[$d]) else . end)&#39; input.json\r\n\r\nIf walk/1 is not in your jq, here is 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\nIf you want to recursively delete a bunch of key-value pairs, then here&#39;s one approach using `--argjson`:\r\n\r\nrdelete.jq:\r\n\r\n    def rdelete(key):\r\n      walk(if type == &quot;object&quot; then del(.[key]) else . end);\r\n\r\n    reduce $strings[] as $s (.; rdelete($s))\r\n\r\nInvocation:\r\n\r\n    $ jq --argjson strings &#39;[&quot;a&quot;,&quot;b&quot;]&#39; -f rdelete.jq input.json\r\n",
                "title": "Passing Multiple Objects to jq for Recursive Filter Operation"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1447372134,
        "creation_date": 1447262824,
        "last_edit_date": 1447372134,
        "question_id": 33656260,
        "body_markdown": "I am trying to use jq 1.5 to develop a script that can take one or more user inputs that represent a key and recursively remove them from JSON input.\r\n\r\nThe JSON I am referencing is here:\r\nhttps://github.com/EmersonElectricCo/fsf/blob/master/docs/Test.json\r\n\r\nMy script, which seems to work pretty well, is as follows.\r\n\r\n    def post_recurse(f):\r\n       def r:\r\n          (f | select(. != null) | r), .;\r\n          r;\r\n    def post_recurse:\r\n       post_recurse(.[]?);\r\n    (post_recurse | objects) |= del(.META_BASIC_INFO)\r\n\r\nHowever, I would like to replace META_BASIC_INFO with one or more user inputs. How would I go about accomplishing this? I presume with --arg from the command line, but I am unclear on how to incorporate this into my .jq script?\r\n\r\nI&#39;ve tried replacing `del(.META_BASIC_INFO)` with `del(.$module)` and invoking with `cat test.json | ./jq -f fsf_key_filter.jq --arg module META_BASIC_INFO` to test but this does not work.\r\n\r\nAny guideance on this is greatly appreciated!\r\n\r\nANSWER:\r\n\r\nBased on a couple of suggestions I was able to arrive to the following that works and users JQ.\r\n\r\nInnvocation:\r\n\r\n    cat test.json | jq --argjson delete &#39;[&quot;META_BASIC_INFO&quot;,&quot;SCAN_YARA&quot;]&#39; -f fsf_module_filter.jq\r\n\r\nCode:\r\n\r\n    def post_recurse(f):\r\n            def r:\r\n                    (f | select(. != null) | r), .;\r\n                    r;\r\n    def post_recurse:\r\n            post_recurse(.[]?);\r\n    (post_recurse | objects) |= reduce $delete[] as $d (.; delpaths([[ $d ]]))\r\n",
        "link": "https://stackoverflow.com/questions/33656260/passing-multiple-objects-to-jq-for-recursive-filter-operation",
        "title": "Passing Multiple Objects to jq for Recursive Filter Operation"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 36,
                "is_accepted": false,
                "score": 36,
                "last_activity_date": 1729027899,
                "last_edit_date": 1729027899,
                "creation_date": 1447442438,
                "answer_id": 33700274,
                "question_id": 33700103,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use quoting as in:\r\n\r\n&lt;!-- language: shell --&gt;\r\n    jq --raw-output &#39;.gateways[0].&quot;External IPs&quot;&#39;",
                "title": "Syntax when there is a space in the key"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1447536276,
                "creation_date": 1447536276,
                "answer_id": 33713547,
                "question_id": 33700103,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Ok I figured it out. \r\n\r\nIn the end what @JeffMercado suggested worked. Problem is that `apt-get install jq` install version 1.3 of jq. I had to update manually jq (to 1.5) and then it worked. \r\n\r\nThanks! ",
                "title": "Syntax when there is a space in the key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 25,
        "last_activity_date": 1729027899,
        "creation_date": 1447441715,
        "last_edit_date": 1729027867,
        "question_id": 33700103,
        "body_markdown": "This is driving me nuts. \r\n\r\nI have a JSON that looks like this: \r\n\r\n&lt;!-- language: json --&gt;\r\n    {\r\n    &quot;gateways&quot;: [\r\n        {\r\n            &quot;DHCP&quot;: &quot;On&quot;,\r\n            &quot;External IPs&quot;: &quot;46.244.46.66&quot;,\r\n            &quot;Firewall&quot;: &quot;On&quot;,\r\n            &quot;NAT&quot;: &quot;Off&quot;,\r\n            &quot;Name&quot;: &quot;gateway&quot;,\r\n            &quot;Routed Networks&quot;: &quot;photon, default-routed-network&quot;,\r\n            &quot;Selected&quot;: &quot;*&quot;,\r\n            &quot;Syslog&quot;: &quot;&quot;,\r\n            &quot;Uplinks&quot;: &quot;d5p6v51-ext&quot;,\r\n            &quot;VPN&quot;: &quot;Off&quot;\r\n        }\r\n    ]\r\n    }\r\n\r\nI can easily extract values for most of the keys. \r\n\r\nE.g.\r\n\r\n    jq --raw-output .gateways[0].Name\r\n    gateway\r\n\r\nHowever, what I really need to get is the `&quot;External IPs&quot;` value and I can&#39;t figure out how to manage the space. \r\n\r\nI tried\r\n\r\n    jq --raw-output .gateways[0].&#39;External IPs&#39;\r\n\r\n    jq --raw-output .gateways[0].`External IPs`\r\n\r\n    jq --raw-output .gateways[0].&quot;External IPs&quot;\r\n\r\nBut none of these work. \r\n\r\nAny hint? ",
        "link": "https://stackoverflow.com/questions/33700103/syntax-when-there-is-a-space-in-the-key",
        "title": "Syntax when there is a space in the key"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 15,
                "is_accepted": true,
                "score": 15,
                "last_activity_date": 1447445783,
                "creation_date": 1447445783,
                "answer_id": 33701068,
                "question_id": 33700997,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "When defining an object literal, the parentheses indicates that the expression value should be the property name.  Otherwise if you didn&#39;t use parentheses, it&#39;s the literal name.\r\n\r\nSo these are equivalent ways to define an object with a `&quot;foo&quot;` property:\r\n\r\n    { foo: 1 }\r\n    { &quot;foo&quot;: 2 }\r\n    &quot;foo&quot; as $name | { ($name): 3 }\r\n    { somename: &quot;foo&quot; } | { (.somename): 4 }",
                "title": "Parentheses in JQ for .key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 7,
        "last_activity_date": 1447445783,
        "creation_date": 1447445497,
        "question_id": 33700997,
        "body_markdown": "I don&#39;t understand why key has to be in `()` for this to work:\r\n\r\n    # kbrandt at glade.local in ~ on git:master x [15:08:19]\r\n    $ cat host | jq &#39;. | to_entries | map({ (.key) : .value.CPU.PercentUsed })&#39; | tail\r\n      {\r\n        &quot;rpi-b827eb2d7d23&quot;: 10.333333333333334\r\n      },\r\n      {\r\n        &quot;rpi-b827eb8d7c8d&quot;: 60\r\n      },\r\n      {\r\n        &quot;rpi-b827eba999fa&quot;: 40.733333333333334\r\n      }\r\n    ]\r\n    \r\n    # kbrandt at glade.local in ~ on git:master x [15:08:54]\r\n    $ cat host | jq &#39;. | to_entries | map({ .key : .value.CPU.PercentUsed })&#39; | tail\r\n    jq: error: syntax error, unexpected FIELD (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    . | to_entries | map({ .key : .value.CPU.PercentUsed })\r\n    jq: 1 compile error",
        "link": "https://stackoverflow.com/questions/33700997/parentheses-in-jq-for-key",
        "title": "Parentheses in JQ for .key"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1447504355,
                "creation_date": 1447504355,
                "answer_id": 33708440,
                "question_id": 33707655,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Yeah, found solution:\r\n\r\n    to_entries  | map( {(.key): ({a: .key}+.value)} ) | add\r\nwill return\r\n\r\n    {\r\n      &quot;key x&quot;: {\r\n        &quot;a&quot;: &quot;key x&quot;,\r\n        &quot;b&quot;: &quot;1&quot;\r\n      },\r\n      &quot;key y&quot;: {\r\n        &quot;a&quot;: &quot;key y&quot;,\r\n        &quot;b&quot;: &quot;1&quot;\r\n      }\r\n    }\r\n\r\nto_entries splits to key/value pairs what is much easier to access each key and extend its value by new object.",
                "title": "JQ: add nested object with name of top-level key"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1447719325,
                "last_edit_date": 1447719325,
                "creation_date": 1447508154,
                "answer_id": 33708974,
                "question_id": 33707655,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A simple answer would be:\r\n\r\n    with_entries(.value.a = .key)",
                "title": "JQ: add nested object with name of top-level key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1447719325,
        "creation_date": 1447498643,
        "last_edit_date": 1447499917,
        "question_id": 33707655,
        "body_markdown": "In my input in JQ 1.4...\r\n\r\n    {\r\n        &quot;key x&quot;: {\r\n            &quot;b&quot;: &quot;1&quot;\r\n        },\r\n        &quot;key y&quot;: {\r\n            &quot;b&quot;: &quot;1&quot;\r\n        }\r\n    }\r\n\r\n...should add new nested objects under each top-level key with the name of its &lt;unknown&gt; top-level key. So the result looks like\r\n\r\n    {\r\n        &quot;key x&quot;: {\r\n            &quot;a&quot;: &quot;key x&quot;,\r\n            &quot;b&quot;: &quot;1&quot;\r\n        },\r\n        &quot;key y&quot;: {\r\n            &quot;a&quot;: &quot;key y&quot;,\r\n            &quot;b&quot;: &quot;1&quot;\r\n        }\r\n    }\r\n\r\nBut without using the key names (e.g. .&quot;key x&quot;.a=&quot;key x&quot;) directly, because i dont know during runtime the real key names.",
        "link": "https://stackoverflow.com/questions/33707655/jq-add-nested-object-with-name-of-top-level-key",
        "title": "JQ: add nested object with name of top-level key"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 386425,
                    "reputation": 57870,
                    "user_id": 744178,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a3193139ea494c45e63752504f5ff1f2?s=256&d=identicon&r=PG",
                    "display_name": "jwodder",
                    "link": "https://stackoverflow.com/users/744178/jwodder"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1447605925,
                "post_id": 33722144,
                "comment_id": 55213975,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 418043,
                    "reputation": 12643,
                    "user_id": 794380,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/tLc9e.jpg?s=256",
                    "display_name": "Idan Arye",
                    "link": "https://stackoverflow.com/users/794380/idan-arye"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1447606101,
                "post_id": 33722144,
                "comment_id": 55214033,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7297292,
                    "reputation": 471,
                    "user_id": 5561549,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/982ebccf5b9167056cba78ed95293c07?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Nic",
                    "link": "https://stackoverflow.com/users/5561549/nic"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1447662250,
                "post_id": 33722144,
                "comment_id": 55230788,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1447665411,
                "creation_date": 1447665411,
                "answer_id": 33731842,
                "question_id": 33722144,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Ok, found this annoying &quot;bug&quot;: my jq file was in UTF-8, if i change it to ansi it works! Thanks for the support.",
                "title": "JQ: error: syntax error, unexpected INVALID_CHARACTER, expecting $end"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1572298956,
                "creation_date": 1572298956,
                "answer_id": 58598782,
                "question_id": 33722144,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In my case I am doing a copy paste of this command from slack and it change normal quotes \r\n\r\n&gt; &#39;&#39;\r\n\r\nto stylish quotes \r\n\r\n&gt; ‘ ’\r\n\r\nYou might not run into this but if you do, you will thank me :)\r\n\r\n[jq with quotes image][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/GEB8M.png",
                "title": "JQ: error: syntax error, unexpected INVALID_CHARACTER, expecting $end"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1586420175,
                "creation_date": 1586420175,
                "answer_id": 61116743,
                "question_id": 33722144,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I get a very similar error when I use MS Windows line endings.  For example, prepare a couple of files, `id.jq` with sane Unix line endings and `id-ms.jq` with Microsoft&#39;s CP/M style CR-LF line endings, and finally `id-utf8bom.jq` with a Unix line endings and a UTF-8 BOM:\r\n```sh\r\nprintf &#39;.\\n&#39; &gt; id.jq\r\nprintf &#39;.\\r\\n&#39; &gt; id-ms.jq\r\nprintf &#39;\\xef\\xbb\\xbf.\\n&#39; &gt; id-utf8bom.jq\r\n```\r\nand the Unix version succeeds:\r\n```sh\r\necho true | jq -f id.jq\r\n```\r\nwhile the file with carriage return and line feeds for new lines:\r\n```sh\r\necho true | jq -f id-ms.jq\r\n```\r\ncauses jq (version 1.6) to fail with:\r\n```none\r\njq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\r\njq: error: try .[&quot;field&quot;] instead of .field for unusually named fields at &lt;top-level&gt;, line 1:\r\n.\r\njq: 2 compile errors\r\n```\r\nand the version with a UTF-8 BOM version:\r\n```sh\r\necho true | jq -f id-utf8bom.jq\r\n```\r\ngives a more limited error message:\r\n```plain\r\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n﻿.\r\njq: 1 compile error\r\n```\r\nwould be great if it recognised / handled these relatively common encodings, but it doesn&#39;t seem to at the moment!",
                "title": "JQ: error: syntax error, unexpected INVALID_CHARACTER, expecting $end"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1678101276,
                "creation_date": 1678101276,
                "answer_id": 75650157,
                "question_id": 33722144,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In my case it was a missing `+`:\r\n\r\n**Fails:**\r\n\r\n    yq e yourfile.yaml -j | jq -r &#39;to_entries | .[] | .key + &quot;=&quot; (.value|tostring)&#39;\r\n    \r\n    jq: error: syntax error, unexpected &#39;(&#39;, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    to_entries | .[]? | .key + &quot;=&quot;  (.value|tostring)                                \r\n    jq: 1 compile error\r\n\r\n**Works:**\r\n\r\n    yq e yourfile.yaml -j | jq -r &#39;to_entries | .[] | .key + &quot;=&quot; + (.value|tostring)&#39;",
                "title": "JQ: error: syntax error, unexpected INVALID_CHARACTER, expecting $end"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 18,
        "last_activity_date": 1678101276,
        "creation_date": 1447605731,
        "last_edit_date": 1447605835,
        "question_id": 33722144,
        "body_markdown": "I am calling jq on the command line in Linux like this:\r\n\r\n    jq -s -R -f get.jq get-config.txt\r\n\r\nwhich returns:\r\n\r\n    error: syntax error, unexpected INVALID_CHARACTER, expecting $end\r\n    .1 compile error\r\n\r\nBut there is only a dot in get.jq file to test like\r\n\r\n    jq -s -R . get-config.txt\r\n\r\nWhich returns fine. So what&#39;s wrong with the jq file?",
        "link": "https://stackoverflow.com/questions/33722144/jq-error-syntax-error-unexpected-invalid-character-expecting-end",
        "title": "JQ: error: syntax error, unexpected INVALID_CHARACTER, expecting $end"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 366283,
                    "reputation": 5414,
                    "user_id": 711717,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8f13967c21c586e7b0dc4e5c3993f31b?s=256&d=identicon&r=PG",
                    "display_name": "FelisCatus",
                    "link": "https://stackoverflow.com/users/711717/feliscatus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1447653802,
                "post_id": 33729261,
                "comment_id": 55227780,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1447662317,
                "creation_date": 1447662317,
                "answer_id": 33731015,
                "question_id": 33729261,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your data has no structure, it&#39;ll be easier if you gave it some.\r\n\r\n    { users: map(.users // empty), messages: map(.messages // empty) }\r\n\r\nWhen you slurp that file up with this, it&#39;ll give you this:\r\n\r\n    {\r\n      &quot;users&quot;: [\r\n        { &quot;347793&quot;: &quot;user1&quot; },\r\n        { &quot;6560536&quot;: &quot;user2&quot; },\r\n        { &quot;6637901&quot;: &quot;user3&quot; },\r\n        { &quot;5850517&quot;: &quot;user4&quot; },\r\n        { &quot;2907509&quot;: &quot;user5&quot; },\r\n        { &quot;6611743&quot;: &quot;user6&quot; },\r\n        { &quot;6535592&quot;: &quot;user7&quot; },\r\n        { &quot;5586286&quot;: &quot;user8&quot; },\r\n        { &quot;2484439&quot;: &quot;user9&quot; }\r\n      ],\r\n      &quot;messages&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;id1&quot;,\r\n          &quot;owner&quot;: { &quot;id&quot;: &quot;347793&quot;, &quot;type&quot;: &quot;user&quot; },\r\n          &quot;otherUser&quot;: { &quot;id&quot;: &quot;6560536&quot;, &quot;type&quot;: &quot;user&quot; }\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;id2&quot;,\r\n          &quot;owner&quot;: { &quot;id&quot;: &quot;6637901&quot;, &quot;type&quot;: &quot;user&quot; },\r\n          &quot;otherUser&quot;: { &quot;id&quot;: &quot;6560536&quot;, &quot;type&quot;: &quot;user&quot; }\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;id3&quot;,\r\n          &quot;owner&quot;: { &quot;id&quot;: &quot;2907509&quot;, &quot;type&quot;: &quot;user&quot; },\r\n          &quot;otherUser&quot;: { &quot;id&quot;: &quot;2484439&quot;, &quot;type&quot;: &quot;user&quot; }\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;id4&quot;,\r\n          &quot;owner&quot;: { &quot;id&quot;: &quot;347793&quot;, &quot;type&quot;: &quot;user&quot; },\r\n          &quot;otherUser&quot;: { &quot;id&quot;: &quot;2907509&quot;, &quot;type&quot;: &quot;user&quot; }\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;id5&quot;,\r\n          &quot;owner&quot;: { &quot;id&quot;: &quot;5850517&quot;, &quot;type&quot;: &quot;user&quot; },\r\n          &quot;otherUser&quot;: { &quot;id&quot;: &quot;5850517&quot;, &quot;type&quot;: &quot;user&quot; }\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;id6&quot;,\r\n          &quot;owner&quot;: { &quot;id&quot;: &quot;5586286&quot;, &quot;type&quot;: &quot;user&quot; },\r\n          &quot;otherUser&quot;: { &quot;id&quot;: &quot;347793&quot;, &quot;type&quot;: &quot;user&quot; }\r\n        }\r\n      ]\r\n    }\r\n\r\nThen doing the replacement should be easier.\r\n\r\n    (.users | add) as $users\r\n        | (.messages[].owner |= (.type = $users[.id]))\r\n        | (.messages[].otherUser |= (.type = $users[.id]))\r\n\r\nThen if for whatever reason you want to go back to your other structure, then it should be easy (but I wouldn&#39;t recommend it).\r\n\r\n    { users: .users[] }, { messages: .messages[] }",
                "title": "JQ:How can i update the value of json by jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1447709322,
                "creation_date": 1447709322,
                "answer_id": 33744981,
                "question_id": 33729261,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If the number of &quot;messages&quot; is very large, then it might be better to process each one separately, to avoid having to read them all into memory.\r\n\r\nAt any rate, the following illustrates how one can use jq to read in one file to construct a dictionary, and to process a second file on a line-by-line basis.\r\n\r\nLet&#39;s suppose we have partitioned the JSON into two files (users.json and messages.json), and that the following lines are in process.jq:\r\n\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    ($users | map(.users) | add) as $dict\r\n    | walk(if type == &quot;object&quot; and .type == &quot;user&quot;\r\n           then .type = $dict[.id]\r\n           else .\r\n           end)\r\n\r\n(If your jq already has walk/1, then its definition can be omitted.)\r\n\r\nThen the following command can be used to process the messages:\r\n\r\n    $ jq --slurpfile users users.json -f process.jq messages.json\r\n",
                "title": "JQ:How can i update the value of json by jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1502162719,
        "creation_date": 1447653227,
        "last_edit_date": 1502162719,
        "question_id": 33729261,
        "body_markdown": "I have a json file like this :\r\n\r\n    {&quot;users&quot;:{&quot;347793&quot;:&quot;user1&quot;}}\r\n    {&quot;users&quot;:{&quot;6560536&quot;:&quot;user2&quot;}}\r\n    {&quot;users&quot;:{&quot;6637901&quot;:&quot;user3&quot;}}\r\n    {&quot;users&quot;:{&quot;5850517&quot;:&quot;user4&quot;}}\r\n    {&quot;users&quot;:{&quot;2907509&quot;:&quot;user5&quot;}}\r\n    {&quot;users&quot;:{&quot;6611743&quot;:&quot;user6&quot;}}\r\n    {&quot;users&quot;:{&quot;6535592&quot;:&quot;user7&quot;}}\r\n    {&quot;users&quot;:{&quot;5586286&quot;:&quot;user8&quot;}}\r\n    {&quot;users&quot;:{&quot;2484439&quot;:&quot;user9&quot;}}\r\n    {&quot;messages&quot;:{&quot;id&quot;:&quot;id1&quot;,&quot;owner&quot;:{&quot;id&quot;:&quot;347793&quot;,&quot;type&quot;:&quot;user&quot;},&quot;otherUser&quot;:{&quot;id&quot;:&quot;6560536&quot;,&quot;type&quot;:&quot;user&quot;}}}\r\n    {&quot;messages&quot;:{&quot;id&quot;:&quot;id2&quot;,&quot;owner&quot;:{&quot;id&quot;:&quot;6637901&quot;,&quot;type&quot;:&quot;user&quot;},&quot;otherUser&quot;:{&quot;id&quot;:&quot;6560536&quot;,&quot;type&quot;:&quot;user&quot;}}}\r\n    {&quot;messages&quot;:{&quot;id&quot;:&quot;id3&quot;,&quot;owner&quot;:{&quot;id&quot;:&quot;2907509&quot;,&quot;type&quot;:&quot;user&quot;},&quot;otherUser&quot;:{&quot;id&quot;:&quot;2484439&quot;,&quot;type&quot;:&quot;user&quot;}}}\r\n    {&quot;messages&quot;:{&quot;id&quot;:&quot;id4&quot;,&quot;owner&quot;:{&quot;id&quot;:&quot;347793&quot;,&quot;type&quot;:&quot;user&quot;},&quot;otherUser&quot;:{&quot;id&quot;:&quot;2907509&quot;,&quot;type&quot;:&quot;user&quot;}}}\r\n    {&quot;messages&quot;:{&quot;id&quot;:&quot;id5&quot;,&quot;owner&quot;:{&quot;id&quot;:&quot;5850517&quot;,&quot;type&quot;:&quot;user&quot;},&quot;otherUser&quot;:{&quot;id&quot;:&quot;5850517&quot;,&quot;type&quot;:&quot;user&quot;}}}\r\n    {&quot;messages&quot;:{&quot;id&quot;:&quot;id6&quot;,&quot;owner&quot;:{&quot;id&quot;:&quot;5586286&quot;,&quot;type&quot;:&quot;user&quot;},&quot;otherUser&quot;:{&quot;id&quot;:&quot;347793&quot;,&quot;type&quot;:&quot;user&quot;}}}\r\n\r\n\r\nI want to get the output file like this, to change the owner&#39;s type to the user&#39;s name: \r\n\r\n    {&quot;users&quot;:{&quot;347793&quot;:&quot;user1&quot;}}\r\n    {&quot;users&quot;:{&quot;6560536&quot;:&quot;user2&quot;}}\r\n    {&quot;users&quot;:{&quot;6637901&quot;:&quot;user3&quot;}}\r\n    {&quot;users&quot;:{&quot;5850517&quot;:&quot;user4&quot;}}\r\n    {&quot;users&quot;:{&quot;2907509&quot;:&quot;user5&quot;}}\r\n    {&quot;users&quot;:{&quot;6611743&quot;:&quot;user6&quot;}}\r\n    {&quot;users&quot;:{&quot;6535592&quot;:&quot;user7&quot;}}\r\n    {&quot;users&quot;:{&quot;5586286&quot;:&quot;user8&quot;}}\r\n    {&quot;users&quot;:{&quot;2484439&quot;:&quot;user9&quot;}}\r\n    {&quot;messages&quot;:{&quot;id&quot;:&quot;id1&quot;,&quot;owner&quot;:{&quot;id&quot;:&quot;347793&quot;,&quot;type&quot;:&quot;user1&quot;},&quot;otherUser&quot;:{&quot;id&quot;:&quot;6560536&quot;,&quot;type&quot;:&quot;user2&quot;}}}\r\n    {&quot;messages&quot;:{&quot;id&quot;:&quot;id2&quot;,&quot;owner&quot;:{&quot;id&quot;:&quot;6637901&quot;,&quot;type&quot;:&quot;user3&quot;},&quot;otherUser&quot;:{&quot;id&quot;:&quot;6560536&quot;,&quot;type&quot;:&quot;user2&quot;}}}\r\n    {&quot;messages&quot;:{&quot;id&quot;:&quot;id3&quot;,&quot;owner&quot;:{&quot;id&quot;:&quot;2907509&quot;,&quot;type&quot;:&quot;user5&quot;},&quot;otherUser&quot;:{&quot;id&quot;:&quot;2484439&quot;,&quot;type&quot;:&quot;user9&quot;}}}\r\n    {&quot;messages&quot;:{&quot;id&quot;:&quot;id4&quot;,&quot;owner&quot;:{&quot;id&quot;:&quot;347793&quot;,&quot;type&quot;:&quot;user1&quot;},&quot;otherUser&quot;:{&quot;id&quot;:&quot;2907509&quot;,&quot;type&quot;:&quot;user5&quot;}}}\r\n    {&quot;messages&quot;:{&quot;id&quot;:&quot;id5&quot;,&quot;owner&quot;:{&quot;id&quot;:&quot;5850517&quot;,&quot;type&quot;:&quot;user4&quot;},&quot;otherUser&quot;:{&quot;id&quot;:&quot;5850517&quot;,&quot;type&quot;:&quot;user4&quot;}}}\r\n    {&quot;messages&quot;:{&quot;id&quot;:&quot;id6&quot;,&quot;owner&quot;:{&quot;id&quot;:&quot;5586286&quot;,&quot;type&quot;:&quot;user8&quot;},&quot;otherUser&quot;:{&quot;id&quot;:&quot;347793&quot;,&quot;type&quot;:&quot;user10&quot;}}}\r\n\r\nI have no idea to do this, I try some code but it not works.\r\n\r\n    jq -c &#39;.messages[] as $message| $message.owner.type|=.users[]|select(.id==$message.owner.id).name&#39;",
        "link": "https://stackoverflow.com/questions/33729261/jqhow-can-i-update-the-value-of-json-by-jq",
        "title": "JQ:How can i update the value of json by jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 31,
                "is_accepted": true,
                "score": 31,
                "last_activity_date": 1447810453,
                "last_edit_date": 1447810453,
                "creation_date": 1447796792,
                "answer_id": 33767630,
                "question_id": 33766735,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You were almost there. Just pipe the `version` array to the `unique` function:\r\n\r\n    jq &#39;[.[]|{name, &quot;version&quot;: [.servers[].version]|unique}]&#39; input",
                "title": "remove duplicates in JSON values using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1501882073,
                "creation_date": 1501882073,
                "answer_id": 45515744,
                "question_id": 33766735,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that uses **reduce** to gather version keys in a temporary object and dedup at the end using **keys**\r\n\r\n     [\r\n       . []\r\n     | reduce .servers[].version as $v (\r\n         {name, version:{}}\r\n       ; .version[$v] = 1\r\n       )\r\n     | .version |= keys\r\n     ]",
                "title": "remove duplicates in JSON values using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 21,
        "last_activity_date": 1501882073,
        "creation_date": 1447793412,
        "last_edit_date": 1447797187,
        "question_id": 33766735,
        "body_markdown": "I have the following JSON:\r\n\r\n    [\r\n      {\r\n        &quot;function&quot;: &quot;ping&quot;,\r\n        &quot;name&quot;: &quot;start&quot;,\r\n        &quot;servers&quot;: [\r\n          {\r\n            &quot;load&quot;: 581.6875,\r\n            &quot;last_heard&quot;: 2.379324197769165,\r\n            &quot;version&quot;: &quot;1.0&quot;,\r\n            &quot;hidden&quot;: false,\r\n            &quot;pid&quot;: &quot;19735&quot;\r\n          },\r\n          {\r\n            &quot;load&quot;: 444.0625,\r\n            &quot;last_heard&quot;: 1.3227169513702393,\r\n            &quot;version&quot;: &quot;1.0&quot;,\r\n            &quot;hidden&quot;: false,\r\n            &quot;pid&quot;: &quot;12092&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;function&quot;: &quot;pong&quot;,\r\n        &quot;name&quot;: &quot;middle&quot;,\r\n        &quot;servers&quot;: [\r\n          {\r\n            &quot;load&quot;: 581.6875,\r\n            &quot;last_heard&quot;: 2.379324197769165,\r\n            &quot;version&quot;: &quot;2.0&quot;,\r\n            &quot;hidden&quot;: false,\r\n            &quot;pid&quot;: &quot;19735&quot;\r\n          },\r\n          {\r\n            &quot;load&quot;: 444.0625,\r\n            &quot;last_heard&quot;: 1.3227169513702393,\r\n            &quot;version&quot;: &quot;3.0&quot;,\r\n            &quot;hidden&quot;: false,\r\n            &quot;pid&quot;: &quot;12092&quot;\r\n          },\r\n          {\r\n            &quot;load&quot;: 444.0625,\r\n            &quot;last_heard&quot;: 1.3227169513702393,\r\n            &quot;version&quot;: &quot;3.0&quot;,\r\n            &quot;hidden&quot;: false,\r\n            &quot;pid&quot;: &quot;12093&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;function&quot;: &quot;pang&quot;,\r\n        &quot;name&quot;: &quot;end&quot;,\r\n        &quot;servers&quot;: [\r\n          {\r\n            &quot;load&quot;: 581.6875,\r\n            &quot;last_heard&quot;: 2.379324197769165,\r\n            &quot;version&quot;: &quot;2.0&quot;,\r\n            &quot;hidden&quot;: false,\r\n            &quot;pid&quot;: &quot;19735&quot;\r\n          },\r\n          {\r\n            &quot;load&quot;: 444.0625,\r\n            &quot;last_heard&quot;: 1.3227169513702393,\r\n            &quot;version&quot;: &quot;2.0&quot;,\r\n            &quot;hidden&quot;: false,\r\n            &quot;pid&quot;: &quot;12092&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\n(it&#39;s just a sample, it&#39;s hundreds of entries)\r\n\r\nWhat I need is to get\r\n\r\n    [{&quot;name&quot;: &quot;start&quot;, &quot;version&quot;: [&quot;1.0&quot;]},\r\n    {&quot;name&quot;: &quot;middle&quot;, &quot;version&quot;: [&quot;2.0&quot;, &quot;3.0&quot;]},\r\n    {&quot;name&quot;: &quot;end&quot;, &quot;version&quot;: [&quot;2.0&quot;]}]\r\n\r\nSo I need to remove useless data and then get a list of names with their unique values for &quot;version&quot;.\r\n\r\nI can get until the point where I have\r\n\r\n    {\r\n      &quot;name&quot;: &quot;ping&quot;,\r\n      &quot;version&quot;: [\r\n        &quot;1.0&quot;,\r\n        &quot;1.0&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;pong&quot;,\r\n      &quot;version&quot;: [\r\n        &quot;2.0&quot;,\r\n        &quot;3.0&quot;,\r\n        &quot;3.0&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;pang&quot;,\r\n      &quot;version&quot;: [\r\n        &quot;2.0&quot;,\r\n        &quot;2.0&quot;\r\n      ]\r\n    }\r\n\r\nusing \r\n\r\n    jq &#39;.[] | {name: .function, version: [.servers[].version]}&#39;\r\n\r\nBut I need to get rid of the duplicated values.\r\nIs this possible using jq?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/33766735/remove-duplicates-in-json-values-using-jq",
        "title": "remove duplicates in JSON values using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1447867269,
                "creation_date": 1447867269,
                "answer_id": 33786369,
                "question_id": 33784931,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a one-liner that answers your main question -- if you can&#39;t see how it works, try breaking it up into separate pieces:\r\n\r\n\r\n    map( .sizes |= map( select(.countries | index(&quot;de&quot;) ) | del(.countries) ))\r\n\r\nRegarding the selection of fields, you can use del/1 as above, or sometimes simply using an expression such as `{key1, key2}` will do the trick.  Consider also this function and the following example:\r\n\r\n    def query(queryobject):\r\n      with_entries( select( .key as $key | queryobject | has( $key ) ));\r\n\r\n\r\nExample:\r\n\r\n    $ jq -c -n &#39;{&quot;a&quot;: 1, &quot;b&quot;: null, &quot;c&quot;:3} | query( {a,b,d} )&#39;\r\n    {&quot;a&quot;:1,&quot;b&quot;:null}\r\n\r\n",
                "title": "Filter by values using ./jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1447867269,
        "creation_date": 1447863018,
        "question_id": 33784931,
        "body_markdown": "Given the input of sizes:\r\n\r\n    [\r\n      {\r\n        &quot;stock&quot;: 1,\r\n        &quot;sales&quot;: 0,\r\n        &quot;sizes&quot;: [\r\n          {\r\n            &quot;countries&quot;: [&quot;at&quot;, &quot;be&quot;, &quot;ch&quot;, &quot;cy&quot;, &quot;de&quot;, &quot;ee&quot;, &quot;es&quot;, &quot;fi&quot;, &quot;gr&quot;, &quot;ie&quot;, &quot;lu&quot;, &quot;lv&quot;, &quot;nl&quot;, &quot;pl&quot;, &quot;pt&quot;, &quot;se&quot;, &quot;si&quot;, &quot;sk&quot;],\r\n            &quot;size&quot;: &quot;EU 45,5&quot;\r\n          },\r\n          {\r\n            &quot;countries&quot;: [&quot;it&quot;],\r\n            &quot;size&quot;: &quot;EU 45,5&quot;\r\n          },\r\n          {\r\n            &quot;countries&quot;: [&quot;fr&quot;],\r\n            &quot;size&quot;: &quot;EU 45,5&quot;\r\n          },\r\n          {\r\n            &quot;countries&quot;: [&quot;gb&quot;],\r\n            &quot;size&quot;: &quot;EU 45,5&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nI will like to get the same structure without the ones that `countries` hasn&#39;t &quot;de&quot; (Germany) and remove the field complete. Expected something like this:\r\n\r\n    [\r\n      {\r\n        &quot;stock&quot;: 1,\r\n        &quot;sizes&quot;: [\r\n          {\r\n            &quot;size&quot;: &quot;EU 45,5&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nI tried this:\r\n\r\n    map(.sizes[] |= select(.countries | join(&quot;,&quot;) | contains(&quot;de&quot;))) | map({ stock, sizes })\r\n\r\nBut the filter is not working properly, throwing `jq: error (at &lt;stdin&gt;:48): Cannot iterate over null (null)`.\r\n\r\nTried `has`, `in`, `contains`, `inside` and nothing seems to work.\r\n\r\nAlso, how can I filter which field appears? With `map({ stock, sizes })` countries still there. Can I do something like `map({ stock, sizes: { size } })`?",
        "link": "https://stackoverflow.com/questions/33784931/filter-by-values-using-jq",
        "title": "Filter by values using ./jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1447944653,
                "creation_date": 1447944653,
                "answer_id": 33807127,
                "question_id": 33805577,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Does this solve your problem?\r\n\r\n    .cars | map(.name? // empty) | join(&quot;,&quot;)",
                "title": "JQ JSON parser, concatenate a certain child of an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1504642743,
        "creation_date": 1447940438,
        "last_edit_date": 1504642743,
        "question_id": 33805577,
        "body_markdown": "I have the following JSON input.\r\nThe array is called cars.\r\nSo if I do .cars I get what you see below.\r\n\r\nNow I have to concatenate all .name elements for each item of the array.\r\nI want the output to be\r\n\r\n    Audi\r\n    VW\r\n    Audi,Honda,Chevy\r\n\r\nCan you please help me construct the filter to output this concatenation of .name?\r\nSometimes .name can be empty, not null, nothing just empty. So I do need a // &quot;null&quot; added to the filter as well.\r\nThank you in advance.\r\n\r\n\r\n    [\r\n      {\r\n        &quot;self&quot;: &quot;link&quot;,\r\n        &quot;id&quot;: &quot;18900&quot;,\r\n        &quot;name&quot;: &quot;Audi&quot;,\r\n        &quot;releaseDate&quot;: &quot;2015-12-11&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;self&quot;: &quot;link&quot;,\r\n        &quot;id&quot;: &quot;18900&quot;,\r\n        &quot;name&quot;: &quot;VW&quot;,\r\n        &quot;releaseDate&quot;: &quot;2015-12-11&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;self&quot;: &quot;link&quot;,\r\n        &quot;id&quot;: &quot;19400&quot;,\r\n        &quot;name&quot;: &quot;Audi&quot;,\r\n        &quot;releaseDate&quot;: &quot;2015-11-20&quot;\r\n      },\r\n      {\r\n        &quot;self&quot;: &quot;link&quot;,\r\n        &quot;id&quot;: &quot;18900&quot;,\r\n        &quot;name&quot;: &quot;Honda&quot;,\r\n        &quot;releaseDate&quot;: &quot;2015-12-11&quot;\r\n      },\r\n      {\r\n        &quot;self&quot;: &quot;link&quot;,\r\n        &quot;id&quot;: &quot;19201&quot;,\r\n        &quot;name&quot;: &quot;Chevy&quot;,\r\n        &quot;releaseDate&quot;: &quot;2016-01-08&quot;\r\n      }\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/33805577/jq-json-parser-concatenate-a-certain-child-of-an-array",
        "title": "JQ JSON parser, concatenate a certain child of an array"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 34,
                "is_accepted": false,
                "score": 34,
                "last_activity_date": 1736172266,
                "last_edit_date": 1736172266,
                "creation_date": 1448025917,
                "answer_id": 33827867,
                "question_id": 33827226,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [`del()`][1] function:\r\n\r\n    jq &#39;del(.[]|.key_x)&#39; input.json\r\n\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/#del",
                "title": "JQ: exclude specified embedded keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 27,
        "last_activity_date": 1736172266,
        "creation_date": 1448023986,
        "last_edit_date": 1448083697,
        "question_id": 33827226,
        "body_markdown": "From the following input:\r\n\r\n    {\r\n        &quot;key1&quot;: {\r\n            &quot;key_x&quot;: &quot;1&quot;,\r\n            ...\r\n            &quot;key_z&quot;: &quot;2&quot;\r\n        },\r\n        &quot;key2&quot;: {\r\n            &quot;key_x&quot;: &quot;2&quot;,\r\n            ...\r\n            &quot;key_z&quot;: &quot;3&quot;\r\n        }\r\n    }\r\n\r\nI would like to exclude all keys with the name `&quot;key_x&quot;` so the result should be\r\n\r\n    {\r\n        &quot;key1&quot;: {\r\n            ...\r\n            &quot;key_z&quot;: &quot;2&quot;\r\n        },\r\n        &quot;key2&quot;: {\r\n            ...\r\n            &quot;key_z&quot;: &quot;3&quot;\r\n        }\r\n    }\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/33827226/jq-exclude-specified-embedded-keys",
        "title": "JQ: exclude specified embedded keys"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1619337190,
                "last_edit_date": 1619337190,
                "creation_date": 1448331744,
                "answer_id": 33884346,
                "question_id": 33883060,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[EDITED to use find]\r\n\r\nOne obvious thing to consider would be to process one file at a time, and then &quot;slurp&quot; them:\r\n\r\n    $ while IFS= read -r f ; cat &quot;$f&quot; ; done &lt;(find . -maxdepth 1 -name &quot;*.json&quot;) | jq -s .\r\n\r\nThis however would presumably require a lot of memory. Thus the following may be closer to what you need:\r\n\r\n    #!/bin/bash\r\n    # &quot;slurp&quot; a bunch of files\r\n    # Requires a version of jq with &#39;inputs&#39;.\r\n    echo &quot;[&quot;\r\n    while read f\r\n    do\r\n      jq -nr &#39;inputs | (., &quot;,&quot;)&#39; $f\r\n    done &lt; &lt;(find . -maxdepth 1 -name &quot;*.json&quot;) | sed &#39;$d&#39;\r\n    echo &quot;]&quot;\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "Using jq to combine json files, getting file list length too long error"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1448336734,
                "last_edit_date": 1448336734,
                "creation_date": 1448336231,
                "answer_id": 33885014,
                "question_id": 33883060,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The problem is that the length of a command line is limited, and `*.json` produces too many argument for one command line. One workaround is to expand the pattern in a `for` loop, which does not have the same limits as a command line, because `bash` can iterate over the result internally rather than having to construct an argument list for an external command:\r\n\r\n    for f in *.json; do\r\n        cat &quot;$f&quot;\r\n    done | jq -s &#39;.&#39; &gt; output.json\r\n\r\nThis is rather inefficient, though, since it requires running `cat` once for each file. A more efficient solution is to use `find` to call `cat` with as many files as possible each time.\r\n\r\n    find . -name &#39;*.json&#39; -exec cat &#39;{}&#39; + | jq -s &#39;.&#39; &gt; output.json\r\n\r\n(You may be able to simply use\r\n\r\n    find . -name &#39;*.json&#39; -exec jq -s &#39;{}&#39; + &gt; output.json\r\n\r\nas well; it may depend on what is in the files and how multiple calls to `jq` using the `-s` option compares to a single call.)",
                "title": "Using jq to combine json files, getting file list length too long error"
            },
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1448366510,
                "last_edit_date": 1495540493,
                "creation_date": 1448366510,
                "answer_id": 33893199,
                "question_id": 33883060,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If `jq -s . *.json &gt; output.json` produces &quot;argument list too long&quot;; you could [fix it using `zargs` in zsh](https://unix.stackexchange.com/q/128559/1321):\r\n\r\n    $ zargs *.json -- cat | jq -s . &gt; output.json\r\n\r\nThat you could emulate using `find` as shown in [@chepner&#39;s answer](https://stackoverflow.com/a/33885014/4279):\r\n\r\n    $ find -maxdepth 1 -name \\*.json -exec cat {} + | jq -s . &gt; output.json\r\n\r\n[*&quot;Data in jq is represented as streams of JSON values ... This is a `cat`-friendly format - you can just join two JSON streams together and get a valid JSON stream.&quot;*](https://stedolan.github.io/jq/tutorial/):\r\n\r\n    $ echo &#39;{&quot;a&quot;:1}{&quot;b&quot;:2}&#39; | jq -s .\r\n    [\r\n      {\r\n        &quot;a&quot;: 1\r\n      },\r\n      {\r\n        &quot;b&quot;: 2\r\n      }\r\n    ]\r\n",
                "title": "Using jq to combine json files, getting file list length too long error"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 10,
        "last_activity_date": 1619337190,
        "creation_date": 1448323022,
        "last_edit_date": 1504600281,
        "question_id": 33883060,
        "body_markdown": "Using `jq` to concat json files in a directory.\r\n\r\nThe directory contains a few hundred thousand files.\r\n\r\n`jq -s &#39;.&#39; *.json &gt; output.json`\r\n\r\nreturns an error that the file list is too long. Is there a way to write this that uses a method that will take in more files?",
        "link": "https://stackoverflow.com/questions/33883060/using-jq-to-combine-json-files-getting-file-list-length-too-long-error",
        "title": "Using jq to combine json files, getting file list length too long error"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 144,
                "is_accepted": true,
                "score": 144,
                "last_activity_date": 1448373531,
                "last_edit_date": 1448373531,
                "creation_date": 1448372479,
                "answer_id": 33895231,
                "question_id": 33895076,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you just want to delete the timestamps you can use the `del()` function:\r\n\r\n    jq &#39;del(.[].timestamp)&#39; input.json\r\n\r\n---\r\n\r\nHowever to achieve the desired output, I would not use the `del()` function. Since you know which fields should appear in output, you can simply populate an array with `group` and `id` and then use the `join()` function:\r\n\r\n    jq -r &#39;.[]|[.group,.uid]|join(&quot;,&quot;)&#39; input.json\r\n\r\n`-r` stands for *raw ouput*. `jq` will not print quotes around the values.\r\n\r\nOutput:\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    employees,elgalu\r\n    employees,mike\r\n    services,pacts\r\n\r\n",
                "title": "Exclude column from jq json output"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1448384047,
                "creation_date": 1448384047,
                "answer_id": 33899437,
                "question_id": 33895076,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For the record, an alternative would be:\r\n\r\n    $ jq -r &#39;.[] | &quot;\\(.uid),\\(.group)&quot;&#39; input.json\r\n\r\n(The white-listing approach makes it easy to rearrange the order, and this variant makes it easy to modify the spacing, etc.)\r\n\r\nThe following example may be of interest to anyone who wants safe CSV (i.e. even if the values have embedded commas or newline characters):\r\n\r\n    $ jq -r &#39;.[] | [.uid, .group] | @csv&#39; input.json\r\n    &quot;elgalu&quot;,&quot;employees&quot;\r\n    &quot;mike&quot;,&quot;employees&quot;\r\n    &quot;pacts&quot;,&quot;services&quot;\r\n\r\n\r\n",
                "title": "Exclude column from jq json output"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -5,
                "last_activity_date": 1643217318,
                "last_edit_date": 1643217318,
                "creation_date": 1643207674,
                "answer_id": 70865146,
                "question_id": 33895076,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Sed is your best friend - I can&#39;t think of anything simpler. I&#39;ve got here having the same problem as the question&#39;s author - but maybe this is a simpler answer to the same problem:\r\n\r\n\r\n    &lt; file sed -e &#39;/timestamp/d&#39;",
                "title": "Exclude column from jq json output"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 83,
        "last_activity_date": 1643217318,
        "creation_date": 1448371999,
        "question_id": 33895076,
        "body_markdown": "I would like to get rid of the `timestamp` field here using [jq](https://stedolan.github.io/jq/) JSON processor.\r\n\r\n    [\r\n      {\r\n        &quot;timestamp&quot;: 1448369447295,\r\n        &quot;group&quot;: &quot;employees&quot;,\r\n        &quot;uid&quot;: &quot;elgalu&quot;\r\n      },\r\n      {\r\n        &quot;timestamp&quot;: 1448369447296,\r\n        &quot;group&quot;: &quot;employees&quot;,\r\n        &quot;uid&quot;: &quot;mike&quot;\r\n      },\r\n      {\r\n        &quot;timestamp&quot;: 1448369786667,\r\n        &quot;group&quot;: &quot;services&quot;,\r\n        &quot;uid&quot;: &quot;pacts&quot;\r\n      }\r\n    ]\r\n\r\nWhite listing would also works for me, i.e. `select uid, group`\r\n\r\nUltimately what I would really like is a list with unique values like this:\r\n\r\n    employees,elgalu\r\n    employees,mike\r\n    services,pacts\r\n",
        "link": "https://stackoverflow.com/questions/33895076/exclude-column-from-jq-json-output",
        "title": "Exclude column from jq json output"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1448398474,
                "last_edit_date": 1448398474,
                "creation_date": 1448397043,
                "answer_id": 33903232,
                "question_id": 33903013,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try putting parentheses around the expression:\r\n\r\n    .fields.customfield_10025 | if .value != null then (.value + &quot;,&quot; + .child.value ) else &quot;&quot; end\r\n\r\nThat is, `[1,2 | type]` is parsed as `[(1,2) | type]`, not `[1, (2|type)]`.\r\n",
                "title": "jq Cannot index string with string &quot;value&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1448398474,
        "creation_date": 1448396258,
        "last_edit_date": 1448397243,
        "question_id": 33903013,
        "body_markdown": "I have the short jq filter below which works perfectly:\r\n\r\n    cat data.tmp2 | ./jq-linux64-1.5 -r &#39;.issues[].fields.customfield_10025 | if .value != null then (.value + &quot;,&quot; + .child.value ) else &quot;&quot; end&#39;\r\n\r\nIt produces exactly what I need, if the field is empty it returns &quot;&quot; if the field is not empty it uses the value of the field and concatenates a comma and a child value.\r\nHowever when I move my filter in a larger filter seen below, I get an error: Cannot index string with string &quot;value&quot;\r\n\r\nThis is the longer filter that fails:\r\n\r\n\r\n    cat data.tmp2 | ./jq-linux64-1.5 -r &#39;.issues | map([.key,.fields.project.name,.fields.parent.key,.fields.issuetype.name,.fields.status.name,.fields.priority.name,.fields.resolution.name,.fields.assignee.name,.fields.reporter.name,.fields.created,.fields.updated,.fields.resolutiondate,.fields.summary,(.fields.components | (map(.name?) | join (&quot;,&quot;))),(.fields.fixVersions | (map(.name?) | join (&quot;,&quot;))),.fields.customfield_10025 | if .value != null then (.value + &quot;,&quot; + .child.value ) else &quot;&quot; end,.fields.customfield_10201] | join (&quot;---&quot;))\r\n",
        "link": "https://stackoverflow.com/questions/33903013/jq-cannot-index-string-with-string-value",
        "title": "jq Cannot index string with string &quot;value&quot;"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1448469099,
                "creation_date": 1448469099,
                "answer_id": 33921717,
                "question_id": 33919650,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using reduce seems to do the trick: `.result[] | .hostid + &quot;, &quot; + .host + &quot;, &quot; + (reduce .groups[].name as $gn (&quot;&quot;; . + $gn + &quot; &quot;))`\r\n\r\nYou might want to trim the output as well, as this produces and extra whitespace character.",
                "title": "writing array values to the same line while extracting data from json using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1448470897,
                "creation_date": 1448470897,
                "answer_id": 33922335,
                "question_id": 33919650,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use this:\r\n\r\n    jq -r &#39;.result[]|[.hostid,.host,.groups[].name]|@csv&#39;\r\n\r\nOutput:\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    &quot;15226&quot;,&quot;host1&quot;,&quot;Group 1&quot;,&quot;Group 2&quot;\r\n\r\n---\r\n\r\n`@csv` makes proper csv out of it. If you don&#39;t like that, a simple `join(&#39;,&#39;)` should be enough:\r\n\r\n    jq -r &#39;.result[]|[.hostid,.host,.groups[].name]|join(&quot;,&quot;)&#39;\r\n\r\nOutput:\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    15226,host1,Group 1,Group 2\r\n\r\n",
                "title": "writing array values to the same line while extracting data from json using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501883386,
                "creation_date": 1501883386,
                "answer_id": 45515972,
                "question_id": 33919650,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**join** / **@csv** as described by [hek2mgl](https://stackoverflow.com/users/171318/hek2mgl) is definitely the easiest way to do this.  \r\n\r\nFor reference, here is a version that uses string interpolation to build the initial part of the line and **reduce** to add the group names to it:\r\n\r\n      .result[]\r\n    | reduce .groups[].name as $g (\r\n          &quot;\\(.hostid), \\(.host)&quot;\r\n        ; . + &quot;, &quot; + $g \r\n      )",
                "title": "writing array values to the same line while extracting data from json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1501883386,
        "creation_date": 1448463344,
        "question_id": 33919650,
        "body_markdown": "I have the following json:\r\n\r\n    {\r\n      &quot;jsonrpc&quot;: &quot;2.0&quot;,\r\n      &quot;result&quot;: [\r\n        {\r\n          &quot;hostid&quot;: &quot;15226&quot;,\r\n          &quot;host&quot;: &quot;host1&quot;,\r\n          &quot;groups&quot;: [\r\n            {\r\n              &quot;groupid&quot;: &quot;56&quot;,\r\n              &quot;name&quot;: &quot;Group 1&quot;,\r\n              &quot;internal&quot;: &quot;0&quot;,\r\n              &quot;flags&quot;: &quot;0&quot;\r\n            },\r\n            {\r\n              &quot;groupid&quot;: &quot;112&quot;,\r\n              &quot;name&quot;: &quot;Group 2&quot;,\r\n              &quot;internal&quot;: &quot;0&quot;,\r\n              &quot;flags&quot;: &quot;0&quot;\r\n            }\r\n          ]\r\n        }\r\n      ],\r\n      &quot;id&quot;: 1\r\n    }\r\n\r\nI am trying to extract values from it to create this line using jq:\r\n\r\n    15226, host1, Group 1, Group 2\r\n\r\nI am able to do the following but it&#39;s not quite what I want:\r\n\r\n    jq -r &#39;.result[] | .hostid + &quot;, &quot; + .host + &quot;, &quot; + .groups[].name&#39; hostlist.json\r\n    15226, host1, Group 1\r\n    15226, host1, Group 2\r\n\r\nCouldn&#39;t figure it out, any help is appreciated.\r\n",
        "link": "https://stackoverflow.com/questions/33919650/writing-array-values-to-the-same-line-while-extracting-data-from-json-using-jq",
        "title": "writing array values to the same line while extracting data from json using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1448540437,
                "creation_date": 1448540437,
                "answer_id": 33938592,
                "question_id": 33938284,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "[Hjson][1] does this kind of thing really well.\r\n\r\n    $ hjson -j &lt;&lt;EOF\r\n    &gt; {\r\n    &gt;   name: &quot;Leo&quot;,\r\n    &gt;   active: true\r\n    &gt; }\r\n    &gt; EOF\r\n    {\r\n      &quot;name&quot;: &quot;Leo&quot;,\r\n      &quot;active&quot;: true\r\n    }\r\n\r\n\r\n  [1]: http://hjson.org/",
                "title": "Convert invalid json into valid one in bash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1448541506,
                "creation_date": 1448541506,
                "answer_id": 33938961,
                "question_id": 33938284,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As I don&#39;t know how easy it is to deploy Hjson (from Steve Bennett&#39;s answer), here&#39;s a more lightweight alternative, using `sed`:\r\n\r\n    $ sed &#39;s/\\b\\([^:&quot;]*\\)\\b\\s*:/&quot;\\1&quot;:/g&#39; &lt;&lt;EOF\r\n    &gt; {\r\n    &gt;   name: &quot;Leo&quot;,\r\n    &gt;   active: true\r\n    &gt; }\r\n    &gt; EOF\r\n    {\r\n      &quot;name&quot;: &quot;Leo&quot;,\r\n      &quot;active&quot;: true\r\n    }\r\n\r\nNote that this is more specific to the example you&#39;ve provided in the question: it will only fix missing quotation around keys. Also, it might be too aggressive about that, as, for example, integer keys would be quoted as well.",
                "title": "Convert invalid json into valid one in bash"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1482306465,
                "last_edit_date": 1482306465,
                "creation_date": 1448552350,
                "answer_id": 33942368,
                "question_id": 33938284,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The jq FAQ at https://github.com/stedolan/jq/wiki/FAQ#processing-not-quite-valid-json lists several tools (including hjson) for converting near-JSON to JSON.  Some of them can be used as bash commands, e.g.\r\nhttps://www.npmjs.com/package/any-json, which is particularly versatile.\r\n\r\nIncidentally, since jq allows JSON to be specified in a jq program in a flexible way (e.g. quotation marks around key names can be omitted and &quot;#&quot; comments can be added), you can use jq itself to convert many instances of not-quite JSON to JSON.  Using your example, if the not-quite JSON text is in a file named input.nqj, then the invocation:\r\n\r\n    $ jq -n -f input.nqj\r\n\r\nwould produce:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;Leo&quot;,\r\n      &quot;active&quot;: true\r\n    }\r\n",
                "title": "Convert invalid json into valid one in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1482306465,
        "creation_date": 1448539573,
        "last_edit_date": 1495541635,
        "question_id": 33938284,
        "body_markdown": "I get invalid JSON from a script, e.g.\r\n\r\n    {\r\n      name: &quot;Leo&quot;,\r\n      active: true\r\n    }\r\n\r\nIs there a bash install-able tool I can use to pipe that output and turn it into valid JSON so can be processed by [jq]() given jq [doesn&#39;t support it]() ?\r\n\r\nThis question is similar to https://stackoverflow.com/questions/8815586/convert-invalid-json-into-valid-json except I need a command line utility and not some replace based php code.\r\n",
        "link": "https://stackoverflow.com/questions/33938284/convert-invalid-json-into-valid-one-in-bash",
        "title": "Convert invalid json into valid one in bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2735036,
                    "reputation": 1028,
                    "user_id": 2357890,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3cd8c7e853f0e43e27c8cd111501931d?s=256&d=identicon&r=PG",
                    "display_name": "xjedam",
                    "link": "https://stackoverflow.com/users/2357890/xjedam"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1448577831,
                "post_id": 33947584,
                "comment_id": 55654810,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 61,
                "is_accepted": true,
                "score": 61,
                "last_activity_date": 1631360542,
                "last_edit_date": 1631360542,
                "creation_date": 1448608979,
                "answer_id": 33952189,
                "question_id": 33947584,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By default, `jq` formats its output to be a valid JSON value. This means that character strings are wrapped in quotes. \r\n\r\nFortunately, the `--raw-output` or `-r` [parameter overrides](https://stedolan.github.io/jq/manual/) that behaviour so your string output can be free of those nasty quotation marks.",
                "title": "Concat numbers from JSON without doublequotes using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 39,
        "last_activity_date": 1631360542,
        "creation_date": 1448575292,
        "last_edit_date": 1537268728,
        "question_id": 33947584,
        "body_markdown": "I have files with 1 json document per row and the fields `start_id` and `end_id` in each document. I&#39;d like to use jq to extract these and print them on the same row.\r\n\r\nSo far I have:\r\n\r\n    cat part* | jq &#39;&quot;\\(.start_id) \\(.end_id)&quot;&#39; | sed s/\\&quot;//g | head\r\n\r\nThis works, but I need the `sed` to remove the double quotes.\r\n\r\nIn order to improve my jq-foo, is there a way to do this _without using sed_?\r\n\r\ne.g. given\r\n\r\n    {&quot;start_id&quot;:1,&quot;end_id&quot;:50}\r\n    {&quot;start_id&quot;:50,&quot;end_id&quot;:99}\r\n    {&quot;start_id&quot;:99,&quot;end_id&quot;:12}\r\n\r\nget\r\n\r\n    1 50\r\n    50 99\r\n    99 12\r\n\r\ninstead of \r\n\r\n    &quot;1 50&quot;\r\n    &quot;50 99&quot;\r\n    &quot;99 12&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/33947584/concat-numbers-from-json-without-doublequotes-using-jq",
        "title": "Concat numbers from JSON without doublequotes using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 484897,
                    "reputation": 56487,
                    "user_id": 900873,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/2d2e6d99a0835208b1c35aacc28c6db5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kevin",
                    "link": "https://stackoverflow.com/users/900873/kevin"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1448600959,
                "post_id": 33950596,
                "comment_id": 55659697,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 514320,
                    "reputation": 25519,
                    "user_id": 1392132,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://i.sstatic.net/QF6FZ.jpg?s=256",
                    "display_name": "5gon12eder",
                    "link": "https://stackoverflow.com/users/1392132/5gon12eder"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1448601520,
                "post_id": 33950596,
                "comment_id": 55659850,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3060975,
                    "reputation": 4780,
                    "user_id": 3288346,
                    "user_type": "registered",
                    "accept_rate": 34,
                    "profile_image": "https://www.gravatar.com/avatar/2a9fd94299faabe6988e648d1e263b2d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "kosta",
                    "link": "https://stackoverflow.com/users/3288346/kosta"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1448602055,
                "post_id": 33950596,
                "comment_id": 55659977,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1448601392,
                "creation_date": 1448601392,
                "answer_id": 33950682,
                "question_id": 33950596,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try Build it around this example. (Source: Original Site)\r\n\r\nExample:\r\n\r\n    jq &#39;[foreach .[] as $item ([[],[]]; if $item == null then [[],.[0]]     else [(.[0] + [$item]),[]] end; if $item == null then .[1] else empty end)]&#39;\r\n\r\n`Input\t[1,2,3,4,null,&quot;a&quot;,&quot;b&quot;,null]`\r\n\r\n`Output\t[[1,2,3,4],[&quot;a&quot;,&quot;b&quot;]]`",
                "title": "Iterating through JSON array in Shell script"
            },
            {
                "up_vote_count": 208,
                "is_accepted": false,
                "score": 205,
                "last_activity_date": 1449170469,
                "last_edit_date": 1449170469,
                "creation_date": 1448610449,
                "answer_id": 33952539,
                "question_id": 33950596,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just use a filter that would return each item in the array.  Then loop over the results, just make sure you use the compact output option (`-c`) so each result is put on a single line and is treated as one item in the loop.\r\n\r\n    jq -c &#39;.[]&#39; input.json | while read i; do\r\n        # do stuff with $i\r\n    done",
                "title": "Iterating through JSON array in Shell script"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1448615213,
                "creation_date": 1448615213,
                "answer_id": 33953764,
                "question_id": 33950596,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "An earlier answer in this thread suggested using jq&#39;s `foreach`, but that may be much more complicated than needed, especially given the stated task. Specifically, `foreach` (and `reduce`) are intended for certain cases where you need to accumulate results.  \r\n\r\nIn many cases (including some cases where eventually a reduction step is necessary), it&#39;s better to use `.[]` or `map(_)`.  The latter is just another way of writing [.[] | _] so if you are going to use jq, it&#39;s really useful to understand that .[] simply creates a *stream* of values.\r\nFor example, `[1,2,3] | .[]` produces a stream of the three values.\r\n\r\nTo take a simple map-reduce example, suppose you want to find the maximum length of an array of strings.  One solution would be `[ .[] | length] | max`.",
                "title": "Iterating through JSON array in Shell script"
            },
            {
                "up_vote_count": 28,
                "is_accepted": false,
                "score": 28,
                "last_activity_date": 1549984096,
                "creation_date": 1549984096,
                "answer_id": 54653099,
                "question_id": 33950596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` has a shell formatting option: `@sh`.\r\n\r\nYou can use the following to format your json data as shell parameters:\r\n```\r\ncat data.json | jq &#39;. | map([.original_name, .changed_name])&#39; | jq @sh\r\n```\r\n\r\nThe output will look like:\r\n```\r\n&quot;&#39;pdf_convert&#39; &#39;pdf_convert_1&#39;&quot;\r\n&quot;&#39;video_encode&#39; &#39;video_encode_1&#39;&quot;,\r\n&quot;&#39;video_transcode&#39; &#39;video_transcode_1&#39;&quot;\r\n```\r\n\r\nTo process each row, we need to do a couple of things:\r\n\r\n - Set the bash for-loop to read the entire row, rather than stopping at the first space (default behavior).\r\n - Strip the enclosing double-quotes off of each row, so each value can be passed as a parameter to the function which processes each row.\r\n\r\nTo read the entire row on each iteration of the bash for-loop, set the `IFS` variable, as described in [this answer][1].\r\n\r\nTo strip off the double-quotes, we&#39;ll run it through the bash shell interpreter using `xargs`:\r\n```\r\nstripped=$(echo $original | xargs echo)\r\n```\r\n\r\n----------\r\n\r\n\r\nPutting it all together, we have:\r\n```\r\n#!/bin/bash\r\n\r\nfunction processRow() {\r\n  original_name=$1\r\n  changed_name=$2\r\n\r\n  # TODO\r\n}\r\n\r\nIFS=$&#39;\\n&#39; # Each iteration of the for loop should read until we find an end-of-line\r\nfor row in $(cat data.json | jq &#39;. | map([.original_name, .changed_name])&#39; | jq @sh)\r\ndo\r\n  # Run the row through the shell interpreter to remove enclosing double-quotes\r\n  stripped=$(echo $row | xargs echo)\r\n\r\n  # Call our function to process the row\r\n  # eval must be used to interpret the spaces in $stripped as separating arguments\r\n  eval processRow $stripped\r\ndone\r\nunset IFS # Return IFS to its original value\r\n```\r\n\r\n  [1]: https://askubuntu.com/questions/344407/how-to-read-complete-line-in-for-loop-with-spaces",
                "title": "Iterating through JSON array in Shell script"
            },
            {
                "up_vote_count": 39,
                "is_accepted": false,
                "score": 38,
                "last_activity_date": 1674833661,
                "last_edit_date": 1674833661,
                "creation_date": 1621606409,
                "answer_id": 67638584,
                "question_id": 33950596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By leveraging the power of Bash arrays, you can do something like:\r\n\r\n```sh\r\n# read each item in the JSON array to an item in the Bash array\r\nreadarray -t my_array &lt; &lt;(jq --compact-output &#39;.[]&#39; input.json)\r\n\r\n# iterate through the Bash array\r\nfor item in &quot;${my_array[@]}&quot;; do\r\n  original_name=$(jq --raw-output &#39;.original_name&#39; &lt;&lt;&lt; &quot;$item&quot;)\r\n  changed_name=$(jq --raw-output &#39;.changed_name&#39; &lt;&lt;&lt; &quot;$item&quot;)\r\n  # do your stuff\r\ndone\r\n```",
                "title": "Iterating through JSON array in Shell script"
            },
            {
                "up_vote_count": 21,
                "is_accepted": false,
                "score": 19,
                "last_activity_date": 1630163693,
                "creation_date": 1630163693,
                "answer_id": 68965629,
                "question_id": 33950596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From https://stackoverflow.com/questions/58635875/iterate-over-json-array-of-dates-in-bash-has-whitespace\r\n\r\n    items=$(echo &quot;$JSON_Content&quot; | jq -c -r &#39;.[]&#39;)\r\n    for item in ${items[@]}; do\r\n        echo $item\r\n        # whatever you are trying to do ...\r\n    done",
                "title": "Iterating through JSON array in Shell script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1636983768,
                "last_edit_date": 1636983768,
                "creation_date": 1632420511,
                "answer_id": 69304984,
                "question_id": 33950596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is what I have done so far\r\n\r\n     arr=$(echo &quot;$array&quot; | jq -c -r &#39;.[]&#39;)\r\n                for item in ${arr[@]}; do\r\n                   original_name=$(echo $item | jq -r &#39;.original_name&#39;)\r\n                   changed_name=$(echo $item | jq -r &#39;.changed_name&#39;)\r\n                  echo $original_name $changed_name\r\n                done",
                "title": "Iterating through JSON array in Shell script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1647532763,
                "last_edit_date": 1647532763,
                "creation_date": 1647284264,
                "answer_id": 71472907,
                "question_id": 33950596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I stopped using `jq` and started using `jp`, since JMESpath is the same language as used by the `--query` argument of my cloud service and I find it difficult to juggle both languages at once. You can quickly learn the basics of JMESpath expressions here: https://jmespath.org/tutorial.html\r\n\r\nSince you didn&#39;t **specifically** ask for a `jq` answer but instead, an approach to iterating JSON in bash, I think it&#39;s an appropriate answer.\r\n\r\n**Style points:** \r\n1. I use backticks and those have fallen out of fashion. You can substitute with another command substitution operator.\r\n2. I use `cat` to pipe the input contents into the command. Yes, you can also specify the filename as a parameter, but I find this distracting because it breaks my left-to-right reading of the sequence of operations. Of course you can update this from my style to yours.\r\n3. `set -u` has no function in this solution, but is important if you are fiddling with bash to get something to work. The command forces you to declare variables and therefore doesn&#39;t allow you to misspell a variable name.\r\n\r\nHere&#39;s how I do it:\r\n\r\n    #!/bin/bash\r\n    set -u\r\n    \r\n    # exploit the JMESpath length() function to get a count of list elements to iterate\r\n    export COUNT=`cat data.json | jp &quot;length( [*] )&quot;`\r\n\r\n    # The `seq` command produces the sequence `0 1 2` for our indexes\r\n    # The $(( )) operator in bash produces an arithmetic result ($COUNT minus one)\r\n    for i in `seq 0 $((COUNT - 1))` ; do\r\n\r\n         # The list elements in JMESpath are zero-indexed\r\n         echo &quot;Here is element $i:&quot;\r\n         cat data.json | jp &quot;[$i]&quot;\r\n\r\n         # Add or replace whatever operation you like here.\r\n\r\n    done\r\n\r\nNow, it would also be a common use case to pull the original JSON data from an online API and not from a local file. In that case, I use a slightly modified technique of caching the full result in a variable:\r\n\r\n    #!/bin/bash\r\n    set -u\r\n    \r\n    # cache the JSON content in a stack variable, downloading it only once\r\n    export DATA=`api --profile foo compute instance list --query &quot;bar&quot;`\r\n\r\n    export COUNT=`echo &quot;$DATA&quot; | jp &quot;length( [*] )&quot;`\r\n    for i in `seq 0 $((COUNT - 1))` ; do\r\n         echo &quot;Here is element $i:&quot;\r\n         echo &quot;$DATA&quot; | jp &quot;[$i]&quot;\r\n    done\r\n\r\nThis second example has the added benefit that if the data is changing rapidly, you are guaranteed to have a consistent count between the elements you are iterating through, and the elements in the iterated data.",
                "title": "Iterating through JSON array in Shell script"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1674452784,
                "last_edit_date": 1674452784,
                "creation_date": 1663877394,
                "answer_id": 73820171,
                "question_id": 33950596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a simple example that works in *zch* shell:\r\n\r\n    \r\n    DOMAINS=&#39;[&quot;google&quot;,&quot;amazon&quot;]&#39;\r\n\r\n    arr=$(echo $DOMAINS | jq -c &#39;.[]&#39;)\r\n    for d in $arr; do\r\n        printf &quot;Here is your domain: ${d}\\n&quot;\r\n    done",
                "title": "Iterating through JSON array in Shell script"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1666210334,
                "creation_date": 1666210334,
                "answer_id": 74131349,
                "question_id": 33950596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "None of the answers here worked for me, out-of-the-box.\r\n\r\nWhat did work was a combination of a few:\r\n\r\n```\r\nprojectList=$(echo &quot;$projRes&quot; | jq -c &#39;.projects[]&#39;)\r\n\r\nIFS=$&#39;\\n&#39; # Read till newline\r\n\r\nfor project in ${projectList[@]}; do\r\n  projectId=$(jq &#39;.id&#39; &lt;&lt;&lt; &quot;$project&quot;)\r\n  projectName=$(jq -r &#39;.name&#39; &lt;&lt;&lt; &quot;$project&quot;)\r\n  ...\r\ndone\r\n\r\nunset IFS\r\n```\r\n\r\nNOTE: I&#39;m not using the same data as the question does, in this example assume `projRes` is the output from an API that gives us a JSON list of projects, eg:\r\n\r\n```\r\n{\r\n  &quot;projects&quot;: [ \r\n    {&quot;id&quot;:1,&quot;name&quot;:&quot;Project&quot;}, \r\n    ... // array of projects\r\n  ] \r\n}\r\n```",
                "title": "Iterating through JSON array in Shell script"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1698872833,
                "last_edit_date": 1698872833,
                "creation_date": 1693315552,
                "answer_id": 77000649,
                "question_id": 33950596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the general case, [@Jeff&#39;s answer](https://stackoverflow.com/a/33952539/2158479) is the way to go. It uses jq&#39;s `--compact-output` (or `-c`) flag to print each iteration result on its own single line, then uses the shell&#39;s `read` function in a `while` loop to linewise read the results into a shell variable.\r\n\r\n```sh\r\njq -c &#39;.[]&#39; input.json | while read i; do\r\n    # do stuff with $i\r\ndone\r\n```\r\n\r\nBut utilizing that flag comes at the cost of sacrificing the pretty-printing otherwise present in jq&#39;s non-compact outputs. If you needed that formatting, the proximate attempt would be to subsequently run other instances of jq on each iteration step to (re-)establish the formatting for each output. However, this can be expensive, especially on large input arrays, and could be generally avoided by retaining the initial formatting while using a delimiter other than the newline character (because the pretty-printed, multi-line output items themselves already do contain newlines characters).\r\n\r\nAs `bash` is tagged, one way would be using `read`&#39;s (non-POSIX) `-d` option to provide a custom delimiter. With an empty string, it defaults to &quot;terminate a line when it reads a NUL character&quot;, which can be added to jq&#39;s output using `&quot;\\u0000&quot;`. As for the jq filter, opening a new context (with `|`) after the iteration ensures it&#39;s printed with every array item. Finally, jq&#39;s `--join-output` (or `-j`) flag decodes the JSON-encoded NUL character while suppressing the otherwise appended newline characters after each item.\r\n\r\n```sh\r\njq -j &#39;.[] | ., &quot;\\u0000&quot;&#39; input.json | while read -d &#39;&#39; i; do\r\n    # do stuff with pretty-printed, multi-line &quot;$i&quot;\r\ndone\r\n```\r\n\r\n**Edit**: With [jq 1.7](https://github.com/jqlang/jq/releases/tag/jq-1.7), a new flag `--raw-output0` (note the `0` at the end) was introduced, which behaves just like the regular `--raw-output` (or `-r`) flag, but emits NUL characters instead of newlines after each output printed. It thus perfectly covers the last approach while rendering all its manual arrangements (adding `&quot;\\u0000&quot;` and using the `-j` flag) unnecessary.\r\n\r\n```sh\r\njq --raw-output0 &#39;.[]&#39; input.json | while read -d &#39;&#39; i; do\r\n    # do stuff with pretty-printed, multi-line &quot;$i&quot;\r\ndone\r\n```",
                "title": "Iterating through JSON array in Shell script"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1704968731,
                "creation_date": 1704968731,
                "answer_id": 77799307,
                "question_id": 33950596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In case if you are receiving some problems, it might be related to the transformed escape character `\\&quot;` being parsed to just `&quot;`, which will result in error: \r\n\r\n**parse error: Invalid escape at line ...**\r\n\r\nMy solution to this problem is using `sed`. So, if we would transform the query from one of the previous answers, the command would look like this:\r\n```\r\njq -c &#39;.[]&#39; input.json | sed &#39;s/\\\\&quot;/\\\\&#39;\\&#39;&#39;/g&#39; | while read i; do\r\n    # do stuff with $i | jq\r\ndone\r\n```\r\n\r\nwhere the command `sed &#39;s/\\\\&quot;/\\\\&#39;\\&#39;&#39;/g&#39;` would replace all `\\&quot;` with `&#39;`.\r\n\r\nThere might be different parsing error scenarios when iterating through the objects. If there would I would adjust the sed command to make the JSON syntax valid.",
                "title": "Iterating through JSON array in Shell script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1753838993,
                "creation_date": 1753838993,
                "answer_id": 79719357,
                "question_id": 33950596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think in most cases, using JSON and jq is not useful.\r\n\r\nBut it&#39;s normal to try to use what we learnt in other languages.\r\n\r\nInstead we could use [BASH arrays](https://www.gnu.org/software/bash/manual/html_node/Arrays.html) and iterators, to get the best of best world, so we could craft advanced stuffs and roll math, while keeping the sugar syntax `$fruit`. \r\n\r\n\r\n```\r\nLIST=(&quot;orange&quot; &quot;apple&quot; &quot;banana&quot;)\r\n\r\nI=$((&quot;0&quot;)) # String to number\r\nfor fruit in &quot;${LIST[@]}&quot;; do\r\n    echo &quot;$I: $fruit&quot;\r\n    I=$(( $I + 1 )) # Iterator: Make your own\r\ndone\r\n\r\n# Or direct read by key\r\necho &quot;${LIST[2]}&quot;\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n0: orange\r\n1: apple\r\n2: banana\r\nbanana\r\n```",
                "title": "Iterating through JSON array in Shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 13,
        "score": 120,
        "last_activity_date": 1753838993,
        "creation_date": 1448600811,
        "last_edit_date": 1539032553,
        "question_id": 33950596,
        "body_markdown": "I have a JSON data as follows in data.json file\r\n\r\n    [\r\n      {&quot;original_name&quot;:&quot;pdf_convert&quot;,&quot;changed_name&quot;:&quot;pdf_convert_1&quot;},\r\n      {&quot;original_name&quot;:&quot;video_encode&quot;,&quot;changed_name&quot;:&quot;video_encode_1&quot;},\r\n      {&quot;original_name&quot;:&quot;video_transcode&quot;,&quot;changed_name&quot;:&quot;video_transcode_1&quot;}\r\n    ]\r\n\r\n\r\nI want to iterate through the array and extract the value for each element in a loop. I saw [jq][1]. I find it difficult to use it to iterate. How can I do that?\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
        "link": "https://stackoverflow.com/questions/33950596/iterating-through-json-array-in-shell-script",
        "title": "Iterating through JSON array in Shell script"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1448733097,
                "post_id": 33973816,
                "comment_id": 55705178,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6663049,
                    "reputation": 225,
                    "user_id": 5141502,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/gremL.jpg?s=256",
                    "display_name": "brian",
                    "link": "https://stackoverflow.com/users/5141502/brian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1448735396,
                "post_id": 33973816,
                "comment_id": 55706070,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1448771219,
                "creation_date": 1448771219,
                "answer_id": 33979412,
                "question_id": 33973816,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There&#39;s more than one way to skin a jq cat, but one of the main keys\r\nto obtaining a crisp solution is the ability to define helper\r\nfunctions, which in fact can be nested.  Here at any rate is a solution that uses a helper function which does have an inner function.\r\n\r\n    # Does &quot;obj&quot; match any of the objects in the input array?\r\n    def anymatch(obj):\r\n      # Do all the key-value pairs in obj also occur in the input?\r\n      def match(obj):\r\n        . as $in\r\n        | obj as $o\r\n        | all( $o|keys[]; $in[.] == $o[.]);\r\n      any(.[]; match(obj));\r\n\r\n    .TagDescriptions[]\r\n    | select( .Tags\r\n            | (anymatch({&quot;Key&quot;:&quot;customer_prefix&quot;, &quot;Value&quot;: &quot;widget_xyz&quot;})\r\n               and anymatch({&quot;Key&quot;:&quot;environment&quot;, &quot;Value&quot;: &quot;production&quot;})\r\n               and anymatch({&quot;Key&quot;:&quot;service&quot;, &quot;Value&quot;: &quot;widget&quot;} ) ))\r\n    | .LoadBalancerName\r\n\r\n\r\nFor the given input, this produces:\r\n```\r\n&quot;widget-xyz-widget-prod&quot;\r\n```\r\n\r\n(By the way, I don&#39;t think your &quot;ANOTHER UPDATE&quot; solution is a valid solution to the stated problem, at least as I understand it.)\r\n",
                "title": "Filtering JSON object list with jq by matching multiple objects"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1448771861,
                "creation_date": 1448771861,
                "answer_id": 33979456,
                "question_id": 33973816,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The `Tags` array are perfect for creating an object out of for easy access.  Make things easy on yourself and do so.  Then access to the values would be significantly easier.  Then you could easily test to see if your conditions are satisfied.\r\n\r\n    .TagDescriptions[] | select(\r\n        .Tags | from_entries | [\r\n            .service == &quot;widget&quot;,\r\n            .environment == &quot;production&quot;,\r\n            .customer_prefix == &quot;widget_xyz&quot;\r\n        ] | all\r\n    ).LoadBalancerName",
                "title": "Filtering JSON object list with jq by matching multiple objects"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1448771909,
        "creation_date": 1448729202,
        "last_edit_date": 1448771909,
        "question_id": 33973816,
        "body_markdown": "I&#39;m trying to filter the output of &#39;aws elb describe-tags&#39; and get a LoadBalancerName by matching three tags. I&#39;m not seeing how I can select a specific element of an object list and compare both Key and Value. I have three objects to look against, and if they&#39;re all a match I need to return LoadBalancerName.\r\n\r\nHere&#39;s an example output of three load balancers, with only one having the correct set of tags.\r\n\r\n    {\r\n        &quot;TagDescriptions&quot;: [\r\n            {\r\n                &quot;Tags&quot;: [\r\n                    {\r\n                        &quot;Value&quot;: &quot;production&quot;,\r\n                        &quot;Key&quot;: &quot;environment&quot;\r\n                    },\r\n                    {\r\n                        &quot;Value&quot;: &quot;widget&quot;,\r\n                        &quot;Key&quot;: &quot;service&quot;\r\n                    },\r\n                    {\r\n                        &quot;Value&quot;: &quot;widget_xyz&quot;,\r\n                        &quot;Key&quot;: &quot;customer_prefix&quot;\r\n                    },\r\n                    {\r\n                        &quot;Value&quot;: &quot;widget_xyz-widget-production&quot;,\r\n                        &quot;Key&quot;: &quot;Name&quot;\r\n                    }\r\n                ],\r\n                &quot;LoadBalancerName&quot;: &quot;widget-xyz-widget-prod&quot;\r\n            },\r\n            {\r\n                &quot;Tags&quot;: [\r\n                    {\r\n                        &quot;Value&quot;: &quot;widget-xyz-stage-widget-ConsulStack-DKJSADKJS&quot;,\r\n                        &quot;Key&quot;: &quot;aws:cloudformation:stack-name&quot;\r\n                    },\r\n                    {\r\n                        &quot;Value&quot;: &quot;stage&quot;,\r\n                        &quot;Key&quot;: &quot;environment&quot;\r\n                    },\r\n                    {\r\n                        &quot;Value&quot;: &quot;arn:aws:cloudformation:us-east-1:123456789:stack/widget-xyz-stage-widget-ConsulStack-DKJSADKJS/d46ad520-92e7-11e5-a975-500150b34c7c&quot;,\r\n                        &quot;Key&quot;: &quot;aws:cloudformation:stack-id&quot;\r\n                    },\r\n                    {\r\n                        &quot;Value&quot;: &quot;widget&quot;,\r\n                        &quot;Key&quot;: &quot;service&quot;\r\n                    },\r\n                    {\r\n                        &quot;Value&quot;: &quot;widget_xyz&quot;,\r\n                        &quot;Key&quot;: &quot;customer_prefix&quot;\r\n                    },\r\n                    {\r\n                        &quot;Value&quot;: &quot;ELB&quot;,\r\n                        &quot;Key&quot;: &quot;aws:cloudformation:logical-id&quot;\r\n                    },\r\n                    {\r\n                        &quot;Value&quot;: &quot;widget_xyz-widget-stage&quot;,\r\n                        &quot;Key&quot;: &quot;Name&quot;\r\n                    }\r\n                ],\r\n                &quot;LoadBalancerName&quot;: &quot;widget-xyz-ELB-SDKJSDKJSADKJAS&quot;\r\n            },\r\n            {\r\n                &quot;Tags&quot;: [\r\n                    {\r\n                        &quot;Value&quot;: &quot;widget-xyz-prod-widget-ConsulStack-DLFJEIJNWDKD&quot;,\r\n                        &quot;Key&quot;: &quot;aws:cloudformation:stack-name&quot;\r\n                    },\r\n                    {\r\n                        &quot;Value&quot;: &quot;prod&quot;,\r\n                        &quot;Key&quot;: &quot;environment&quot;\r\n                    },\r\n                    {\r\n                        &quot;Value&quot;: &quot;arn:aws:cloudformation:us-east-1:123456789:stack/widget-xyz-prod-widget-ConsulStack-DLFJEIJNWDKD/ab2292f0-9398-11e5-b0f6-50d501114c2c&quot;,\r\n                        &quot;Key&quot;: &quot;aws:cloudformation:stack-id&quot;\r\n                    },\r\n                    {\r\n                        &quot;Value&quot;: &quot;widget&quot;,\r\n                        &quot;Key&quot;: &quot;service&quot;\r\n                    },\r\n                    {\r\n                        &quot;Value&quot;: &quot;widget_xyz&quot;,\r\n                        &quot;Key&quot;: &quot;customer_prefix&quot;\r\n                    },\r\n                    {\r\n                        &quot;Value&quot;: &quot;ELB&quot;,\r\n                        &quot;Key&quot;: &quot;aws:cloudformation:logical-id&quot;\r\n                    },\r\n                    {\r\n                        &quot;Value&quot;: &quot;widget_xyz-widget-prod&quot;,\r\n                        &quot;Key&quot;: &quot;Name&quot;\r\n                    }\r\n                ],\r\n                &quot;LoadBalancerName&quot;: &quot;widget-xyz-ELB-SKDJSKDJSAKDJAS&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nI&#39;ve successfully implemented my query, but unsafely. It&#39;s returning the LoadBalancerName as long as any three values match my search pattern. I would like to search for a specific Key, and then compare the Value.\r\n\r\nHere&#39;s my unsafe query that is successful on the snippit on gist. It returns widget-xyz-widget-prod, which is the parameter I&#39;m looking to get.\r\n\r\n`jq --raw-output &#39;.TagDescriptions[] | select(.Tags[].Value==&quot;widget_xyz&quot;) | select(.Tags[].Value==&quot;widget&quot;) | select(.Tags[].Value==&quot;production&quot;) | .LoadBalancerName&#39;\r\n`\r\n\r\nIt should return if all three conditions are true:\r\n\r\n    Key == &quot;service&quot; &amp;&amp; Value == &quot;widget&quot;\r\n    Key == &quot;environment&quot; &amp;&amp; Value == &quot;production&quot;\r\n    Key == &quot;customer_prefix&quot; &amp;&amp; Value == &quot;widget_xyz&quot;\r\n\r\nAs you can see in my query above I am only comparing Value.\r\n\r\nUPDATE: I&#39;ve been able to construct a query that filters against matching both Key and Value from one object, but I&#39;m still trying to work on matching more than one object.\r\n\r\n`.TagDescriptions[] | select(.Tags[].Key==&quot;customer_prefix&quot; and .Tags[].Value == &quot;widget_xyz&quot;) | .LoadBalancerName` \r\n\r\nANOTHER UPDATE: Ok, so, I&#39;ve been able to hack a query together. I feel as if I&#39;m still missing a piece of the puzzle, and this query can be greatly simplified using some slick feature of jq that I have yet to understand.\r\n\r\n`.TagDescriptions[] | [select(.Tags[].Key == &quot;customer_prefix&quot; and .Tags[].Value == &quot;widget_xyz&quot;)][] | [select(.Tags[].Key == &quot;environment&quot; and .Tags[].Value == &quot;production&quot;)][] | [select(.Tags[].Key == &quot;service&quot; and .Tags[].Value == &quot;widget&quot;)][] | .LoadBalancerName`\r\n",
        "link": "https://stackoverflow.com/questions/33973816/filtering-json-object-list-with-jq-by-matching-multiple-objects",
        "title": "Filtering JSON object list with jq by matching multiple objects"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 34514,
                    "reputation": 29329,
                    "user_id": 97627,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/794c03b043debe3b5b64873b00a3b76f?s=256&d=identicon&r=PG",
                    "display_name": "Paul Wagland",
                    "link": "https://stackoverflow.com/users/97627/paul-wagland"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1448983255,
                "post_id": 33994887,
                "comment_id": 55802713,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2422321,
                    "reputation": 507,
                    "user_id": 2115020,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/daae04cbd9092e5bb630b9af576eb59a?s=256&d=identicon&r=PG",
                    "display_name": "Subhankar",
                    "link": "https://stackoverflow.com/users/2115020/subhankar"
                },
                "reply_to_user": {
                    "account_id": 34514,
                    "reputation": 29329,
                    "user_id": 97627,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/794c03b043debe3b5b64873b00a3b76f?s=256&d=identicon&r=PG",
                    "display_name": "Paul Wagland",
                    "link": "https://stackoverflow.com/users/97627/paul-wagland"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1449548839,
                "post_id": 33994887,
                "comment_id": 56043556,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1448890481,
                "creation_date": 1448890481,
                "answer_id": 33999886,
                "question_id": 33994887,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You want something like the following:\r\n\r\n    jq &#39;.servers[]|select(.addresses.services_z1[].addr==&quot;10.3.3.18&quot;)|.id&#39;\r\n\r\nThis says to look through all of the servers, match those that have .addresses.services_z1[].addr==&quot;10.3.3.18&quot;, and then print the id of those servers.",
                "title": "Jq parsing : Selecting an object from a list of objects based on criteria"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1448890481,
        "creation_date": 1448874529,
        "question_id": 33994887,
        "body_markdown": "I have a JSON like this.\r\n\r\n\r\n\r\n    {\r\n      &quot;servers&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;1&quot;,\r\n          &quot;addresses&quot;: {\r\n            &quot;services_z1&quot;: [\r\n              {\r\n                &quot;OS-EXT-IPS-MAC:mac_addr&quot;: &quot;fa:16:3e:bc:db:7d&quot;,\r\n                &quot;addr&quot;: &quot;10.3.3.18&quot;,\r\n                &quot;version&quot;: 4,\r\n                &quot;OS-EXT-IPS:type&quot;: &quot;fixed&quot;\r\n              }\r\n            ]\r\n          }\r\n          \r\n        },\r\n        \r\n        {\r\n          &quot;id&quot;: &quot;2&quot;,\r\n          &quot;addresses&quot;: {\r\n            &quot;services_z1&quot;: [\r\n              {\r\n                &quot;OS-EXT-IPS-MAC:mac_addr&quot;: &quot;fa:16:3e:bc:db:7d&quot;,\r\n                &quot;addr&quot;: &quot;10.3.3.19&quot;,\r\n                &quot;version&quot;: 4,\r\n                &quot;OS-EXT-IPS:type&quot;: &quot;fixed&quot;\r\n              }\r\n            ]\r\n          }\r\n          \r\n        },\r\n        \r\n        {\r\n          &quot;id&quot;: &quot;3&quot;,\r\n          &quot;addresses&quot;: {\r\n            &quot;services_z1&quot;: [\r\n              {\r\n                &quot;OS-EXT-IPS-MAC:mac_addr&quot;: &quot;fa:16:3e:bc:db:7d&quot;,\r\n                &quot;addr&quot;: &quot;10.3.3.20&quot;,\r\n                &quot;version&quot;: 4,\r\n                &quot;OS-EXT-IPS:type&quot;: &quot;fixed&quot;\r\n              }\r\n            ]\r\n          }\r\n          \r\n        },\r\n        \r\n        {\r\n          &quot;id&quot;: &quot;4&quot;,\r\n          &quot;addresses&quot;: {\r\n            &quot;services_z1&quot;: [\r\n              {\r\n                &quot;OS-EXT-IPS-MAC:mac_addr&quot;: &quot;fa:16:3e:bc:db:7d&quot;,\r\n                &quot;addr&quot;: &quot;10.3.3.21&quot;,\r\n                &quot;version&quot;: 4,\r\n                &quot;OS-EXT-IPS:type&quot;: &quot;fixed&quot;\r\n              }\r\n            ]\r\n          }\r\n          \r\n        }\r\n        \r\n        ]\r\n        \r\n    }\r\n\r\nI am trying to find the server id for which the addr value is 10.3.3.18. How can I achieve that? \r\n\r\nI know that it would be something like jq &#39;.servers[] | select(some criteria)&#39;\r\n\r\nBut I am not able ot form that criteria.\r\n\r\nAny pointer would be of huge help.    \r\n\r\n",
        "link": "https://stackoverflow.com/questions/33994887/jq-parsing-selecting-an-object-from-a-list-of-objects-based-on-criteria",
        "title": "Jq parsing : Selecting an object from a list of objects based on criteria"
    },
    {
        "tags": [
            "json",
            "jq",
            "amazon-route53"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1449186236,
                "creation_date": 1449186236,
                "answer_id": 34078429,
                "question_id": 34076779,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You&#39;re adding an object to that array, not a string. Create an object to be inserted.\r\n\r\n    .Changes[].ResourceRecordSet.ResourceRecords += [{Value:&quot;456.456.456.456&quot;}]",
                "title": "Adding Elements to AWS Route 53 JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1504654074,
        "creation_date": 1449179086,
        "last_edit_date": 1504654074,
        "question_id": 34076779,
        "body_markdown": "I&#39;ve been attempting to programmatically update the AWS Route 53 DNS records, so I&#39;ve been using jq to update the following JSON file;\r\n\r\n    {\r\n      &quot;Comment&quot;: &quot;Update &#39;A&#39; record for drivepoc.biz zone file&quot;,\r\n      &quot;Changes&quot;: [\r\n        {\r\n          &quot;Action&quot;: &quot;UPSERT&quot;,\r\n          &quot;ResourceRecordSet&quot;: {\r\n            &quot;Name&quot;: &quot;www.domain.biz.&quot;,\r\n            &quot;Type&quot;: &quot;A&quot;,\r\n            &quot;TTL&quot;: 60,\r\n            &quot;ResourceRecords&quot;: [\r\n              {\r\n                &quot;Value&quot;: &quot;123.123.123.123&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nSo, the existing entry `&quot;Value&quot;: &quot;123.123.123.123&quot;` needs to remain, but needs to have additional entry of `&quot;Value&quot;: &quot;456.456.456.456&quot;`.  The nearest I got to do this was:\r\n\r\n    cat a_record.json | jq &#39;.Changes[0].ResourceRecordSet.ResourceRecords |= .+ [&quot;Value: 456.456.456.456&quot;]&#39;\r\n\r\nbut this puts it outside the braces and the quotes are wrong;\r\n\r\n     &quot;ResourceRecords&quot;: [\r\n       {\r\n         &quot;Value&quot;: &quot;52.18.219.57&quot;\r\n       },\r\n       &quot;Value&quot;: &quot;456.456.456.456&quot;\r\n     ]\r\n\r\nInstead of what is required;\r\n\r\n     &quot;ResourceRecords&quot;: [\r\n       {\r\n         &quot;Value&quot;: &quot;52.18.219.57&quot;\r\n       },\r\n       {\r\n         &quot;Value&quot;: &quot;456.456.456.456&quot;\r\n       }\r\n     ]\r\n\r\nCan anyone give me any tips please?",
        "link": "https://stackoverflow.com/questions/34076779/adding-elements-to-aws-route-53-json",
        "title": "Adding Elements to AWS Route 53 JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 59908,
                    "reputation": 106517,
                    "user_id": 179125,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4d9968add4ad2af158fbdd7c24a87876?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordan Running",
                    "link": "https://stackoverflow.com/users/179125/jordan-running"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1449266746,
                "post_id": 34098002,
                "comment_id": 55948569,
                "content_license": "CC BY-SA 3.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": 1,
                "creation_date": 1449267707,
                "post_id": 34098002,
                "comment_id": 55949023,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 515705,
                    "reputation": 4093,
                    "user_id": 3160967,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/1d5285da7116b41a824dd9cf0e77e4ea?s=256&d=identicon&r=PG",
                    "display_name": "mwag",
                    "link": "https://stackoverflow.com/users/3160967/mwag"
                },
                "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": 1449268385,
                "post_id": 34098002,
                "comment_id": 55949299,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 515705,
                    "reputation": 4093,
                    "user_id": 3160967,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/1d5285da7116b41a824dd9cf0e77e4ea?s=256&d=identicon&r=PG",
                    "display_name": "mwag",
                    "link": "https://stackoverflow.com/users/3160967/mwag"
                },
                "reply_to_user": {
                    "account_id": 59908,
                    "reputation": 106517,
                    "user_id": 179125,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4d9968add4ad2af158fbdd7c24a87876?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordan Running",
                    "link": "https://stackoverflow.com/users/179125/jordan-running"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1449268424,
                "post_id": 34098002,
                "comment_id": 55949319,
                "content_license": "CC BY-SA 3.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": 1449269067,
                "post_id": 34098002,
                "comment_id": 55949560,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1449269913,
                "creation_date": 1449269913,
                "answer_id": 34098900,
                "question_id": 34098002,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;m not sure what exactly you&#39;re trying to accomplish in your question but I&#39;m assuming you want to recursively search through a json response and remove json objects that satisfy some condition.\r\n\r\nYou can do this rather easily with the help of the `walk` filter that will be coming up in a future version of jq, see the implementation in the [source](https://github.com/stedolan/jq/blob/master/src/builtin.jq).\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\nWith that, you can filter them out like so:\r\n\r\n    def filter_objects(predicate): # removes objects that satisfies some predicate\r\n        walk(\r\n            if (type == &quot;object&quot;) and (predicate) then\r\n                empty\r\n            else\r\n                .\r\n            end\r\n        )\r\n        ;\r\n    filter_objects(.delete_me) # remove objects that has a truthy property &quot;delete_me&quot;",
                "title": "jq: easiest way to recursively remove objects based on object value condition"
            },
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1449289713,
                "last_edit_date": 1449289713,
                "creation_date": 1449284941,
                "answer_id": 34100808,
                "question_id": 34098002,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Jeff&#39;s solution may zap too much.  For example, using:\r\n\r\n    def data: [1,2, {&quot;hello&quot;: {&quot;delete_me&quot;: true, &quot;a&quot;:3 }, &quot;there&quot;: 4} ]; ];\r\n\r\nJeff&#39;s solution yields empty (i.e. nothing).\r\n\r\nThe following may therefore be closer to what you&#39;re looking for:\r\n\r\n    walk(if (type == &quot;object&quot; and .delete_me) then del(.) else . end )\r\n\r\nFor `data`, this yields:\r\n\r\n    [1,2,{&quot;hello&quot;:null,&quot;there&quot;:4}]\r\n\r\n### Alternative Solution\r\nIf a solution that eliminates the `&quot;hello&quot;:null` in the above example is required, then a variant of jq&#39;s map_values/1 is needed. Here&#39;s one approach:\r\n\r\n    def mapper(f):\r\n      if type == &quot;array&quot; then map(f)\r\n      elif type == &quot;object&quot; then\r\n      . as $in\r\n      | reduce keys[] as $key\r\n          ({};\r\n           [$in[$key] | f ] as $value\r\n           | if $value | length == 0 then . \r\n             else . + {($key): $value[0]} end)\r\n      else .\r\n      end;\r\n\r\n    data | walk( mapper(select((type == &quot;object&quot; and .delete_me) | not)) )\r\n\r\n\r\nThe result is:\r\n\r\n    [1,2,{&quot;there&quot;:4}]\r\n    \r\n\r\n",
                "title": "jq: easiest way to recursively remove objects based on object value condition"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1503698607,
                "last_edit_date": 1503698607,
                "creation_date": 1503698295,
                "answer_id": 45889893,
                "question_id": 34098002,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses a recursive function:\r\n\r\n    def clean(condition):\r\n      if type == &quot;object&quot; then\r\n        if condition\r\n        then empty\r\n        else\r\n        with_entries(\r\n          if (.value|type) == &quot;object&quot; and (.value|condition)\r\n          then empty\r\n          else .value |= clean(condition)\r\n          end\r\n        )\r\n        end\r\n      elif type == &quot;array&quot; then\r\n        map(\r\n          if type == &quot;object&quot; and condition\r\n          then empty\r\n          else clean(condition)\r\n          end\r\n        )\r\n      else .\r\n      end\r\n    ;\r\n\r\n    clean(\r\n      has(&quot;delete_if_this_is_null&quot;) and (.delete_if_this_is_null == null)\r\n    )",
                "title": "jq: easiest way to recursively remove objects based on object value condition"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 7,
        "last_activity_date": 1726434823,
        "creation_date": 1449265546,
        "last_edit_date": 1726434823,
        "question_id": 34098002,
        "body_markdown": "I would like to use ```jq``` to remove all dictionaries within a JSON &quot;object&quot; (I used that term generally to refer to either an Array or a Dictionary) that \r\n\r\na) contain a key named &quot;delete_me&quot;, AND\r\nb) where the key &quot;delete_me&quot; meets some predetermined condition (null, non-zero, true, etc)\r\n\r\nBasically, the logic I want to implement is: walk the input, and at each node, if that node is not an Array or an Object, then keep it and move on, otherwise, keep it but remove from it any children that are dictionaries for which either condition a) or b) fail.\r\n\r\nAny suggestions?\r\n\r\nSample input:\r\n\r\n&lt;!-- language: json --&gt;\r\n    {\r\n      &quot;a&quot;: { &quot;foo&quot;: &quot;bar&quot; },\r\n      &quot;b&quot;: {\r\n        &quot;i&quot;: {\r\n          &quot;A&quot;: {\r\n            &quot;i&quot;: [\r\n              {\r\n                &quot;foo&quot;: {},\r\n                &quot;bar&quot;: {\r\n                  &quot;delete_if_this_is_null&quot;: false,\r\n                  &quot;an_array&quot;: [],\r\n                  &quot;another_array&quot;: [\r\n                    {\r\n                        &quot;delete_if_this_is_null&quot;: null,\r\n                        &quot;foo&quot;: &quot;bar&quot;\r\n                    }\r\n                  ],\r\n                  &quot;etc&quot;: &quot;&quot;\r\n                },\r\n                &quot;foo2&quot;: &quot;s&quot;\r\n              },\r\n              {\r\n                &quot;foo&quot;: {\r\n                  &quot;an_array&quot;: [\r\n                    {\r\n                      &quot;delete_if_this_is_null&quot;: &quot;ok&quot;,\r\n                      &quot;foo&quot;:&quot;bar&quot;,\r\n                      &quot;another_object&quot;: { &quot;a&quot;:1 }\r\n                    },\r\n                    {\r\n                      &quot;delete_if_this_is_null&quot;: null,\r\n                      &quot;foo2&quot;:&quot;bar2&quot;,\r\n                      &quot;another_object&quot;: { &quot;a&quot;:1 },\r\n                      &quot;name&quot;: null\r\n                    }\r\n                  ],\r\n                  &quot;an_object&quot;: {\r\n                    &quot;delete_if_this_is_null&quot;:null,\r\n                    &quot;foo3&quot;:&quot;bar3&quot;\r\n                  }\r\n                },\r\n                &quot;zero&quot;: 0,\r\n                &quot;b&quot;: &quot;b&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nshould yield, if the &quot;delete_me&quot; key is ```delete_if_this_is_null``` and the predetermined condition is ```delete_if_this_is_null == null```:\r\n\r\n&lt;!-- language: json --&gt;\r\n    {\r\n      &quot;a&quot;: { &quot;foo&quot;: &quot;bar&quot; },\r\n      &quot;b&quot;: {\r\n        &quot;i&quot;: {\r\n          &quot;A&quot;: {\r\n            &quot;i&quot;: [\r\n              {\r\n                &quot;foo&quot;: {},\r\n                &quot;bar&quot;: {\r\n                  &quot;delete_if_this_is_null&quot;: false,\r\n                  &quot;an_array&quot;: [],\r\n                  &quot;another_array&quot;: [],\r\n                  &quot;etc&quot;: &quot;&quot;\r\n                },\r\n                &quot;foo2&quot;: &quot;s&quot;\r\n              },\r\n              {\r\n                &quot;foo&quot;: {\r\n                  &quot;an_array&quot;: [\r\n                    {\r\n                      &quot;delete_if_this_is_null&quot;: &quot;ok&quot;,\r\n                      &quot;foo&quot;:&quot;bar&quot;,\r\n                      &quot;another_object&quot;: { &quot;a&quot;:1 }\r\n                    }\r\n                  ]\r\n                },\r\n                &quot;zero&quot;: 0,\r\n                &quot;b&quot;: &quot;b&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n\r\n&lt;hr&gt;\r\nUPDATE: Here&#39;s the solution: Assume the input is in a file &#39;input.json&#39;:\r\n\r\n&lt;!-- language: shell --&gt;\r\n    jq &#39;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    def mapper(f):\r\n      if type == &quot;array&quot; then map(f)\r\n      elif type == &quot;object&quot; then\r\n      . as $in\r\n      | reduce keys[] as $key\r\n          ({};\r\n           [$in[$key] | f ] as $value\r\n           | if $value | length == 0 then .\r\n             else . + {($key): $value[0]} end)\r\n      else .\r\n      end;\r\n    \r\n    walk( mapper(select((type == &quot;object&quot; and .delete_if_this_is_null == null) | not)) )&#39; &lt; input.json",
        "link": "https://stackoverflow.com/questions/34098002/jq-easiest-way-to-recursively-remove-objects-based-on-object-value-condition",
        "title": "jq: easiest way to recursively remove objects based on object value condition"
    },
    {
        "tags": [
            "json",
            "aws-cloudformation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1449324847,
                "creation_date": 1449324847,
                "answer_id": 34106475,
                "question_id": 34105038,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use the `select()` function:\r\n\r\n    jq &#39;.Resources[]|select(.Type==&quot;AWS::EC2::VPC&quot;)&#39; aws.json\r\n\r\nYou can use `or` if you want to filter by multiple conditions, like this:\r\n\r\n    jq &#39;.Resources[]|select(.Type==&quot;AWS::EC2::VPC&quot; or .Type==&quot;foo&quot;)&#39; aws.json\r\n\r\n\r\n\r\n",
                "title": "Filtering cloudformation stack resources using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1449326863,
                "creation_date": 1449326863,
                "answer_id": 34106807,
                "question_id": 34105038,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "@hek2mgl&#39;s suggestion may be sufficient for your purposes, but it doesn&#39;t quite produce the answer you requested.  Here&#39;s one very similar solution that does.  It uses a generalization of jq&#39;s map() and map_values() filters that is often useful anyway:\r\n\r\n    def mapper(f):\r\n      if type == &quot;array&quot; then map(f)\r\n      elif type == &quot;object&quot; then\r\n      . as $in\r\n      | reduce keys[] as $key\r\n          ({};\r\n           [$in[$key] | f ] as $value\r\n           | if $value | length == 0 then . else . + {($key): $value[0]}\r\n             end)\r\n      else .\r\n      end;\r\n\r\n    .Resources |= mapper(select(.Type==&quot;AWS::EC2::VPC&quot;))\r\n\r\nUsing your example input:\r\n\r\n    $ jq -f resources.jq resources.json\r\n    {\r\n      &quot;Resources&quot;: {\r\n        &quot;vpc001&quot;: {\r\n          &quot;Type&quot;: &quot;AWS::EC2::VPC&quot;,\r\n          &quot;Properties&quot;: {\r\n            &quot;CidrBlock&quot;: &quot;10.1.0.0/16&quot;,\r\n            &quot;InstanceTenancy&quot;: &quot;default&quot;,\r\n            &quot;EnableDnsSupport&quot;: &quot;true&quot;,\r\n            &quot;EnableDnsHostnames&quot;: &quot;true&quot;\r\n          }\r\n        }\r\n      }\r\n\r\nAs @hek2mgl pointed out, it&#39;s now trivial to specify a more complex selection criterion.\r\n    }\r\n",
                "title": "Filtering cloudformation stack resources using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1475102029,
                "creation_date": 1475102029,
                "answer_id": 39758680,
                "question_id": 34105038,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use aws cli&#39;s --query parameter.\r\nCompletely eliminates the need for jq.\r\nhttp://docs.aws.amazon.com/cli/latest/userguide/controlling-output.html#controlling-output-filter",
                "title": "Filtering cloudformation stack resources using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1503902401,
                "creation_date": 1503902401,
                "answer_id": 45913035,
                "question_id": 34105038,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses a separate function to select all resources matching a specified condition which is passed a {key,value} pair for each resource.  \r\n\r\n    def condition:\r\n      .value.Type == &quot;AWS::EC2::VPC&quot;\r\n    ;\r\n\r\n    {\r\n      Resources: .Resources | with_entries(select(condition))\r\n    }\r\n\r\nOutput from sample data:\r\n\r\n    {\r\n      &quot;Resources&quot;: {\r\n        &quot;vpc001&quot;: {\r\n          &quot;Type&quot;: &quot;AWS::EC2::VPC&quot;,\r\n          &quot;Properties&quot;: {\r\n            &quot;CidrBlock&quot;: &quot;10.1.0.0/16&quot;,\r\n            &quot;InstanceTenancy&quot;: &quot;default&quot;,\r\n            &quot;EnableDnsSupport&quot;: &quot;true&quot;,\r\n            &quot;EnableDnsHostnames&quot;: &quot;true&quot;\r\n          }\r\n        }\r\n      }\r\n    }",
                "title": "Filtering cloudformation stack resources using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1674668994,
                "creation_date": 1674668994,
                "answer_id": 75237893,
                "question_id": 34105038,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I found one way to do this without defining a function:\r\n```\r\njq &#39;.Resources | to_entries[] | select(.value.Type == &quot;AWS::EC2::InternetGateway&quot;)|[{key: .key, value: .value}]|from_entries&#39; example.json\r\n\r\n{\r\n  &quot;ig001&quot;: {\r\n    &quot;Type&quot;: &quot;AWS::EC2::InternetGateway&quot;,\r\n    &quot;Properties&quot;: {\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;ig001&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```",
                "title": "Filtering cloudformation stack resources using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 1,
        "last_activity_date": 1674668994,
        "creation_date": 1449319432,
        "question_id": 34105038,
        "body_markdown": "I&#39;m trying to write a JQ-filter for filtering specific resources from an AWS cloudformation template based on resource properties.\r\n\r\nFor example, when starting from the following (shortened) cloudformation template:\r\n\r\n    {\r\n    &quot;Resources&quot;: {\r\n    &quot;vpc001&quot;: {\r\n      &quot;Type&quot;: &quot;AWS::EC2::VPC&quot;,\r\n      &quot;Properties&quot;: {\r\n        &quot;CidrBlock&quot;: &quot;10.1.0.0/16&quot;,\r\n        &quot;InstanceTenancy&quot;: &quot;default&quot;,\r\n        &quot;EnableDnsSupport&quot;: &quot;true&quot;,\r\n        &quot;EnableDnsHostnames&quot;: &quot;true&quot;\r\n      }\r\n    },\r\n    &quot;ig001&quot;: {\r\n      &quot;Type&quot;: &quot;AWS::EC2::InternetGateway&quot;,\r\n      &quot;Properties&quot;: {\r\n        &quot;Tags&quot;: [\r\n          {\r\n            &quot;Key&quot;: &quot;Name&quot;,\r\n            &quot;Value&quot;: &quot;ig001&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n    }\r\n    }\r\n\r\n\r\nI would like to construct a jq-filter enabling me to filter out specific resources based on (one or multiple) of their property fields.\r\n\r\nFor example:\r\n\r\nwhen filtering for Type=&quot;AWS::EC2::InternetGateway&quot; the result should be\r\n\r\n    {\r\n     &quot;Resources&quot;: {\r\n    &quot;ig001&quot;: {\r\n      &quot;Type&quot;: &quot;AWS::EC2::InternetGateway&quot;,\r\n      &quot;Properties&quot;: {\r\n        &quot;Tags&quot;: [\r\n          {\r\n            &quot;Key&quot;: &quot;Name&quot;,\r\n            &quot;Value&quot;: &quot;ig001&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n    }\r\n    }\r\n\r\nAn added bonus would be to be able to filter on a &#39;OR&#39;-ed combination of values.\r\nAs such a filter for &quot;AWS::EC2::InternetGateway&quot; OR &quot;AWS::EC2::VPC&quot; should yield the original document.\r\n\r\nAny suggestion or insight would be greatly appreciated.\r\n\r\nTx!\r\n\r\n  ",
        "link": "https://stackoverflow.com/questions/34105038/filtering-cloudformation-stack-resources-using-jq",
        "title": "Filtering cloudformation stack resources using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "ubuntu",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1449456903,
                "last_edit_date": 1449456903,
                "creation_date": 1449415944,
                "answer_id": 34119160,
                "question_id": 34118786,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    $ jq &#39;map(  (.ip[] | { &quot;ip&quot;: .}) + del(.ip) )&#39; input.json\r\n    [\r\n      {\r\n        &quot;ip&quot;: &quot;8.8.4.4/32&quot;,\r\n        &quot;port&quot;: 25,\r\n        &quot;proto&quot;: &quot;tcp&quot;\r\n      },\r\n      {\r\n        &quot;ip&quot;: &quot;212.40.11.20/32&quot;,\r\n        &quot;port&quot;: 25,\r\n        &quot;proto&quot;: &quot;tcp&quot;\r\n      },\r\n      {\r\n        &quot;ip&quot;: &quot;212.40.11.30/32&quot;,\r\n        &quot;port&quot;: 3389,\r\n        &quot;proto&quot;: &quot;tcp&quot;\r\n      }\r\n    ]\r\n    \r\n\r\nEquivalently, one can write `map( . + {ip:.ip[]} )`.  \r\n\r\nThat is (and this is one of those things that make jq so powerful), if STREAMn is a stream of length n, then `value + STREAMn` yields a stream of length n, assuming (value + x) is valid for each item in the stream.\r\n\r\nIndeed, `STREAMn + STREAMm` yields the &quot;Cartesian product stream&quot; of length m * n, assuming the items can be added pairwise.",
                "title": "json remapping with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1449416625,
                "last_edit_date": 1495542193,
                "creation_date": 1449416222,
                "answer_id": 34119191,
                "question_id": 34118786,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Alternatively to [Peak&#39;s nice solution][1], you can use the following expression:\r\n\r\n    jq &#39;[.[]|{ip:.ip[],port,proto}]&#39; aws.json\r\n\r\nIt shows nicely how `jq` &quot;flattens&quot; the *ip* array.\r\n\r\nOutput:\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;ip&quot;: &quot;8.8.4.4/32&quot;,\r\n        &quot;port&quot;: 25,\r\n        &quot;proto&quot;: &quot;tcp&quot;\r\n      },\r\n      {\r\n        &quot;ip&quot;: &quot;212.40.11.20/32&quot;,\r\n        &quot;port&quot;: 25,\r\n        &quot;proto&quot;: &quot;tcp&quot;\r\n      },\r\n      {\r\n        &quot;ip&quot;: &quot;212.40.11.30/32&quot;,\r\n        &quot;port&quot;: 3389,\r\n        &quot;proto&quot;: &quot;tcp&quot;\r\n      }\r\n    ]\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/34119160/171318",
                "title": "json remapping with jq"
            },
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1449438573,
                "creation_date": 1449438573,
                "answer_id": 34123219,
                "question_id": 34118786,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A shorter and simpler alternative than both @peak&#39;s and @hek2mgl&#39;s, but still fundamentally operating on the same concept:\r\n\r\n    jq &#39;map(.ip = .ip[])&#39;",
                "title": "json remapping with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1449456903,
        "creation_date": 1449413910,
        "last_edit_date": 1449415257,
        "question_id": 34118786,
        "body_markdown": "I have the following json:\r\n\r\n    [\r\n      {\r\n        &quot;ip&quot;: [\r\n          &quot;8.8.4.4/32&quot;,\r\n          &quot;212.40.11.20/32&quot;\r\n        ],\r\n        &quot;port&quot;: 25,\r\n        &quot;proto&quot;: &quot;tcp&quot;\r\n      },\r\n      {\r\n        &quot;ip&quot;: [\r\n          &quot;212.40.11.30/32&quot;\r\n        ],\r\n        &quot;port&quot;: 3389,\r\n        &quot;proto&quot;: &quot;tcp&quot;\r\n      }\r\n    ]\r\n\r\nUsing `jq` I want to separate the ip addresses in the `ip` array, like this:\r\n\r\n    [\r\n      {\r\n        &quot;ip&quot;: &quot;8.8.4.4/32&quot;,\r\n        &quot;port&quot;: 25,\r\n        &quot;proto&quot;: &quot;tcp&quot;\r\n      },\r\n      {\r\n        &quot;ip&quot;: &quot;212.40.11.20/32&quot;,\r\n        &quot;port&quot;: 25,\r\n        &quot;proto&quot;: &quot;tcp&quot;\r\n      },\r\n      {\r\n        &quot;ip&quot;: &quot;212.40.11.30/32&quot;,\r\n        &quot;port&quot;: 3389,\r\n        &quot;proto&quot;: &quot;tcp&quot;\r\n      }\r\n    ]\r\n\r\nI&#39;m using `jq 1.5` on `Ubuntu 15.04` with `bash 4.3.42(1)`.\r\n\r\nEDIT:  \r\nThis is how I generated this list from AWS:  \r\n`aws ec2 describe-security-groups --group-id sg-2cf5e31 --query &#39;SecurityGroups[].IpPermissions[].{port:ToPort,proto:IpProtocol,ip:IpRanges[].CidrIp[]}&#39; | jq &#39;.[]&#39;`\r\n\r\nNext step would be adding a custom field.\r\n\r\nThanks for your assistance.",
        "link": "https://stackoverflow.com/questions/34118786/json-remapping-with-jq",
        "title": "json remapping with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1449522270,
                "creation_date": 1449522270,
                "answer_id": 34143187,
                "question_id": 34142687,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Pretty simple.  Find the objects that you want to update, then update them.\r\n\r\nLook through the values of your root object, filtering them based on your condition, the update the `Properties` property deleting the property you want.\r\n\r\n    (.[] | select(.Type == &quot;Type2&quot;)).Properties |= del(.Property2)\r\n\r\nUsing `.[]` on an object yields all property values of an object.  Also worth mentioning, when you update a value using assignments, the result of the expression just returns the input (in other words, it doesn&#39;t change the context).",
                "title": "JQ delete property based other property value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1449522857,
                "creation_date": 1449522857,
                "answer_id": 34143346,
                "question_id": 34142687,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A direct approach:\r\n\r\n    .[] |= (if .Type == &quot;Type2&quot; then delpaths([[&quot;Properties&quot;, &quot;Property2&quot;]]) else . end)",
                "title": "JQ delete property based other property value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1711938168,
                "creation_date": 1711938168,
                "answer_id": 78253399,
                "question_id": 34142687,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another approach:\r\n\r\n    del(.[] | select(.Type == &quot;Type2&quot;).Properties.Property2)",
                "title": "JQ delete property based other property value"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1711938168,
        "creation_date": 1449520461,
        "question_id": 34142687,
        "body_markdown": "I&#39;m trying to write a JQ filter allowing me to selectively filter object properties based on other of it&#39;s values.\r\n\r\nFor example, given following input\r\n\r\n    {\r\n    &quot;object1&quot;: {\r\n    &quot;Type&quot;: &quot;Type1&quot;,\r\n    &quot;Properties&quot;: {\r\n      &quot;Property1&quot;: &quot;blablabla&quot;,\r\n      &quot;Property2&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;xxx&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;Surname&quot;,\r\n          &quot;Value&quot;: &quot;yyy&quot;\r\n        }\r\n      ],\r\n      &quot;Property3&quot;: &quot;xxx&quot;\r\n     }\r\n    },\r\n    &quot;object2&quot;: {\r\n    &quot;Type&quot;: &quot;Type2&quot;,\r\n    &quot;Properties&quot;: {\r\n      &quot;Property1&quot;: &quot;blablabla&quot;,\r\n      &quot;Property2&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;xxx&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;Surname&quot;,\r\n          &quot;Value&quot;: &quot;yyy&quot;\r\n        }\r\n      ],\r\n      &quot;Property3&quot;: &quot;xxx&quot;\r\n      }\r\n     }\r\n    }\r\n\r\nI would like to construct a filter, that based upon the object type, say &quot;Type2&quot;, deletes or clears a property of that object, say Property2.\r\nThe resulting output would then be:\r\n\r\n    {\r\n    &quot;object1&quot;: {\r\n    &quot;Type&quot;: &quot;Type1&quot;,\r\n    &quot;Properties&quot;: {\r\n      &quot;Property1&quot;: &quot;blablabla&quot;,\r\n      &quot;Property2&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;Name&quot;,\r\n          &quot;Value&quot;: &quot;xxx&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;Surname&quot;,\r\n          &quot;Value&quot;: &quot;yyy&quot;\r\n        }\r\n      ],\r\n      &quot;Property3&quot;: &quot;xxx&quot;\r\n     }\r\n    },\r\n    &quot;object2&quot;: {\r\n    &quot;Type&quot;: &quot;Type2&quot;,\r\n    &quot;Properties&quot;: {\r\n      &quot;Property1&quot;: &quot;blablabla&quot;,\r\n      &quot;Property3&quot;: &quot;xxx&quot;\r\n      }\r\n     }\r\n    }\r\n\r\nAny help greatly appreciated. Thanks in advance.\r\n",
        "link": "https://stackoverflow.com/questions/34142687/jq-delete-property-based-other-property-value",
        "title": "JQ delete property based other property value"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 17,
                "is_accepted": true,
                "score": 17,
                "last_activity_date": 1449609616,
                "creation_date": 1449609616,
                "answer_id": 34166237,
                "question_id": 34165201,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First of all, I&#39;m not sure what is the purpose of obtaining an array of `jq` programs. While means of doing this exist, they are seldom necessary; jq does not provide any sort of `eval` command.\r\n\r\njq has the concept of a path, which is an array of strings and numbers representing the position of an element in a JSON; this is equivalent to the strings on your expected output. As an example, `&quot;.json[1][2][1]&quot;` would be represented as `[&quot;json&quot;, 1, 2, 1]`. The standard library contains several functions that operate with this concept, such as `getpath`, `setpath`, `paths` and `leaf_paths`.\r\n\r\nWe can thus obtain all leaf paths in the given JSON and iterate through them, select those for which their value in the input JSON is &quot;foo&quot;, and generate an array out of them:\r\n\r\n    jq &#39;[paths as $path | select(getpath($path) == &quot;foo&quot;) | $path]&#39;\r\n\r\nThis will return, for your given input, the following output:\r\n\r\n    [\r\n      [&quot;json&quot;, 1, 2, 1],\r\n      [&quot;json&quot;, 1, 3, 0, 1]\r\n    ]\r\n\r\nNow, although it should not be necessary, and it is most likely a sign that you&#39;re approaching whatever problem you are facing in the wrong way, it is possible to convert these arrays to the jq path strings you seek by transforming each path through the following script:\r\n\r\n    &quot;.\\(map(&quot;[\\(tojson)]&quot;) | join(&quot;&quot;))&quot;\r\n\r\nThe full script would therefore be:\r\n\r\n    jq &#39;[paths as $path | select(getpath($path) == &quot;foo&quot;) | $path | &quot;.\\(map(&quot;[\\(tojson)]&quot;) | join(&quot;&quot;))&quot;]&#39;\r\n\r\nAnd its output would be:\r\n\r\n    [\r\n      &quot;.[\\&quot;json\\&quot;][1][2][1]&quot;,\r\n      &quot;.[\\&quot;json\\&quot;][1][3][0][1]&quot;\r\n    ]",
                "title": "How to get the index path of found values using jq?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1449678700,
                "last_edit_date": 1449678700,
                "creation_date": 1449615784,
                "answer_id": 34167773,
                "question_id": 34165201,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Santiago&#39;s excellent program can be further tweaked to produce output in the requested format:\r\n\r\n    def jqpath:\r\n      def t: test(&quot;^[A-Za-z_][A-Za-z0-9_]*$&quot;);\r\n      reduce .[] as $x\r\n        (&quot;&quot;;\r\n         if ($x|type) == &quot;string&quot;\r\n         then . + ($x | if t then &quot;.\\(.)&quot; else  &quot;.[&quot; + tojson + &quot;]&quot; end)\r\n         else . + &quot;[\\($x)]&quot;\r\n         end);\r\n\r\n    [paths as $path | select( getpath($path) == &quot;foo&quot; ) | $path | jqpath]\r\n\r\n\r\n    jq -f wrangle.jq input.json\r\n\r\n    [\r\n      &quot;.json[1][2][1]&quot;,\r\n      &quot;.json[1][3][0][1]&quot;\r\n    ]\r\n",
                "title": "How to get the index path of found values using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 10,
        "last_activity_date": 1683142331,
        "creation_date": 1449605767,
        "last_edit_date": 1683142331,
        "question_id": 34165201,
        "body_markdown": "Say I have a JSON like this:\r\n\r\n&lt;!-- language: json --&gt;\r\n\t{\r\n\t  &quot;json&quot;: [\r\n\t\t&quot;a&quot;, \r\n\t\t[\r\n\t\t  &quot;b&quot;, \r\n\t\t  &quot;c&quot;, \r\n\t\t  [\r\n\t\t\t&quot;d&quot;, \r\n\t\t\t&quot;foo&quot;, \r\n\t\t\t1\r\n\t\t  ], \r\n\t\t  [\r\n\t\t\t[\r\n\t\t\t  42, \r\n\t\t\t  &quot;foo&quot;\r\n\t\t\t]\r\n\t\t  ]\r\n\t\t]\r\n\t  ]\r\n\t}\r\n\r\nAnd I want an array of `jq` index paths that contain `foo`:\r\n\r\n    [\r\n        &quot;.json[1][2][1]&quot;,\r\n        &quot;.json[1][3][0][1]&quot;\r\n    ]\r\n\r\nCan I achieve this using `jq` and how?\r\nI tried `recurse | .foo` to get the matches first but I receive an error: `Cannot index array with string &quot;foo&quot;`.",
        "link": "https://stackoverflow.com/questions/34165201/how-to-get-the-index-path-of-found-values-using-jq",
        "title": "How to get the index path of found values using jq?"
    },
    {
        "tags": [
            "json",
            "regex",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1449620519,
                "creation_date": 1449620519,
                "answer_id": 34168652,
                "question_id": 34168623,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "OMG I just figured it out... I need to double-escape the `\\`. I&#39;m a moron &gt;.&lt;\r\n\r\n    $ echo &#39;&quot;f1&quot;&#39; | jq &#39;test(&quot;\\\\d&quot;)&#39;\r\n    true\r\n",
                "title": "How to use jq&#39;s match and test with character classes?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1449620519,
        "creation_date": 1449620407,
        "question_id": 34168623,
        "body_markdown": "I think this should be pretty simple but for the life of me I can&#39;t figure it out. I can test for the containment of a literal:\r\n\r\n    $ echo &#39;&quot;f1&quot;&#39; | jq &#39;test(&quot;1&quot;)&#39;\r\n    true\r\n\r\n\r\nBut I can&#39;t test for the containment of a character class (in this example, a digit):\r\n\r\n    $ echo &#39;&quot;f1&quot;&#39; | jq &#39;test(&quot;\\d&quot;)&#39;\r\n    jq: error: Invalid escape at line 1, column 4 (while parsing &#39;&quot;\\d&quot;&#39;) at &lt;top-    level&gt;, line 1:\r\n    test(&quot;\\d&quot;)      \r\n    jq: 1 compile error\r\n\r\nI&#39;m using the release version jq-1.5.\r\n\r\nI&#39;ve tried absolutely everything I can think of. Please help.",
        "link": "https://stackoverflow.com/questions/34168623/how-to-use-jqs-match-and-test-with-character-classes",
        "title": "How to use jq&#39;s match and test with character classes?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1449745425,
                "post_id": 34197900,
                "comment_id": 56145261,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1449780857,
                "last_edit_date": 1449780857,
                "creation_date": 1449769124,
                "answer_id": 34208338,
                "question_id": 34197900,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    #!/bin/bash\r\n    \r\n    # For simplicity, assume each file in FILELIST contains a single JSON entity.\r\n    # Then instead of using cat FILELIST, use mycat FILELIST, e.g. mycat *.json\r\n    \r\n    function mycat {\r\n      for file\r\n      do\r\n        jq --arg file &quot;$file&quot; &#39;{&quot;file&quot;: $file, &quot;contents&quot;: .}&#39; &quot;$file&quot;\r\n      done\r\n    }\r\n\r\nIf you have a sufficiently recent version of jq (e.g. jq 1.5) then one alternative would be: \r\n   \r\n    jq &#39;{file: input_filename, contents: .}&#39; FILELIST",
                "title": "json jq add same element to each object/array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1449780857,
        "creation_date": 1449739292,
        "last_edit_date": 1449742519,
        "question_id": 34197900,
        "body_markdown": "I have files with json structure like this:\r\n\r\n    [\r\n      {\r\n        &quot;uid&quot;: 11111,\r\n        &quot;something&quot;: {\r\n    \t\t(...)\r\n        }\r\n      },\r\n      {\r\n        &quot;uid&quot;: 22222,\r\n        &quot;something&quot;: {\r\n    \t\t(...)\r\n        }\r\n      }\r\n    ]\r\n\r\nI&#39;ll read all files at one time (cat *) and i&#39;d like to know which part is from which file, so i need to group it in some way.\r\n\r\nSo, my idea is to move content of each file to higher (parent) object with own members.\r\n\r\n    [\r\n      {\r\n      &quot;var1&quot;: &quot;val1&quot;\r\n      &quot;var2&quot;: &quot;val2&quot;\r\n        {\r\n          &quot;uid&quot;: 11111,\r\n          &quot;something&quot;: {\r\n    \t\t\t(...)\r\n          }\r\n        },\r\n        {\r\n          &quot;uid&quot;: 22222,\r\n          &quot;something&quot;: {\r\n    \t\t\t(...)\r\n          }\r\n        }\r\n      }\r\n\r\n\r\nHow to do that with jq?\r\n",
        "link": "https://stackoverflow.com/questions/34197900/json-jq-add-same-element-to-each-object-array",
        "title": "json jq add same element to each object/array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "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": 0,
                "creation_date": 1449785001,
                "post_id": 34212371,
                "comment_id": 56169607,
                "content_license": "CC BY-SA 3.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": 1449785045,
                "post_id": 34212371,
                "comment_id": 56169627,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1449789381,
                "creation_date": 1449789381,
                "answer_id": 34213524,
                "question_id": 34212371,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The script you provide is already pretty good! This variation of your script saves the index into the variable instead of the input object, which feels more natural to read for me. It then creates an array of one key objects and adds them together.\r\n\r\n    jq &#39;[range(.key | length) as $i | {(.key[$i]): .string[$i]}] | add&#39;\r\n\r\nWhen I first looked at this issue, I though that a `zip` builtin would improve the situation. Then I remembered: there is already a `zip` builtin! It&#39;s just called `transpose`. Using it, you can create a script such as this:\r\n\r\n    jq &#39;[.key, .string] | transpose | map({key: .[0], value: .[1]}) | from_entries&#39;\r\n\r\nIt seems easier to follow to me as well, although it is quite long too; I assume, however, that the focus is readability and not character count. Of course, you can also mix up both solutions:\r\n\r\n    jq &#39;[.key, .string] | transpose | map({(.[0]): .[1]}) | add&#39;",
                "title": "Turn array of keys and array of values into object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501806373,
                "creation_date": 1501806373,
                "answer_id": 45496491,
                "question_id": 34212371,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **reduce** with a state object holding an iteration index and a result object.  It iterates over `.key` setting corresponding values in the result from `.string`\r\n\r\n      .string as $v\r\n    | reduce .key[] as $k (\r\n       {idx:0, result:{}}; .result[$k] = $v[.idx] | .idx += 1\r\n      )\r\n    | .result\r\n",
                "title": "Turn array of keys and array of values into object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1501806373,
        "creation_date": 1449784073,
        "last_edit_date": 1495541206,
        "question_id": 34212371,
        "body_markdown": "I have, for complicated reasons involving a trip from an Apple plist through `xml2json`, a number of JSON files with data in this form:\r\n\r\n    { \r\n      &quot;key&quot;: [ &quot;key1&quot;, &quot;key2&quot;, &quot;key3&quot; ],\r\n      &quot;string&quot;: [ &quot;value1&quot;, &quot;value2&quot;, &quot;value3&quot; ]\r\n    }\r\n\r\nAnd I would like to convert that to a normal JSON object:\r\n\r\n    { \r\n      &quot;key1&quot;: &quot;value1&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;,\r\n      &quot;key3&quot;: &quot;value3&quot;     \r\n    }\r\n\r\nAfter some head-banging, I came up with this `jq` program to do the trick:\r\n\r\n    jq &#39;. as $d|[range(.key|length)|{&quot;key&quot;:$d.key[.],&quot;value&quot;:$d.string[.]}]|from_entries&#39;\r\n\r\nThat works, but it seems a little convoluted. I was wondering if there were a cleaner solution?\r\n\r\nThis is indeed similar to [this question](https://stackoverflow.com/questions/28103489), but the difference is that this is an object with named key and value elements instead just an array containing the two arrays directly.",
        "link": "https://stackoverflow.com/questions/34212371/turn-array-of-keys-and-array-of-values-into-object",
        "title": "Turn array of keys and array of values into object"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 39,
                "is_accepted": false,
                "score": 38,
                "last_activity_date": 1449791600,
                "creation_date": 1449791600,
                "answer_id": 34213910,
                "question_id": 34212688,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you mean by trimming long strings, sure.  Figure out which strings to trim then trim them.\r\n\r\ne.g., trimming a string to the first 10 characters\r\n\r\n    $ echo &#39;&quot;12345678901234567890&quot;&#39; | jq &#39;.[0:10]&#39;\r\n\r\nRead, take the first 0-10 characters of the string.",
                "title": "Is there a way to truncate field data"
            },
            {
                "up_vote_count": 11,
                "is_accepted": false,
                "score": 11,
                "last_activity_date": 1449792628,
                "creation_date": 1449792628,
                "answer_id": 34214073,
                "question_id": 34212688,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you want to recursively trim all strings:\r\n\r\n\r\n    .. |= (if type == &quot;string&quot; then .[0:2] else . end)\r\n\r\nFor example, if the input is:\r\n\r\n    {&quot;a&quot;: &quot;aaaaaaaaaaaaaaaaaaaaaaaaaaaa&quot;, \r\n     &quot;b&quot;: &quot;bbbbbbbbbbbbbbbbbbbbbbbbbb&quot;,\r\n     &quot;c&quot;: [&quot;ddddddddddddddd&quot;]\r\n    }\r\n\r\nthe output (compacted) would be:\r\n\r\n    {&quot;a&quot;:&quot;aa&quot;,&quot;b&quot;:&quot;bb&quot;,&quot;c&quot;:[&quot;dd&quot;]}",
                "title": "Is there a way to truncate field data"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 21,
        "last_activity_date": 1449792628,
        "creation_date": 1449785528,
        "question_id": 34212688,
        "body_markdown": "I have some fields that are really long, but I just want to see the beginning of them. Is there a way to truncate a field to only the first X characters?",
        "link": "https://stackoverflow.com/questions/34212688/is-there-a-way-to-truncate-field-data",
        "title": "Is there a way to truncate field data"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 272,
                "is_accepted": true,
                "score": 272,
                "last_activity_date": 1710181244,
                "last_edit_date": 1710181244,
                "creation_date": 1449849532,
                "answer_id": 34227629,
                "question_id": 34226370,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get the top-level keys as a stream, you can use the [built-in function][1] `keys[]`.  So one solution to your particular problem would be:\r\n\r\n&lt;!-- language: shell --&gt;\r\n    jq -r &#39;keys[] as $k | &quot;\\($k), \\(.[$k] | .ip)&quot;&#39; \r\n\r\n`keys` produces the key names in sorted order; if you want them in the original order, use `keys_unsorted`.\r\n\r\nAnother alternative, which produces keys in the original order, is: \r\n\r\n&lt;!-- language: shell --&gt;\r\n    jq -r &#39;to_entries[] | &quot;\\(.key), \\(.value | .ip)&quot;&#39;\r\n\r\n### CSV and TSV output\r\n\r\nThe @csv and @tsv filters might also be worth considering here, e.g.\r\n\r\n    jq -r &#39;to_entries[] | [.key, .value.ip] | @tsv&#39;\r\n\r\nproduces:\r\n\r\n    host1\t10.1.2.3\r\n    host2\t10.1.2.2\r\n    host3\t10.1.18.1\r\n\r\n### Embedded objects\r\nIf the keys of interest are embedded as in the following example, the jq filter would have to be modified along the lines shown.\r\n\r\nInput:\r\n\r\n```json\r\n{\r\n  &quot;myhosts&quot;: {\r\n    &quot;host1&quot;: { &quot;ip&quot;: &quot;10.1.2.3&quot; },\r\n    &quot;host2&quot;: { &quot;ip&quot;: &quot;10.1.2.2&quot; },\r\n    &quot;host3&quot;: { &quot;ip&quot;: &quot;10.1.18.1&quot; }\r\n  }\r\n}\r\n```\r\n\r\nModification:\r\n\r\n```shell\r\njq -r &#39;.myhosts | keys[] as $k | &quot;\\($k), \\(.[$k] | .ip)&quot;&#39;\r\n```\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions",
                "title": "jq: print key and value for each entry in an object"
            },
            {
                "up_vote_count": 112,
                "is_accepted": false,
                "score": 112,
                "last_activity_date": 1521975804,
                "last_edit_date": 1521975804,
                "creation_date": 1521104347,
                "answer_id": 49295083,
                "question_id": 34226370,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Came across very elegant solution\r\n    \r\n    jq &#39;with_entries(.value |= .ip)&#39;\r\n\r\nWhich ouputs\r\n\r\n    {\r\n      &quot;host1&quot;: &quot;10.1.2.3&quot;,\r\n      &quot;host2&quot;: &quot;10.1.2.2&quot;,\r\n      &quot;host3&quot;: &quot;10.1.18.1&quot;\r\n    }\r\n\r\nHere is the jqplay snippet to play with: https://jqplay.org/s/Jb_fnBveMQ\r\n\r\nThe function `with_entries` converts each object in the list of objects to Key/Value-pair, thus we can access `.key` or `.value` respectively, we&#39;re updating (overwriting) every KV-item `.value` with the field `.ip` by using update `|=` operator",
                "title": "jq: print key and value for each entry in an object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 163,
        "last_activity_date": 1710181244,
        "creation_date": 1449845890,
        "last_edit_date": 1687499892,
        "question_id": 34226370,
        "body_markdown": "How do I get **jq** to take json like this:\r\n\r\n    {\r\n      &quot;host1&quot;: { &quot;ip&quot;: &quot;10.1.2.3&quot; },\r\n      &quot;host2&quot;: { &quot;ip&quot;: &quot;10.1.2.2&quot; },\r\n      &quot;host3&quot;: { &quot;ip&quot;: &quot;10.1.18.1&quot; }\r\n    }\r\n\r\nand generate this output:\r\n\r\n    host1, 10.1.2.3\r\n    host2, 10.1.2.2\r\n    host3, 10.1.18.1\r\n\r\nI&#39;m not interested in the formatting, I just can&#39;t figure out how to access the key name and value.",
        "link": "https://stackoverflow.com/questions/34226370/jq-print-key-and-value-for-each-entry-in-an-object",
        "title": "jq: print key and value for each entry in an object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1450133428,
                "last_edit_date": 1450133428,
                "creation_date": 1450120700,
                "answer_id": 34274903,
                "question_id": 34273921,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following will merge an array of objects into a single object as you describe (in particular, null is used as a filler, which certainly makes sense if, for example, each input object is regarded as an &quot;observation&quot;), but please note that merge/0 as defined here makes no assumptions about the sets of keys in the input objects, and could potentially be made much faster depending on the assumptions that could be made.\r\n\r\n    def merge:\r\n      def allkeys: map(keys) | add | unique;\r\n      allkeys as $allkeys\r\n      | reduce .[] as $in ({};\r\n         reduce $allkeys[] as $k (.;\r\n           . + {($k): (.[$k] + [$in[$k]]) } ));\r\n\r\n    merge\r\n\r\n\r\nNow use the &quot;slurp&quot; option, e.g.:\r\n\r\n     $ jq -s -f merge.jq file*.json\r\n\r\n\r\n\r\n",
                "title": "Turn an array of objects into an object of arrays with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1450125447,
                "creation_date": 1450125447,
                "answer_id": 34276153,
                "question_id": 34273921,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is probably slower than @peak&#39;s solution, but maybe easier to read:\r\n\r\n    map(to_entries)\r\n    | flatten(1)\r\n    | group_by(.key)\r\n    | map({\r\n        key: .[0].key,\r\n        value: map(.value)})\r\n    | from_entries\r\n\r\nUse it like:\r\n\r\n    jq -s &#39;map(to_entries) | flatten(1) | group_by(.key) | map({key: .[0].key, value: map(.value)}) | from_entries&#39; file*.json\r\n\r\nUnlike your desired output, it does not put nulls in place of missing values, which may be useful if &quot;null&quot; is a valid value in itself.",
                "title": "Turn an array of objects into an object of arrays with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503718798,
                "creation_date": 1503718798,
                "answer_id": 45891714,
                "question_id": 34273921,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another solution.\r\n\r\n      (add | keys) as $all                                                  # get all keys\r\n    | map( . as $o | reduce $all[] as $k ({}; .[$k] = $o[$k]) )             # normalize objects\r\n    |    ( . as $a | reduce $all[] as $k ({}; .[$k] = ($a | map(.[$k]))) )  # transpose\r\n\r\nTo run it use the `-s` option, e.g:\r\n\r\n    $ jq -s -f filter.jq file1.json file2.json\r\n\r\nSample output:\r\n\r\n    {\r\n      &quot;key1&quot;: [\r\n        5,\r\n        2\r\n      ],\r\n      &quot;key2&quot;: [\r\n        10,\r\n        null\r\n      ]\r\n    }\r\n \r\nIf you have more files, e.g. `file3.json`\r\n\r\n    {\r\n      &quot;key3&quot;: 2\r\n    }\r\n \r\njust add them to the command line\r\n \r\n    $ jq -s -f filter.jq file1.json file2.json file3.json\r\n\r\nSample output:\r\n\r\n    {\r\n      &quot;key1&quot;: [\r\n        5,\r\n        2,\r\n        null\r\n      ],\r\n      &quot;key2&quot;: [\r\n        10,\r\n        null,\r\n        null\r\n      ],\r\n      &quot;key3&quot;: [\r\n        null,\r\n        null,\r\n        2\r\n      ]\r\n    }",
                "title": "Turn an array of objects into an object of arrays with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1503718798,
        "creation_date": 1450117081,
        "last_edit_date": 1450121109,
        "question_id": 34273921,
        "body_markdown": "I would like to use `jq` to turn an array of objects into an object of arrays.\r\n\r\nConsider if I have the following two files:\r\n\r\n**file1.json**:\r\n\r\n    {\r\n      &quot;key1&quot;: 5,\r\n      &quot;key2&quot;: 10\r\n    }\r\n\r\n**file2.json**:\r\n\r\n    {\r\n      &quot;key1&quot;: 2\r\n    }\r\n\r\nI would like to merge them together to form:\r\n\r\n    {\r\n      &quot;key1&quot;: [5, 2]\r\n      &quot;key2&quot;: [10, null]\r\n    }\r\n\r\nIt&#39;s easy to do this with one field per `jq` command, but I can&#39;t figure out how to do it with all the fields at once.  My thought is that I need to convert all the values to arrays and then use reduce with `*`, but I couldn&#39;t get it to work.\r\n\r\nThe `jq` command needs to work for an arbitrary number of files (more than 2).",
        "link": "https://stackoverflow.com/questions/34273921/turn-an-array-of-objects-into-an-object-of-arrays-with-jq",
        "title": "Turn an array of objects into an object of arrays with jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 94756,
                    "reputation": 81440,
                    "user_id": 258523,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/f2c517550a86045c885bc36eca722b9d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Etan Reisner",
                    "link": "https://stackoverflow.com/users/258523/etan-reisner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1450367980,
                "post_id": 34338427,
                "comment_id": 56419116,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1450369151,
                "creation_date": 1450369151,
                "answer_id": 34339401,
                "question_id": 34338427,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You&#39;ll have to use the associative array notation for arbitrary key strings\r\n\r\n    jq &quot;.[\\&quot;$search\\&quot;].value&quot; &quot;$file",
                "title": "jq: Accessing fields with - character in shell script"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1450374520,
                "creation_date": 1450374520,
                "answer_id": 34341081,
                "question_id": 34338427,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As a general rule of thumb, I would strongly suggest not placing shell variables within your filters, and use arguments to pass them in.\r\n\r\n    jq --arg search &quot;$search&quot; &#39;.[$search].value&#39; &quot;$file&quot;\r\n\r\nYour filter string is an equivalent to a script. You wouldn&#39;t want to modify your script every time you wanted to change a value, you would parameterize it.",
                "title": "jq: Accessing fields with - character in shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1450374520,
        "creation_date": 1450366601,
        "last_edit_date": 1450368614,
        "question_id": 34338427,
        "body_markdown": "I am trying to access the field &quot;my-tag&quot; from the following json using jq from a shell script:\r\n\r\njson file:\r\n\r\n    {\r\n\t    &quot;tag&quot;: {\r\n\t\t    &quot;value&quot;: &quot;hello&quot;\r\n\t    },\r\n\t    &quot;my-tag&quot;: {\r\n\t\t    &quot;value&quot;: &quot;hello-my-tag&quot;\r\n\t    }\r\n    }\r\n\r\nShell script:\r\n    \r\n    #!/bin/bash\r\n    main()\r\n    {\r\n        search=&quot;my-tag&quot;\r\n        file=&quot;myjson.json&quot;\r\n        value=($(jq &quot;.$search.value&quot; &quot;$file&quot;))\r\n        echo $value\r\n    }\r\n\r\n    main &quot;$@&quot;\r\n\r\nOn executing this script, I get the following error:\r\n\r\n    error: tag is not defined\r\n    .-tag.value\r\n    ^^^\r\n    1 compile error\r\n\r\nHow can I extract the field correctly in the shell script?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/34338427/jq-accessing-fields-with-character-in-shell-script",
        "title": "jq: Accessing fields with - character in shell script"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 151,
                "is_accepted": true,
                "score": 151,
                "last_activity_date": 1709678633,
                "last_edit_date": 1709678633,
                "creation_date": 1450373517,
                "answer_id": 34340787,
                "question_id": 34340549,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [`fromjson`](https://jqlang.github.io/jq/manual/#convert-to-from-json).\r\n\r\nIt parses a string to its appropriate json value.  `tojson` (and `@json`) goes the other way around and takes a json value and converts it to a string.\r\n\r\nSo you could do this:\r\n\r\n    .response.text | fromjson.title",
                "title": "Convert string to json in jq"
            },
            {
                "up_vote_count": 35,
                "is_accepted": false,
                "score": 33,
                "last_activity_date": 1572302874,
                "creation_date": 1572302874,
                "answer_id": 58599343,
                "question_id": 34340549,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also do this:\r\n\r\n    jq -r &#39;.response.text&#39; | jq &#39;.recordID&#39;\r\n",
                "title": "Convert string to json in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 96,
        "last_activity_date": 1709678633,
        "creation_date": 1450372730,
        "last_edit_date": 1521823772,
        "question_id": 34340549,
        "body_markdown": "## Background ##\r\n\r\nI have a json file that contains a string of json within an object:\r\n\r\n    {\r\n        &quot;requestType&quot;: &quot;POST&quot;,\r\n        &quot;response&quot;: {\r\n            &quot;size&quot;: 78,\r\n            &quot;text&quot;: &quot;{\\&quot;recordID\\&quot;:123, \\&quot;title\\&quot;:\\&quot;Hello World\\&quot;, \\&quot;content\\&quot;:\\&quot;Lorem ipsum...\\&quot;}&quot;\r\n        }\r\n    }\r\n\r\nI need to interperet the contents of the `.response.text` string as json using the json command line interpereter, [jq][1].\r\n\r\nWhen I run this command:\r\n\r\n    jq &#39;.response.text | @json&#39;\r\n\r\nOutput: `&quot;\\&quot;{\\\\\\&quot;recordID\\\\\\&quot;:123, \\\\\\&quot;title\\\\\\&quot;:\\\\\\&quot;Hello World\\\\\\&quot;, \\\\\\&quot;content\\\\\\&quot;:\\\\\\&quot;Lorem ipsum...\\\\\\&quot;}\\&quot;&quot;`\r\n\r\nI get some weird escaped json string instead of json that I can access via something like this: `.response.text | @json | .recordID`.\r\n\r\nI realize that the `@json` function will take json and output a json escaped string, so there must be another way, but `@text` doesn&#39;t seem to do anything.\r\n\r\n## Question ##\r\n\r\nIs there some way to convert a string of escaped json to actual json that I can parse with a command such as this: `jq &#39;.response.text | @json | .title&#39;` and get this output: `&quot;Hello World&quot;`?\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/34340549/convert-string-to-json-in-jq",
        "title": "Convert string to json in jq"
    },
    {
        "tags": [
            "json",
            "apache-pig",
            "flatten",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1450398242,
                "creation_date": 1450398242,
                "answer_id": 34346700,
                "question_id": 34343151,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Rather than going through the authors separately in separate expressions, you need to go through the authors once.  You could put the results in a variable and access them later.\r\n\r\n    select(.authors != null) | .authors[] as $author |\r\n        [ .identifiers.doi, .date, .journal.id, $author.name, $author.type ]",
                "title": "JQ: PigLatin style FLATTEN function"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1450399655,
                "creation_date": 1450399655,
                "answer_id": 34346890,
                "question_id": 34343151,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Jeff&#39;s suggestion to use a one-step approach makes sense, but if one did have to translate the array `[field1,field2,field3,[author1,...,authorN],[author_type1,...,author_typeN]]` to a stream of arrays of the form `[field1,field2,field3,authorI,author_typeI]` then a suitable jq filter would be:\r\n\r\n    .[0:2] + ([.[3], .[4]] | transpose[])",
                "title": "JQ: PigLatin style FLATTEN function"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1450399655,
        "creation_date": 1450382045,
        "question_id": 34343151,
        "body_markdown": "I have been looking for a quite specific feature that may not exist in `jq`. If you know that it&#39;s not there, I would appreciate a kind notice and some suggestion to solve this problem.\r\n\r\nI am processing a public [dataset](http://journals.aps.org/datasets). I have managed to reduce the data into the following line format:\r\n\r\n    [field1,field2,field3,[author1,...,authorN],[author_type1,...,author_typeN]]\r\n\r\nThe bash command I am using to get to this format is the following:\r\n\r\n    find aps-dataset-metadata_subdir_path/ -name &#39;*.json&#39; | \\\r\n    xargs cat | \\\r\n    jq --compact-output \\\r\n        &#39;select(.authors != null) | [.identifiers.doi, .date, .journal.id, [.authors[].name], [.authors[].type]]&#39;\r\n\r\nNotice that the `authorN` and `author_typeN` are in the same object (i.e. having the same parent) in the raw data.\r\n\r\nI have been looking for a way to produce from each of these line the following:\r\n\r\n    [field1,field2,field3,author1,author_type1]\r\n    [field1,field2,field3,author2,author_type2]\r\n    ...\r\n    ...\r\n    [field1,field2,field3,authorN,author_typeN]\r\n\r\nThe flatten function in `jq` seems to be level-flattening without generating new lists. If some of you knows PigLatin, what I want is exactly the [PigLatin built-in Flatten](http://chimera.labs.oreilly.com/books/1234000001811/ch06.html) operator.\r\n\r\nAgain, I am aware of the possibility that it is not implemented in `jq`. In that case probably I will post-process the output in `Python`, or any other awesome way that you guys suggest in answers.\r\n\r\nThank you very much!",
        "link": "https://stackoverflow.com/questions/34343151/jq-piglatin-style-flatten-function",
        "title": "JQ: PigLatin style FLATTEN function"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1450508444,
                "last_edit_date": 1450508444,
                "creation_date": 1450504265,
                "answer_id": 34367747,
                "question_id": 34367613,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For each input top-level JSON entity, the following filter will recursively examine all the objects to see if they have a &quot;country&quot; key, and it will then report the distinct &quot;country&quot; values for that top-level entity:\r\n\r\n    jq -c &#39;[.. | if type == &quot;object&quot; and has(&quot;country&quot;) \r\n                 then .country\r\n                 else empty end] | unique&#39; \r\n    [&quot;Israel&quot;]\r\n    [&quot;USA&quot;]\r\n    [&quot;Germany&quot;,&quot;USA&quot;]\r\n    [&quot;USA&quot;]\r\n    [&quot;Spain&quot;,&quot;USA&quot;]\r\n    [&quot;USA&quot;]\r\n    [&quot;USA&quot;]\r\n    [&quot;USA&quot;]\r\n    [&quot;Germany&quot;,&quot;USA&quot;]\r\n    [&quot;USA&quot;]\r\n\r\nHere&#39;s a filter that will produce the same results in your example, though it is not exactly equivalent:\r\n\r\n    [.. | .country? // empty] | unique\r\n\r\n[Exercise for the interested reader: what is the difference? :-) ]",
                "title": "Extracting variable number of fields using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1503719878,
                "creation_date": 1503719878,
                "answer_id": 45891795,
                "question_id": 34367613,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses a function to handle the variation in `.address_name`\r\n\r\n     def address_specs:\r\n        if type == &quot;array&quot; then .[].address_spec else .address_spec end\r\n     ;\r\n\r\n     .addresses | .address_name | [address_specs | .country] | unique",
                "title": "Extracting variable number of fields using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1503719878,
        "creation_date": 1450503017,
        "question_id": 34367613,
        "body_markdown": "I am new to this website and came here because I am really struggling with a problem of extracting information from a JSON file. The tricky part is that there are variable number of fields, so I can&#39;t get away with simple syntax.\r\n\r\nHere&#39;s a sample code:\r\n\r\n    {\r\n      &quot;addresses&quot;: {\r\n        &quot;@count&quot;: &quot;1&quot;,\r\n        &quot;address_name&quot;: {\r\n          &quot;address_spec&quot;: {\r\n            &quot;@addr_no&quot;: &quot;1&quot;,\r\n            &quot;full_address&quot;: &quot;Tel Aviv Univ, Eitan Berglas Sch Econ, IL-69978 Tel Aviv, Israel&quot;,\r\n            &quot;organizations&quot;: {\r\n              &quot;@count&quot;: &quot;2&quot;,\r\n              &quot;organization&quot;: [\r\n                &quot;Tel Aviv Univ&quot;,\r\n                {\r\n                  &quot;@pref&quot;: &quot;Y&quot;,\r\n                  &quot;#text&quot;: &quot;Tel Aviv University&quot;\r\n                }\r\n              ]\r\n            },\r\n            &quot;suborganizations&quot;: {\r\n              &quot;@count&quot;: &quot;1&quot;,\r\n              &quot;suborganization&quot;: &quot;Eitan Berglas Sch Econ&quot;\r\n            },\r\n            &quot;city&quot;: &quot;Tel Aviv&quot;,\r\n            &quot;country&quot;: &quot;Israel&quot;,\r\n            &quot;zip&quot;: {\r\n              &quot;@location&quot;: &quot;BC&quot;,\r\n              &quot;#text&quot;: &quot;IL-69978&quot;\r\n            }\r\n          }\r\n        }\r\n      },\r\n      &quot;category_info&quot;: {\r\n        &quot;headings&quot;: {\r\n          &quot;@count&quot;: &quot;1&quot;,\r\n          &quot;heading&quot;: &quot;Social Sciences&quot;\r\n        },\r\n        &quot;subjects&quot;: {\r\n          &quot;@count&quot;: &quot;3&quot;,\r\n          &quot;subject&quot;: [\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;extended&quot;,\r\n              &quot;#text&quot;: &quot;Business &amp;amp; Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;ECONOMICS&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n    {\r\n      &quot;addresses&quot;: {\r\n        &quot;@count&quot;: &quot;1&quot;,\r\n        &quot;address_name&quot;: {\r\n          &quot;address_spec&quot;: {\r\n            &quot;@addr_no&quot;: &quot;1&quot;,\r\n            &quot;full_address&quot;: &quot;MIT, Cambridge, MA 02139 USA&quot;,\r\n            &quot;organizations&quot;: {\r\n              &quot;@count&quot;: &quot;2&quot;,\r\n              &quot;organization&quot;: [\r\n                &quot;MIT&quot;,\r\n                {\r\n                  &quot;@pref&quot;: &quot;Y&quot;,\r\n                  &quot;#text&quot;: &quot;Massachusetts Institute of Technology (MIT)&quot;\r\n                }\r\n              ]\r\n            },\r\n            &quot;city&quot;: &quot;Cambridge&quot;,\r\n            &quot;state&quot;: &quot;MA&quot;,\r\n            &quot;country&quot;: &quot;USA&quot;,\r\n            &quot;zip&quot;: {\r\n              &quot;@location&quot;: &quot;AP&quot;,\r\n              &quot;#text&quot;: &quot;02139&quot;\r\n            }\r\n          }\r\n        }\r\n      },\r\n      &quot;category_info&quot;: {\r\n        &quot;headings&quot;: {\r\n          &quot;@count&quot;: &quot;1&quot;,\r\n          &quot;heading&quot;: &quot;Social Sciences&quot;\r\n        },\r\n        &quot;subjects&quot;: {\r\n          &quot;@count&quot;: &quot;3&quot;,\r\n          &quot;subject&quot;: [\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;extended&quot;,\r\n              &quot;#text&quot;: &quot;Business &amp;amp; Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;ECONOMICS&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n    {\r\n      &quot;addresses&quot;: {\r\n        &quot;@count&quot;: &quot;2&quot;,\r\n        &quot;address_name&quot;: [\r\n          {\r\n            &quot;address_spec&quot;: {\r\n              &quot;@addr_no&quot;: &quot;1&quot;,\r\n              &quot;full_address&quot;: &quot;Univ Kentucky, Lexington, KY 40506 USA&quot;,\r\n              &quot;organizations&quot;: {\r\n                &quot;@count&quot;: &quot;2&quot;,\r\n                &quot;organization&quot;: [\r\n                  &quot;Univ Kentucky&quot;,\r\n                  {\r\n                    &quot;@pref&quot;: &quot;Y&quot;,\r\n                    &quot;#text&quot;: &quot;University of Kentucky&quot;\r\n                  }\r\n                ]\r\n              },\r\n              &quot;city&quot;: &quot;Lexington&quot;,\r\n              &quot;state&quot;: &quot;KY&quot;,\r\n              &quot;country&quot;: &quot;USA&quot;,\r\n              &quot;zip&quot;: {\r\n                &quot;@location&quot;: &quot;AP&quot;,\r\n                &quot;#text&quot;: &quot;40506&quot;\r\n              }\r\n            }\r\n          },\r\n          {\r\n            &quot;address_spec&quot;: {\r\n              &quot;@addr_no&quot;: &quot;2&quot;,\r\n              &quot;full_address&quot;: &quot;Univ Bonn, ZEI, D-5300 Bonn, Germany&quot;,\r\n              &quot;organizations&quot;: {\r\n                &quot;@count&quot;: &quot;2&quot;,\r\n                &quot;organization&quot;: [\r\n                  &quot;Univ Bonn&quot;,\r\n                  {\r\n                    &quot;@pref&quot;: &quot;Y&quot;,\r\n                    &quot;#text&quot;: &quot;University of Bonn&quot;\r\n                  }\r\n                ]\r\n              },\r\n              &quot;suborganizations&quot;: {\r\n                &quot;@count&quot;: &quot;1&quot;,\r\n                &quot;suborganization&quot;: &quot;ZEI&quot;\r\n              },\r\n              &quot;city&quot;: &quot;Bonn&quot;,\r\n              &quot;country&quot;: &quot;Germany&quot;,\r\n              &quot;zip&quot;: {\r\n                &quot;@location&quot;: &quot;BC&quot;,\r\n                &quot;#text&quot;: &quot;D-5300&quot;\r\n              }\r\n            }\r\n          }\r\n        ]\r\n      },\r\n      &quot;category_info&quot;: {\r\n        &quot;headings&quot;: {\r\n          &quot;@count&quot;: &quot;1&quot;,\r\n          &quot;heading&quot;: &quot;Social Sciences&quot;\r\n        },\r\n        &quot;subjects&quot;: {\r\n          &quot;@count&quot;: &quot;3&quot;,\r\n          &quot;subject&quot;: [\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;extended&quot;,\r\n              &quot;#text&quot;: &quot;Business &amp;amp; Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;ECONOMICS&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n    {\r\n      &quot;addresses&quot;: {\r\n        &quot;@count&quot;: &quot;1&quot;,\r\n        &quot;address_name&quot;: {\r\n          &quot;address_spec&quot;: {\r\n            &quot;@addr_no&quot;: &quot;1&quot;,\r\n            &quot;full_address&quot;: &quot;Harvard Univ, Cambridge, MA 02138 USA&quot;,\r\n            &quot;organizations&quot;: {\r\n              &quot;@count&quot;: &quot;2&quot;,\r\n              &quot;organization&quot;: [\r\n                &quot;Harvard Univ&quot;,\r\n                {\r\n                  &quot;@pref&quot;: &quot;Y&quot;,\r\n                  &quot;#text&quot;: &quot;Harvard University&quot;\r\n                }\r\n              ]\r\n            },\r\n            &quot;city&quot;: &quot;Cambridge&quot;,\r\n            &quot;state&quot;: &quot;MA&quot;,\r\n            &quot;country&quot;: &quot;USA&quot;,\r\n            &quot;zip&quot;: {\r\n              &quot;@location&quot;: &quot;AP&quot;,\r\n              &quot;#text&quot;: &quot;02138&quot;\r\n            }\r\n          }\r\n        }\r\n      },\r\n      &quot;category_info&quot;: {\r\n        &quot;headings&quot;: {\r\n          &quot;@count&quot;: &quot;1&quot;,\r\n          &quot;heading&quot;: &quot;Social Sciences&quot;\r\n        },\r\n        &quot;subjects&quot;: {\r\n          &quot;@count&quot;: &quot;3&quot;,\r\n          &quot;subject&quot;: [\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;extended&quot;,\r\n              &quot;#text&quot;: &quot;Business &amp;amp; Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;ECONOMICS&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n    {\r\n      &quot;addresses&quot;: {\r\n        &quot;@count&quot;: &quot;3&quot;,\r\n        &quot;address_name&quot;: [\r\n          {\r\n            &quot;address_spec&quot;: {\r\n              &quot;@addr_no&quot;: &quot;1&quot;,\r\n              &quot;full_address&quot;: &quot;Columbia Univ, New York, NY 10027 USA&quot;,\r\n              &quot;organizations&quot;: {\r\n                &quot;@count&quot;: &quot;2&quot;,\r\n                &quot;organization&quot;: [\r\n                  &quot;Columbia Univ&quot;,\r\n                  {\r\n                    &quot;@pref&quot;: &quot;Y&quot;,\r\n                    &quot;#text&quot;: &quot;Columbia University&quot;\r\n                  }\r\n                ]\r\n              },\r\n              &quot;city&quot;: &quot;New York&quot;,\r\n              &quot;state&quot;: &quot;NY&quot;,\r\n              &quot;country&quot;: &quot;USA&quot;,\r\n              &quot;zip&quot;: {\r\n                &quot;@location&quot;: &quot;AP&quot;,\r\n                &quot;#text&quot;: &quot;10027&quot;\r\n              }\r\n            }\r\n          },\r\n          {\r\n            &quot;address_spec&quot;: {\r\n              &quot;@addr_no&quot;: &quot;2&quot;,\r\n              &quot;full_address&quot;: &quot;NYU, New York, NY USA&quot;,\r\n              &quot;organizations&quot;: {\r\n                &quot;@count&quot;: &quot;2&quot;,\r\n                &quot;organization&quot;: [\r\n                  &quot;NYU&quot;,\r\n                  {\r\n                    &quot;@pref&quot;: &quot;Y&quot;,\r\n                    &quot;#text&quot;: &quot;New York University&quot;\r\n                  }\r\n                ]\r\n              },\r\n              &quot;city&quot;: &quot;New York&quot;,\r\n              &quot;state&quot;: &quot;NY&quot;,\r\n              &quot;country&quot;: &quot;USA&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;address_spec&quot;: {\r\n              &quot;@addr_no&quot;: &quot;3&quot;,\r\n              &quot;full_address&quot;: &quot;Univ Pompeu Fabra, Barcelona, Spain&quot;,\r\n              &quot;organizations&quot;: {\r\n                &quot;@count&quot;: &quot;2&quot;,\r\n                &quot;organization&quot;: [\r\n                  &quot;Univ Pompeu Fabra&quot;,\r\n                  {\r\n                    &quot;@pref&quot;: &quot;Y&quot;,\r\n                    &quot;#text&quot;: &quot;Pompeu Fabra University&quot;\r\n                  }\r\n                ]\r\n              },\r\n              &quot;city&quot;: &quot;Barcelona&quot;,\r\n              &quot;country&quot;: &quot;Spain&quot;\r\n            }\r\n          }\r\n        ]\r\n      },\r\n      &quot;category_info&quot;: {\r\n        &quot;headings&quot;: {\r\n          &quot;@count&quot;: &quot;1&quot;,\r\n          &quot;heading&quot;: &quot;Social Sciences&quot;\r\n        },\r\n        &quot;subjects&quot;: {\r\n          &quot;@count&quot;: &quot;3&quot;,\r\n          &quot;subject&quot;: [\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;extended&quot;,\r\n              &quot;#text&quot;: &quot;Business &amp;amp; Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;ECONOMICS&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n    {\r\n      &quot;addresses&quot;: {\r\n        &quot;@count&quot;: &quot;2&quot;,\r\n        &quot;address_name&quot;: [\r\n          {\r\n            &quot;address_spec&quot;: {\r\n              &quot;@addr_no&quot;: &quot;1&quot;,\r\n              &quot;full_address&quot;: &quot;Univ Chicago, Chicago, IL 60637 USA&quot;,\r\n              &quot;organizations&quot;: {\r\n                &quot;@count&quot;: &quot;2&quot;,\r\n                &quot;organization&quot;: [\r\n                  &quot;Univ Chicago&quot;,\r\n                  {\r\n                    &quot;@pref&quot;: &quot;Y&quot;,\r\n                    &quot;#text&quot;: &quot;University of Chicago&quot;\r\n                  }\r\n                ]\r\n              },\r\n              &quot;city&quot;: &quot;Chicago&quot;,\r\n              &quot;state&quot;: &quot;IL&quot;,\r\n              &quot;country&quot;: &quot;USA&quot;,\r\n              &quot;zip&quot;: {\r\n                &quot;@location&quot;: &quot;AP&quot;,\r\n                &quot;#text&quot;: &quot;60637&quot;\r\n              }\r\n            }\r\n          },\r\n          {\r\n            &quot;address_spec&quot;: {\r\n              &quot;@addr_no&quot;: &quot;2&quot;,\r\n              &quot;full_address&quot;: &quot;Amer Bar Fdn, Chicago, IL 60611 USA&quot;,\r\n              &quot;organizations&quot;: {\r\n                &quot;@count&quot;: &quot;1&quot;,\r\n                &quot;organization&quot;: &quot;Amer Bar Fdn&quot;\r\n              },\r\n              &quot;city&quot;: &quot;Chicago&quot;,\r\n              &quot;state&quot;: &quot;IL&quot;,\r\n              &quot;country&quot;: &quot;USA&quot;,\r\n              &quot;zip&quot;: {\r\n                &quot;@location&quot;: &quot;AP&quot;,\r\n                &quot;#text&quot;: &quot;60611&quot;\r\n              }\r\n            }\r\n          }\r\n        ]\r\n      },\r\n      &quot;category_info&quot;: {\r\n        &quot;headings&quot;: {\r\n          &quot;@count&quot;: &quot;1&quot;,\r\n          &quot;heading&quot;: &quot;Social Sciences&quot;\r\n        },\r\n        &quot;subjects&quot;: {\r\n          &quot;@count&quot;: &quot;3&quot;,\r\n          &quot;subject&quot;: [\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;extended&quot;,\r\n              &quot;#text&quot;: &quot;Business &amp;amp; Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;ECONOMICS&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n    {\r\n      &quot;addresses&quot;: {\r\n        &quot;@count&quot;: &quot;2&quot;,\r\n        &quot;address_name&quot;: [\r\n          {\r\n            &quot;address_spec&quot;: {\r\n              &quot;@addr_no&quot;: &quot;1&quot;,\r\n              &quot;full_address&quot;: &quot;Ohio State Univ, Columbus, OH 43210 USA&quot;,\r\n              &quot;organizations&quot;: {\r\n                &quot;@count&quot;: &quot;2&quot;,\r\n                &quot;organization&quot;: [\r\n                  &quot;Ohio State Univ&quot;,\r\n                  {\r\n                    &quot;@pref&quot;: &quot;Y&quot;,\r\n                    &quot;#text&quot;: &quot;Ohio State University&quot;\r\n                  }\r\n                ]\r\n              },\r\n              &quot;city&quot;: &quot;Columbus&quot;,\r\n              &quot;state&quot;: &quot;OH&quot;,\r\n              &quot;country&quot;: &quot;USA&quot;,\r\n              &quot;zip&quot;: {\r\n                &quot;@location&quot;: &quot;AP&quot;,\r\n                &quot;#text&quot;: &quot;43210&quot;\r\n              }\r\n            }\r\n          },\r\n          {\r\n            &quot;address_spec&quot;: {\r\n              &quot;@addr_no&quot;: &quot;2&quot;,\r\n              &quot;full_address&quot;: &quot;Harvard Univ, Cambridge, MA 02138 USA&quot;,\r\n              &quot;organizations&quot;: {\r\n                &quot;@count&quot;: &quot;2&quot;,\r\n                &quot;organization&quot;: [\r\n                  &quot;Harvard Univ&quot;,\r\n                  {\r\n                    &quot;@pref&quot;: &quot;Y&quot;,\r\n                    &quot;#text&quot;: &quot;Harvard University&quot;\r\n                  }\r\n                ]\r\n              },\r\n              &quot;city&quot;: &quot;Cambridge&quot;,\r\n              &quot;state&quot;: &quot;MA&quot;,\r\n              &quot;country&quot;: &quot;USA&quot;,\r\n              &quot;zip&quot;: {\r\n                &quot;@location&quot;: &quot;AP&quot;,\r\n                &quot;#text&quot;: &quot;02138&quot;\r\n              }\r\n            }\r\n          }\r\n        ]\r\n      },\r\n      &quot;category_info&quot;: {\r\n        &quot;headings&quot;: {\r\n          &quot;@count&quot;: &quot;1&quot;,\r\n          &quot;heading&quot;: &quot;Social Sciences&quot;\r\n        },\r\n        &quot;subjects&quot;: {\r\n          &quot;@count&quot;: &quot;3&quot;,\r\n          &quot;subject&quot;: [\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;extended&quot;,\r\n              &quot;#text&quot;: &quot;Business &amp;amp; Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;ECONOMICS&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n    {\r\n      &quot;addresses&quot;: {\r\n        &quot;@count&quot;: &quot;1&quot;,\r\n        &quot;address_name&quot;: {\r\n          &quot;address_spec&quot;: {\r\n            &quot;@addr_no&quot;: &quot;1&quot;,\r\n            &quot;full_address&quot;: &quot;Univ Chicago, Chicago, IL 60637 USA&quot;,\r\n            &quot;organizations&quot;: {\r\n              &quot;@count&quot;: &quot;2&quot;,\r\n              &quot;organization&quot;: [\r\n                &quot;Univ Chicago&quot;,\r\n                {\r\n                  &quot;@pref&quot;: &quot;Y&quot;,\r\n                  &quot;#text&quot;: &quot;University of Chicago&quot;\r\n                }\r\n              ]\r\n            },\r\n            &quot;city&quot;: &quot;Chicago&quot;,\r\n            &quot;state&quot;: &quot;IL&quot;,\r\n            &quot;country&quot;: &quot;USA&quot;,\r\n            &quot;zip&quot;: {\r\n              &quot;@location&quot;: &quot;AP&quot;,\r\n              &quot;#text&quot;: &quot;60637&quot;\r\n            }\r\n          }\r\n        }\r\n      },\r\n      &quot;category_info&quot;: {\r\n        &quot;headings&quot;: {\r\n          &quot;@count&quot;: &quot;1&quot;,\r\n          &quot;heading&quot;: &quot;Social Sciences&quot;\r\n        },\r\n        &quot;subjects&quot;: {\r\n          &quot;@count&quot;: &quot;3&quot;,\r\n          &quot;subject&quot;: [\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;extended&quot;,\r\n              &quot;#text&quot;: &quot;Business &amp;amp; Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;ECONOMICS&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n    {\r\n      &quot;addresses&quot;: {\r\n        &quot;@count&quot;: &quot;2&quot;,\r\n        &quot;address_name&quot;: [\r\n          {\r\n            &quot;address_spec&quot;: {\r\n              &quot;@addr_no&quot;: &quot;1&quot;,\r\n              &quot;full_address&quot;: &quot;Wissensch Zentrum Berlin Sozialforsch, D-1000 Berlin, Germany&quot;,\r\n              &quot;organizations&quot;: {\r\n                &quot;@count&quot;: &quot;1&quot;,\r\n                &quot;organization&quot;: &quot;Wissensch Zentrum Berlin Sozialforsch&quot;\r\n              },\r\n              &quot;city&quot;: &quot;Berlin&quot;,\r\n              &quot;country&quot;: &quot;Germany&quot;,\r\n              &quot;zip&quot;: {\r\n                &quot;@location&quot;: &quot;BC&quot;,\r\n                &quot;#text&quot;: &quot;D-1000&quot;\r\n              }\r\n            }\r\n          },\r\n          {\r\n            &quot;address_spec&quot;: {\r\n              &quot;@addr_no&quot;: &quot;2&quot;,\r\n              &quot;full_address&quot;: &quot;Harvard Univ, Dept Govt, Cambridge, MA 02138 USA&quot;,\r\n              &quot;organizations&quot;: {\r\n                &quot;@count&quot;: &quot;2&quot;,\r\n                &quot;organization&quot;: [\r\n                  &quot;Harvard Univ&quot;,\r\n                  {\r\n                    &quot;@pref&quot;: &quot;Y&quot;,\r\n                    &quot;#text&quot;: &quot;Harvard University&quot;\r\n                  }\r\n                ]\r\n              },\r\n              &quot;suborganizations&quot;: {\r\n                &quot;@count&quot;: &quot;1&quot;,\r\n                &quot;suborganization&quot;: &quot;Dept Govt&quot;\r\n              },\r\n              &quot;city&quot;: &quot;Cambridge&quot;,\r\n              &quot;state&quot;: &quot;MA&quot;,\r\n              &quot;country&quot;: &quot;USA&quot;,\r\n              &quot;zip&quot;: {\r\n                &quot;@location&quot;: &quot;AP&quot;,\r\n                &quot;#text&quot;: &quot;02138&quot;\r\n              }\r\n            }\r\n          }\r\n        ]\r\n      },\r\n      &quot;category_info&quot;: {\r\n        &quot;headings&quot;: {\r\n          &quot;@count&quot;: &quot;1&quot;,\r\n          &quot;heading&quot;: &quot;Social Sciences&quot;\r\n        },\r\n        &quot;subjects&quot;: {\r\n          &quot;@count&quot;: &quot;3&quot;,\r\n          &quot;subject&quot;: [\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;extended&quot;,\r\n              &quot;#text&quot;: &quot;Business &amp;amp; Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;ECONOMICS&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n    {\r\n      &quot;addresses&quot;: {\r\n        &quot;@count&quot;: &quot;2&quot;,\r\n        &quot;address_name&quot;: [\r\n          {\r\n            &quot;address_spec&quot;: {\r\n              &quot;@addr_no&quot;: &quot;1&quot;,\r\n              &quot;full_address&quot;: &quot;NYU, CV Starr Ctr Appl Econ, New York, NY 10003 USA&quot;,\r\n              &quot;organizations&quot;: {\r\n                &quot;@count&quot;: &quot;2&quot;,\r\n                &quot;organization&quot;: [\r\n                  &quot;NYU&quot;,\r\n                  {\r\n                    &quot;@pref&quot;: &quot;Y&quot;,\r\n                    &quot;#text&quot;: &quot;New York University&quot;\r\n                  }\r\n                ]\r\n              },\r\n              &quot;suborganizations&quot;: {\r\n                &quot;@count&quot;: &quot;1&quot;,\r\n                &quot;suborganization&quot;: &quot;CV Starr Ctr Appl Econ&quot;\r\n              },\r\n              &quot;city&quot;: &quot;New York&quot;,\r\n              &quot;state&quot;: &quot;NY&quot;,\r\n              &quot;country&quot;: &quot;USA&quot;,\r\n              &quot;zip&quot;: {\r\n                &quot;@location&quot;: &quot;AP&quot;,\r\n                &quot;#text&quot;: &quot;10003&quot;\r\n              }\r\n            }\r\n          },\r\n          {\r\n            &quot;address_spec&quot;: {\r\n              &quot;@addr_no&quot;: &quot;2&quot;,\r\n              &quot;full_address&quot;: &quot;Princeton Univ, Princeton, NJ 08544 USA&quot;,\r\n              &quot;organizations&quot;: {\r\n                &quot;@count&quot;: &quot;2&quot;,\r\n                &quot;organization&quot;: [\r\n                  &quot;Princeton Univ&quot;,\r\n                  {\r\n                    &quot;@pref&quot;: &quot;Y&quot;,\r\n                    &quot;#text&quot;: &quot;Princeton University&quot;\r\n                  }\r\n                ]\r\n              },\r\n              &quot;city&quot;: &quot;Princeton&quot;,\r\n              &quot;state&quot;: &quot;NJ&quot;,\r\n              &quot;country&quot;: &quot;USA&quot;,\r\n              &quot;zip&quot;: {\r\n                &quot;@location&quot;: &quot;AP&quot;,\r\n                &quot;#text&quot;: &quot;08544&quot;\r\n              }\r\n            }\r\n          }\r\n        ]\r\n      },\r\n      &quot;category_info&quot;: {\r\n        &quot;headings&quot;: {\r\n          &quot;@count&quot;: &quot;1&quot;,\r\n          &quot;heading&quot;: &quot;Social Sciences&quot;\r\n        },\r\n        &quot;subjects&quot;: {\r\n          &quot;@count&quot;: &quot;3&quot;,\r\n          &quot;subject&quot;: [\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;extended&quot;,\r\n              &quot;#text&quot;: &quot;Business &amp;amp; Economics&quot;\r\n            },\r\n            {\r\n              &quot;@ascatype&quot;: &quot;traditional&quot;,\r\n              &quot;#text&quot;: &quot;ECONOMICS&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\nWhat I was hoping to extract is a country for each of the records (some records have more than one country, which seems to be causing the problem). So my naive approach was to say:\r\n\r\n    .static_data.&quot;fullrecord_metadata&quot;.addresses.address_name.country\r\n\r\nThis however gives me several errors (null has no keys, and cannot index array with string). Checking using the keys command:\r\n\r\n    .static_data.&quot;fullrecord_metadata&quot;.addresses.address_name | keys\r\n\r\nI can see that it&#39;s seems there&#39;s a problem with the way the data is structured... \r\n\r\nSo, could you suggest if I can actually extract the list of countries for each entry using jq? Thank you!",
        "link": "https://stackoverflow.com/questions/34367613/extracting-variable-number-of-fields-using-jq",
        "title": "Extracting variable number of fields using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1450826883,
                "creation_date": 1450826883,
                "answer_id": 34426171,
                "question_id": 34425957,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq -r  &#39;\r\n      .indices\r\n      | to_entries[]\r\n      | &quot;\\(.key) \\(.value.total.filter_cache.memory_size)&quot;\r\n    &#39; input.json\r\n\r\nOutput:\r\n\r\n    oreserverdk04180047 0b\r\n    janbe10200002 0b",
                "title": "Iterate over items within an object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1505969731,
                "last_edit_date": 1505969731,
                "creation_date": 1501884151,
                "answer_id": 45516083,
                "question_id": 34425957,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that uses **foreach**\r\n\r\n      .indices\r\n    | foreach keys[] as $k (\r\n          .\r\n        ; .\r\n        ; &quot;\\($k) \\(.[$k].total.filter_cache.memory_size)&quot;\r\n      )\r\n\r\nEDIT: I now realize a filter of the form `foreach E as $X (.; .; R)` can almost always be rewritten as `E as $X | R` so the above is really just\r\n\r\n      .indices\r\n    | keys[] as $k\r\n    | &quot;\\($k) \\(.[$k].total.filter_cache.memory_size)&quot;\r\n",
                "title": "Iterate over items within an object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1505969731,
        "creation_date": 1450825732,
        "last_edit_date": 1450830882,
        "question_id": 34425957,
        "body_markdown": "I am trying to parse through the json output of one of our es clusters to collect filter cache stats and was hoping to use Jq to do it. Here is the output from the `curl` command:\r\n\r\n    {\r\n      &quot;_shards&quot;: {\r\n        &quot;total&quot;: 5662,\r\n        &quot;successful&quot;: 5662,\r\n        &quot;failed&quot;: 0\r\n      },\r\n      &quot;_all&quot;: {\r\n        &quot;primaries&quot;: {\r\n          &quot;filter_cache&quot;: {\r\n            &quot;memory_size&quot;: &quot;32.8gb&quot;,\r\n            &quot;memory_size_in_bytes&quot;: 35245081088,\r\n            &quot;evictions&quot;: 31347095\r\n          }\r\n        },\r\n        &quot;total&quot;: {\r\n          &quot;filter_cache&quot;: {\r\n            &quot;memory_size&quot;: &quot;94.3gb&quot;,\r\n            &quot;memory_size_in_bytes&quot;: 101307321504,\r\n            &quot;evictions&quot;: 79329152\r\n          }\r\n        }\r\n      },\r\n      &quot;indices&quot;: {\r\n        &quot;oreserverdk04180047&quot;: {\r\n          &quot;primaries&quot;: {\r\n            &quot;filter_cache&quot;: {\r\n              &quot;memory_size&quot;: &quot;0b&quot;,\r\n              &quot;memory_size_in_bytes&quot;: 0,\r\n              &quot;evictions&quot;: 11\r\n            }\r\n          },\r\n          &quot;total&quot;: {\r\n            &quot;filter_cache&quot;: {\r\n              &quot;memory_size&quot;: &quot;0b&quot;,\r\n              &quot;memory_size_in_bytes&quot;: 0,\r\n              &quot;evictions&quot;: 132\r\n            }\r\n          }\r\n        },\r\n        &quot;janbe10200002&quot;: {\r\n          &quot;primaries&quot;: {\r\n            &quot;filter_cache&quot;: {\r\n              &quot;memory_size&quot;: &quot;0b&quot;,\r\n              &quot;memory_size_in_bytes&quot;: 0,\r\n              &quot;evictions&quot;: 88\r\n            }\r\n          },\r\n          &quot;total&quot;: {\r\n            &quot;filter_cache&quot;: {\r\n              &quot;memory_size&quot;: &quot;0b&quot;,\r\n              &quot;memory_size_in_bytes&quot;: 0,\r\n              &quot;evictions&quot;: 119\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nBasically I would like to get the output to look something like this:\r\n\r\n    oreserverdk04180047 0b\r\n    janbe10200002 0b\r\n\r\nI just want the name of the index and the memory_size column from &quot;total&quot;. I can get it if I run this through hardcoding the index names as such:\r\n\r\n    jq &#39;. | {memory_size: .indices.janbe10200002.total.filter_cache.memory_size}&#39;\r\n\r\nBut I was hoping to iterate through using some sort of wild card for the index name.\r\n",
        "link": "https://stackoverflow.com/questions/34425957/iterate-over-items-within-an-object",
        "title": "Iterate over items within an object"
    },
    {
        "tags": [
            "json",
            "jq",
            "jsawk"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2587836,
                    "reputation": 9827,
                    "user_id": 2243104,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6c2656379a2f69a1d6f116f9a3b3bf5a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Reti43",
                    "link": "https://stackoverflow.com/users/2243104/reti43"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1450829438,
                "post_id": 34426441,
                "comment_id": 56594572,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1450829764,
                "post_id": 34426441,
                "comment_id": 56594653,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1450832266,
                "creation_date": 1450832266,
                "answer_id": 34426982,
                "question_id": 34426441,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming all `category` values are simple strings and you want all category values, regardless of where it is in the JSON, you could use this filter using jq:\r\n\r\n    .. | objects.category // empty\r\n\r\nThis returns the following strings:\r\n\r\n    &quot;cocker spaniel&quot;\r\n    &quot;dog&quot;\r\n\r\n",
                "title": "Need help to parse and print only &#39;category&#39; values either using jq or jsawk or shell script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1505970723,
                "last_edit_date": 1505970723,
                "creation_date": 1501885478,
                "answer_id": 45516285,
                "question_id": 34426441,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **leaf_paths** and **select** to find all the paths with a leaf &quot;category&quot; member and then extract the corresponding values with **foreach**\r\n\r\n    foreach (leaf_paths | select(.[-1] == &quot;category&quot;)) as $p (\r\n        .\r\n      ; .\r\n      ; getpath($p)\r\n    )\r\n\r\nIf your input is in a file called `input.json` and the above filter is in a file called `filter.jq` then the shell command\r\n\r\n    jq -f filter.jq input.json\r\n\r\nshould produce\r\n\r\n    &quot;cocker spaniel&quot;\r\n    &quot;dog&quot;\r\n\r\nYou can use the `-r` flag if you don&#39;t want the quotes in the output.\r\n\r\n\r\nEDIT: I now realize a filter of the form `foreach E as $X (.; .; R)` can almost always be rewritten as `E as $X | R` so the above is really just\r\n\r\n      (leaf_paths | select(.[-1] == &quot;category&quot;)) as $p\r\n    | getpath($p)",
                "title": "Need help to parse and print only &#39;category&#39; values either using jq or jsawk or shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1505970723,
        "creation_date": 1450828364,
        "last_edit_date": 1450845963,
        "question_id": 34426441,
        "body_markdown": "Need help to parse and print only `category` values either using jq or jsawk or shell script.\r\n\r\n    {\r\n      &quot;fine_grained&quot;: {\r\n        &quot;dog&quot;: [\r\n          {\r\n            &quot;category&quot;: &quot;cocker spaniel&quot;,\r\n            &quot;mark&quot;: 0.9958831668\r\n          }\r\n        ]\r\n      },\r\n      &quot;coarse&quot;: [\r\n        {\r\n          &quot;category&quot;: &quot;dog&quot;,\r\n          &quot;mark&quot;: 0.948208034\r\n        }\r\n      ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/34426441/need-help-to-parse-and-print-only-category-values-either-using-jq-or-jsawk-or",
        "title": "Need help to parse and print only &#39;category&#39; values either using jq or jsawk or shell script"
    },
    {
        "tags": [
            "arrays",
            "json",
            "addition",
            "jq",
            "fileslurp"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 515705,
                    "reputation": 4093,
                    "user_id": 3160967,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/1d5285da7116b41a824dd9cf0e77e4ea?s=256&d=identicon&r=PG",
                    "display_name": "mwag",
                    "link": "https://stackoverflow.com/users/3160967/mwag"
                },
                "edited": false,
                "score": 6,
                "creation_date": 1492462645,
                "post_id": 34477547,
                "comment_id": 73974952,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 149,
                "is_accepted": false,
                "score": 149,
                "last_activity_date": 1625078503,
                "last_edit_date": 1625078503,
                "creation_date": 1451192164,
                "answer_id": 34477713,
                "question_id": 34477547,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your input is a stream of objects, then unless your jq has `inputs`, the objects must be &quot;slurped&quot;, e.g. using the -s command-line option, in order to combine them.\r\n\r\nThus one way to combine objects in the input stream is to use:\r\n\r\n    jq -s add\r\n\r\nFor the second problem, creating an array:\r\n\r\n    jq -s .\r\n\r\nThere are of course other alternatives, but these are simple and do not require the most recent version of jq. With jq 1.5 and later, you can use &#39;inputs&#39;, e.g. `jq -n &#39;[inputs]&#39;`\r\n\r\n## Efficient solution\r\n\r\nFor the first problem (reduction), rather than slurping (whether via the -s option, or using `[inputs]`), it would be more efficient to use `reduce` with `inputs` and the -n command-line option.  For example, to combine the stream of objects into a single object:\r\n\r\n    jq -n &#39;reduce inputs as $in (null; . + $in)&#39;\r\n\r\n\r\nEquivalently, without `--null-input`:\r\n```\r\njq &#39;reduce inputs as $in (.; . + $in)\r\n```",
                "title": "How to combine the sequence of objects in jq into one object?"
            },
            {
                "up_vote_count": 45,
                "is_accepted": false,
                "score": 45,
                "last_activity_date": 1533163006,
                "last_edit_date": 1533163006,
                "creation_date": 1513985438,
                "answer_id": 47948461,
                "question_id": 34477547,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An alternative to slurping using the -s command-line option is to use the `inputs` filter. Like so:\r\n\r\n    jq -n &#39;[inputs] | add&#39;\r\n\r\nThis will produce an object with all the input objects combined.",
                "title": "How to combine the sequence of objects in jq into one object?"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1596116028,
                "creation_date": 1596116028,
                "answer_id": 63174350,
                "question_id": 34477547,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To combine objects into an array you can use the following:\r\n\r\n```sh\r\n$ echo &#39;\r\n{\r\n  &quot;a&quot;: &quot;green&quot;,\r\n  &quot;b&quot;: &quot;white&quot;\r\n}\r\n{\r\n  &quot;a&quot;: &quot;red&quot;,\r\n  &quot;c&quot;: &quot;purple&quot;\r\n}&#39; | jq -n &#39;[inputs]&#39;\r\n[\r\n  {\r\n    &quot;a&quot;: &quot;green&quot;,\r\n    &quot;b&quot;: &quot;white&quot;\r\n  },\r\n  {\r\n    &quot;a&quot;: &quot;red&quot;,\r\n    &quot;c&quot;: &quot;purple&quot;\r\n  }\r\n]\r\n```",
                "title": "How to combine the sequence of objects in jq into one object?"
            },
            {
                "up_vote_count": 14,
                "is_accepted": false,
                "score": 14,
                "last_activity_date": 1611251575,
                "last_edit_date": 1611251575,
                "creation_date": 1611251229,
                "answer_id": 65832984,
                "question_id": 34477547,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you got to this point via jq filter rather than external input, [mwag&#39;s comment](https://stackoverflow.com/questions/34477547/how-to-combine-the-sequence-of-objects-in-jq-into-one-object#comment73974952_34477547) suggesting wrapping your jq filter in `[]`s might be useful.\r\n\r\nExample:\r\n\r\n    $ echo &#39;[{&quot;foo&quot;:42},{&quot;foo&quot;:43}]&#39; | jq &#39;.[]&#39;\r\n    {\r\n      &quot;foo&quot;: 42\r\n    }\r\n    {\r\n      &quot;foo&quot;: 43\r\n    }\r\n    $ echo &#39;[{&quot;foo&quot;:42},{&quot;foo&quot;:43}]&#39; | jq &#39;[.[]]&#39;\r\n    [\r\n      {\r\n        &quot;foo&quot;: 42\r\n      },\r\n      {\r\n        &quot;foo&quot;: 43\r\n      }\r\n    ]\r\n\r\nSee also [jq Github issue #684: Creating an array from objects?](https://github.com/stedolan/jq/issues/684).",
                "title": "How to combine the sequence of objects in jq into one object?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1714657512,
                "creation_date": 1714657512,
                "answer_id": 78419572,
                "question_id": 34477547,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I ran into these answers (Q2 2024) and had to tinker to get it working on `jq-1.6`. \r\n\r\nGiven a series of objects:\r\n\r\n```\r\n# objects.json\r\n{ &quot;foo&quot;: &quot;bar&quot; }\r\n{ &quot;biz&quot;: &quot;baz&quot; }\r\n```\r\n\r\nI was able to embed them within some other custom object like so:\r\n\r\n```\r\n# Type I: single object\r\n\r\ncat objects.json \\\r\n | jq -ns &#39;{ type: &quot;something&quot;, subtype: &quot;specific&quot;, content: (inputs | add) }&#39;  \r\n```\r\n\r\n\r\n```\r\n# Type II: list object\r\n\r\ncat objects.json \\\r\n | jq -ns &#39;{ type: &quot;something&quot;, subtype: &quot;specific&quot;, content: [inputs] }&#39;  \r\n```\r\n\r\nIn particular, **Type I** was where I had to tinker. ",
                "title": "How to combine the sequence of objects in jq into one object?"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 108,
        "last_activity_date": 1714657512,
        "creation_date": 1451190289,
        "last_edit_date": 1483352152,
        "question_id": 34477547,
        "body_markdown": "I would like to convert the stream of objects:\r\n\r\n    {\r\n      &quot;a&quot;: &quot;green&quot;,\r\n      &quot;b&quot;: &quot;white&quot;\r\n    }\r\n    {\r\n      &quot;a&quot;: &quot;red&quot;,\r\n      &quot;c&quot;: &quot;purple&quot;\r\n    }\r\n\r\ninto one object:\r\n\r\n    {\r\n      &quot;a&quot;: &quot;red&quot;,\r\n      &quot;b&quot;: &quot;white&quot;,\r\n      &quot;c&quot;: &quot;purple&quot;\r\n    }\r\n\r\n\r\nAlso, how can I wrap the same sequence into an array?\r\n\r\n    [\r\n        {\r\n          &quot;a&quot;: &quot;green&quot;,\r\n          &quot;b&quot;: &quot;white&quot;\r\n        },\r\n        {\r\n          &quot;a&quot;: &quot;red&quot;,\r\n          &quot;c&quot;: &quot;purple&quot;\r\n        }\r\n    ]\r\n\r\n\r\nSadly, the manual is seriously lacking in comprehensiveness, and googling doesn&#39;t find the answers either.\r\n",
        "link": "https://stackoverflow.com/questions/34477547/how-to-combine-the-sequence-of-objects-in-jq-into-one-object",
        "title": "How to combine the sequence of objects in jq into one object?"
    },
    {
        "tags": [
            "bash",
            "shell",
            "for-loop",
            "nested",
            "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": 1451436347,
                "post_id": 34509937,
                "comment_id": 56784282,
                "content_license": "CC BY-SA 3.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": 1451436491,
                "post_id": 34509937,
                "comment_id": 56784319,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7515740,
                    "reputation": 913,
                    "user_id": 5709240,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://i.sstatic.net/WbFKm.gif?s=256",
                    "display_name": "crocefisso",
                    "link": "https://stackoverflow.com/users/5709240/crocefisso"
                },
                "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": 1451496497,
                "post_id": 34509937,
                "comment_id": 56809968,
                "content_license": "CC BY-SA 3.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": 1451502728,
                "post_id": 34509937,
                "comment_id": 56813037,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7515740,
                    "reputation": 913,
                    "user_id": 5709240,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://i.sstatic.net/WbFKm.gif?s=256",
                    "display_name": "crocefisso",
                    "link": "https://stackoverflow.com/users/5709240/crocefisso"
                },
                "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": 1451504374,
                "post_id": 34509937,
                "comment_id": 56813864,
                "content_license": "CC BY-SA 3.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": 1451507937,
                "post_id": 34509937,
                "comment_id": 56815648,
                "content_license": "CC BY-SA 3.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": 1451508004,
                "post_id": 34509937,
                "comment_id": 56815683,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 13795134,
                    "reputation": 3684,
                    "user_id": 10440128,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xbqD0.jpg?s=256",
                    "display_name": "milahu",
                    "link": "https://stackoverflow.com/users/10440128/milahu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1707333877,
                "post_id": 34509937,
                "comment_id": 137434439,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1451388543,
                "creation_date": 1451388543,
                "answer_id": 34510057,
                "question_id": 34509937,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You should respect the bash syntax in your `for`s: \r\n\r\n`for (( i=0; i&lt;5; i++ ))`\r\n\r\n`((i=1,i&lt; =52,j++))` won&#39;t work, use `;` instead of `,`.\r\n",
                "title": "How can I do jq nested for-loops from bash?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1451431796,
                "creation_date": 1451431796,
                "answer_id": 34520751,
                "question_id": 34509937,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1) You wrote that your i-loop used ((i=1;i&lt; =52;j++)); that should be `((i-1; i&lt;=52; i++))`\r\n\r\n2) We can&#39;t see exactly what you did with respect to r1 and r$i, so if (1) doesn&#39;t resolve your difficulty, maybe you should double-check that what you did is actually what is needed.  Should you change &quot;&gt; $outputname&quot; to &quot;&gt;&gt; $outputname&quot;?\r\n \r\n3) I suspect that rather than using `s/&quot;//g`, it might be better to use the -r option of jq; you might also consider avoiding sed altogether (jq 1.5 has sub and gsub functions).\r\n\r\n4) As I said, it would be better to get rid of all the backticks.",
                "title": "How can I do jq nested for-loops from bash?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1451496322,
                "creation_date": 1451496322,
                "answer_id": 34534161,
                "question_id": 34509937,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Finally I found the solution, and my issue didn&#39;t come from jq but from the syntax I was using for nested loops... Here it is :\r\n\r\n    for ((i=1;i&lt;=kdr;i++))\r\n    do\r\n       for ((j=0;j&lt;=24;j++))\r\n       do\r\n    \tdatein=$(jq &lt;&quot;r$i.json&quot; &quot;.results[$j].date&quot; | sed &#39;s/&quot;//g&#39;)\r\n    \tdateout=$(date -d &quot;${datein}&quot; +&quot;%Y%m%d%H%M%S&quot;)\r\n    \tcompany=$(jq &lt;&quot;r$i.json&quot; &quot;.results[$j].company&quot; | sed &#39;s/,//g;s/&quot;//g;s/ //g&#39;)\r\n    \tjob=$(jq &lt;&quot;r$i.json&quot; &quot;.results[$j].jobtitle&quot; | sed &#39;s/,//g;s/&quot;//g;s/ //g&#39;)\r\n    \tjq &lt;&quot;r$i.json&quot; &quot;.results[$j]&quot; &gt; ${dateout}_${company}_${job}.json\r\n       done\r\n    done",
                "title": "How can I do jq nested for-loops from bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1451496322,
        "creation_date": 1451388110,
        "last_edit_date": 1451436130,
        "question_id": 34509937,
        "body_markdown": "I have 52 json files (r$i.json) containing each 25 results (0 to 24). I&#39;d like to create a json file with a special name for each of these results. The name would be composed according to the content of each of these results : YYYYMMDDHHMMSS_company_jobtitle.json\r\n\r\n\r\nthe command generating names work fine : \r\n\r\n    #!bin/bash\r\n    for ((j=0;j&lt;=24;j++))\r\n    do\r\n       datein=$(jq &lt;&quot;r1.json&quot; &quot;.results[$j].date&quot; | sed &#39;s/&quot;//g&#39;)\r\n       dateout=$(date -d &quot;${datein}&quot; +&quot;%Y%m%d%H%M%S&quot;)\r\n       company=$(jq &lt;&quot;r1.json&quot; &quot;.results[$j].company&quot; | sed &#39;s/,//g;s/&quot;//g;s/ //g&#39;)\r\n       job=$(jq &lt;&quot;r1.json&quot; &quot;.results[$j].jobtitle&quot; | sed &#39;s/,//g;s/&quot;//g;s/ //g&#39;)\r\n       jq &lt;&quot;r1.json&quot; &quot;.results[$j]&quot; &gt; ${dateout}_${company}_${job}.json\r\n    done\r\n\r\nNow when I replace r1 by r$i and add ((i=1;i&lt;=52;j++)) it doesn&#39;t work... So I guess my problem comes from nested loop syntax in jq...\r\n\r\nr1.json would look like that : \r\n\r\n     {\r\n    \r\n        &quot;radius&quot; : 25,\r\n        &quot;totalResults&quot; : 1329,\r\n    \r\n        &quot;results&quot; : [\r\n            \r\n                    {\r\n                        &quot;jobtitle&quot; : &quot;job1&quot;,\r\n                        &quot;company&quot; : &quot;company1,\r\n                        &quot;date&quot; : &quot;Sun, 01 Sep 2015 07:59:58 GMT&quot;,\r\n    }\r\n    ,\r\n                    {\r\n                        &quot;jobtitle&quot; : &quot;job2&quot;,\r\n                        &quot;company&quot; : &quot;company2&quot;,\r\n                        &quot;date&quot; : &quot;Sun, 02 Sep 2015 07:59:58 GMT&quot;,\r\n    }\r\n    ,\r\n    \t\t\t|...]\r\n                    {\r\n                        &quot;jobtitle&quot; : &quot;job25&quot;,\r\n                        &quot;company&quot; : &quot;company25,\r\n                        &quot;date&quot; : &quot;Sun, 25 Sep 2015 07:59:58 GMT&quot;,\r\n    }\r\n    \r\n        ]\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/34509937/how-can-i-do-jq-nested-for-loops-from-bash",
        "title": "How can I do jq nested for-loops from bash?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1451391329,
                "creation_date": 1451391329,
                "answer_id": 34510878,
                "question_id": 34510742,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "  \r\n\r\n      var data=[\r\n        {&quot;data&quot;:&quot;a&quot;},\r\n        {&quot;data&quot;:&quot;b&quot;},\r\n        {&quot;data&quot;:&quot;c&quot;}\r\n        ];\r\n        var cnt=0;\r\n        data.map(function(data){\r\n           data.id=&quot;xx_&quot;+cnt;\r\n           cnt++;\r\n        })\r\n    \r\n    console.log(data);",
                "title": "How do I create an incremental index with jq"
            },
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1486962282,
                "last_edit_date": 1486962282,
                "creation_date": 1451401795,
                "answer_id": 34513774,
                "question_id": 34510742,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s one way:\r\n\r\n    to_entries | map( (.value.id = &quot;xx_\\(1+.key)&quot; ) | .value)\r\n\r\nHere&#39;s another method, which however requires jq 1.5:\r\n\r\n    def add_id(prefix):\r\n      [ foreach .[] as $o (0;\r\n          . + 1;\r\n          $o + {&quot;id&quot;: (prefix + tostring) }) ];\r\n\r\n    add_id(&quot;xx_&quot;)\r\n\r\nExample:\r\n\r\n    $ jq -c -f add_id.jq\r\n    [ {&quot;data&quot;:&quot;a&quot;}, {&quot;data&quot;:&quot;b&quot;}, {&quot;data&quot;:&quot;c&quot;} ]\r\n\r\nOutput:\r\n\r\n    [{&quot;data&quot;:&quot;a&quot;,&quot;id&quot;:&quot;xx_1&quot;},{&quot;data&quot;:&quot;b&quot;,&quot;id&quot;:&quot;xx_2&quot;},{&quot;data&quot;:&quot;c&quot;,&quot;id&quot;:&quot;xx_3&quot;}]\r\n\r\nA third approach would be to use `transpose`:\r\n\r\n    def add_id(prefix):\r\n      [ .,  [ range(0;length) | {&quot;id&quot;: (prefix + tostring) } ] ]\r\n      | transpose | map(add);\r\n\r\n(If your jq does not have transpose/0, it&#39;s jq definition can readily be found, e.g. by googling.)\r\n\r\n\r\n\r\n",
                "title": "How do I create an incremental index with jq"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1501959769,
                "creation_date": 1501959769,
                "answer_id": 45525443,
                "question_id": 34510742,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here are two solutions.  One using **foreach** which holds a counter in the foreach state while iterating over the input array collecting values back into a result array.  This is similar to [peak](https://stackoverflow.com/users/997358/peak)&#39;s **add_id** function.\r\n\r\n    [\r\n      foreach .[] as $e (\r\n         0\r\n       ; .+1\r\n       ; $e + {&quot;id&quot;:&quot;xx_\\(.)&quot;}\r\n      )\r\n    ]\r\n\r\nand one using **reduce** which holds the input array in the reduce state while iterating over the array indices, updating each element.\r\n\r\n    reduce range(0,length) as $i (\r\n         .\r\n       ; .[$i].id = &quot;xx_\\($i+1)&quot;\r\n    )\r\n\r\nI think the **reduce** is the simpler one for this case.",
                "title": "How do I create an incremental index with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1678122126,
                "creation_date": 1678122126,
                "answer_id": 75653725,
                "question_id": 34510742,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`enumerate/1` as defined below is a useful, generic library function that can be used for problems such as this. It&#39;s stream-oriented, which also makes it worthwhile knowing about. \r\n\r\nTo be consistent with jq&#39;s &quot;index origin&quot;, it starts counting from 0, and hence the `first + 1` to satisfy the requirements of this particular problem:\r\n\r\n```\r\n  def enumerate(s): foreach s as $x (-1; .+1; [., $x]);\r\n  [enumerate(.[]) | last + {id: &quot;xx_\\(first + 1)&quot;}]\r\n```",
                "title": "How do I create an incremental index with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 8,
        "last_activity_date": 1678122126,
        "creation_date": 1451390877,
        "last_edit_date": 1627966046,
        "question_id": 34510742,
        "body_markdown": "I have a json like that :\r\n\r\n    [\r\n        {&quot;data&quot;:&quot;a&quot;},\r\n        {&quot;data&quot;:&quot;b&quot;},\r\n        {&quot;data&quot;:&quot;c&quot;}\r\n    ]\r\n\r\nusing jq I want to add an incremental id field like that:\r\n\r\n    [\r\n        {&quot;data&quot;:&quot;a&quot;,&quot;id&quot;:&quot;xx_1&quot;},\r\n        {&quot;data&quot;:&quot;b&quot;,&quot;id&quot;:&quot;xx_2&quot;},\r\n        {&quot;data&quot;:&quot;c&quot;,&quot;id&quot;:&quot;xx_3&quot;}\r\n    ]\r\nI can&#39;t seem to get the right jq command for that, anyone?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/34510742/how-do-i-create-an-incremental-index-with-jq",
        "title": "How do I create an incremental index with jq"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1451409439,
                "creation_date": 1451409439,
                "answer_id": 34515763,
                "question_id": 34515382,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The problem was that for some of the products, there was no `instanceType` attribute.  I&#39;m not sure what version of jq you were using but 1.5 gives the following error:\r\n\r\n    $ jq --arg type &quot;$type&quot; &#39;.products[] | select(.attributes.instanceType | endswith($type)).sku&#39; input.json\r\n    jq: error (at input.json:1128400): endswith() requires string inputs\r\n\r\nThat indicates that the value being compared wasn&#39;t a string.  `$type` is so the only thing left was the `instanceType` I don&#39;t know if there&#39;s an easy way to debug this sort of problem but I would usually start off by breaking the filter up each step of the way and inspect the result (and work on a local copy of the input).  Start with `.products[].attributes`, then `.products[].attributes.instanceType` and see if it looks like what I would expect.\r\n\r\nTo fix your particular problem, you just need to provide a string value for when there is no `instanceType`.\r\n\r\n    .products[] | select(.attributes.instanceType // &quot;&quot; | endswith($type)).sku",
                "title": "How to debug jq errors for parsing AWS price API"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1728760492,
                "last_edit_date": 1728760492,
                "creation_date": 1451410123,
                "answer_id": 34515933,
                "question_id": 34515382,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks like an assumption your program is making about the input is invalid.\r\n\r\nMy guess is that you&#39;re using an older version of jq (perhaps jq 1.4), and that the assertion violation is being\r\ntriggered by one case in which .attributes.instanceType is not a string (most likely, a null).\r\n\r\nSo I&#39;d suggest starting off by modifying your program to handle the case that .attributes.instanceType is not a string.\r\n\r\nFor example:\r\n\r\n    select( .attributes.instanceType | (type == &quot;string&quot; and endswith($type)) )\r\n\r\nThere is a convenient filter named `debug` for debugging, but in this case, it might be more trouble than it&#39;s worth.\r\n",
                "title": "How to debug jq errors for parsing AWS price API"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1728760492,
        "creation_date": 1451407809,
        "last_edit_date": 1451408488,
        "question_id": 34515382,
        "body_markdown": "I&#39;m trying to parse out some of the AWS price API json results and noticed that I&#39;m getting some errors on string and object validation, but can&#39;t figure out how to debug which object or string `jq` is choking on.\r\n\r\nCould someone help point me in the right direction? I&#39;ve tried changing `endswith` to `startswith` as well as contains, but all exhibit different errors, so I haven&#39;t been able to narrow the object in error (probably doesn&#39;t help the json response is 1.1M+ lines...)\r\n\r\nInterestingly enough, using `endswith($type)` gets me the sku i&#39;m looking for, but also returns `jq: jv.c:721: jv_string_value: Assertion &#39;jv_get_kind(j) == JV_KIND_STRING&#39; failed.`\r\n\r\nI tried looking at line 721 in *jv.c*, but I don&#39;t really know C, so I&#39;m kinda stuck.\r\n\r\nThanks in advance.\r\n\r\nSCRIPT:\r\n\r\n    #!/bin/bash\r\n    type=&quot;hs1.8xlarge&quot;\r\n    curl -s -L -k https://pricing.us-east-1.amazonaws.com/offers/v1.0/aws/AmazonEC2/current/index.json | jq --arg type &quot;$type&quot; &#39;.products[] | select(.attributes.instanceType | endswith($type)).sku&#39;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/34515382/how-to-debug-jq-errors-for-parsing-aws-price-api",
        "title": "How to debug jq errors for parsing AWS price API"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2251762,
                    "reputation": 292345,
                    "user_id": 1983854,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/KiqLo.png?s=256",
                    "display_name": "fedorqui",
                    "link": "https://stackoverflow.com/users/1983854/fedorqui"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1451477368,
                "post_id": 34529156,
                "comment_id": 56799581,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 17,
                "is_accepted": true,
                "score": 17,
                "last_activity_date": 1471184638,
                "last_edit_date": 1471184638,
                "creation_date": 1451477287,
                "answer_id": 34529271,
                "question_id": 34529156,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The problem with your code is that an array initialization in bash looks like this:\r\n\r\n    declare -a arr=(item1 item2 item3)\r\n\r\nItems are separated by space or newline. You can also use:\r\n\r\n    declare -a arr(\r\n        item1\r\n        item2\r\n        item3\r\n    )\r\n\r\nHowever, the `jq` output in the example contains both spaces and newlines, that&#39;s why the reported behaviour is as expected.\r\n\r\n---\r\n\r\nWorkaround:\r\n\r\nI would get the keys first, pipe them to a read loop and then call `jq` for each item of the list:\r\n\r\n&lt;!-- language: bash --&gt;\r\n\r\n    jq -r &#39;.images|keys[]&#39; Contents.json | while read key ; do\r\n        echo &quot;image --$(jq &quot;.images[$key]&quot; Contents.json)&quot;\r\n    done\r\n\r\nYou can also use this `jq` command if you don&#39;t care about pretty printing:\r\n\r\n    jq -r &#39;.images[]|&quot;image --&quot; + tostring&#39; Contents.json\r\n\r\n---\r\n\r\nTo access a certain property of the subarray you can use:\r\n\r\n    jq -r &#39;.images|keys[]&#39; Contents.json | while read key ; do\r\n        echo &quot;image --$(jq &quot;.images[$key].filename&quot; Contents.json)&quot;\r\n    done\r\n\r\nThe above node will print the filename property for each node for example.\r\n\r\nHowever this can be expressed much simpler using `jq` only:\r\n\r\n    jq -r &#39;.images[]|&quot;image --&quot; + .filename&#39; Contents.json\r\n\r\nOr even simpler:\r\n\r\n    jq &#39;&quot;image --\\(.images[].filename)&quot;&#39; Contents.json",
                "title": "Iterate through dictionaries jq - shell"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 8,
        "last_activity_date": 1505222118,
        "creation_date": 1451476759,
        "question_id": 34529156,
        "body_markdown": "I have a JSON like this\r\n\r\n    {\r\n      &quot;images&quot; : [\r\n        {\r\n          &quot;size&quot; : &quot;29x29&quot;,\r\n          &quot;idiom&quot; : &quot;iphone&quot;,\r\n          &quot;filename&quot; : &quot;Icon-Small@2x.png&quot;,\r\n          &quot;scale&quot; : &quot;2x&quot;\r\n        }\r\n         ......\r\n         ......\r\n        {\r\n          &quot;size&quot; : &quot;60x60&quot;,\r\n          &quot;idiom&quot; : &quot;iphone&quot;,\r\n          &quot;filename&quot; : &quot;Icon-60@3x.png&quot;,\r\n          &quot;scale&quot; : &quot;3x&quot;\r\n        }\r\n      ],\r\n      &quot;info&quot; : {\r\n        &quot;version&quot; : 1,\r\n        &quot;author&quot; : &quot;xcode&quot;\r\n      }\r\n    }\r\n\r\nI want to iterate through each dictionary in `images` array.\r\nFor that I wrote\r\n\r\n    declare -a images=($(cat Contents.json | jq &quot;.images[]&quot;))\r\n    for image in &quot;${images[@]}&quot;\r\n    do\r\n        echo &quot;image --$image&quot;\r\n    done\r\nI am expecting output that each dictionary is printing in an iteration. That is\r\n\r\n    image --{\r\n      &quot;size&quot; : &quot;29x29&quot;,\r\n      &quot;idiom&quot; : &quot;iphone&quot;,\r\n      &quot;filename&quot; : &quot;Icon-Small@2x.png&quot;,\r\n      &quot;scale&quot; : &quot;2x&quot;\r\n    }\r\n    image --{\r\n      &quot;size&quot; : &quot;29x29&quot;,\r\n      &quot;idiom&quot; : &quot;iphone&quot;,\r\n      &quot;filename&quot; : &quot;Icon-Small@3x.png&quot;,\r\n      &quot;scale&quot; : &quot;3x&quot;\r\n    }\r\n    image --{\r\n      &quot;size&quot; : &quot;40x40&quot;,\r\n      &quot;idiom&quot; : &quot;iphone&quot;,\r\n      &quot;filename&quot; : &quot;Icon-Spotlight-40@2x.png&quot;,\r\n      &quot;scale&quot; : &quot;2x&quot;\r\n    }\r\n\r\nEtc\r\n\r\nBut its iterating through each and every single elements in each dictionary like\r\n\r\n    image --{\r\n    image --&quot;size&quot;:\r\n    image --&quot;29x29&quot;,\r\n    image --&quot;idiom&quot;:\r\n    image --&quot;iphone&quot;,\r\n    image --&quot;filename&quot;:\r\n    ....\r\n    ....\r\n    ....\r\n\r\nWhat is wrong with  my code",
        "link": "https://stackoverflow.com/questions/34529156/iterate-through-dictionaries-jq-shell",
        "title": "Iterate through dictionaries jq - shell"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1451533803,
                "creation_date": 1451533803,
                "answer_id": 34540745,
                "question_id": 34538789,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you have jq 1.5, the answer is: *yes*, though in general, preprocessing (e.g. using hjson or any-json) would be preferable.\r\n\r\nAnyway, the idea is simply to take advantage of the try/catch feature. Here is an illustration using the `inputs` filter.  Note that jq should in general be invoked with the -n option for this to work.\r\n\r\n## recover.jq\r\n    def handle: inputs | [., &quot;length is \\(length)&quot;] ;\r\n    def process: try handle catch (&quot;Failed&quot;, process) ;\r\n    process\r\n\r\n## bad.json\r\n\r\n    [1,2,3]\r\n    {id=546456, userId=345345}\r\n    [4,5,6]\r\n\r\n## See jq run:\r\n    $ jq -n -f recover.jq bad.json\r\n    [\r\n      &quot;[1,2,3]&quot;,\r\n      &quot;length is 3&quot;\r\n    ]\r\n    &quot;Failed&quot;\r\n    [\r\n      &quot;[4,5,6]&quot;,\r\n      &quot;length is 3&quot;\r\n    ]",
                "title": "Is there a way to have jq keep going after it hits an error?"
            },
            {
                "up_vote_count": 23,
                "is_accepted": false,
                "score": 23,
                "last_activity_date": 1645291513,
                "last_edit_date": 1645291513,
                "creation_date": 1517356990,
                "answer_id": 48532434,
                "question_id": 34538789,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With jq-1.5 I was able to do the following:\r\n\r\nWith this example file:\r\n```sh\r\ncat &lt;&lt; EOF &gt; example.log\r\n{&quot;a&quot;: 1}\r\n{invalid\r\n{&quot;b&quot;: 2}\r\nEOF\r\n```\r\n\r\nOutput non-json lines as unquoted strings:\r\n```sh\r\ncat example.log | jq --raw-input --raw-output &#39;. as $raw | try fromjson catch $raw&#39;\r\n\r\n{\r\n  &quot;a&quot;: 1\r\n}\r\n{invalid\r\n{\r\n  &quot;b&quot;: 2\r\n}\r\n```\r\n\r\nSilently skip non-json lines:\r\n```sh\r\ncat example.log | jq --raw-input &#39;fromjson?&#39;\r\n\r\n{\r\n  &quot;a&quot;: 1\r\n}\r\n{\r\n  &quot;b&quot;: 2\r\n}\r\n```\r\n\r\nYou can add `--slurp` if the entire input is expected to be a single multiline json blob.\r\n\r\nExample files:\r\n```sh\r\ncat &lt;&lt; EOF &gt; valid-multiline.log\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: 2\r\n}\r\nEOF\r\n\r\ncat &lt;&lt; EOF &gt; invalid-multiline.log\r\n{\r\n  asdf\r\n  &quot;b&quot;: 2\r\n}\r\nEOF\r\n```\r\n\r\nOutputs\r\n```sh\r\ncat valid-multiline.log | jq --slurp --raw-input --raw-output &#39;. as $raw | try fromjson catch $raw&#39;\r\n\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: 2\r\n}\r\n\r\ncat invalid-multiline.log | jq --slurp --raw-input --raw-output &#39;. as $raw | try fromjson catch $raw&#39;\r\n\r\n{\r\n  asdf\r\n  &quot;b&quot;: 2\r\n}\r\n```\r\n",
                "title": "Is there a way to have jq keep going after it hits an error?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 21,
        "last_activity_date": 1645291513,
        "creation_date": 1451517711,
        "question_id": 34538789,
        "body_markdown": "I am using jq to parse log data, occasionally the logs contain malformed stuff (invalid json), when this happens, jq aborts processing at that point.\r\n\r\nIs there a way to have jq keep processing what it can, while reporting the problems via stderr?\r\n\r\nI understand that if you have newlines in your JSON, jq may have trouble if it starts with the next line, but in such cases you will still eventually get to the point that you find the start of a legitimate json message and can continue processing.",
        "link": "https://stackoverflow.com/questions/34538789/is-there-a-way-to-have-jq-keep-going-after-it-hits-an-error",
        "title": "Is there a way to have jq keep going after it hits an error?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1266228,
                    "reputation": 2548,
                    "user_id": 1223483,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/4cb1e1632c20f23544b93183b08d9b0f?s=256&d=identicon&r=PG",
                    "display_name": "Onkeltem",
                    "link": "https://stackoverflow.com/users/1223483/onkeltem"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1639053207,
                "post_id": 34543829,
                "comment_id": 124253002,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1266228,
                    "reputation": 2548,
                    "user_id": 1223483,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/4cb1e1632c20f23544b93183b08d9b0f?s=256&d=identicon&r=PG",
                    "display_name": "Onkeltem",
                    "link": "https://stackoverflow.com/users/1223483/onkeltem"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639053745,
                "post_id": 34543829,
                "comment_id": 124253221,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 431524,
                    "reputation": 10647,
                    "user_id": 815646,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/8eb28269b47eff336a5632e610c21da3?s=256&d=identicon&r=PG",
                    "display_name": "Xu Wang",
                    "link": "https://stackoverflow.com/users/815646/xu-wang"
                },
                "reply_to_user": {
                    "account_id": 1266228,
                    "reputation": 2548,
                    "user_id": 1223483,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/4cb1e1632c20f23544b93183b08d9b0f?s=256&d=identicon&r=PG",
                    "display_name": "Onkeltem",
                    "link": "https://stackoverflow.com/users/1223483/onkeltem"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1652840537,
                "post_id": 34543829,
                "comment_id": 127701468,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 86093,
                    "reputation": 10147,
                    "user_id": 239657,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b53c0fe850111d3f1bbd41c24c7c62b3?s=256&d=identicon&r=PG",
                    "display_name": "Beni Cherniavsky-Paskin",
                    "link": "https://stackoverflow.com/users/239657/beni-cherniavsky-paskin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1690192477,
                "post_id": 34543829,
                "comment_id": 135314142,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 190,
                "is_accepted": true,
                "score": 189,
                "last_activity_date": 1451555539,
                "last_edit_date": 1451555539,
                "creation_date": 1451555137,
                "answer_id": 34544406,
                "question_id": 34543829,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It should be:\r\n\r\n    jq &#39;.[].aux[].def&#39; file.json\r\n\r\n`.[]` iterates over the outer array, `.aux[]` then iterates over the the `aux` array of every node and `.def` prints their `.def` property.\r\n\r\nThis will output:\r\n\r\n    &quot;I want this&quot;\r\n\r\nIf you want to get rid of the double quotes pass `-r` (`--raw`) to `jq`:\r\n\r\n    jq -r &#39;.[].aux[].def&#39; file.json\r\n\r\nOutput:\r\n\r\n    I want this",
                "title": "jq: Cannot index array with string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 115,
        "last_activity_date": 1652840423,
        "creation_date": 1451552544,
        "last_edit_date": 1652840423,
        "question_id": 34543829,
        "body_markdown": "I have the following in a file (which I will call &quot;myfile&quot;):\r\n\r\n    [{\r\n    \t&quot;id&quot;: 123,\r\n    \t&quot;name&quot;: &quot;John&quot;,\r\n    \t&quot;aux&quot;: [{\r\n    \t\t&quot;abc&quot;: &quot;random&quot;,\r\n    \t\t&quot;def&quot;: &quot;I want this&quot;\r\n    \t}],\r\n    \t&quot;blah&quot;: 23.11\r\n    }]\r\n\r\nI could parse it if the file did not have the first `[` and last `]` as follows:\r\n\r\n    $ cat myfile | jq -r &#39;.aux[] | .def&#39;\r\n    I want this\r\n    $\r\n\r\nbut with the `[` and `]` I get:\r\n\r\n    $ cat myfile | jq -r &#39;.aux[] | .def&#39;\r\n    jq: error: Cannot index array with string\r\n\r\nHow can I deal with the `[` and `]` using jq? (I&#39;m sure I could parse them off with a different tool but I want to learn correct usage of jq.",
        "link": "https://stackoverflow.com/questions/34543829/jq-cannot-index-array-with-string",
        "title": "jq: Cannot index array with string"
    },
    {
        "tags": [
            "ascii",
            "data-conversion",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2330260,
                    "reputation": 1408,
                    "user_id": 2043876,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/49492119d7a66e43e549f0ff04d55598?s=256&d=identicon&r=PG",
                    "display_name": "Tony Ruth",
                    "link": "https://stackoverflow.com/users/2043876/tony-ruth"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1451694783,
                "post_id": 34561434,
                "comment_id": 56866597,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1451696684,
                "creation_date": 1451696684,
                "answer_id": 34561600,
                "question_id": 34561434,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    $ jq -n &#39;[107] | implode&#39;\r\n    &quot;k&quot;\r\n\r\n`implode` will work for both ASCII and non-ASCII decimal codes.  As illustrated here, it converts an array of admissible decimals to a UTF-8 string equivalent.\r\n\r\nHere&#39;s an example showing conversion:\r\n\r\n    $ jq -n -c &#39;{&quot;a&quot;: [107, 108]} | .a |= implode&#39;\r\n    {&quot;a&quot;:&quot;kl&quot;}",
                "title": "ascii decimal to character using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1451696684,
        "creation_date": 1451694140,
        "question_id": 34561434,
        "body_markdown": "What&#39;s the best way to read and convert a JSON field&#39;s decimal value to an ASCII character?  For instance, converting 107 to &#39;k&#39;.  The manual doesn&#39;t appear to mention a direct way to do so.",
        "link": "https://stackoverflow.com/questions/34561434/ascii-decimal-to-character-using-jq",
        "title": "ascii decimal to character using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "parameter-passing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5198585,
                    "reputation": 1034,
                    "user_id": 4158877,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/03ca06f731cce98372885f1944c50267?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rambo Ramon",
                    "link": "https://stackoverflow.com/users/4158877/rambo-ramon"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1452610001,
                "post_id": 34745451,
                "comment_id": 57238961,
                "content_license": "CC BY-SA 3.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": 5198585,
                    "reputation": 1034,
                    "user_id": 4158877,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/03ca06f731cce98372885f1944c50267?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rambo Ramon",
                    "link": "https://stackoverflow.com/users/4158877/rambo-ramon"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1452620721,
                "post_id": 34745451,
                "comment_id": 57246624,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 110,
                "is_accepted": true,
                "score": 110,
                "last_activity_date": 1452612173,
                "creation_date": 1452612173,
                "answer_id": 34747439,
                "question_id": 34745451,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The jq program `.dev.projects.&quot;$v&quot;` in your example will literally try to find a key named `&quot;$v&quot;`. Try the following instead:\r\n\r\n    jq --arg v &quot;$PRJNAME&quot; &#39;.dev.projects[$v]&#39; config.json \r\n",
                "title": "passing arguments to jq filter"
            },
            {
                "up_vote_count": 43,
                "is_accepted": false,
                "score": 43,
                "last_activity_date": 1597095028,
                "last_edit_date": 1597095028,
                "creation_date": 1488537859,
                "answer_id": 42576771,
                "question_id": 34745451,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `--argjson` too when you make your json.\r\n\r\n    --arg a v   \t# set variable $a to value &lt;v&gt;;\r\n\t--argjson a v\t# set variable $a to JSON value &lt;v&gt;;\r\n\r\n",
                "title": "passing arguments to jq filter"
            },
            {
                "up_vote_count": 26,
                "is_accepted": false,
                "score": 26,
                "last_activity_date": 1520850469,
                "creation_date": 1520850469,
                "answer_id": 49232956,
                "question_id": 34745451,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As asked in a comment above there&#39;s a way to pass multiple argumets.\r\nMaybe there&#39;s a more elegant way, but it works.\r\n\r\n- If you are sure always all keys needed you can use this:\r\n\r\n&lt;!-- language: lang-bsh --&gt;\r\n\r\n    jq --arg key1 $k1 --arg key2 $k2 --arg key3 $k3 --arg key4 $k4 &#39;.[$key1] | .[$key2] | .[$key3] | .[$key4] &#39;\r\n\r\n\r\n----------\r\n\r\n\r\n- If the key isn&#39;t always used you could do it like this:\r\n\r\n&lt;!-- language: lang-bsh --&gt;\r\n\r\n    jq --arg key $k &#39; if key != &quot;&quot; then .[$key] else . end&#39;\r\n\r\n\r\n----------\r\n\r\n\r\n- If key sometimes refers to an array:\r\n\r\n\r\n&lt;!-- language: lang-bsh --&gt;\r\n\r\n    jq --arg key $k &#39; if type == &quot;array&quot; then .[$key |tonumber] else .[$key] end&#39;\r\n\r\nof course you can combine these!",
                "title": "passing arguments to jq filter"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1597238975,
                "creation_date": 1597238975,
                "answer_id": 63377599,
                "question_id": 34745451,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "you can do this:\r\n```shell\r\n\r\n    key=&quot;dev.projects.prj1&quot;\r\n    filter=&quot;.$key&quot;\r\n    cat config.json | jq $filter\r\n\r\n```",
                "title": "passing arguments to jq filter"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1671450351,
                "creation_date": 1671450351,
                "answer_id": 74850070,
                "question_id": 34745451,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "My example bash command to replace an array in a json file. \r\nEverything is in variables:\r\n\r\n    a=/opt/terminal/conf/config.json ; \\\r\n    b=&#39;[&quot;alchohol&quot;]&#39; ; \\\r\n    c=terminal.canceledInspections.resultSendReasons ; \\\r\n    cat $a | jq .$c ; \\\r\n    cat $a | jq --argjson b $b --arg c $c &#39;getpath($c / &quot;.&quot;) = $b&#39; | sponge $a ; \\\r\n    cat $a | jq .$c",
                "title": "passing arguments to jq filter"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 72,
        "last_activity_date": 1683955169,
        "creation_date": 1452606575,
        "last_edit_date": 1452620452,
        "question_id": 34745451,
        "body_markdown": "Here is my config.json:\r\n\r\n    {\r\n        &quot;env&quot;: &quot;dev&quot;,\r\n        &quot;dev&quot;: {\r\n            &quot;projects&quot; : {\r\n                &quot;prj1&quot;: {\r\n                    &quot;dependencies&quot;: {},\r\n                    &quot;description&quot;: &quot;&quot;\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\nHere are my bash commands:\r\n\r\n    PRJNAME=&#39;prj1&#39;\r\n    \r\n    echo $PRJNAME\r\n    \r\n    jq --arg v &quot;$PRJNAME&quot; &#39;.dev.projects.&quot;$v&quot;&#39; config.json \r\n    jq &#39;.dev.projects.prj1&#39; config.json \r\n   \r\n\r\n\r\nThe output:\r\n\r\n\r\n    prj1\r\n    null\r\n    {\r\n      &quot;dependencies&quot;: {},\r\n      &quot;description&quot;: &quot;&quot;\r\n    }\r\n\r\n\r\nSo $PRJNAME is prj1, but the first invocation only outputs `null`.\r\n\r\nCan someone help me?",
        "link": "https://stackoverflow.com/questions/34745451/passing-arguments-to-jq-filter",
        "title": "passing arguments to jq filter"
    },
    {
        "tags": [
            "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": 0,
                "creation_date": 1452725071,
                "post_id": 34778425,
                "comment_id": 57301969,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2289764,
                    "reputation": 2542,
                    "user_id": 2012920,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/84a611000e819ef825421de06c9bca90?s=256&d=identicon&r=PG",
                    "display_name": "memeplex",
                    "link": "https://stackoverflow.com/users/2012920/memeplex"
                },
                "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": 1452727174,
                "post_id": 34778425,
                "comment_id": 57302821,
                "content_license": "CC BY-SA 3.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": 1452729200,
                "post_id": 34778425,
                "comment_id": 57303596,
                "content_license": "CC BY-SA 3.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"
                },
                "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": 1452731778,
                "post_id": 34778425,
                "comment_id": 57304389,
                "content_license": "CC BY-SA 3.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": 1452731902,
                "post_id": 34778425,
                "comment_id": 57304417,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1666439755,
                "last_edit_date": 1666439755,
                "creation_date": 1452742465,
                "answer_id": 34781265,
                "question_id": 34778425,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The answer to the question is essentially &quot;yes&quot;: commands such as &quot;jq --slurp . FILE ....&quot; store the parsed input as an array in memory.   This will often require more memory than the size of the input itself -- consider for example that JSON objects are stored as hash tables.\r\n\r\nWith jq 1.5 there are often better alternatives than &quot;slurping&quot; the input. Most notably, perhaps, the `inputs` filter works very nicely with `reduce` and `foreach`.  (If you do use `inputs` then don&#39;t forget you will probably want to invoke jq with the &quot;-n&quot; option.)\r\n",
                "title": "Memory usage of jq&#39;s --slurp option"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1666439755,
        "creation_date": 1452724754,
        "question_id": 34778425,
        "body_markdown": "Does the `--slurp` option load the entire input in memory before processing it or has it been optimized somehow in order to avoid that?",
        "link": "https://stackoverflow.com/questions/34778425/memory-usage-of-jqs-slurp-option",
        "title": "Memory usage of jq&#39;s --slurp option"
    },
    {
        "tags": [
            "windows",
            "batch-file",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1858106,
                    "reputation": 24496,
                    "user_id": 1683264,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/1775f6311d777e21ee2c59df9769e60b?s=256&d=identicon&r=PG",
                    "display_name": "rojo",
                    "link": "https://stackoverflow.com/users/1683264/rojo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1452778210,
                "post_id": 34789412,
                "comment_id": 57324844,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7635937,
                    "reputation": 1,
                    "user_id": 5789494,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a74d806b1b887ed581ec0f3257c289ac?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "tkzv",
                    "link": "https://stackoverflow.com/users/5789494/tkzv"
                },
                "reply_to_user": {
                    "account_id": 1858106,
                    "reputation": 24496,
                    "user_id": 1683264,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/1775f6311d777e21ee2c59df9769e60b?s=256&d=identicon&r=PG",
                    "display_name": "rojo",
                    "link": "https://stackoverflow.com/users/1683264/rojo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1452778340,
                "post_id": 34789412,
                "comment_id": 57324935,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1858106,
                    "reputation": 24496,
                    "user_id": 1683264,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/1775f6311d777e21ee2c59df9769e60b?s=256&d=identicon&r=PG",
                    "display_name": "rojo",
                    "link": "https://stackoverflow.com/users/1683264/rojo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1452779747,
                "post_id": 34789412,
                "comment_id": 57325929,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7635937,
                    "reputation": 1,
                    "user_id": 5789494,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a74d806b1b887ed581ec0f3257c289ac?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "tkzv",
                    "link": "https://stackoverflow.com/users/5789494/tkzv"
                },
                "reply_to_user": {
                    "account_id": 1858106,
                    "reputation": 24496,
                    "user_id": 1683264,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/1775f6311d777e21ee2c59df9769e60b?s=256&d=identicon&r=PG",
                    "display_name": "rojo",
                    "link": "https://stackoverflow.com/users/1683264/rojo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1452782062,
                "post_id": 34789412,
                "comment_id": 57327611,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1858106,
                    "reputation": 24496,
                    "user_id": 1683264,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/1775f6311d777e21ee2c59df9769e60b?s=256&d=identicon&r=PG",
                    "display_name": "rojo",
                    "link": "https://stackoverflow.com/users/1683264/rojo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1452782502,
                "post_id": 34789412,
                "comment_id": 57327948,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 408099,
                    "reputation": 67575,
                    "user_id": 778560,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/KycfY.png?s=256",
                    "display_name": "Aacini",
                    "link": "https://stackoverflow.com/users/778560/aacini"
                },
                "reply_to_user": {
                    "account_id": 1858106,
                    "reputation": 24496,
                    "user_id": 1683264,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/1775f6311d777e21ee2c59df9769e60b?s=256&d=identicon&r=PG",
                    "display_name": "rojo",
                    "link": "https://stackoverflow.com/users/1683264/rojo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1453101520,
                "post_id": 34789412,
                "comment_id": 57438200,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1452790574,
                "creation_date": 1452790574,
                "answer_id": 34795310,
                "question_id": 34789412,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Perhaps this may help you?\r\n\r\n    @echo off\r\n    \r\n    for /F &quot;tokens=2 delims=[]&quot; %%a in (input.txt) do (\r\n       for %%b in (%%a) do (\r\n          echo %%b\r\n       )\r\n    )\r\n\r\nOutput example:\r\n\r\n    C:\\&gt; type input.txt\r\n    {&quot;ids&quot;:[80001]}\r\n    \r\n    C:\\&gt; test.bat\r\n    80001\r\n    \r\n    C:\\&gt; type input.txt\r\n    {&quot;ids&quot;:[12001,12002,12003,43120]}\r\n    \r\n    C:\\&gt; test.bat\r\n    12001\r\n    12002\r\n    12003\r\n    43120\r\n\r\n",
                "title": "Batch file stops after a series of pipes in XP"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1452790723,
                "creation_date": 1452790723,
                "answer_id": 34795348,
                "question_id": 34789412,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this script and see if it does what you want.  Rather than depending on cURL to fetch the JSON, it uses an XMLHTTPRequest.  Rather than depending on jq to deserialize the JSON, it uses the JavaScript JSON parser.  And unlike Aacini&#39;s solution, it works the same regardless of whether the JSON is minified, beautified, whatever.  Save it with a .bat extension.\r\n\r\n&lt;!-- language-all: lang-js --&gt;\r\n\r\n\t@if (@CodeSection == @Batch) @then\r\n\t@echo off &amp; setlocal\r\n\r\n\tset &quot;server=http://login:password@host:port&quot;\r\n\tset &quot;db=PostgreSQL DB&quot;\r\n\r\n\t&gt;IDs.txt cscript /nologo /e:Jscript &quot;%~f0&quot; &quot;%server%&quot; &quot;%db%&quot;\r\n\r\n\tgoto :EOF\r\n\t@end // end Batch / begin JScript hybrid chimera\r\n\r\n\tvar XHR = WSH.CreateObject(&#39;Microsoft.XMLHTTP&#39;),\r\n\t\thtmlfile = WSH.CreateObject(&#39;htmlfile&#39;),\r\n\t\targs = { &#39;server&#39;: WSH.Arguments(0), &#39;db&#39;: WSH.Arguments(1) },\r\n\t\turl = encodeURI(args.server + &#39;/&#39; + args.db + &#39;/Section&#39;),\r\n\t\tsection = 0;\r\n\r\n\tfunction fetch(url) {\r\n\t\tXHR.open(&#39;GET&#39;, url, true);\r\n\t\tXHR.setRequestHeader(&#39;User-Agent&#39;, &#39;XMLHTTP/1.0&#39;);\r\n\t\tXHR.send(&#39;&#39;);\r\n\t\twhile (XHR.readyState != 4) { WSH.Sleep(50); }\r\n\t\treturn XHR.status == 200 ? XHR.responseText : &#39;&#39;;\r\n\t}\r\n\r\n\t// import JSON method from htmlfile COM object\r\n\thtmlfile.write(&#39;&lt;meta http-equiv=&quot;x-ua-compatible&quot; content=&quot;IE=9&quot; /&gt;&#39;);\r\n\tvar JSON = htmlfile.parentWindow.JSON;\r\n\r\n\t// fetch JSON by section sequentially until 404 error\r\n\twhile ((response = fetch(url + ++section))) {\r\n\t\tWSH.Echo(&#39;Section&#39; + section);\r\n\t\tids = JSON.parse(response).ids;\r\n\t\tfor (var i in ids) WSH.Echo(ids[i]);\r\n\t}",
                "title": "Batch file stops after a series of pipes in XP"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1452843529,
                "last_edit_date": 1452843529,
                "creation_date": 1452793851,
                "answer_id": 34796395,
                "question_id": 34789412,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Rather than trying to use two invocations of `jq`, just use one.  Also, it&#39;s generally best to quote your `jq` filters when they&#39;re given on the command line.\r\n\r\nYou&#39;re dumping the values in the `ids` property, so:\r\n\r\n    jq &quot;.ids[]&quot;\r\n\r\n[EDIT: using double-quotes works here for both Windows and many other platforms, but on non-Windows platforms, single-quotes are usually the best bet.]",
                "title": "Batch file stops after a series of pipes in XP"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1452843529,
        "creation_date": 1452773804,
        "last_edit_date": 1452784766,
        "question_id": 34789412,
        "body_markdown": "I have a following batch file that retrieves data from a database in JSON format, extracts numbers and stores them:\r\n\r\n    set server=http://login:password@host:port\r\n    set db=PostgreSQL%%20DB\r\n    \r\n    del IDs.txt\r\n    echo Section1 &gt;&gt; IDs.txt\r\n    curl &quot;%server%/%db%/Section1&quot; | jq .[] | jq .[] &gt;&gt; IDs.txt\r\n    echo Section2 &gt;&gt; IDs.txt\r\n    curl &quot;%server%/%db%/Section2&quot; | jq .[] | jq .[] &gt;&gt; IDs.txt\r\n    echo Section3 &gt;&gt; IDs.txt\r\n    curl &quot;%server%/%db%/Section3&quot; | jq .[] | jq .[] &gt;&gt; IDs.txt\r\n    ...\r\n\r\nIt works under Windows 8, but under Windows XP it stops after the first curl-jq line. There are no errors. Retrieving numbers works correctly, but only once. \r\n\r\nI tried to replace curl-jq calls with\r\n\r\n    cmd /c &quot;curl %server%/%db%/Section3 | jq .[] | jq .[] &gt;&gt; IDs.txt&quot;\r\n\r\nbut it didn&#39;t help.\r\n\r\nWhat is wrong? Is there a way to make this work in XP?\r\n\r\nThanks in advance.\r\n\r\nUpdate: here are examples of output JSON:\r\n\r\n    {&quot;ids&quot;:[80001]}\r\n\r\nor\r\n\r\n    {&quot;ids&quot;:[12001,12002,12003,43120]}\r\n\r\nWhat I need is just to extract the numbers as a column:\r\n\r\n    80001\r\n\r\nor\r\n\r\n    12001\r\n    12002\r\n    12003\r\n    43120\r\n\r\n",
        "link": "https://stackoverflow.com/questions/34789412/batch-file-stops-after-a-series-of-pipes-in-xp",
        "title": "Batch file stops after a series of pipes in XP"
    },
    {
        "tags": [
            "json",
            "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": 1452793914,
                "post_id": 34794007,
                "comment_id": 57335941,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1452800596,
                "post_id": 34794007,
                "comment_id": 57339715,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1503791005,
                "last_edit_date": 1503791005,
                "creation_date": 1452795175,
                "answer_id": 34796787,
                "question_id": 34794007,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Apart from not using jq at all, you have two main options:\r\n\r\n(1) pre-processing the non-JSON to make it JSON\r\n\r\n(2) using the -R command-line option, e.g.\r\n\r\n    echo &quot;X-RateLimit-Reset: 1452786798&quot; | jq -R &#39;split(&quot;:&quot;)&#39;\r\n\r\n    [\r\n      &quot;X-RateLimit-Reset&quot;,\r\n      &quot; 1452786798&quot;\r\n    ]\r\n\r\n\r\nThus, if you know the value is going to be numeric:\r\n\r\n    echo &quot;X-RateLimit-Reset: 1452786798&quot; |\r\n      jq -Rc &#39;split(&quot;:&quot;) | {(.[0]) : (.[1]|tonumber)}&#39;\r\n    {&quot;X-RateLimit-Reset&quot;:1452786798}\r\n\r\nNote that although the &quot;j&quot; in jq is for JSON, jq (with the -R option) does  just fine for text-processing. \r\n\r\n\r\n",
                "title": "parse error: Invalid numeric literal at line 1, column 9"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1503791005,
        "creation_date": 1452787055,
        "last_edit_date": 1455838329,
        "question_id": 34794007,
        "body_markdown": "I understand that jq search needs to be blocked by `{}` and the key needs to be encased with `&quot;`, for example:\r\n\r\n    {\r\n      &quot;id&quot;: 36815684\r\n    }\r\n\r\nBut if I have something like this:\r\n\r\n    X-RateLimit-Reset: 1452786798\r\n\r\nI get this error:\r\n\r\n&gt; parse error: Invalid numeric literal at line 1, column 9\r\n\r\nDo I need to fall back to `sed/awk/perl ..` or is there a more elegant way of using jq?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/34794007/parse-error-invalid-numeric-literal-at-line-1-column-9",
        "title": "parse error: Invalid numeric literal at line 1, column 9"
    },
    {
        "tags": [
            "jq",
            "ndjson"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1453005605,
                "post_id": 34834519,
                "comment_id": 57411556,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 393,
                "is_accepted": false,
                "score": 391,
                "last_activity_date": 1453005961,
                "creation_date": 1453005961,
                "answer_id": 34835208,
                "question_id": 34834519,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use `jq &#39;.[] | .login, .id&#39;` to obtain each login followed by its id.",
                "title": "How do I select multiple fields in jq?"
            },
            {
                "up_vote_count": 182,
                "is_accepted": false,
                "score": 182,
                "last_activity_date": 1498111957,
                "creation_date": 1498111957,
                "answer_id": 44691469,
                "question_id": 34834519,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This works for me:\r\n\r\n    &gt; echo &#39;{&quot;a&quot;:1,&quot;b&quot;:2,&quot;c&quot;:3}{&quot;a&quot;:1,&quot;b&quot;:2,&quot;c&quot;:3}&#39; | jq &#39;{a,b}&#39;\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: 2\r\n    }\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: 2\r\n    }",
                "title": "How do I select multiple fields in jq?"
            },
            {
                "up_vote_count": 27,
                "is_accepted": false,
                "score": 27,
                "last_activity_date": 1630566269,
                "last_edit_date": 1630566269,
                "creation_date": 1554289922,
                "answer_id": 55493777,
                "question_id": 34834519,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In order to select values which are indented to different levels (i.e. both first and second level), you might use the following:\r\n\r\n    echo &#39;[{&quot;a&quot;:{&quot;aa&quot;:1,&quot;ab&quot;:2},&quot;b&quot;:3,&quot;c&quot;:4},{&quot;a&quot;:{&quot;aa&quot;:5,&quot;ab&quot;:6},&quot;b&quot;:7,&quot;c&quot;:8}]&#39; \\\r\n\t     | jq &#39;.[]|[.a.aa,.a.ab,.b]&#39;\r\n    \r\n    [\r\n      1,\r\n      2,\r\n      3\r\n    ]\r\n    [\r\n      5,\r\n      6,\r\n      7\r\n    ]",
                "title": "How do I select multiple fields in jq?"
            },
            {
                "up_vote_count": 56,
                "is_accepted": false,
                "score": 56,
                "last_activity_date": 1603353423,
                "last_edit_date": 1603353423,
                "creation_date": 1603161373,
                "answer_id": 64437671,
                "question_id": 34834519,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just provide one more example here (jq-1.6):\r\n\r\nWalk through an array and select a field of an object element and a field of object in that object\r\n```\r\necho &#39;[{&quot;id&quot;:1, &quot;private_info&quot;: {&quot;name&quot;: &quot;Ivy&quot;, &quot;age&quot;: 18}}, {&quot;id&quot;:2, &quot;private_info&quot;: {&quot;name&quot;: &quot;Tommy&quot;, &quot;aga&quot;: 18}}]&#39; | jq &quot;.[] | {id: .id, name: .private_info.name}&quot; -\r\n\r\n{\r\n  &quot;id&quot;: 1,\r\n  &quot;name&quot;: &quot;Ivy&quot;\r\n}\r\n{\r\n  &quot;id&quot;: 2,\r\n  &quot;name&quot;: &quot;Tommy&quot;\r\n}\r\n```\r\n\r\nWithout the example data:  \r\n```\r\njq &quot;.[] | {id, name: .private_info.name}&quot; -\r\n```\r\n\r\n`.[]`: walk through an array\r\n\r\n`{id, name: .private_info.name}`: take .id and .private_info.name and wrap it into an object with field name &quot;id&quot; and &quot;name&quot; respectively\r\n",
                "title": "How do I select multiple fields in jq?"
            },
            {
                "up_vote_count": 27,
                "is_accepted": false,
                "score": 27,
                "last_activity_date": 1694316110,
                "creation_date": 1694316110,
                "answer_id": 77074720,
                "question_id": 34834519,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## For jq &gt;= v1.7\r\n\r\nThe builtin function [`pick`][1] is useful to slice objects (i.e. projection).\r\n\r\n```lang-console\r\n$ cat example.ndjson | jq -c &#39;pick(.login, .id)&#39;\r\n{&quot;login&quot;:&quot;dmaxfield&quot;,&quot;id&quot;:7449977}\r\n{&quot;login&quot;:&quot;eiffel&quot;,&quot;id&quot;:7449978}\r\n```\r\n\r\nNested objects can be handled nicely, too.\r\n\r\n```lang-console\r\n$ cat example.ndjson | jq -c &#39;pick(.login, .id, .nested.obj)&#39;\r\n{&quot;login&quot;:&quot;dmaxfield&quot;,&quot;id&quot;:7449977,&quot;nested&quot;:{&quot;obj&quot;:1.23}}\r\n{&quot;login&quot;:&quot;eiffel&quot;,&quot;id&quot;:7449978,&quot;nested&quot;:{&quot;obj&quot;:4.56}}\r\n```\r\n\r\nIf your input is formatted as JSON instead of NDJSON, prepend the script with `.[]`.\r\n\r\n\r\n```lang-console\r\n$ cat example.json | jq &#39;.[] | pick(.login, .id)&#39; | jq -s &#39;.&#39;   \r\n[\r\n  {\r\n    &quot;login&quot;: &quot;dmaxfield&quot;,\r\n    &quot;id&quot;: 7449977\r\n  },\r\n  {\r\n    &quot;login&quot;: &quot;eiffel&quot;,\r\n    &quot;id&quot;: 7449978\r\n  }\r\n]\r\n```\r\n\r\n## For jq &lt; v1.7\r\n\r\nUse `{ login, id }`, which is a shorthand for `{ login: .login, id: .id }`.\r\n\r\n```lang-console\r\n$ cat example.ndjson | jq -c &#39;{ login, id }&#39;                \r\n{&quot;login&quot;:&quot;dmaxfield&quot;,&quot;id&quot;:7449977}\r\n{&quot;login&quot;:&quot;eiffel&quot;,&quot;id&quot;:7449978}\r\n```\r\n\r\nFor nested objects, write like this:\r\n\r\n```lang-console\r\n$ cat example.ndjson | jq -c &#39;{ login, id, nested: { obj: .nested.obj } }&#39;\r\n{&quot;login&quot;:&quot;dmaxfield&quot;,&quot;id&quot;:7449977,&quot;nested&quot;:{&quot;obj&quot;:1.23}}\r\n{&quot;login&quot;:&quot;eiffel&quot;,&quot;id&quot;:7449978,&quot;nested&quot;:{&quot;obj&quot;:4.56}}\r\n```\r\n\r\nFor normal JSON files:\r\n\r\n```lang-console\r\n$ cat example.json | jq &#39;.[] | { login, id }&#39; | jq -s &#39;.&#39;\r\n[\r\n  {\r\n    &quot;login&quot;: &quot;dmaxfield&quot;,\r\n    &quot;id&quot;: 7449977\r\n  },\r\n  {\r\n    &quot;login&quot;: &quot;eiffel&quot;,\r\n    &quot;id&quot;: 7449978\r\n  }\r\n]\r\n```\r\n\r\n## Notes\r\n\r\nI used the following NDJSON file and JSON file.\r\n\r\n```lang-console\r\n$ cat example.ndjson \r\n{ &quot;login&quot;: &quot;dmaxfield&quot;, &quot;id&quot;: 7449977, &quot;foo&quot;: true, &quot;nested&quot;: { &quot;obj&quot;: 1.23 } }\r\n{ &quot;login&quot;: &quot;eiffel&quot;, &quot;id&quot;: 7449978, &quot;foo&quot;: false, &quot;nested&quot;: { &quot;obj&quot;: 4.56 } }\r\n$ cat example.json \r\n[\r\n  { &quot;login&quot;: &quot;dmaxfield&quot;, &quot;id&quot;: 7449977, &quot;foo&quot;: true, &quot;nested&quot;: { &quot;obj&quot;: 1.23 } },\r\n  { &quot;login&quot;: &quot;eiffel&quot;, &quot;id&quot;: 7449978, &quot;foo&quot;: false, &quot;nested&quot;: { &quot;obj&quot;: 4.56 } }\r\n]\r\n```\r\n\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/#pick",
                "title": "How do I select multiple fields in jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1743696245,
                "last_edit_date": 1743696245,
                "creation_date": 1740866006,
                "answer_id": 79478325,
                "question_id": 34834519,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**Get all fields space separated on the same line**\r\n\r\nThis one is also useful sometimes for readability or line oriented downstream processing. We use string interpolation as mentioned at: https://stackoverflow.com/questions/46131727/printing-multiple-values-on-the-same-line\r\n\r\nIf the input is a regular JSON list:\r\n\r\n```\r\njq -r &#39;.[] | &quot;\\(.field1) \\(.field2)&quot;&#39;\r\n```\r\n\r\nExample:\r\n\r\n```\r\nprintf &#39;[\r\n{\r\n  &quot;login&quot;: &quot;value1&quot;,\r\n  &quot;id&quot;: 2,\r\n  &quot;bla&quot;: 3\r\n},\r\n{\r\n  &quot;login&quot;: &quot;value4&quot;,\r\n  &quot;id&quot;: 5,\r\n  &quot;bla&quot;: 4\r\n}\r\n]&#39; | jq -r &#39;.[] | &quot;\\(.login) \\(.id)&quot;&#39;\r\n```\r\n\r\ngives:\r\n\r\n```\r\nvalue1 2\r\nvalue4 5\r\n```\r\n\r\nor if the input is a newline separated JSON it&#39;s just:\r\n\r\n```\r\njq -r &#39;&quot;\\(.login) \\(.id)&quot;&#39;\r\n```\r\n\r\ne.g.:\r\n\r\n```\r\njq -r &#39;&quot;\\(.login) \\(.id)&quot;&#39; &lt;&lt;&#39;EOF&#39;\r\n{&quot;login&quot;: &quot;value1&quot;,&quot;id&quot;: 2,&quot;bla&quot;: 3}\r\n{&quot;login&quot;: &quot;value4&quot;,&quot;id&quot;: 5,&quot;bla&quot;: 4}\r\nEOF\r\n```\r\n\r\nproduces the same output.\r\n\r\nThis is similar to solutions in other answers suggesting `-c` + `| {login, id}`, but it is cleaner when your rows don&#39;t have spaces or special characters in them and you don&#39;t need JSONL output.\r\n\r\nTested on jq 1.7, Ubuntu 24.10.\r\n\r\n\r\n",
                "title": "How do I select multiple fields in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 303,
        "last_activity_date": 1743696245,
        "creation_date": 1452998304,
        "last_edit_date": 1678813531,
        "question_id": 34834519,
        "body_markdown": "My input file is newline delimited JSON (`ndjson`) looking something like this:\r\n\r\n    {\r\n      &quot;login&quot;: &quot;dmaxfield&quot;,\r\n      &quot;id&quot;: 7449977,\r\n      ...\r\n    }\r\n    {\r\n      &quot;login&quot;: &quot;dmaxfield&quot;,\r\n      &quot;id&quot;: 7449977,\r\n      ...\r\n    }\r\n\r\nI can get all the `login` names with this : `cat members | jq &#39;.[].login&#39;` but I have not been able to crack the syntax to get both the `login` _and_ `id`?",
        "link": "https://stackoverflow.com/questions/34834519/how-do-i-select-multiple-fields-in-jq",
        "title": "How do I select multiple fields in jq?"
    },
    {
        "tags": [
            "command-line",
            "io",
            "pagination",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 33,
                "is_accepted": true,
                "score": 33,
                "last_activity_date": 1671305171,
                "last_edit_date": 1671305171,
                "creation_date": 1453051547,
                "answer_id": 34841287,
                "question_id": 34839073,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `jq -C` (colorize) option before paginating it with a pager like `more -r` or `less -r`.",
                "title": "How to print jq output sequentially"
            },
            {
                "up_vote_count": 18,
                "is_accepted": false,
                "score": 18,
                "last_activity_date": 1505176524,
                "creation_date": 1505176524,
                "answer_id": 46166211,
                "question_id": 34839073,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "report.json is a file with JSON (`cat report.json` prints but not formatted)\r\n\r\n    cat report.json | jq . -C | more\r\n\r\nOutputs jq with pager and color\r\n\r\nor via less instead of more\r\n\r\n    cat report.json | jq . -C | less -r\r\n\r\nP.S: the comments in this question where also helpful so thanks for that",
                "title": "How to print jq output sequentially"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 26,
        "last_activity_date": 1671305171,
        "creation_date": 1453038633,
        "last_edit_date": 1453155449,
        "question_id": 34839073,
        "body_markdown": "When using `jq` to process JSON, I often lose the overview due to long JSON objects. Thus, something like `jq . | less` would be nice. However, although the above works, the nice coloring by `jq` is gone.\r\n\r\nIs there another way to read `jq`&#39;s output line by line, or window by window, without having the terminal spammed with the full JSON object?\r\n\r\n**Edit:** This did not work for me: `echo &#39;{&quot;hello&quot;: &quot;world&quot;}&#39; | jq . | less -C`",
        "link": "https://stackoverflow.com/questions/34839073/how-to-print-jq-output-sequentially",
        "title": "How to print jq output sequentially"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 367746,
                    "reputation": 25570,
                    "user_id": 714112,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/83b2bbbdc0f34ed6148dab188c6bb987?s=256&d=identicon&r=PG",
                    "display_name": "Sridhar Sarnobat",
                    "link": "https://stackoverflow.com/users/714112/sridhar-sarnobat"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1483663733,
                "post_id": 34867088,
                "comment_id": 70200567,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1453176912,
                "creation_date": 1453176912,
                "answer_id": 34868411,
                "question_id": 34867088,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The simplest complete jq query is this:\r\n\r\n    echo &quot;{}&quot; | jq .\r\n\r\nDo you want to append the periods and see how it&#39;d go?",
                "title": "Jq can&#39;t seem to be able to read its own output?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1453190642,
                "last_edit_date": 1453190642,
                "creation_date": 1453181807,
                "answer_id": 34869188,
                "question_id": 34867088,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There was a bug/misfeature in jq 1.5 that explains the anomaly you evidently found (it has to do with the fact that your first invocation does not have an explicit filter).  Using a more recent version (available via github):\r\n \r\n    $ jq --version\r\n    jq-1.5rc2-146-gd228490\r\n\r\n    $ echo &quot;{}&quot; | jq -scaM --unbuffered | jq\r\n    [\r\n      {}\r\n    ]\r\n\r\n",
                "title": "Jq can&#39;t seem to be able to read its own output?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1453190642,
        "creation_date": 1453167002,
        "question_id": 34867088,
        "body_markdown": "Even stripped out of most decoration, this doesn&#39;t work - why ?\r\n\r\n`echo &quot;{}&quot; | jq -scaM --unbuffered  | jq`\r\n",
        "link": "https://stackoverflow.com/questions/34867088/jq-cant-seem-to-be-able-to-read-its-own-output",
        "title": "Jq can&#39;t seem to be able to read its own output?"
    },
    {
        "tags": [
            "jq",
            "whitelist"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1527098547,
                "last_edit_date": 1527098547,
                "creation_date": 1453215092,
                "answer_id": 34879861,
                "question_id": 34878915,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Doing `$value in $collection` could be achieved using the pattern `select($value == $collection[])`. A more efficient alternative would be `select(any($value == $collection[]; .))`  So your filter should be this:\r\n\r\n    [1, 7] as $whitelist | select(any(.b == $whitelist[]; .))\r\n\r\nHaving the array in a variable has its benefits as it lets you change the whitelist easily using arguments.\r\n\r\n    $ jq --argjson whitelist &#39;[2, 7]&#39; &#39;select(any(.b == $whitelist[]; .))&#39;",
                "title": "jq - How to select objects based on a &#39;whitelist&#39; of property values"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1498971977,
                "last_edit_date": 1498971977,
                "creation_date": 1453233090,
                "answer_id": 34885734,
                "question_id": 34878915,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following approach using index/1 is similar to what was originally sought (&quot;.b in [1, 7]&quot;), and might be noticeably faster than using .[] within `select` if the whitelist is large.\r\n\r\nIf your jq supports --argjson:\r\n\r\n    jq --argjson w &#39;[1,7]&#39; &#39;. as $in | select($w | index($in.b))&#39;\r\n \r\nOtherwise:\r\n\r\n    jq --arg w &#39;[1,7]&#39; &#39;. as $in | ($w|fromjson) as $w | select($w | index($in.b))&#39;\r\n\r\nor:\r\n\r\n    jq &#39;. as $in | select([1, 7] | index($in.b))&#39;\r\n\r\n### UPDATE\r\n\r\nOn Jan 30, 2017, a builtin named `IN` was added for efficiently testing whether a JSON entity is contained in a stream. It can also be used for efficiently testing membership in an array. For example, the above invocation with --argjson can be simplified to:\r\n\r\n    jq --argjson w &#39;[1,7]&#39; &#39;select( .b | IN($w[]) )&#39;\r\n\r\n\r\nIf your jq does not have `IN/1`, then so long as your jq has `first/1`, you can use this equivalent definition:\r\n\r\n    def IN(s): . as $in | first(if (s == $in) then true else empty end) // false;\r\n\r\n",
                "title": "jq - How to select objects based on a &#39;whitelist&#39; of property values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1527098547,
        "creation_date": 1453212449,
        "last_edit_date": 1453245936,
        "question_id": 34878915,
        "body_markdown": "Since an example is worth a thousand words, say I have the following JSON stream:\r\n\r\n    {&quot;a&quot;: 0, &quot;b&quot;: 1}\r\n    {&quot;a&quot;: 2, &quot;b&quot;: 2}\r\n    {&quot;a&quot;: 7, &quot;b&quot;: null}\r\n    {&quot;a&quot;: 3, &quot;b&quot;: 7}\r\n\r\nHow can I keep all the objects for which the `.b` property is one of `[1, 7]` (in reality the list is much longer so I don&#39;t want to do `select(.b == 1 or .b == 7)`). I&#39;m looking for something like this: `select(.b in [1, 7])`, but I couldn&#39;t find what I&#39;m looking for in the man page.",
        "link": "https://stackoverflow.com/questions/34878915/jq-how-to-select-objects-based-on-a-whitelist-of-property-values",
        "title": "jq - How to select objects based on a &#39;whitelist&#39; of property values"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1453218613,
                "creation_date": 1453218613,
                "answer_id": 34881122,
                "question_id": 34880288,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First of all, `.foo.bar` is just shorthand syntax for `.[&quot;foo&quot;][&quot;bar&quot;]`. Use the latter for non-alphanumeric values such as `api-client`.\r\n\r\nSecondly, you should never compose jq scripts by interpolating shell variables into them. Instead, pass values to them using --arg. That is, instead of doing this:\r\n\r\n    ${JQ} -r &quot;.projects.\\&quot;${PROJECT}\\&quot;&quot; ${CACHE}\r\n\r\nYou should probably be doing this:\r\n\r\n    ${JQ} --arg project &quot;$PROJECT&quot; -r &#39;.projects[$project]&#39; ${CACHE}\r\n\r\nNote the single quotes around the jq program: `$project` is syntax for a jq variable, like in Perl or PHP; it is not being interpolated by the shell. Always use single quotes around your jq programs.\r\n\r\nThirdly, you can use `-e` so that the status code is 0 on truthy values. Instead of this:\r\n\r\n    if [[ $(${JQ} -r &quot;.projects.\\&quot;${PROJECT}\\&quot;&quot; ${CACHE}) != null ]]; then\r\n\r\nYou can just do this:\r\n\r\n    if ${JQ} --arg project &quot;$PROJECT&quot; -e -r &#39;.projects[$project]&#39; ${CACHE}; then\r\n\r\nSimilarly, you can remove the comparison to true in the same manner.",
                "title": "JQ parsing strings with &quot;-&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1453233520,
        "creation_date": 1453216263,
        "last_edit_date": 1453233520,
        "question_id": 34880288,
        "body_markdown": "My JSON:\r\n\r\n    {\r\n        &quot;projects&quot;: {\r\n            &quot;api-client&quot;: {\r\n                &quot;status&quot;: &quot;false&quot;,\r\n                &quot;when&quot;: &quot;19-01-2016 12:54:47&quot;\r\n            },\r\n            &quot;api-admin&quot;: {\r\n                &quot;status&quot;: &quot;false&quot;,\r\n                &quot;when&quot;: &quot;19-01-2016 12:54:47&quot;\r\n            },\r\n            &quot;myweb&quot;: {\r\n                &quot;status&quot;: &quot;false&quot;,\r\n                &quot;when&quot;: &quot;19-01-2016 12:54:47&quot;\r\n            }\r\n        }\r\n    }\r\n\r\nScript:\r\n\r\n    JQ=$(which jq)\r\n    CACHE=&#39;cache.json&#39;\r\n    PROJECT=(&quot;api-client&quot; &quot;api-admin&quot; &quot;myweb&quot;)\r\n    for PROJECT in ${PROJECTS[*]}; do\r\n        if [[ $(${JQ} -r &quot;.projects.\\&quot;${PROJECT}\\&quot;&quot; ${CACHE}) != null ]]; then\r\n            if [[ $(${JQ} -r &quot;.projects.\\&quot;${PROJECT}\\&quot;.status&quot; ${CACHE}) == true ]]; then\r\n                local PROJECTDATE=$(${JQ} -r &quot;.projects.\\&quot;${PROJECT}\\&quot;.when&quot; ${CACHE})\r\n                local STATUS=&quot;${COLOR_GREEN}Installed${CLEAR} on ${COLOR_YELLOW}${PROJECTDATE}${CLEAR}&quot;\r\n            else\r\n                local STATUS=&quot;${COLOR_RED}Not installed${CLEAR}&quot;\r\n            fi\r\n            echo -e &quot;${CLEAR}    - ${COLOR_CYAN}${PROJECT}${CLEAR} =&gt; ${STATUS}&quot;\r\n        fi\r\n    done\r\n\r\n&gt; Error: error: syntax error, unexpected QQSTRING_START, expecting IDENT\r\n&gt; .projects.&quot;api-client&quot;\r\n&gt;           ^ 1 compile error error: syntax error, unexpected QQSTRING_START, expecting IDENT .projects.&quot;api-client&quot;.status\r\n&gt;           ^ 1 compile error\r\n&gt;     - api-client =&gt; Not installed\r\n\r\nCan someone please help debug my script?",
        "link": "https://stackoverflow.com/questions/34880288/jq-parsing-strings-with",
        "title": "JQ parsing strings with &quot;-&quot;"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1453508938,
                "last_edit_date": 1453508938,
                "creation_date": 1453508699,
                "answer_id": 34958170,
                "question_id": 34958101,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It looks like you&#39;re building up CSV data, the `@csv` filter was made for this.  You just need to collect an array of the values you want to write out and pass it in to the filter.  You could do this:\r\n\r\n    $ jq -r &#39;.attributes[] as $attr | [.object, $attr.type, $attr.description, $attr.value] | @csv&#39; input.json\r\n\r\nWhich produces this:\r\n\r\n    &quot;alpha&quot;,&quot;A&quot;,&quot;a&quot;,1271129046.9144535\r\n    &quot;alpha&quot;,&quot;B&quot;,&quot;b&quot;,6738889338.63777\r\n    &quot;alpha&quot;,&quot;C&quot;,&quot;c&quot;,214918692.38456276\r\n    &quot;alpha&quot;,&quot;D&quot;,&quot;d&quot;,140222346.75136077\r\n    &quot;alpha&quot;,&quot;E&quot;,&quot;e&quot;,2085635554.8128803\r\n\r\n",
                "title": "Converting object into array using only jq and bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1453521485,
                "creation_date": 1453521485,
                "answer_id": 34959444,
                "question_id": 34958101,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "(1) Slightly briefer than the accepted answer:\r\n\r\n    jq -r &#39;[.object] + (.attributes[] | [.type, .description, .value]) | @csv&#39;\r\n\r\n\r\n(2) If you don&#39;t want the quotation marks, then one possibility would be:\r\n\r\n    jq -r &#39;&quot;\\(.object),&quot; + (.attributes[] | &quot;\\(.type),\\(.description),\\(.value)&quot;)&#39;",
                "title": "Converting object into array using only jq and bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1453521485,
        "creation_date": 1453508162,
        "question_id": 34958101,
        "body_markdown": "I have a JSON formatted stream, full of objects. Each object looks like this:\r\n\r\n    {\r\n      &quot;object&quot;: &quot;alpha&quot;,\r\n      &quot;attributes&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;A&quot;,\r\n          &quot;description&quot;: &quot;a&quot;,\r\n          &quot;value&quot;: 1271129046.9144535\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;B&quot;,\r\n          &quot;description&quot;: &quot;b&quot;,\r\n          &quot;value&quot;: 6738889338.63777\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;C&quot;,\r\n          &quot;description&quot;: &quot;c&quot;,\r\n          &quot;value&quot;: 214918692.38456276\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;D&quot;,\r\n          &quot;description&quot;: &quot;d&quot;,\r\n          &quot;value&quot;: 140222346.75136077\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;E&quot;,\r\n          &quot;description&quot;: &quot;e&quot;,\r\n          &quot;value&quot;: 2085635554.8128803\r\n        }\r\n      ]\r\n    }\r\n\r\nI&#39;d like to get data out as:\r\n\r\n    alpha,A,a,1271129046.9144535\r\n    alpha,B,b,6738889338.63777\r\n    alpha,C,c,214918692.38456276\r\n    alpha,D,d,140222346.75136077\r\n    alpha,E,e,2085635554.8128803\r\n\r\nThe next object may be &quot;beta&quot; instead of &quot;alpha&quot;, hence I don&#39;t want to just strip the &quot;object&quot; key.\r\n\r\nMy restrictions are that I want to process this stream in a bash pipeline. I&#39;m hoping I can just use &quot;jq&quot; for this, rather than piping through python/ruby/perl etc which I&#39;d rather not depend on if I can help it.\r\n\r\nAny ideas would be most grateful!",
        "link": "https://stackoverflow.com/questions/34958101/converting-object-into-array-using-only-jq-and-bash",
        "title": "Converting object into array using only jq and bash"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 228130,
                    "reputation": 656,
                    "user_id": 490240,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4c64a9d5c93890e5043388e0f8508fc5?s=256&d=identicon&r=PG",
                    "display_name": "jrw32982",
                    "link": "https://stackoverflow.com/users/490240/jrw32982"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1611250755,
                "post_id": 35005893,
                "comment_id": 116397171,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 67,
                "is_accepted": true,
                "score": 66,
                "last_activity_date": 1636636368,
                "last_edit_date": 1636636368,
                "creation_date": 1453774375,
                "answer_id": 35005983,
                "question_id": 35005893,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is that `jq` is still just outputting lines of text; &lt;s&gt;you can&#39;t necessarily preserve each array element as a single unit. That said, as long as a newline is not a valid character in any object,&lt;/s&gt; you can still output each object on a separate line.\r\n\r\n    get_json_array | jq -c &#39;.[]&#39; | while read object; do\r\n        api_call &quot;$object&quot;\r\n    done\r\n\r\nUnder that assumption, you could use the `readarray` command in `bash` 4 to build an array:\r\n\r\n    readarray -t conversations &lt; &lt;(get_json_array | jq -c &#39;.[]&#39;)\r\n    for conversation in &quot;${conversations[@]}&quot;; do\r\n        api_call &quot;$conversation&quot;\r\n    done",
                "title": "Convert a JSON array to a bash array of strings"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1655803196,
                "creation_date": 1655803196,
                "answer_id": 72698250,
                "question_id": 35005893,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution without loops:\r\n```bash\r\njson=$(jq -c &quot;.my_key[]&quot;  ./my-file.json)\r\njson_without_quotes=$(echo ${json//\\&quot;/&quot;&quot;})\r\ndeclare -a all_apps_array=($(echo $json_without_quotes | tr &quot;\\n&quot; &quot; &quot;))\r\n```",
                "title": "Convert a JSON array to a bash array of strings"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1669321266,
                "creation_date": 1669321266,
                "answer_id": 74565883,
                "question_id": 35005893,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Also another option without having to loop.\r\n\r\n    jq -c &quot;.response[]&quot;  &quot;${file}&quot; | sed &#39;s/[{|}]//g&#39; | tr &#39;,&#39; &#39;\\n&#39; | sed &#39;s/&quot;//g&#39; | awk -F&quot;:&quot; &#39;{print toupper($1)&quot;:&quot;$2}&#39;\r\n\r\nHope it helps someone",
                "title": "Convert a JSON array to a bash array of strings"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1669658517,
                "creation_date": 1669658517,
                "answer_id": 74604720,
                "question_id": 35005893,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Credit for this approach goes to [@ingernet][1]. No `jq` required. This uses sed to remove `[`, `]`, and `,`, leaving a space between so it can be wrapped with ().\r\n\r\n```bash\r\nnewArray=( $(echo $jsonArrayString | sed -e &#39;s/\\[//g&#39; -e &#39;s/\\]//g&#39; -e &#39;s/\\,/ /g&#39;) );\r\n```\r\n\r\n\r\n  [1]: https://ingernet.github.io/bash/jq/json/2020/04/16/json-array-bash-array.html",
                "title": "Convert a JSON array to a bash array of strings"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1683051630,
                "creation_date": 1683051630,
                "answer_id": 76157784,
                "question_id": 35005893,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should convert a json array to a bash array regardless of the contents of the json entries. I needed it to pass a list of files to a linter inside of a github action. It was important to make a single call to the linter rather than one call per file to get the output I needed. It works in bash 3.2 \r\n\r\n```\r\ncount=$(jq length &lt;&lt;&lt; &quot;$pr_files&quot;)\r\ndeclare -a files=()\r\nfor (( i=0; i &lt; count; i++ ))\r\ndo\r\n    file=$(jq -r &quot;.[$i]&quot; &lt;&lt;&lt; &quot;$pr_files&quot;)\r\n    files+=( &quot;$file&quot; )\r\ndone\r\n```",
                "title": "Convert a JSON array to a bash array of strings"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 36,
        "last_activity_date": 1683051630,
        "creation_date": 1453773758,
        "last_edit_date": 1589429450,
        "question_id": 35005893,
        "body_markdown": "How do I parse a json array of objects to a bash array with those objects as strings?\r\n\r\nI am trying to do the following:\r\n\r\n    CONVO=$(get_json_array | jq &#39;.[]&#39;)\r\n\tfor CONVERSATION in $CONVERSATIONS\r\n\tdo\r\n\t\techo &quot;${CONVERSATION}&quot;\r\n\tdone\r\n\r\nBut the echo prints out lines instead of the specific objects.\r\nThe format of the object is:\r\n\r\n    { &quot;key1&quot;:&quot;value1&quot;, &quot;key2&quot;: &quot;value2&quot;}\r\n\r\nand I need to pass it to an api:\r\n\r\n    api_call &#39;{ &quot;key1&quot;:&quot;value1&quot;, &quot;key2&quot;: &quot;value2&quot;}&#39;",
        "link": "https://stackoverflow.com/questions/35005893/convert-a-json-array-to-a-bash-array-of-strings",
        "title": "Convert a JSON array to a bash array of strings"
    },
    {
        "tags": [
            "windows",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1453873589,
                "creation_date": 1453873589,
                "answer_id": 35029721,
                "question_id": 35029593,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The double-quotes in the original (i.e., the interior double-quotes) must be escaped, as discussed in the [Windows section of the jq FAQ][1].\r\n\r\nThus your example would become:\r\n\r\n    jq -r &quot;.\\&quot;FOO-BAR\\&quot;[] | .foo+ \\&quot; \\&quot; + .bar[]&quot;\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ#windows",
                "title": "Windows equivalent of Linux JQ tool command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1453873589,
        "creation_date": 1453872889,
        "question_id": 35029593,
        "body_markdown": "I have a linux jq command \r\n\r\n     jq -r &#39;.&quot;FOO-BAR&quot;[] | .foo+ &quot; &quot; + .bar[]&#39;\r\n\r\nWhat would be equivalent of this in Windows shell syntax? I have tried this and I get a compile error \r\n\r\n     jq -r &quot;.&quot;FOO-BAR&quot;[] | .foo+ &quot; &quot; + .bar[]&quot;\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/35029593/windows-equivalent-of-linux-jq-tool-command",
        "title": "Windows equivalent of Linux JQ tool command"
    },
    {
        "tags": [
            "json",
            "regex",
            "url",
            "jq",
            "string-matching"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1456967446,
                "last_edit_date": 1456967446,
                "creation_date": 1454091216,
                "answer_id": 35091272,
                "question_id": 35086206,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The good news is that there&#39;s a simple solution to the problem:\r\n\r\n    map( if .url | test(&quot;http://otherdomain.com.*filenameB.*&quot;)\r\n         then .url |= sub(  &quot;http://otherdomain.com.*filenameB.*&quot;; \r\n               &quot;http://yetanotherdomain.com/new/path/to/filenameC.tar.gz&quot;)\r\n         else .\r\n         end)\r\n\r\nThe not-so-good news is that it&#39;s not so easy to explain unless you understand the key cleverness here - the &quot;|=&quot; filter.  There is plenty of jq documentation about it, so I&#39;ll just point out that it is similar to the += family of operators in the C family of programming languages.  \r\n\r\nSpecifically, `.url |= sub(A;B)` is like `.url = (.url|sub(A;B))`.  That is how the update is done &quot;in-place&quot;.\r\n\r\n",
                "title": "jq: how do I update a value based on a substring match?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1501896747,
                "creation_date": 1501896747,
                "answer_id": 45517389,
                "question_id": 35086206,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which identifies paths to url members with **tostream** and **select** and then updates the values using **reduce** and **setpath**\r\n\r\n      &quot;http://otherdomain.com.*filenameB.*&quot;                      as $from\r\n    | &quot;http://yetanotherdomain.com/new/path/to/filenameC.tar.gz&quot; as $to\r\n  \r\n    | reduce (tostream | select(length == 2 and .[0][-1] == &quot;url&quot;)) as $p (\r\n          .\r\n        ; setpath($p[0]; $p[1] | sub($from; $to))\r\n      )",
                "title": "jq: how do I update a value based on a substring match?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1627626578,
        "creation_date": 1454075491,
        "last_edit_date": 1627626578,
        "question_id": 35086206,
        "body_markdown": "I&#39;ve got a **jq** question.  Given a file **file.json** containing:\r\n\r\n    [\r\n      {\r\n        &quot;type&quot;: &quot;A&quot;,\r\n        &quot;name&quot;: &quot;name 1&quot;,\r\n        &quot;url&quot;: &quot;http://domain.com/path/to/filenameA.zip&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;B&quot;,\r\n        &quot;name&quot;: &quot;name 2&quot;,\r\n        &quot;url&quot;: &quot;http://domain.com/otherpath/to/filenameB.zip&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;C&quot;,\r\n        &quot;name&quot;: &quot;name 3&quot;,\r\n        &quot;url&quot;: &quot;http://otherdomain.com/otherpath/to/filenameB.zip&quot;\r\n      }\r\n    ]\r\n\r\nI&#39;m looking to create another file using **jq** with url modified only if the url&#39;s value matches some pattern.  For example, I&#39;d want to update any url matching the pattern:\r\n\r\n    http://otherdomain.com.*filenameB.*\r\n\r\nto some fixed string such as:\r\n\r\n    http://yetanotherdomain.com/new/path/to/filenameC.tar.gz\r\n\r\nwith the resulting json:\r\n\r\n\r\n    [\r\n      {\r\n        &quot;type&quot;: &quot;A&quot;,\r\n        &quot;name&quot;: &quot;name 1&quot;,\r\n        &quot;url&quot;: &quot;http://domain.com/path/to/filenameA.zip&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;B&quot;,\r\n        &quot;name&quot;: &quot;name 2&quot;,\r\n        &quot;url&quot;: &quot;http://domain.com/otherpath/to/filenameB.zip&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;C&quot;,\r\n        &quot;name&quot;: &quot;name 3&quot;,\r\n        &quot;url&quot;: &quot;http://yetanotherdomain.com/new/path/to/filenameB.tar.gz&quot;\r\n      }\r\n    ]\r\n\r\nI haven&#39;t gotten far even on being able to find the url, let alone update it.  This is as far as I&#39;ve gotten (wrong results and doesn&#39;t help me with the update issue):\r\n\r\n    % cat file.json | jq -r &#39;.[] | select(.url | index(&quot;filenameB&quot;)).url&#39;\r\n    http://domain.com/otherpath/to/filenameB.zip\r\n    http://otherdomain.com/otherpath/to/filenameB.zip\r\n    %\r\n\r\nAny ideas on how to get the path of the key that has a value matching a regex?  And after that, how to update the key with some new string value?  If there are multiple matches, all should be updated with the same new value.",
        "link": "https://stackoverflow.com/questions/35086206/jq-how-do-i-update-a-value-based-on-a-substring-match",
        "title": "jq: how do I update a value based on a substring match?"
    },
    {
        "tags": [
            "json",
            "key",
            "iteration",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 419726,
                    "reputation": 95735,
                    "user_id": 797049,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/5f4f7a23e3d0134123a66015bdc4edd1?s=256&d=identicon&r=PG",
                    "display_name": "Mark Reed",
                    "link": "https://stackoverflow.com/users/797049/mark-reed"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1454126995,
                "post_id": 35086391,
                "comment_id": 57917207,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3552582,
                    "reputation": 1766,
                    "user_id": 3014025,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/25zFH.jpg?s=256",
                    "display_name": "Adam vonNieda",
                    "link": "https://stackoverflow.com/users/3014025/adam-vonnieda"
                },
                "reply_to_user": {
                    "account_id": 419726,
                    "reputation": 95735,
                    "user_id": 797049,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/5f4f7a23e3d0134123a66015bdc4edd1?s=256&d=identicon&r=PG",
                    "display_name": "Mark Reed",
                    "link": "https://stackoverflow.com/users/797049/mark-reed"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1454293538,
                "post_id": 35086391,
                "comment_id": 57964839,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 57,
                "is_accepted": true,
                "score": 57,
                "last_activity_date": 1597022197,
                "last_edit_date": 1597022197,
                "creation_date": 1454091901,
                "answer_id": 35091473,
                "question_id": 35086391,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The original tag for this question was `jq` so here is a `jq` solution: \r\n\r\n    .[] | keys[]\r\n\r\nFor example, with the input as shown in the question:\r\n \r\n\r\n    $ jq &#39;.[] | keys[]&#39; input.json\r\n \r\n    &quot;identifier1&quot;\r\n    &quot;identifier2&quot;\r\n\r\nTo retrieve the key names in the order they appear in the JSON object, use `keys_unsorted`.\r\n",
                "title": "jq - How to iterate through keys of different names"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1546909026,
                "creation_date": 1546909026,
                "answer_id": 54083952,
                "question_id": 35086391,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I came here hoping to sort out a bunch of keys from my JSON, I found two features handy. There are three functions &quot;to_entries&quot;, &quot;from_entries&quot;, and &quot;with_entries&quot;. You can filter the values by key or value, like so:\r\n\r\n&lt;!-- language: bash --&gt;\r\n\r\n    JSON_DATA=&#39;\r\n    {\r\n      &quot;fields&quot;: {\r\n        &quot;first&quot;: null,\r\n        &quot;second&quot;: &quot;two&quot;,\r\n        &quot;third&quot;: &quot;three&quot;\r\n      }\r\n    }\r\n    &#39;\r\n    \r\n    echo &quot;$JSON_DATA&quot; | jq &#39;{fields: .fields | with_entries(select(.value != null and .key != &quot;third&quot;)) }&#39;\r\n\r\nOutput:\r\n\r\n&lt;!-- language: json --&gt;\r\n\r\n    {\r\n      &quot;fields&quot;: {\r\n        &quot;second&quot;: &quot;two&quot;\r\n      }\r\n    }\r\n",
                "title": "jq - How to iterate through keys of different names"
            },
            {
                "up_vote_count": 38,
                "is_accepted": false,
                "score": 38,
                "last_activity_date": 1713649233,
                "last_edit_date": 1713649233,
                "creation_date": 1590707883,
                "answer_id": 62076101,
                "question_id": 35086391,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d think something along these lines would work well:\r\n\r\n    jq &#39;. | to_entries | .[].key&#39;\r\n\r\nsee https://jqlang.github.io/jq/manual/#to_entries-from_entries-with_entries\r\n\r\nor if you wanted to get the values from a variable:\r\n\r\n    JSON_DATA={main:{k1:v1,k2:v2}}\r\n    result=$(jq -n &quot;$JSON_DATA&quot; | jq &#39;.main | to_entries | .[].value&#39; --raw-output)\r\n    echo $result\r\n\r\n    ##outputs: v1 v2\r\n\r\n    ",
                "title": "jq - How to iterate through keys of different names"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1675792629,
                "last_edit_date": 1675792629,
                "creation_date": 1670496211,
                "answer_id": 74729018,
                "question_id": 35086391,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "simpler solution - just treat internal hash as a new hash and add one more filter. The query that helped me:\r\n\r\n```\r\n$ docker network inspect bridge|jq &#39;.[].Containers&#39;\r\n{\r\n  &quot;35c9e1273c43db01c45b5f43f6999d04c18beff3996ea09fb8b87a8b635c38ff&quot;: {\r\n    &quot;Name&quot;: &quot;nginx&quot;,\r\n    &quot;EndpointID&quot;: &quot;a6e788d6f90eb14df2321a2eb02517f0862c1fe7fe50c02f2b8c103c0c79cb6b&quot;,\r\n    &quot;MacAddress&quot;: &quot;02:42:ac:11:00:02&quot;,\r\n    &quot;IPv4Address&quot;: &quot;172.17.0.2/16&quot;,\r\n    &quot;IPv6Address&quot;: &quot;&quot;\r\n  },\r\n  &quot;b46c157cec243969f9227251dfd6fa65b7a904e145df80a63f79d4dc8b281355&quot;: {\r\n    &quot;Name&quot;: &quot;sweet_gates&quot;,\r\n    &quot;EndpointID&quot;: &quot;a600d9c1ee35b9f7db31249ae8f589c202e0b260e10a394757a88bfd66b5b42f&quot;,\r\n    &quot;MacAddress&quot;: &quot;02:42:ac:11:00:03&quot;,\r\n    &quot;IPv4Address&quot;: &quot;172.17.0.3/16&quot;,\r\n    &quot;IPv6Address&quot;: &quot;&quot;\r\n  }\r\n}\r\n```\r\nAs I needed only couple of fields, add to above .json one more query:\r\n```\r\n$ docker network inspect bridge|jq -jr &#39;.[].Containers[]|.IPv4Address, &quot;\\t&quot;, .Name, &quot;\\n&quot;&#39;\r\n172.17.0.2/16\tnginx\r\n172.17.0.3/16\tsweet_gates\r\n```\r\n\r\n",
                "title": "jq - How to iterate through keys of different names"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 40,
        "last_activity_date": 1713649233,
        "creation_date": 1454076035,
        "last_edit_date": 1500583299,
        "question_id": 35086391,
        "body_markdown": "I&#39;ve got JSON that looks like this \r\n\r\n    {\r\n      &quot;keyword1&quot;: {\r\n        &quot;identifier1&quot;: 16\r\n      },\r\n      &quot;keyword2&quot;: {\r\n        &quot;identifier2&quot;: 16\r\n      }\r\n    }\r\n\r\nand I need to loop through the keywords to get the identifiers (not sure if I&#39;m using the right terminology here). Seems pretty simple, but because the keywords are all named different, I don&#39;t know how to handle that.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/35086391/jq-how-to-iterate-through-keys-of-different-names",
        "title": "jq - How to iterate through keys of different names"
    },
    {
        "tags": [
            "csv",
            "filter",
            "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": 1454333825,
                "post_id": 35131859,
                "comment_id": 57983441,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1563634,
                    "reputation": 153,
                    "user_id": 1452907,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/c12af0d85b0ab58fbbbb88e50c034c33?s=256&d=identicon&r=PG",
                    "display_name": "Stephan Beutel",
                    "link": "https://stackoverflow.com/users/1452907/stephan-beutel"
                },
                "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": 1454335831,
                "post_id": 35131859,
                "comment_id": 57984822,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1454335850,
                "creation_date": 1454335850,
                "answer_id": 35132673,
                "question_id": 35131859,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "@csv only works on a flat array, so you could add &#39;| .[] | @csv&#39; to your pipeline.",
                "title": "jq filter to convert Elasticsearch result to CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1454336069,
        "creation_date": 1454333588,
        "last_edit_date": 1454336069,
        "question_id": 35131859,
        "body_markdown": "I&#39;m trying to convert my json search result from Elasticsearch to a csv format using jq.\r\n\r\nMy actual jq command looks like this:\r\n\r\n    .aggregations[&quot;byLabels&quot;].buckets | map({key,doc_count,range: .byRange.buckets | map({str:(.from_as_string + &quot;-&quot; + .to_as_string), dc:.doc_count} | [.str, .dc])} | flatten )\r\n\r\nAnd the actual result:\r\n\r\n    [\r\n      [\r\n        &quot;Page 1&quot;,\r\n        15001,\r\n        &quot;0.0-1000.0&quot;,\r\n        7,\r\n        &quot;1000.0-2000.0&quot;,\r\n        1005,\r\n        &quot;2000.0-&quot;,\r\n        8907\r\n      ],\r\n      [\r\n        &quot;Page 2&quot;,\r\n        340,\r\n        &quot;0.0-1000.0&quot;,\r\n        23,\r\n        &quot;1000.0-2000.0&quot;,\r\n        261,\r\n        &quot;2000.0-&quot;,\r\n        18\r\n      ]\r\n    ]\r\n\r\nBut the csv output I need should look like this (with or without quotation marks):\r\n\r\n    &quot;Page1&quot;,15001,&quot;0.0-1000.0&quot;,7,1000.0-2000.0,1005,&quot;2000.0-*&quot;,8907\r\n    &quot;Page2&quot;,340,&quot;0.0-1000.0&quot;,23,1000.0-2000.0,261,&quot;2000.0-*&quot;,18\r\n\r\nI tried to add a additional add[] or flatten or join(&quot;,&quot;) filters, but only get errors when trying to use |@csv.\r\n\r\nThis is my first time I use jq, so I think this is not a problem for any experiences jq user.\r\n\r\nThe original json file looks like this:\r\n\r\n    {\r\n      &quot;took&quot; : 3,\r\n      &quot;timed_out&quot; : false,\r\n      &quot;_shards&quot; : {\r\n        &quot;total&quot; : 5,\r\n        &quot;successful&quot; : 5,\r\n        &quot;failed&quot; : 0\r\n      },\r\n      &quot;hits&quot; : {\r\n        &quot;total&quot; : 51632,\r\n        &quot;max_score&quot; : 0.0,\r\n        &quot;hits&quot; : [ ]\r\n      },\r\n      &quot;aggregations&quot; : {\r\n        &quot;byLabels&quot; : {\r\n          &quot;doc_count_error_upper_bound&quot; : 0,\r\n          &quot;sum_other_doc_count&quot; : 2478,\r\n          &quot;buckets&quot; : [ {\r\n            &quot;key&quot; : &quot;Page 1&quot;,\r\n            &quot;doc_count&quot; : 15001,\r\n            &quot;byRange&quot; : {\r\n              &quot;buckets&quot; : {\r\n                &quot;0.0-1000.0&quot; : {\r\n                  &quot;from&quot; : 0.0,\r\n                  &quot;from_as_string&quot; : &quot;0.0&quot;,\r\n                  &quot;to&quot; : 1000.0,\r\n                  &quot;to_as_string&quot; : &quot;1000.0&quot;,\r\n                  &quot;doc_count&quot; : 7\r\n                },\r\n                &quot;1000.0-2000.0&quot; : {\r\n                  &quot;from&quot; : 1000.0,\r\n                  &quot;from_as_string&quot; : &quot;1000.0&quot;,\r\n                  &quot;to&quot; : 2000.0,\r\n                  &quot;to_as_string&quot; : &quot;2000.0&quot;,\r\n                  &quot;doc_count&quot; : 1005\r\n                },\r\n                &quot;2000.0-*&quot; : {\r\n                  &quot;from&quot; : 2000.0,\r\n                  &quot;from_as_string&quot; : &quot;2000.0&quot;,\r\n                  &quot;doc_count&quot; : 8907\r\n                }\r\n              }\r\n            }\r\n          }, {\r\n            &quot;key&quot; : &quot;Page 2&quot;,\r\n            &quot;doc_count&quot; : 340,\r\n            &quot;byRange&quot; : {\r\n              &quot;buckets&quot; : {\r\n                &quot;0.0-1000.0&quot; : {\r\n                  &quot;from&quot; : 0.0,\r\n                  &quot;from_as_string&quot; : &quot;0.0&quot;,\r\n                  &quot;to&quot; : 1000.0,\r\n                  &quot;to_as_string&quot; : &quot;1000.0&quot;,\r\n                  &quot;doc_count&quot; : 23\r\n                },\r\n                &quot;1000.0-2000.0&quot; : {\r\n                  &quot;from&quot; : 1000.0,\r\n                  &quot;from_as_string&quot; : &quot;1000.0&quot;,\r\n                  &quot;to&quot; : 2000.0,\r\n                  &quot;to_as_string&quot; : &quot;2000.0&quot;,\r\n                  &quot;doc_count&quot; : 261\r\n                },\r\n                &quot;2000.0-*&quot; : {\r\n                  &quot;from&quot; : 2000.0,\r\n                  &quot;from_as_string&quot; : &quot;2000.0&quot;,\r\n                  &quot;doc_count&quot; : 18\r\n                }\r\n              }\r\n            }\r\n          } ]\r\n        }\r\n      }\r\n    }\r\n\r\nThanks for help.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/35131859/jq-filter-to-convert-elasticsearch-result-to-csv",
        "title": "jq filter to convert Elasticsearch result to CSV"
    },
    {
        "tags": [
            "json",
            "type-conversion",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1454354220,
                "creation_date": 1454354220,
                "answer_id": 35138457,
                "question_id": 35137058,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    echo &#39;asw|uduu|sssdd&#39; | jq -Rc &#39;split(&quot;|&quot;)&#39;\r\n\r\nproduces:\r\n    [&quot;asw&quot;,&quot;uduu&quot;,&quot;sssdd&quot;]\r\n\r\nThe &quot;-c&quot; option is inessential here - it just compacts the output.\r\n\r\n    echo &#39;A:1|B:1|C:1&#39; |\r\n     jq -Rc &#39;split(&quot;|&quot;) | map( split(&quot;:&quot;) | {(.[0]): .[1]} ) | add&#39;\r\nproduces: {&quot;A&quot;:&quot;1&quot;,&quot;B&quot;:&quot;1&quot;,&quot;C&quot;:&quot;1&quot;}\r\n\r\nTo understand how the last one works, run the leftmost part of the pipeline first, and then add successive parts.",
                "title": "Convert a bash variable to JSON array and JSON object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1454354492,
        "creation_date": 1454348974,
        "last_edit_date": 1454354492,
        "question_id": 35137058,
        "body_markdown": "I have a variable, X, in a bash script that has a value like `asw|uduu|sssdd`. How can I convert it to a JSON array using jq?\r\n\r\nA second variable, Y, has a value like `A:1|B:1|C:1`. How can I convert it to a JSON object using jq?\r\n\r\nPlease help me solve these conversion tasks.",
        "link": "https://stackoverflow.com/questions/35137058/convert-a-bash-variable-to-json-array-and-json-object-using-jq",
        "title": "Convert a bash variable to JSON array and JSON object using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1454368384,
                "post_id": 35141521,
                "comment_id": 58004739,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1454365563,
                "creation_date": 1454365563,
                "answer_id": 35141597,
                "question_id": 35141521,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I know in JavaScript you could do this\r\n\r\n    array.forEach(function(a) {\r\n         console.log(Object.keys(a));\r\n    });\r\n\r\nObject.keys is particularly handy because it lets you get keys of an object. Then just iterate over an array and log to console\r\n\r\nhttps://jsfiddle.net/f8rbdn85/",
                "title": "jq how to grab all values and use for script arguments"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1454368922,
                "creation_date": 1454368922,
                "answer_id": 35142336,
                "question_id": 35141521,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "What you&#39;re trying to attempt is pretty much unclear, but here&#39;s some possibly helpful pointers:\r\n\r\nTo get the values your script needs, just refer to them with the `.foo` syntax. For example, running `jq -r &#39;.[].name&#39;` over the given input file would produce the following output:\r\n\r\n    jms1\r\n    jms2\r\n\r\nSimilarly, you can refer to all of them:\r\n\r\n`jq -r &#39;.[] | .name, .port1, .port2, .port3&#39;`\r\n\r\n    jms1\r\n    24000\r\n    25000\r\n    26000\r\n    jms2\r\n    24001\r\n    25000\r\n    26001\r\n\r\nAnd, if you&#39;d like them in an array as in the example above, just wrap them in brackets:\r\n\r\n`jq -r -c &#39;.[] | [.name, .port1, .port2, .port3]&#39;`\r\n\r\n    [&quot;jms1&quot;, 24000, 25000, 26000]\r\n    [&quot;jms2&quot;, 24001, 25000, 26001]\r\n\r\nHope this helps! That&#39;s as far as I can go without really understanding your problem.",
                "title": "jq how to grab all values and use for script arguments"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1454434645,
                "last_edit_date": 1454434645,
                "creation_date": 1454387547,
                "answer_id": 35145094,
                "question_id": 35141521,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Taking Santiago&#39;s answer one step further, you could write:\r\n\r\n    $ jq -r &#39;.[] | &quot;port_script.sh \\&quot;\\(.name)\\&quot; \\&quot;\\(.port1)\\&quot; \\&quot;\\(.port2)\\&quot; \\&quot;\\(.port3)\\&quot;&quot;&#39;\r\n\r\nWith your input, this produces:\r\n\r\n    port_script.sh &quot;jms1&quot; &quot;24000&quot; &quot;25000&quot; &quot;26000&quot;\r\n    port_script.sh &quot;jms2&quot; &quot;24001&quot; &quot;25000&quot; &quot;26001&quot;\r\n\r\nOr better yet perhaps:\r\n\r\n    $ jq -r --arg command port_script.sh &#39;.[] \r\n      | $command + &quot; \\&quot;\\(.name)\\&quot; \\&quot;\\(.port1)\\&quot; \\&quot;\\(.port2)\\&quot; \\&quot;\\(.port3)\\&quot;&quot;&#39;\r\n\r\nIf the keys in each object are in the order required by the script, then we can generalize one step further so that the jq script will work for any number of keys:\r\n\r\n    jq -nr --arg command port_script.sh &#39;\r\n      .[] | $command + &quot; &quot; + ([.[]] | @sh)&#39;\r\n\r\n    port_script.sh &#39;jms1&#39; 24000 25000 26000\r\n    port_script.sh &#39;jms2&#39; 24001 25000 26001\r\n\r\n(Unfortunately, jq does not have a `system` subcommand, at least not yet.)",
                "title": "jq how to grab all values and use for script arguments"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1603811481,
                "creation_date": 1603811481,
                "answer_id": 64557353,
                "question_id": 35141521,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I had to deal with this lately because i was asked to use json in a shell script.\r\n\r\nSo for anyone finding this topic in the future:\r\n\r\n\r\nInstead of using the eval function I would suggest using a more native shell approach.\r\n\r\nConsider the use of a loop and the read command.\r\n\r\n    #!/bin/bash\r\n    read -d &#39;&#39; JSON &lt;&lt;&#39;EOF&#39; || true\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;jms1&quot;,\r\n            &quot;port1&quot;: 24000,\r\n            &quot;port2&quot;: 25000,\r\n            &quot;port3&quot;: 26000\r\n        },\r\n    \r\n        {\r\n            &quot;name&quot;: &quot;jms2&quot;,\r\n            &quot;port1&quot;: 24001,\r\n            &quot;port2&quot;: 25000,\r\n            &quot;port3&quot;: 26001\r\n        }\r\n    ]\r\n    EOF\r\n    \r\n    while IFS=$&#39;\\t&#39; read name port1 port2 port3 eol ; do\r\n    \r\n    \t./port_script.sh &quot;$name&quot; &quot;$port1&quot; &quot;$port2&quot; &quot;$port3&quot;\r\n    \r\n    done &lt;&lt;&lt;&quot; $(echo &quot;$JSON&quot; | jq --raw-output &#39;.[] | [.name, .port1, .port2, .port3] | @tsv&#39; )&quot;\r\n    \r\n\r\n**Note:**\r\n\r\nIf, by desgin, your JSON could contain empty fields this can be a problem. The @tsv function of jq works correctly and separates everything with tabs. But at least the Bash will treat multiple delimiters as one. This is only true if you use whitespaces (&quot; &quot; or &quot;\\t&quot;) as separators. I worked around this by using:\r\n\r\n    $(echo &quot;$JSON&quot; | jq --raw-output &#39;.[] | [.name, .port1, .port2, .port3] | @tsv&#39; | tr $&#39;\\011&#39; $&#39;\\037&#39; )  \r\n\r\nThis will replace all tabs (octal 011) with the ASCII Unit Separator (octal 037). \r\n\r\nI first tried just replacing &#39;\\t\\t&#39; with &#39;\\t[space]\\t&#39; which would work fine as multiple spaces would once again get reduced to one when you use them as parameters to your port_script.sh... but this would throw off any conditional tests (test -z for example). \r\n\r\nThe Unit Separator should be safe to use for this. Would be nice if jq could implement this directly.... but yeah :)\r\n\r\nAnd also change this for your while loop:\r\n\r\n    ...\r\n    while IFS=$&#39;\\037&#39; read name port1 port2 port3 eol ; do\r\n    ...",
                "title": "jq how to grab all values and use for script arguments"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 4,
        "last_activity_date": 1603811481,
        "creation_date": 1454365247,
        "last_edit_date": 1454444419,
        "question_id": 35141521,
        "body_markdown": "I have this vms.json\r\n\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;jms1&quot;,\r\n            &quot;port1&quot;: 24000,\r\n            &quot;port2&quot;: 25000,\r\n            &quot;port3&quot;: 26000\r\n        },\r\n\r\n        {\r\n            &quot;name&quot;: &quot;jms2&quot;,\r\n            &quot;port1&quot;: 24001,\r\n            &quot;port2&quot;: 25000,\r\n            &quot;port3&quot;: 26001\r\n        }\r\n    ]\r\n\r\nI have a port_script.sh  which takes \r\n[name] [port1] [port2] [port3]  as numbered arguments.\r\n\r\nI can run this jq, to get keys, but I need to get values.\r\n   \r\n    jq -r -c &#39;.[] |keys&#39; vms.json\r\n    [&quot;port1&quot;,&quot;name&quot;,&quot;port2&quot;,&quot;port3&quot;]\r\n    [&quot;port1&quot;,&quot;name&quot;,&quot;port2&quot;,&quot;port3&quot;]\r\n\r\nI don&#39;t know how to use this output to get the associated values. \r\nIf I can get the values I should be able to pipe them to my script via xargs.\r\n\r\nThanks in advance for your help\r\n\r\nadded: port_script.sh\r\n\r\n    #!/bin/bash\r\n    name=$1\r\n    port1=$2\r\n    port2=$3\r\n    port3=$4\r\n    vagrant ssh ${name} -- \\\r\n        -L ${port1}:127.0.0.1:${port1}  \\\r\n        -R ${port2}:127.0.0.1:${port2}  \\\r\n        -L ${port3}:127.0.0.1:${port3} \r\n\r\nApplying Santiago and Peak&#39;s responses - this works for me\r\n\r\n    eval &quot;$(jq -r &#39;.[] | [&quot;./port_script.sh&quot;] + [.name, .port1, .port2, .port3 | @sh] | join(&quot; &quot;)&#39; vms.json)&quot;\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/35141521/jq-how-to-grab-all-values-and-use-for-script-arguments",
        "title": "jq how to grab all values and use for script arguments"
    }
]