[
    {
        "tags": [
            "json",
            "string",
            "sed",
            "escaping",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 207422,
                    "reputation": 67485,
                    "user_id": 457268,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://i.sstatic.net/Htrwe.jpg?s=256",
                    "display_name": "k0pernikus",
                    "link": "https://stackoverflow.com/users/457268/k0pernikus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1508337478,
                "post_id": 35154684,
                "comment_id": 80572673,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 370,
                "is_accepted": true,
                "score": 369,
                "last_activity_date": 1454420905,
                "creation_date": 1454420905,
                "answer_id": 35155249,
                "question_id": 35154684,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "jq has the [`fromjson`](https://stedolan.github.io/jq/manual/v1.5/#Convertto/fromJSON) builtin for this:\r\n\r\n    jq &#39;.c | fromjson | .id&#39; myFile.json\r\n\r\n`fromjson` was added in version 1.4.",
                "title": "how to parse a JSON String with jq (or other alternatives)?"
            },
            {
                "up_vote_count": 89,
                "is_accepted": false,
                "score": 89,
                "last_activity_date": 1454435046,
                "last_edit_date": 1454435046,
                "creation_date": 1454421021,
                "answer_id": 35155290,
                "question_id": 35154684,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use the raw output (-r) that will unescape characters:\r\n\r\n    jq -r .c myfile.json | jq .id\r\n\r\nADDENDUM: This has the advantage that it works in jq 1.3 and up; indeed, it should work in every version of jq that has the -r option.",
                "title": "how to parse a JSON String with jq (or other alternatives)?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1620115465,
                "last_edit_date": 1620115465,
                "creation_date": 1620114683,
                "answer_id": 67380760,
                "question_id": 35154684,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**Motivation**: you want to parse JSON string -  you want to escape a JSON object that&#39;s wrapped with quotes and represented as a String buffer, and convert it to a valid JSON object. For example:\r\n\r\nsome **JSON unescaped string** :\r\n\r\n    &quot;{\\&quot;name\\&quot;:\\&quot;John Doe\\&quot;,\\&quot;position\\&quot;:\\&quot;developer\\&quot;}&quot;\r\n\r\nthe **expected result** ( a JSON object ):\r\n\r\n    {&quot;name&quot;:&quot;John Doe&quot;,&quot;position&quot;:&quot;developer&quot;}\r\n\r\n**Solution**: In order to escape a JSON string and convert it into a valid JSON object use the `sed` tool in command line and use regex expressions to remove/replace specific characters:\r\n\r\n    cat current_json.txt | sed -e &#39;s/\\\\\\&quot;/\\&quot;/g&#39; -e &#39;s/^.//g&#39; -e &#39;s/.$//g&#39;\r\n\r\n\r\n `s/\\\\\\&quot;/\\&quot;/g` replacing all backslashes and quotes ( `\\&quot;` ) into quotes only (`&quot;`)\r\n\r\n  `s/^.//g` replacing the first character in the stream to none character\r\n\r\n  `s/.$//g` replacing the last character in the stream to none character",
                "title": "how to parse a JSON String with jq (or other alternatives)?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1742733701,
                "creation_date": 1742733701,
                "answer_id": 79528962,
                "question_id": 35154684,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you are open to alternatives to JQ, I would like to also suggest a more intuitive way to achieve what you were doing with JQ.\r\n\r\nToolkit.app has a JSON query tool that lets you run plain JS functions to query and transform JSON. In your case, you can just input your JSON into the input field and add the following transform function to get your desired result.  \r\n  \r\nDisclaimer: I created this tool because JQ syntax still feels unintuitive to me and I almost always have to open the manual, google the solution or ask an LLM. \r\n\r\nhttps://gettoolkit.app/tools/data/json-query-transform\r\n\r\n```\r\nfunction transform(data) {\r\n  return JSON.parse(data.c).id;\r\n}\r\n```",
                "title": "how to parse a JSON String with jq (or other alternatives)?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 210,
        "last_activity_date": 1742733701,
        "creation_date": 1454419294,
        "last_edit_date": 1620207798,
        "question_id": 35154684,
        "body_markdown": "I&#39;m trying to get `jq` to parse a JSON structure like:\r\n  \r\n    {\r\n      &quot;a&quot; : 1,\r\n      &quot;b&quot; : 2,\r\n      &quot;c&quot; : &quot;{\\&quot;id\\&quot;:\\&quot;9ee ...\\&quot;,\\&quot;parent\\&quot;:\\&quot;abc...\\&quot;}\\n&quot;\r\n    }\r\n\r\nThat is, an element in the JSON is a string with escaped json.\r\n\r\nSo, I have something along the lines of\r\n`$ jq [.c] myFile.json | jq [.id]`\r\n\r\nBut that crashes with `jq: error: Cannot index string with string`\r\n\r\nThis is because the output of .c is a string, not more JSON.\r\nHow do I get jq to parse this string?\r\n\r\nMy initial solution is to use sed to replace all the escape chars (`\\&quot;:\\&quot;`, `\\&quot;,\\&quot;` and `\\&quot;`) but that&#39;s messy, I assume there&#39;s a way built into `jq` to do this?\r\n\r\nThanks!\r\n\r\nedit:\r\nAlso, the jq version available here is:\r\n    \r\n    $ jq --version\r\n    jq version 1.3\r\n\r\nI guess I could update it if required.",
        "link": "https://stackoverflow.com/questions/35154684/how-to-parse-a-json-string-with-jq-or-other-alternatives",
        "title": "how to parse a JSON String with jq (or other alternatives)?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 127,
                "is_accepted": false,
                "score": 125,
                "last_activity_date": 1454432907,
                "creation_date": 1454432907,
                "answer_id": 35365770,
                "question_id": 35365769,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The jq command has the [tostring][1] function.  It took me a while to learn to use it by trial and error.  Here is how to use it:\r\n\r\n    jq -r &#39;.[] | [ .string, .number|tostring ] | join(&quot;: &quot;)&#39; &lt;&lt;&lt; &#39;\r\n    [{ &quot;number&quot;: 9, &quot;string&quot;: &quot;nine&quot;},\r\n     { &quot;number&quot;: 4, &quot;string&quot;: &quot;four&quot;}]\r\n    &#39;\r\n    nine: 9\r\n    four: 4\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#tostring",
                "title": "How do I use jq to convert number to string?"
            },
            {
                "up_vote_count": 83,
                "is_accepted": false,
                "score": 83,
                "last_activity_date": 1507665115,
                "creation_date": 1507665115,
                "answer_id": 46674867,
                "question_id": 35365769,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "An alternative and arguably more intuitive format is:\r\n\r\n    jq &#39;.[] | .string + &quot;: &quot; + (.number|tostring)&#39; &lt;&lt;&lt; ...\r\n\r\nWorth noting the need for parens around `.number|tostring`.",
                "title": "How do I use jq to convert number to string?"
            },
            {
                "up_vote_count": 19,
                "is_accepted": false,
                "score": 19,
                "last_activity_date": 1608251191,
                "last_edit_date": 1608251191,
                "creation_date": 1565352722,
                "answer_id": 57429821,
                "question_id": 35365769,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For such simple case [string interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-\\%28foo%29)&#39;s implicit casting to string will do it:\r\n\r\n&lt;!-- language: lang-jq --&gt;\r\n\r\n    .[] | &quot;\\( .string ): \\( .number )&quot;\r\n\r\nSee it in action on [jq‣play](https://jqplay.org/s/o3ki4PNtPo).\r\n",
                "title": "How do I use jq to convert number to string?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 126,
        "last_activity_date": 1707222156,
        "creation_date": 1454432907,
        "last_edit_date": 1707222156,
        "question_id": 35365769,
        "body_markdown": "Given the following jq command and Json:\r\n\r\n\r\n    jq &#39;.[]|[.string,.number]|join(&quot;: &quot;)&#39; &lt;&lt;&lt; &#39;\r\n    [\r\n      {\r\n        &quot;number&quot;: 3,\r\n        &quot;string&quot;: &quot;three&quot;\r\n      },\r\n      {\r\n        &quot;number&quot;: 7,\r\n        &quot;string&quot;: &quot;seven&quot;\r\n      }\r\n    ]\r\n    &#39;\r\nI&#39;m trying to format the output as:\r\n\r\n    three: 3\r\n    seven: 7\r\n\r\nUnfortunately, my attempt is resulting in the following error:\r\n\r\n&gt; jq: error: string and number cannot be added\r\n\r\nHow do I convert the number to string so both can be joined?",
        "link": "https://stackoverflow.com/questions/35365769/how-do-i-use-jq-to-convert-number-to-string",
        "title": "How do I use jq to convert number to string?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1454523114,
                "last_edit_date": 1454523114,
                "creation_date": 1454509134,
                "answer_id": 35179535,
                "question_id": 35177992,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Building on your approach, you could, for example, simply write:\r\n\r\n    jq &#39;[.events[]|.severity|contains(&quot;WARNING&quot;)] | any&#39;\r\n\r\nOr more succinctly:\r\n\r\n    jq &#39;any(.events[].severity; contains(&quot;WARNING&quot;))&#39; \r\n\r\nIf you want to test for the condition in ANY object, no matter where it is, then consider using walk/1.\r\n",
                "title": "jq - How to test for the occurrence of a particular value in a JSON response"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1454523114,
        "creation_date": 1454504958,
        "last_edit_date": 1454510897,
        "question_id": 35177992,
        "body_markdown": "Using jq I would like to test for the occurrence of a particular key value in the JSON below, for example that &quot;WARNING&quot; has occurred as a &#39;severity&#39; value (even once) no matter the amount of objects returned, such that I return a boolean. For simplicity I have 2 objects below, but it could be 2000\r\n\r\n    {\r\n      &quot;events&quot;: [\r\n        {\r\n          &quot;severity&quot;: &quot;WARNING&quot;,\r\n          &quot;status&quot;: &quot;&quot;,\r\n          &quot;time_raised&quot;: &quot;1454502910919&quot;,\r\n          &quot;data_1&quot;: &quot;00000000&quot;,\r\n          &quot;data_2&quot;: &quot;00000000&quot;,\r\n          &quot;data_3&quot;: &quot;00000000&quot;,\r\n          &quot;register_0&quot;: &quot;40000&quot;,\r\n          &quot;register_1&quot;: &quot;4&quot;,\r\n          &quot;register_2&quot;: &quot;10&quot;,\r\n          &quot;register_3&quot;: &quot;0&quot;\r\n        },\r\n        {\r\n          &quot;severity&quot;: &quot;ERROR&quot;,\r\n          &quot;status&quot;: &quot;&quot;,\r\n          &quot;time_raised&quot;: &quot;1454502840915&quot;,\r\n          &quot;data_1&quot;: &quot;00000000&quot;,\r\n          &quot;data_2&quot;: &quot;00000000&quot;,\r\n          &quot;data_3&quot;: &quot;00000000&quot;,\r\n          &quot;register_0&quot;: &quot;50000&quot;,\r\n          &quot;register_1&quot;: &quot;4&quot;,\r\n          &quot;register_2&quot;: &quot;8&quot;,\r\n          &quot;register_3&quot;: &quot;0&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nMy approach has been to try using the &#39;contains&#39; filter like so\r\n\r\n    jq .events[]|.severity|contains(&quot;WARNING&quot;)\r\n\r\nWhich outputs\r\n\r\n    true\r\n    false\r\n\r\nAs I want to have a single boolean value returned, I&#39;ve tried to merge the values into a single string or array before using &#39;contains&#39;, but I can&#39;t find a way to do this. \r\n\r\nI&#39;d rather keep the logic in jq, so I&#39;m hoping I&#39;ve missed the wood from the trees and that there is a simple way of doing this in jq.",
        "link": "https://stackoverflow.com/questions/35177992/jq-how-to-test-for-the-occurrence-of-a-particular-value-in-a-json-response",
        "title": "jq - How to test for the occurrence of a particular value in a JSON response"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1454592266,
                "creation_date": 1454592266,
                "answer_id": 35202218,
                "question_id": 35199809,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Select those who do *not* have `target`; that way, you do not use `del`:\r\n\r\n    jq -r &#39;select(has(&quot;target&quot;) | not)&#39;",
                "title": "jq: exclude object with specified key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1454659516,
        "creation_date": 1454585352,
        "last_edit_date": 1454659516,
        "question_id": 35199809,
        "body_markdown": "Input:\r\n\r\n    {\r\n        &quot;name&quot;:&quot;JSON&quot;,\r\n        &quot;good&quot;:true,\r\n        &quot;target&quot;:&quot;yes&quot;\r\n    }\r\n    {\r\n        &quot;name&quot;:&quot;XML&quot;,\r\n        &quot;good&quot;:false\r\n    }\r\n\r\nI would like to exclude object WITHOUT key &quot;target&quot;, as follow but NOT has:\r\n\r\n    jq -r &quot;.| select(has(\\&quot;target\\&quot;))&quot;\r\n\r\nexpected output:\r\n\r\n    {\r\n        &quot;name&quot;:&quot;XML&quot;,\r\n        &quot;good&quot;:false\r\n    }\r\n\r\ntried this:\r\n\r\n    jq -r &quot; . | del(select(has(\\&quot;target\\&quot;)))&quot;\r\n\r\nbut there are two returned objects, one of them NULL\r\n\r\n    null\r\n    {\r\n      &quot;good&quot;: false,\r\n      &quot;name&quot;: &quot;XML&quot;\r\n    }\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/35199809/jq-exclude-object-with-specified-key",
        "title": "jq: exclude object with specified key"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 264636,
                    "reputation": 15242,
                    "user_id": 551045,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://www.gravatar.com/avatar/d3cf04e39bcaab5592938990ea158d51?s=256&d=identicon&r=PG",
                    "display_name": "RedX",
                    "link": "https://stackoverflow.com/users/551045/redx"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1454598868,
                "post_id": 35204397,
                "comment_id": 58124943,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7186708,
                    "reputation": 125,
                    "user_id": 5488432,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/a5b7d64c1217b2cfb0236e8774567745?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Alex",
                    "link": "https://stackoverflow.com/users/5488432/alex"
                },
                "reply_to_user": {
                    "account_id": 264636,
                    "reputation": 15242,
                    "user_id": 551045,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://www.gravatar.com/avatar/d3cf04e39bcaab5592938990ea158d51?s=256&d=identicon&r=PG",
                    "display_name": "RedX",
                    "link": "https://stackoverflow.com/users/551045/redx"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1454599628,
                "post_id": 35204397,
                "comment_id": 58125528,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1454607228,
                "last_edit_date": 1454607228,
                "creation_date": 1454601193,
                "answer_id": 35205553,
                "question_id": 35204397,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to escape the slashes to escape a `&quot;`\r\n\r\n    $ echo [{&quot;a&quot; : &quot;b&quot;}] | jq-win64.exe --raw-output &quot;.[] | \\&quot;Result is: \\\\\\&quot;\\&quot; + .a + \\&quot;\\\\\\&quot;.\\&quot;&quot;\r\n    Result is: &quot;b&quot;.",
                "title": "jq: How to output quotes on raw output on Windows"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1454601449,
                "creation_date": 1454601449,
                "answer_id": 35205642,
                "question_id": 35204397,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since you&#39;re trying to output double quotes in a double quoted string, you need to escape the inner quotes.  And to escape the inner quotes, you need to also escape the escaping backslashes.  So a literal double quote would have to be entered as `\\\\\\&quot;`.  You can do this a little cleaner by using string interpolation instead of regular string concatenation.\r\n\r\n    jq -r &quot;.[] | \\&quot;Result is: \\\\\\&quot;\\(.a)\\\\\\&quot;.\\&quot;&quot;",
                "title": "jq: How to output quotes on raw output on Windows"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1738099724,
                "last_edit_date": 1738099724,
                "creation_date": 1454603850,
                "answer_id": 35206558,
                "question_id": 35204397,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A hacky workaround with less backslashing could be:\r\n\r\n    jq -r &quot;.[] | \\&quot;Result is: \\&quot; + (.a|tojson)&quot;\r\n",
                "title": "jq: How to output quotes on raw output on Windows"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1738099724,
        "creation_date": 1454598027,
        "last_edit_date": 1738099650,
        "question_id": 35204397,
        "body_markdown": "Using raw output, I have to quote some values of the output.\r\n\r\nFor example,\r\n\r\n    echo [{&quot;a&quot; : &quot;b&quot;}] | jq-win64.exe --raw-output &quot;.[] | \\&quot;Result is: \\&quot; + .a + \\&quot;.\\&quot;&quot;\r\n\r\ngenerates\r\n\r\n    Result is: b.\r\n\r\nbut how can I generate the following?\r\n\r\n    Result is: &quot;b&quot;.\r\n\r\nUnfortunately, it has to run on Windows, called from inside a [CMD][1] file.\r\n\r\n  [1]: https://en.wikipedia.org/wiki/Cmd.exe\r\n",
        "link": "https://stackoverflow.com/questions/35204397/jq-how-to-output-quotes-on-raw-output-on-windows",
        "title": "jq: How to output quotes on raw output on Windows"
    },
    {
        "tags": [
            "json",
            "mapreduce",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1455095135,
                "last_edit_date": 1455095135,
                "creation_date": 1455093491,
                "answer_id": 35310247,
                "question_id": 35308616,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Command:\r\n\r\n    $ jq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39; array_of_objects.json | \r\n      jq &#39;select(.batters.batter[].type == &quot;Chocolate&quot;) | .id&#39;\r\n\r\nOutput:\r\n\r\n    &quot;0001&quot;\r\n    &quot;0003&quot;\r\n\r\n\r\nThe first invocation of jq converts the array of objects into a stream of objects.  The second is based on your invocation and can be tailored further to your needs.\r\n\r\nOf course the two invocations can (and probably should) be combined into one, but you might want to use the first invocation to save the big file as a file containing the stream of objects.\r\n\r\nBy the way, it would probably be better to use the following `select`: \r\n\r\n    select( any(.batters.batter[]; .type == &quot;Chocolate&quot;) )",
                "title": "jq streaming of large json files to get only objects whose properties have a specific value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503723383,
                "creation_date": 1503723383,
                "answer_id": 45892069,
                "question_id": 35308616,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another approach.  Start with a streaming filter `filter1.jq` that extracts the record number and the minimum set of attributes you need to process.  E.g.\r\n\r\n      select(length==2)\r\n    | . as [$p, $v]\r\n    | {r:$p[0]}\r\n    | if   $p[1] == &quot;id&quot;                           then .id   = $v\r\n      elif $p[1] == &quot;batters&quot; and $p[-1] == &quot;type&quot; then .type = $v\r\n      else  empty\r\n      end      \r\n\r\nRunning this with\r\n\r\n    jq -M -c --stream -f filter1.jq bigdata.json\r\n\r\nproduces values like\r\n\r\n    {&quot;r&quot;:0,&quot;id&quot;:&quot;0001&quot;}\r\n    {&quot;r&quot;:0,&quot;type&quot;:&quot;Regular&quot;}\r\n    {&quot;r&quot;:0,&quot;type&quot;:&quot;Chocolate&quot;}\r\n    {&quot;r&quot;:0,&quot;type&quot;:&quot;Blueberry&quot;}\r\n    {&quot;r&quot;:0,&quot;type&quot;:&quot;Devil&#39;s Food&quot;}\r\n    {&quot;r&quot;:1,&quot;id&quot;:&quot;0002&quot;}\r\n    {&quot;r&quot;:1,&quot;type&quot;:&quot;Regular&quot;}\r\n    {&quot;r&quot;:2,&quot;id&quot;:&quot;0003&quot;}\r\n    {&quot;r&quot;:2,&quot;type&quot;:&quot;Regular&quot;}\r\n    {&quot;r&quot;:2,&quot;type&quot;:&quot;Chocolate&quot;}\r\n\r\nnow pipe this into a second filter `filter2.jq` which does the processing you want on those attributes for each record\r\n\r\n    foreach .[] as $i (\r\n         {c: null, r:null, id:null, type:null}\r\n\r\n       ; .c = $i\r\n       | if .r != .c.r then .id=null | .type=null | .r=.c.r else . end   # control break\r\n       | .id   = if .c.id == null   then .id   else .c.id   end\r\n       | .type = if .c.type == null then .type else .c.type end\r\n\r\n       ; if ([.id, .type] | contains([null])) then empty else . end\r\n    )\r\n    | select(.type == &quot;Chocolate&quot;).id\r\n\r\nwith a command like\r\n    \r\n    jq -M -c --stream -f filter1.jq bigdata.json | jq -M -s -r -f filter2.jq \r\n\r\nto produce\r\n\r\n    0001\r\n    0003\r\n\r\n`filter1.jq` and `filter2.jq` do a little more than what you need for this specific problem but they can be generalized easily.\r\n",
                "title": "jq streaming of large json files to get only objects whose properties have a specific value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1503723383,
        "creation_date": 1455086984,
        "last_edit_date": 1455128456,
        "question_id": 35308616,
        "body_markdown": "I have some rather large json files (~500mb - 4gb compressed) for which I cannot load into memory for manipulation. So I am using the `--stream` option with jq.\r\n\r\nFor example my json might look like this - only bigger:\r\n\r\n    [{\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;name&quot;: &quot;Cake&quot;,\r\n      &quot;ppu&quot;: 0.55,\r\n      &quot;batters&quot;: {\r\n        &quot;batter&quot;: [{\r\n          &quot;id&quot;: &quot;1001&quot;,\r\n          &quot;type&quot;: &quot;Regular&quot;\r\n        }, {\r\n          &quot;id&quot;: &quot;1002&quot;,\r\n          &quot;type&quot;: &quot;Chocolate&quot;\r\n        }, {\r\n          &quot;id&quot;: &quot;1003&quot;,\r\n          &quot;type&quot;: &quot;Blueberry&quot;\r\n        }, {\r\n          &quot;id&quot;: &quot;1004&quot;,\r\n          &quot;type&quot;: &quot;Devil&#39;s Food&quot;\r\n        }]\r\n      },\r\n      &quot;topping&quot;: [{\r\n        &quot;id&quot;: &quot;5001&quot;,\r\n        &quot;type&quot;: &quot;None&quot;\r\n      }, {\r\n        &quot;id&quot;: &quot;5002&quot;,\r\n        &quot;type&quot;: &quot;Glazed&quot;\r\n      }, {\r\n        &quot;id&quot;: &quot;5005&quot;,\r\n        &quot;type&quot;: &quot;Sugar&quot;\r\n      }, {\r\n        &quot;id&quot;: &quot;5007&quot;,\r\n        &quot;type&quot;: &quot;Powdered Sugar&quot;\r\n      }, {\r\n        &quot;id&quot;: &quot;5006&quot;,\r\n        &quot;type&quot;: &quot;Chocolate with Sprinkles&quot;\r\n      }, {\r\n        &quot;id&quot;: &quot;5003&quot;,\r\n        &quot;type&quot;: &quot;Chocolate&quot;\r\n      }, {\r\n        &quot;id&quot;: &quot;5004&quot;,\r\n        &quot;type&quot;: &quot;Maple&quot;\r\n      }]\r\n    }, {\r\n      &quot;id&quot;: &quot;0002&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;name&quot;: &quot;Raised&quot;,\r\n      &quot;ppu&quot;: 0.55,\r\n      &quot;batters&quot;: {\r\n        &quot;batter&quot;: [{\r\n          &quot;id&quot;: &quot;1001&quot;,\r\n          &quot;type&quot;: &quot;Regular&quot;\r\n        }]\r\n      },\r\n      &quot;topping&quot;: [{\r\n        &quot;id&quot;: &quot;5001&quot;,\r\n        &quot;type&quot;: &quot;None&quot;\r\n      }, {\r\n        &quot;id&quot;: &quot;5002&quot;,\r\n        &quot;type&quot;: &quot;Glazed&quot;\r\n      }, {\r\n        &quot;id&quot;: &quot;5005&quot;,\r\n        &quot;type&quot;: &quot;Sugar&quot;\r\n      }, {\r\n        &quot;id&quot;: &quot;5003&quot;,\r\n        &quot;type&quot;: &quot;Chocolate&quot;\r\n      }, {\r\n        &quot;id&quot;: &quot;5004&quot;,\r\n        &quot;type&quot;: &quot;Maple&quot;\r\n      }]\r\n    }, {\r\n      &quot;id&quot;: &quot;0003&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;name&quot;: &quot;Old Fashioned&quot;,\r\n      &quot;ppu&quot;: 0.55,\r\n      &quot;batters&quot;: {\r\n        &quot;batter&quot;: [{\r\n          &quot;id&quot;: &quot;1001&quot;,\r\n          &quot;type&quot;: &quot;Regular&quot;\r\n        }, {\r\n          &quot;id&quot;: &quot;1002&quot;,\r\n          &quot;type&quot;: &quot;Chocolate&quot;\r\n        }]\r\n      },\r\n      &quot;topping&quot;: [{\r\n        &quot;id&quot;: &quot;5001&quot;,\r\n        &quot;type&quot;: &quot;None&quot;\r\n      }, {\r\n        &quot;id&quot;: &quot;5002&quot;,\r\n        &quot;type&quot;: &quot;Glazed&quot;\r\n      }, {\r\n        &quot;id&quot;: &quot;5003&quot;,\r\n        &quot;type&quot;: &quot;Chocolate&quot;\r\n      }, {\r\n        &quot;id&quot;: &quot;5004&quot;,\r\n        &quot;type&quot;: &quot;Maple&quot;\r\n      }]\r\n    }]\r\n\r\n\r\nIf this were the type of file I could hold in memory, and I wanted to select objects that only have batter type &quot;Chocolate&quot;, I could use:\r\n\r\n`cat sample.json | jq &#39;.[] | select(.batters.batter[].type == &quot;Chocolate&quot;)&#39;`\r\n\r\nAnd I would only get back the full objects with ids `&quot;0001&quot;` and `&quot;0003&quot;`\r\n\r\nBut with streaming I know it&#39;s different.\r\n\r\nI am reading through the jq documentation on streaming [here][1] and [here][2], but I am still quite confused as the examples don&#39;t really demonstrate real world problems with json.\r\n\r\nNamely, Is it even possible to select whole objects after streaming through their paths and identifying a notable event, or in this case a property value that matches a certain string?\r\n\r\nI know that I can use: \r\n\r\n`cat sample.json | jq --stream &#39;select(.[0][1] == &quot;batters&quot; and .[0][2] == &quot;batter&quot; and .[0][4] == &quot;type&quot;) | .[1]&#39;`\r\n\r\nto give me all of the batter types. But is there a way to say: &quot;If it&#39;s Chocolate, grab the object this leaf is a part of&quot;?\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Streaming\r\n  [2]: https://github.com/stedolan/jq/wiki/FAQ#streaming-json-parser",
        "link": "https://stackoverflow.com/questions/35308616/jq-streaming-of-large-json-files-to-get-only-objects-whose-properties-have-a-spe",
        "title": "jq streaming of large json files to get only objects whose properties have a specific value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1455183373,
                "creation_date": 1455183373,
                "answer_id": 35335493,
                "question_id": 35333175,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your expected result is not meaningful as a JSON! On a JSON object, the property keys must be unique. When property keys are repeated, JSON parsers will usually only keep the last one&#39;s value, disregarding the rest.\r\n\r\nYou can, however, obtain something like this:\r\n\r\n    {\r\n      &quot;num_of_vulns&quot;: 2,\r\n      &quot;lib&quot;: &quot;libxml2&quot;,\r\n      &quot;license&quot;: &quot;permissive&quot;,\r\n      &quot;vulns&quot;: [&quot;CVE-2012-0841&quot;, &quot;CVE-2012-2871&quot;]\r\n    }\r\n\r\nHere&#39;s a sample script that does so (I omitted your wrapping `if` for empty vulns, but it could be added around it):\r\n\r\n    {\r\n        num_of_vulns: .&quot;vuln-count&quot;.exact,\r\n        lib: .lib,\r\n        license: .license.type,\r\n        vulns: .vulns | map(select(.exact).vuln.cve)\r\n    }",
                "title": "how to convert this array in one?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1455198788,
        "creation_date": 1455175620,
        "last_edit_date": 1455198788,
        "question_id": 35333175,
        "body_markdown": "I am playing around with jq at https://jqplay.org/\r\n\r\nThe JSON I currently have is :\r\n\r\n    {\r\n      &quot;license&quot;: {\r\n        &quot;type&quot;: &quot;permissive&quot;,\r\n        &quot;url&quot;: &quot;http://en.wikipedia.org/wiki/MIT_License&quot;,\r\n        &quot;name&quot;: &quot;MIT&quot;\r\n      },\r\n      &quot;lib&quot;: &quot;libxml2&quot;,\r\n      &quot;vuln-count&quot;: {\r\n        &quot;exact&quot;: 2,\r\n        &quot;total&quot;: 3,\r\n        &quot;historical&quot;: 1\r\n      },\r\n      &quot;vulns&quot;: [\r\n        {\r\n          &quot;exact&quot;: false,\r\n          &quot;timestamp-objects&quot;: [],\r\n          &quot;vuln&quot;: {\r\n            &quot;published-epoch&quot;: &quot;1072839600&quot;,\r\n            &quot;cvss&quot;: 9.3,\r\n            &quot;summary&quot;: &quot;libxml2, possibly before 2.5.0.\\&quot;&quot;,\r\n            &quot;published&quot;: &quot;2003-12-31T03:00:00&quot;,\r\n            &quot;cve&quot;: &quot;CVE-2003-1564&quot;,\r\n            &quot;modified&quot;: &quot;2008-10-24T01:30:02&quot;,\r\n            &quot;modified-epoch&quot;: &quot;1224811802&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;exact&quot;: true,\r\n          &quot;timestamp-objects&quot;: [\r\n            &quot;libxml2-2.8.0-1.x86_64.cpio:/usr/lib64/libxml2.so.2.8.0&quot;\r\n          ],\r\n          &quot;vuln&quot;: {\r\n            &quot;published-epoch&quot;: &quot;1356061574&quot;,\r\n            &quot;cvss&quot;: 5,\r\n            &quot;summary&quot;: &quot;libxml2 before 2.8.0 computes hash values.&quot;,\r\n            &quot;published&quot;: &quot;2012-12-21T03:46:14&quot;,\r\n            &quot;cve&quot;: &quot;CVE-2012-0841&quot;,\r\n            &quot;modified&quot;: &quot;2014-01-28T02:42:55&quot;,\r\n            &quot;modified-epoch&quot;: &quot;1390876975&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;exact&quot;: true,\r\n          &quot;timestamp-objects&quot;: [\r\n            &quot;libxml2-2.8.0-1.x86_64.cpio:/usr/lib64/libxml2.so.2.8.0&quot;\r\n          ],\r\n          &quot;vuln&quot;: {\r\n            &quot;published-epoch&quot;: &quot;1346432101&quot;,\r\n            &quot;cvss&quot;: 6.8,\r\n            &quot;summary&quot;: &quot;libxml2 2.9.0-rc1 and earlier.&quot;,\r\n            &quot;published&quot;: &quot;2012-08-31T16:55:01&quot;,\r\n            &quot;cve&quot;: &quot;CVE-2012-2871&quot;,\r\n            &quot;modified&quot;: &quot;2014-01-28T02:45:36&quot;,\r\n            &quot;modified-epoch&quot;: &quot;1390877136&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nmy current filter is\r\n\r\n    if .[&quot;vuln-count&quot;].exact &gt;0 \r\n    then {num_of_vulns: .[&quot;vuln-count&quot;].exact, lib: .lib, license: .license.type, vuln: .vulns[]|select (.exact==true)|.vuln.cve} \r\n    else empty end\r\n\r\nAnd the result is\r\n\r\n    {\r\n      &quot;num_of_vulns&quot;: 2,\r\n      &quot;lib&quot;: &quot;libxml2&quot;,\r\n      &quot;license&quot;: &quot;permissive&quot;,\r\n      &quot;vuln&quot;: &quot;CVE-2012-0841&quot;\r\n    }\r\n    {\r\n      &quot;num_of_vulns&quot;: 2,\r\n      &quot;lib&quot;: &quot;libxml2&quot;,\r\n      &quot;license&quot;: &quot;permissive&quot;,\r\n      &quot;vuln&quot;: &quot;CVE-2012-2871&quot;\r\n    }\r\n\r\nWhat is the filter to use in order to get the following output?\r\n\r\n    {\r\n      &quot;num_of_vulns&quot;: 2,\r\n      &quot;lib&quot;: &quot;libxml2&quot;,\r\n      &quot;license&quot;: &quot;permissive&quot;,\r\n      &quot;vulns&quot;: [&quot;CVE-2012-0841&quot;, &quot;CVE-2012-2871&quot;]\r\n    }\r\n\r\nThanks to Santiago, here is the working filter:\r\n\r\n    if .[&quot;vuln-count&quot;].exact &gt;0  then {\r\n       num_of_vulns: .&quot;vuln-count&quot;.exact,\r\n       lib: .lib,\r\n       license: .license.type,\r\n       vulns: .vulns | map(select(.exact).vuln.cve)\r\n    }  else empty end\r\n\r\n",
        "link": "https://stackoverflow.com/questions/35333175/how-to-convert-this-array-in-one",
        "title": "how to convert this array in one?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1455273415,
                "creation_date": 1455273415,
                "answer_id": 35360409,
                "question_id": 35360297,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can convert it [to a number][1], like this:\r\n\r\n    jq --arg ARG1 1 &#39;.[$ARG1|tonumber]&#39; &lt;&lt;&lt; &#39;[&quot;foo&quot;. &quot;bar&quot;]&#39;\r\n    &quot;bar&quot;\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#tonumber",
                "title": "How to make jq treat argument as numeric instead of string?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1455279545,
                "last_edit_date": 1455279545,
                "creation_date": 1455279117,
                "answer_id": 35362373,
                "question_id": 35360297,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`--arg` always binds the value as a string. You can use `--argjson` (introduced in version 1.5) to treat the argument as a json-encoded value instead.\r\n\r\n    jq --argjson ARG1 $CURR_INDEX &#39;.[$ARG1].patchSets&#39; inputfile.json\r\n\r\nTo see it in action, you can reproduce your original error:\r\n\r\n    $ jq --argjson ARG1 &#39;&quot;1&quot;&#39; &#39;.[$ARG1]&#39; &lt;&lt;&lt; &#39;[&quot;foo&quot;, &quot;bar&quot;]&#39;\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index array with string &quot;1&quot;\r\n\r\nthen correct it:\r\n\r\n    $ jq --argjson ARG1 1 &#39;.[$ARG1]&#39; &lt;&lt;&lt; &#39;[&quot;foo&quot;, &quot;bar&quot;]&#39;\r\n    &quot;bar&quot;",
                "title": "How to make jq treat argument as numeric instead of string?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 10,
        "last_activity_date": 1455283208,
        "creation_date": 1455273070,
        "last_edit_date": 1455283208,
        "question_id": 35360297,
        "body_markdown": "How to make `jq` treat an input argument as numeric instead of string? In the following example, `CURR_INDEX` is a Bash variable which has array index value that I want to extract. \r\n\r\n    jq --arg ARG1 $CURR_INDEX &#39;.[$ARG1].patchSets&#39; inputfile.json\r\n\r\nI get the following error:\r\n\r\n    jq: error: Cannot index array with string\r\n\r\nI tried the workaround of using `bash` `eval` but some `jq` filters do not work properly in `eval` statements.",
        "link": "https://stackoverflow.com/questions/35360297/how-to-make-jq-treat-argument-as-numeric-instead-of-string",
        "title": "How to make jq treat argument as numeric instead of string?"
    },
    {
        "tags": [
            "bash",
            "variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1455321623,
                "creation_date": 1455321623,
                "answer_id": 35374277,
                "question_id": 35373972,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Ideally, your input should be JSON so you should run your file through something that could convert your CSV file to arrays containing your data so it can be consumed by jq.  Assuming your data won&#39;t be complex and the values themselves won&#39;t contain commas, you could read in the raw lines and split them.  Then it&#39;s just a matter of building out your result.\r\n\r\n    $ jq -R &#39;split(&quot;,&quot;) as $k |\r\n        reduce (inputs | split(&quot;,&quot;)) as $r ({};\r\n            .[$r[0]] = ([range(1;$k|length) | { key: $k[.], value: $r[.] }] | from_entries)\r\n        )&#39; input.csv\r\n",
                "title": "jq: generate JSON: dynamic key creation possible?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1455562094,
                "last_edit_date": 1455562094,
                "creation_date": 1455346217,
                "answer_id": 35376993,
                "question_id": 35373972,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a straightforward solution that is actually very similar to Jeff&#39;s (in particular, it makes the same assumptions about the CSV), but it uses `input` for the first line, `inputs` for the remaining lines, a simplified version of &quot;objectify&quot; from the jq Cookbook, and `add` instead of `reduce` in the main filter:\r\n\r\n    jq -R -n &#39;\r\n      def objectify(headers): . as $in\r\n        | reduce range(0; headers|length) as $i\r\n            ({}; .[headers[$i]] = $in[$i]  );\r\n\r\n      ((input|split(&quot;,&quot;))[1:]) as $headers\r\n      | [ (inputs|split(&quot;,&quot;)) as $line\r\n          | { ($line[0]): ($line[1:] | objectify($headers)) } ]\r\n      | add\r\n    &#39;\r\n   ",
                "title": "jq: generate JSON: dynamic key creation possible?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1455562094,
        "creation_date": 1455319775,
        "last_edit_date": 1495541248,
        "question_id": 35373972,
        "body_markdown": "I&#39;ve never used jq to generate JSON, only parse. So this is untraveled territory for me. \r\n\r\nI found https://stackoverflow.com/questions/22434290/jq-bash-make-json-array-from-variable, which gets me closer to what I&#39;m seeking. However, I&#39;ve yet to determine how to dynamically create key names for the structure I&#39;m seeking.\r\n\r\nThe structure I&#39;m seeking looks something like this:\r\n\r\n    {\r\n      &quot;eth0&quot;:\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      &quot;eth3&quot;:\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\n\r\nderived from csv:\r\n\r\n    iface,key1,key2,key3\r\n    eth0,value1,value2,value3\r\n    eth3,value1,value2,value3\r\n\r\nThe problem I&#39;ve been having is the dynamic generation of the keys in the JSON from the CSV. I haven&#39;t been able to find jq&#39;s ability to do that. I&#39;m using jq 1.5.\r\n\r\nAm I spinning my wheels on this?\r\n\r\n**EDIT - possible answer**\r\n\r\nCurrently investigating this cookbook answer:\r\n\r\nhttps://github.com/stedolan/jq/wiki/Cookbook#convert-a-csv-file-with-headers-to-json",
        "link": "https://stackoverflow.com/questions/35373972/jq-generate-json-dynamic-key-creation-possible",
        "title": "jq: generate JSON: dynamic key creation possible?"
    },
    {
        "tags": [
            "json",
            "bash",
            "while-loop",
            "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": 1455341278,
                "post_id": 35376426,
                "comment_id": 58458531,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7779583,
                    "reputation": 25,
                    "user_id": 5886442,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-LhO65g_znhw/AAAAAAAAAAI/AAAAAAAAABY/UzJrcS4xUDU/s256-rj/photo.jpg",
                    "display_name": "ubr",
                    "link": "https://stackoverflow.com/users/5886442/ubr"
                },
                "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": 1455341850,
                "post_id": 35376426,
                "comment_id": 58458651,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1455343594,
                "creation_date": 1455343594,
                "answer_id": 35376708,
                "question_id": 35376426,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As Jeff pointed out, it would be advisable to do everything in jq if\r\npossible, but even if a loop cannot be avoided, the eval most definitely can and probably should be, both for efficiency and\r\nto avoid complications.\r\n\r\nFor example, I suspect you could simply write:\r\n\r\n    jq --arg line &quot;$line&quot; &#39;\r\n      .Reservations[].Instances[]\r\n      | select(contains({Tags: [{Key: &quot;Name&quot;}, {Value: $line}]}))\r\n    &#39; describe-instances.json\r\n",
                "title": "using eval to execute jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1455471532,
                "creation_date": 1455471532,
                "answer_id": 35394916,
                "question_id": 35376426,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "thank you peak, couple of minor edits and your suggestion worked perfectly\r\n\r\n`\r\nwhile read line\r\n do\r\n        jq --arg line &quot;$line&quot; &#39;.Reservations[].Instances[] | select(contains({Tags: [{Key: &quot;Name&quot;}, {Value: &quot;line&quot;}]}))&#39; describe-instances.json;\r\ndone &lt; &quot;./instances-names&quot;\r\n`",
                "title": "using eval to execute jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1455471532,
        "creation_date": 1455340984,
        "last_edit_date": 1455341255,
        "question_id": 35376426,
        "body_markdown": "I&#39;m trying to run a jq filter in a loop, taking the key value that I&#39;m matching from a list in another file.\r\n\r\n\r\n    while read line\r\n    do\r\n        jqfilter=&quot;jq &#39;.Reservations[].Instances[] | select(contains({Tags: [{Key: &quot;Name&quot;}, {Value: &quot;$line&quot;}]}))&#39; describe-instances.json&quot;\r\n        eval &quot;$jqfilter&quot;;\r\n    done &lt; &quot;./list&quot;\r\n\r\nThe loop is working, `$line` is being substituted with the appropriate value. \r\n\r\nThe issue is with `{Key: &quot;Name&quot;}`, eval strips the quotes around NAME, and as a result the jq filter does not work.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/35376426/using-eval-to-execute-jq",
        "title": "using eval to execute jq"
    },
    {
        "tags": [
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1455529939,
                "post_id": 35402535,
                "comment_id": 58513547,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1455565947,
                "last_edit_date": 1455565947,
                "creation_date": 1455552479,
                "answer_id": 35413909,
                "question_id": 35402535,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can normalize the objects using:\r\n\r\n    def sortKeys: to_entries | sort | from_entries\r\n\r\nFor example, if A is an array of the unnormalized objects, you could write:\r\n\r\n    A | map(sortKeys)\r\n\r\nOr the objects could be normalized as soon as they are created.\r\n\r\nFor CSV, you might want to fix the order based on a pre-determined array of key names.  In that case, you could use:\r\n\r\n    def selectKeys(keys):\r\n      . as $in | reduce keys[] as $k ({}; . + {($k): $in[$k]})\r\n\r\n",
                "title": "joining jq arrays, for CSV output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1455572024,
        "creation_date": 1455516476,
        "last_edit_date": 1455572024,
        "question_id": 35402535,
        "body_markdown": "I&#39;m looking to create a CSV based on two json arrays (arrays are a reduction of a large jason array with key value pairs)\r\n\r\n    [\r\n      &quot;Name&quot;,\r\n      &quot;Role&quot;,\r\n      &quot;Type&quot;,\r\n      &quot;Service&quot;,\r\n      &quot;Group&quot;,\r\n    ]\r\n    [\r\n      &quot;some-server.com&quot;,\r\n      &quot;web server&quot;,\r\n      &quot;production&quot;,\r\n      &quot;apps&quot;,\r\n      &quot;main&quot;,\r\n    ]\r\n\r\nI&#39;m able to get a more less what I&#39;m looking for with:\r\n\r\n    jq -r &#39;[.Tags[].Key], [.Tags[].Value] | join (&quot;,&quot;)&#39; output.json\r\n\r\nThe issue is, the keys are not always sorted in the same order. For some objects I get:\r\n\r\n    Name, Role, Type\r\n\r\nand other times:\r\n\r\n    Role, Type Name ..\r\n\r\nI&#39;m looking for a way to make the output consistent.",
        "link": "https://stackoverflow.com/questions/35402535/joining-jq-arrays-for-csv-output",
        "title": "joining jq arrays, for CSV output"
    },
    {
        "tags": [
            "json",
            "diff",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1455756191,
                "post_id": 35469941,
                "comment_id": 58636693,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1455756254,
                "post_id": 35469941,
                "comment_id": 58636721,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1543622,
                    "reputation": 6380,
                    "user_id": 1932452,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://www.gravatar.com/avatar/7dfca62a1e4eb69f39ce00152862c70e?s=256&d=identicon&r=PG",
                    "display_name": "wyer33",
                    "link": "https://stackoverflow.com/users/1932452/wyer33"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1455765683,
                "post_id": 35469941,
                "comment_id": 58639498,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1455766857,
                "creation_date": 1455766857,
                "answer_id": 35472393,
                "question_id": 35469941,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If I understand the question correctly, the following should do the job.  I&#39;ll assume you have access to jq 1.5, which includes the filter walk/1 (if that is not the case, it&#39;s easy to supplement the file below with the definition, which can be found on the web, e.g. the src/builtin.jq file), and that you have a reasonably modern Mac or Linux-like shell.\r\n\r\n(1) Create a file called (let&#39;s say) jq-diff.jq with these two lines:\r\n\r\n    def sortKeys: to_entries | sort | from_entries;\r\n    walk( if type == &quot;object&quot; then sortKeys else . end )\r\n\r\n(2) Assuming the two files with JSON entities in them are FILE1 and FILE2, then run one of the following commands, depending on whether you want the JSON entities within each file to be sorted:\r\n\r\n    diff &lt;(jq -cf jq-diff.jq FILE1 | sort) &lt;(jq -cf jq-diff.jq FILE2 | sort)\r\n\r\n    # OR:\r\n\r\n    diff &lt;(jq -cf jq-diff.jq FILE1) &lt;(jq -cf jq-diff.jq FILE2)\r\n\r\n\r\nBrief explanation:\r\n\r\nThe role of jq here is to sort the keys in the objects (without sorting the arrays) and to print them in a standard way, one per line (courtesy of the -c option).  \r\n",
                "title": "Is there a method to obtain a diff for `JSON Lines` files?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1455817867,
                "creation_date": 1455817867,
                "answer_id": 35488821,
                "question_id": 35469941,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use the `-s` flag to slurp your newline-separated JSON objects into a JSON array containing them, thus making them eligible for comparison with `json-diff`.",
                "title": "Is there a method to obtain a diff for `JSON Lines` files?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1455857356,
        "creation_date": 1455752267,
        "last_edit_date": 1455857356,
        "question_id": 35469941,
        "body_markdown": "Is there a method to obtain a diff for `JSON Lines` files?  In case there&#39;s confusion, by &quot;JSON Lines&quot;, I mean the format described [here][1], which basically requires that every line is a valid JSON structure.  Anyway, there&#39;s an answer [here][2] that discusses using jq in order to diff two different JSON files.   \r\n  \r\nHowever, there, the question wanted the diff not to consider within-list ordering whereas I do care about that ordering.  In addition, the answers contain jq scripts that just give a true or false response and do not give a full diff.  Ideally, I&#39;d like a full diff.  There is a project call [json-diff][3] that does diff JSON files, but it only works for a single JSON entity, not with JSON lines.\r\n\r\nTo reiterate, is there a method or something like a jq script that can obtain a diff for JSON lines formatted files?\r\n\r\n\r\n  [1]: http://jsonlines.org/\r\n  [2]: https://stackoverflow.com/questions/31930041/using-jq-or-alternative-command-line-tools-to-diff-json-files\r\n  [3]: https://github.com/andreyvit/json-diff",
        "link": "https://stackoverflow.com/questions/35469941/is-there-a-method-to-obtain-a-diff-for-json-lines-files",
        "title": "Is there a method to obtain a diff for `JSON Lines` files?"
    },
    {
        "tags": [
            "bash",
            "hadoop",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1455814312,
                "last_edit_date": 1455814312,
                "creation_date": 1455808876,
                "answer_id": 35485439,
                "question_id": 35484244,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It looks like you somehow missed the `-f FILE` option!",
                "title": "JQ, Hadoop: taking command from a file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1459371686,
        "creation_date": 1455805913,
        "last_edit_date": 1459371686,
        "question_id": 35484244,
        "body_markdown": "I have been enjoying the powerful filters provided by `JQ` ([Doc][1]).\r\n\r\nTwitter&#39;s public API gives nicely formatted json files. I have access to a large amount of it, and I have access to a Hadoop cluster. There I decided to, instead of loading them in `Pig` using `Elephantbird`, try out `JQ` in mapper streaming to see if it is any faster.\r\n\r\nHere is my final query:\r\n\r\n    nohup hadoop jar $HADOOP_HOME/share/hadoop/tools/lib/hadoop-streaming-2.5.1.jar\\\r\n        -files $HOME/bin/jq \\\r\n        -D mapreduce.map.memory.mb=2048\\\r\n        -D mapred.output.compression.codec=org.apache.hadoop.io.compress.GzipCodec \\\r\n        -mapper &quot;./jq --raw-output &#39;select((.lang == \\&quot;en\\&quot;) and (.entities.hashtags | length &gt; 0)) | .entities.hashtags[] as \\$tags | [.id_str, .user.id_str, .created_at, \\$tags.text] | @csv&#39;&quot; \\\r\n        -reducer NONE \\\r\n        -input /path/to/input/*.json.gz \\\r\n        -output /path/to/output \\\r\n        &amp;\r\n\r\nI am distributing my local `jq` executable to every compute node and telling them to run my command with it for their `stdin` stream.\r\n\r\nThe query is long enough that I got into quoting and formatting issues in `bash` and `JQ`.\r\n\r\nI wish I could have written something like this:\r\n\r\n    nohup hadoop jar $HADOOP_HOME/share/hadoop/tools/lib/hadoop-streaming-2.5.1.jar\\\r\n            -files $HOME/bin/jq,$PROJECT_DIR/cmd.jq \\\r\n            -D mapreduce.map.memory.mb=2048\\\r\n            -D mapred.output.compression.codec=org.apache.hadoop.io.compress.GzipCodec \\\r\n            -mapper &quot;./jq --raw-output --run-cmd-file=cmd.jq&quot; \\\r\n            -reducer NONE \\\r\n            -input /path/to/input/*.json.gz \\\r\n            -output /path/to/output \\\r\n            &amp;\r\n\r\nwhere I can just put my command in a file, ship it to compute nodes and call it with an option.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/35484244/jq-hadoop-taking-command-from-a-file",
        "title": "JQ, Hadoop: taking command from a file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1455925929,
                "post_id": 35515770,
                "comment_id": 58724912,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1455926593,
                "creation_date": 1455926593,
                "answer_id": 35517321,
                "question_id": 35515770,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&quot;The whole line&quot; is not by itself a valid JSON object. You can get an object with all the elements that match your predicate; this would be one way of doing so:\r\n\r\n    jq &#39;.interfaces.UDPInterface[0].connectTo | with_entries(select(.value.user | contains(&quot;bob&quot;)))&#39;\r\n\r\nThe output for your given input would be:\r\n\r\n    {\r\n      &quot;1.2.3.4:25925&quot;: {\r\n        &quot;user&quot;: &quot;bob&quot;,\r\n        &quot;password&quot;: &quot;aaaaaaaa&quot;,\r\n        &quot;publicKey&quot;: &quot;foirncnqwpnqwopnqrrvn308g9h4b.k&quot;\r\n      }\r\n    }\r\n",
                "title": "JQ Select by child object value with varying parent object name"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1505971331,
                "last_edit_date": 1505971331,
                "creation_date": 1501894900,
                "answer_id": 45517247,
                "question_id": 35515770,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **tostream**, **select** and **foreach** to enumerate paths to objects with &quot;user:&quot;bob&quot; and return those objects in the desired format with **getpath**\r\n\r\n    foreach (   tostream\r\n              | select(length == 2 and .[0][-1] == &quot;user&quot; and .[1] == &quot;bob&quot;)\r\n              | .[0]\r\n            ) as $p (\r\n         .\r\n       ; .\r\n       ; { ($p[-2]): getpath($p[:-1]) }\r\n    )\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\r\n      ( tostream | select(length == 2 and .[0][-1] == &quot;user&quot; and .[1] == &quot;bob&quot;) | .[0] ) as $p\r\n    | { ($p[-2]): getpath($p[:-1]) }\r\n\r\n",
                "title": "JQ Select by child object value with varying parent object name"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1505971331,
        "creation_date": 1455918837,
        "last_edit_date": 1455930834,
        "question_id": 35515770,
        "body_markdown": "I have the json:\r\n\r\n    {\r\n      &quot;interfaces&quot;: {\r\n        &quot;UDPInterface&quot;: [\r\n          {\r\n            &quot;connectTo&quot;: {\r\n              &quot;1.2.3.4:25925&quot;: {\r\n                &quot;user&quot;: &quot;bob&quot;,\r\n                &quot;password&quot;: &quot;aaaaaaaa&quot;,\r\n                &quot;publicKey&quot;: &quot;foirncnqwpnqwopnqrrvn308g9h4b.k&quot;\r\n              },\r\n              &quot;4.3.2.1:24970&quot;: {\r\n                &quot;user&quot;: &quot;sam&quot;,\r\n                &quot;password&quot;: &quot;bbbbbbbb&quot;,\r\n                &quot;publicKey&quot;: &quot;v09ervn4uvr78cweyclfirnfuq3c9pwper.k&quot;\r\n              },\r\n              &quot;1.3.4.2:41872&quot;: {\r\n                &quot;user&quot;: &quot;betty&quot;,\r\n                &quot;password&quot;: &quot;cccccccccc&quot;,\r\n                &quot;publicKey&quot;: &quot;crnn497hg3j34f34uvrnfwmnriuhqrmoweje.k&quot;\r\n              }\r\n            },\r\n            &quot;bind&quot;: &quot;0.0.0.0:64660&quot;\r\n          },\r\n          {\r\n            &quot;connectTo&quot;: {},\r\n            &quot;bind&quot;: &quot;[::]:54887&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\n\r\n and would like to be able to use jq to print the contents of the IP address line based on the &quot;user&quot; value.  I can get close with this:\r\n\r\n    jq &#39;.interfaces.UDPInterface[0].connectTo.&quot;1.2.3.4:25925&quot; | select(.user | contains(&quot;bob&quot;))&#39;\r\n\r\nHowever, this gives me only the values for the 1.2.3.4:25925 object:\r\n\r\n    {&quot;user&quot; : &quot;bob&quot;, &quot;password&quot; : &quot;aaaaaaaa&quot;, &quot;publicKey&quot; : &quot;foirncnqwpnqwopnqrrvn308g9h4b.k&quot;},\r\n\r\nWhen what I need is the whole line:\r\n\r\n    &quot;1.2.3.4:25925&quot; : {&quot;user&quot; : &quot;bob&quot;, &quot;password&quot; : &quot;aaaaaaaa&quot;, &quot;publicKey&quot; : &quot;foirncnqwpnqwopnqrrvn308g9h4b.k&quot;},\r\n\r\nHowever, I can&#39;t figure out how to build such an expression without knowing the parent object name before hand (each IP address:port will be unique).\r\n\r\nI&#39;ve been beating my head against this all day and haven&#39;t been able to figure it out.  Any help would be very appreciated!\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/35515770/jq-select-by-child-object-value-with-varying-parent-object-name",
        "title": "JQ Select by child object value with varying parent object name"
    },
    {
        "tags": [
            "json",
            "sorting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 41,
                "is_accepted": true,
                "score": 41,
                "last_activity_date": 1456085574,
                "creation_date": 1456085574,
                "answer_id": 35541425,
                "question_id": 35540294,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In jq, arrays sort by the sorting of the elements they contain, in order. That is:\r\n\r\n    $ jq -n &#39;[1, 2] &lt; [1, 3], [1, 2] &lt; [2, 1]&#39;\r\n    true\r\n    true\r\n\r\nThe [`sort_by`](https://stedolan.github.io/jq/manual/#sort,sort_by(path_expression)) filter sorts an array, taking an expression as argument that will be evaluated for each member of the array. For example, if you wanted to sort a list of words by length:\r\n\r\n    $ jq -n &#39;[&quot;prop&quot;, &quot;leo&quot;, &quot;column&quot;, &quot;blast&quot;] | sort_by(length)&#39;\r\n    [\r\n      &quot;leo&quot;,\r\n      &quot;prop&quot;,\r\n      &quot;blast&quot;,\r\n      &quot;column&quot;\r\n    ]\r\n\r\nIf the expression given to `sort_by` as argument returns more than one value, the return values will be implicitly wrapped in an array, which will be subject to the array sorting rules referred to above. For example, if you wanted to sort a list of words by length, and then alphabetically:\r\n\r\n    $ jq -n &#39;[&quot;pro&quot;, &quot;leo&quot;, &quot;column&quot;, &quot;ablast&quot;] | sort_by(length, .)&#39;\r\n    [\r\n      &quot;leo&quot;,\r\n      &quot;pro&quot;,\r\n      &quot;ablast&quot;,\r\n      &quot;column&quot;\r\n    ]\r\n\r\nKnowing this, and taking into account that the values in your example are numeric, you can just do the following:\r\n\r\n    $ jq &#39;sort_by(-.prop1, .prop2)&#39;",
                "title": "Sort descending by multiple keys in jq"
            },
            {
                "up_vote_count": 14,
                "is_accepted": false,
                "score": 14,
                "last_activity_date": 1666781609,
                "creation_date": 1666781609,
                "answer_id": 74206592,
                "question_id": 35540294,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One may use the [`reverse`](https://stedolan.github.io/jq/manual/v1.5/#reverse) (_jq 1.5 Manual_) function like:\r\n\r\n```bash\r\n$ jq -n &#39;[&quot;pro&quot;, &quot;leo&quot;, &quot;column&quot;, &quot;ablast&quot;] | sort | reverse&#39;\r\n[\r\n  &quot;pro&quot;,\r\n  &quot;leo&quot;,\r\n  &quot;column&quot;,\r\n  &quot;ablast&quot;\r\n]\r\n```\r\n\r\nSo your specific example may become:\r\n\r\n```bash\r\n$ jq -n &#39;[{...}, {...}, {...}, {...}] | sort_by(.prop2) | reverse | sort_by(.prop1) | reverse&#39;\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Object 2&quot;,\r\n    &quot;prop1&quot;: 6,\r\n    &quot;prop2&quot;: 4\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Object 1&quot;,\r\n    &quot;prop1&quot;: 5,\r\n    &quot;prop2&quot;: 2\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Object 3&quot;,\r\n    &quot;prop1&quot;: 5,\r\n    &quot;prop2&quot;: 3\r\n  }\r\n]\r\n```\r\n\r\nSQL `ORDER BY prop1 DESC, prop2 ASC` → jq `| sort_by(.prop2) | reverse | sort_by(.prop1) | reverse` – Note, the sorting is specified with properties in the reverse order, and `reverse` is used twice.\r\n\r\nGiven `prop1` and `prop2` are numeric, the accepted answer (`sort_by(-.prop1, .prop2)`) is much simpler/better.",
                "title": "Sort descending by multiple keys in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 36,
        "last_activity_date": 1666781609,
        "creation_date": 1456080087,
        "last_edit_date": 1543384032,
        "question_id": 35540294,
        "body_markdown": "I have the following array:\r\n\r\n    [{\r\n        &quot;name&quot;: &quot;Object 1&quot;,\r\n        &quot;prop1&quot;: 5,\r\n        &quot;prop2&quot;: 2\r\n    }, {\r\n        &quot;name&quot;: &quot;Object 2&quot;,\r\n        &quot;prop1&quot;: 6,\r\n        &quot;prop2&quot;: 4\r\n    }, {\r\n        &quot;name&quot;: &quot;Object 3&quot;,\r\n        &quot;prop1&quot;: 5,\r\n        &quot;prop2&quot;: 3\r\n    }]\r\n\r\nI want to sort this array analogous to this SQL `ORDER BY prop1 DESC, prop2 ASC` so I have this result:\r\n\r\n    [{\r\n        &quot;name&quot;: &quot;Object 2&quot;,\r\n        &quot;prop1&quot;: 6,\r\n        &quot;prop2&quot;: 4\r\n    }, {\r\n        &quot;name&quot;: &quot;Object 1&quot;,\r\n        &quot;prop1&quot;: 5,\r\n        &quot;prop2&quot;: 2\r\n    }, {\r\n        &quot;name&quot;: &quot;Object 3&quot;,\r\n        &quot;prop1&quot;: 5,\r\n        &quot;prop2&quot;: 3\r\n    }]\r\n\r\nHow can I sort an array a) descending by a key and b) by multiple keys?\r\n\r\nVersion: jq 1.5",
        "link": "https://stackoverflow.com/questions/35540294/sort-descending-by-multiple-keys-in-jq",
        "title": "Sort descending by multiple keys in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1456201344,
                "last_edit_date": 1456201344,
                "creation_date": 1456195017,
                "answer_id": 35567763,
                "question_id": 35567519,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The key is the `transpose` filter.  The following:\r\n\r\n    .results[0] | [ .&quot;actividades/_text&quot;, .actividades ] | transpose\r\n\r\nproduces pairs such as:\r\n\r\n    [\r\n      &quot;Ciencias Naturales Logro y Autoevaluaci&#243;n&quot;,\r\n      &quot;http://www.domain.com/ArchivosCargados/2016/CUADRO-PRIMER-BIMESTRE-2016-PRIMERO.pdf&quot;\r\n    ]\r\n\r\nTo combine these pairs into a single object, tack on:\r\n\r\n    | map({ (.[0]):.[1]} ) | add\r\n\r\nTo produce the output in the form &quot;X&quot;:&quot;Y&quot; as you also indicated you want, you could use the following invocation:\r\n\r\n    jq -r  &#39;.results[0]\r\n    | [ .&quot;actividades/_text&quot;, .actividades ]\r\n    | transpose[]\r\n    | &quot;\\&quot;\\(.[0])\\&quot;:\\&quot;\\(.[1])\\&quot;&quot; &#39;\r\n\r\nWith your input, this last produces:\r\n\r\n    &quot;Ciencias Naturales Logro y Autoevaluaci&#243;n&quot;:&quot;http://www.domain.com/ArchivosCargados/2016/CUADRO-PRIMER-BIMESTRE-2016-PRIMERO.pdf&quot;\r\n    &quot;Ciencias Naturales Seres Vivos - Objetos Inertes&quot;:&quot;http://www.domain.com/ArchivosCargados/2016/Hojita-Seres-Vivos.pdf&quot;\r\n    ....\r\n    ....\r\n\r\n\r\n",
                "title": "pairwise combination of information from two embedded JSON arrays using terminal"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1456205476,
        "creation_date": 1456193279,
        "last_edit_date": 1456205476,
        "question_id": 35567519,
        "body_markdown": "I have a json file like this:\r\n\r\n    {&quot;offset&quot;:0,&quot;results&quot;:[{&quot;actividades/_text&quot;:[&quot;Ciencias Naturales Logro y Autoevaluaci&#243;n&quot;,&quot;Ciencias Naturales Seres Vivos - Objetos Inertes&quot;,&quot;Educaci&#243;n Art&#237;stica Contenidos&quot;,&quot;Educaci&#243;n Religiosa Dibujo&quot;,&quot;Educaci&#243;n Religiosa Estructura 1 Periodo&quot;,&quot;Educaci&#243;n Religiosa Comunicado&quot;,&quot;Educaci&#243;n Religiosa Respuesta Eucarist&#237;a&quot;,&quot;Educaci&#243;n Religiosa Eucarist&#237;a&quot;,&quot;Expresi&#243;n Corporal Estructura General&quot;,&quot;Expresi&#243;n Corporal Vestuario de Ensayo&quot;,&quot;Ingles Recomendaciones Generales 2016&quot;,&quot;Ingles Temas Logros Indicadores Todos los Periodos&quot;,&quot;Ingles Rules and oral expressions to be used in the classroom&quot;,&quot;Lengua Castellana Estructura Curricular&quot;,&quot;Matem&#225;ticas Temas Logros 1 Periodo&quot;,&quot;Matem&#225;ticas Taller #1&quot;,&quot;M&#250;sica Estructura 1 Periodo&quot;,&quot;Tecnolog&#237;a e Inform&#225;tica Support guide first term&quot;],&quot;actividades/_source&quot;:[&quot;/ArchivosCargados/2016/CUADRO-PRIMER-BIMESTRE-2016-PRIMERO.pdf&quot;,&quot;/ArchivosCargados/2016/Hojita-Seres-Vivos.pdf&quot;,&quot;/ArchivosCargados/2016/2016-CONTENIDOS-ARTES-PLASTICAS-PRIMARIA-J-T-12345.pdf&quot;,&quot;/ArchivosCargados/2016/PRIMERO-RELILGION.pdf&quot;,&quot;/ArchivosCargados/2016/Estructura-RELGION.pdf&quot;,&quot;/ArchivosCargados/2016/PRIMERO-RELIGION.pdf&quot;,&quot;/ArchivosCargados/2016/RESPUESTAS-EUCARISTIA.pdf&quot;,&quot;/ArchivosCargados/2016/respuestas-misa.pdf&quot;,&quot;/ArchivosCargados/2016/Estructura-general-grado-primero-2016.pdf&quot;,&quot;/ArchivosCargados/2016/VESTUARIO-CLASE-EXPRESION-CORPORAL-2016.pdf&quot;,&quot;/ArchivosCargados/2016/RECOMENDACIONES-GENERALES-2016.pdf&quot;,&quot;/ArchivosCargados/2016/TEMAS-LOGRO-INDICADORES-PERIODO.pdf&quot;,&quot;/ArchivosCargados/2016/ENGLISH-USED-IN-CLASS.pdf&quot;,&quot;/ArchivosCargados/2016/lc-1.pdf&quot;,&quot;/ArchivosCargados/2016/Temas-logros.pdf&quot;,&quot;/ArchivosCargados/2016/Taller1-16.pdf&quot;,&quot;/ArchivosCargados/2016/PROGRAMA-PLATAFORMA.pdf&quot;,&quot;/ArchivosCargados/2016/first-grade.pdf&quot;],&quot;actividades&quot;:[&quot;http://www.domain.com/ArchivosCargados/2016/CUADRO-PRIMER-BIMESTRE-2016-PRIMERO.pdf&quot;,&quot;http://www.domain.com/ArchivosCargados/2016/Hojita-Seres-Vivos.pdf&quot;,&quot;http://www.domain.com/ArchivosCargados/2016/2016-CONTENIDOS-ARTES-PLASTICAS-PRIMARIA-J-T-12345.pdf&quot;,&quot;http://www.domain.com/ArchivosCargados/2016/PRIMERO-RELILGION.pdf&quot;,&quot;http://www.domain.com/ArchivosCargados/2016/Estructura-RELGION.pdf&quot;,&quot;http://www.domain.com/ArchivosCargados/2016/PRIMERO-RELIGION.pdf&quot;,&quot;http://www.domain.com/ArchivosCargados/2016/RESPUESTAS-EUCARISTIA.pdf&quot;,&quot;http://www.domain.com/ArchivosCargados/2016/respuestas-misa.pdf&quot;,&quot;http://www.domain.com/ArchivosCargados/2016/Estructura-general-grado-primero-2016.pdf&quot;,&quot;http://www.domain.com/ArchivosCargados/2016/VESTUARIO-CLASE-EXPRESION-CORPORAL-2016.pdf&quot;,&quot;http://www.domain.com/ArchivosCargados/2016/RECOMENDACIONES-GENERALES-2016.pdf&quot;,&quot;http://www.domain.com/ArchivosCargados/2016/TEMAS-LOGRO-INDICADORES-PERIODO.pdf&quot;,&quot;http://www.domain.com/ArchivosCargados/2016/ENGLISH-USED-IN-CLASS.pdf&quot;,&quot;http://www.domain.com/ArchivosCargados/2016/lc-1.pdf&quot;,&quot;http://www.domain.com/ArchivosCargados/2016/Temas-logros.pdf&quot;,&quot;http://www.domain.com/ArchivosCargados/2016/Taller1-16.pdf&quot;,&quot;http://www.domain.com/ArchivosCargados/2016/PROGRAMA-PLATAFORMA.pdf&quot;,&quot;http://www.domain.com/ArchivosCargados/2016/first-grade.pdf&quot;]}],&quot;cookies&quot;:[&quot;ASP.NET_SessionId=\\&quot;0vy5tp45alrfik55q3bs24mr\\&quot;;Path=\\&quot;/\\&quot;;Domain=\\&quot;www.domain.com\\&quot;;Port=\\&quot;80\\&quot;&quot;],&quot;connectorVersionGuid&quot;:&quot;e35c3b39-301e-4474-b75e-5473963b1852&quot;,&quot;connectorGuid&quot;:&quot;b0fe3dd7-fd92-472b-b197-14d86f91c5fb&quot;,&quot;pageUrl&quot;:&quot;http://www.domain.com/principal.aspx?tbindex=3&amp;tab_codigo=33&quot;,&quot;outputProperties&quot;:[{&quot;name&quot;:&quot;actividades&quot;,&quot;type&quot;:&quot;URL&quot;}]}\r\n\r\nBasicly, i have three objects: actividades, actividades/_text and actividades/_source. I want to create a final json file that have pair actividades and actividades/_text, in the same order that appear in file, i mean, for example:\r\n\r\n\r\n    &quot;Ciencias Naturales Logro y Autoevaluaci&#243;n&quot;:&quot;http://www.domain.com/ArchivosCargados/2016/CUADRO-PRIMER-BIMESTRE-2016-PRIMERO.pdf&quot;\r\n\r\nI want to do this using the linux terminal and doesn&#39;t matter if i must install some utility. I tried with jq without success:\r\n\r\n    jq &#39;.actividades + .actividades/_text&#39; test.json \r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/35567519/pairwise-combination-of-information-from-two-embedded-json-arrays-using-terminal",
        "title": "pairwise combination of information from two embedded JSON arrays using terminal"
    },
    {
        "tags": [
            "json",
            "recursion",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1456338026,
                "creation_date": 1456338026,
                "answer_id": 35609995,
                "question_id": 35609548,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Yes, use `walk/1`.  It is explained in the [jq manual][1].\r\n\r\nIf your jq does not have it defined, here is its definition from [builtin.jq][2]:\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\r\n  [1]: https://stedolan.github.io/jq/manual/\r\n  [2]: https://raw.githubusercontent.com/stedolan/jq/master/src/builtin.jq",
                "title": "How to apply a function to all strings in record&#39;s structure recursively using jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1456353022,
                "creation_date": 1456353022,
                "answer_id": 35614530,
                "question_id": 35609548,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can also do this easily with the recurse operator:\r\n\r\n`jq &#39;(.. | strings) += &quot;\\&#39;&quot;&#39;`\r\n\r\nWhere `..` generates a stream by recursively iterating through every element of the input, `strings` filters the stream for those who are strings, `+=` adds the right-hand element to every element on the left-hand stream and `&quot;\\&#39;&quot;` is a literal containing the &quot;prime&quot; you seek.",
                "title": "How to apply a function to all strings in record&#39;s structure recursively using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501897589,
                "creation_date": 1501897589,
                "answer_id": 45517469,
                "question_id": 35609548,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **paths/1** to identify string values and updates them with **reduce**, **setpath** and **getpath**\r\n\r\n    reduce paths(type == &quot;string&quot;) as $p (\r\n        .\r\n      ; setpath($p; getpath($p) + &quot;&#39;&quot;)\r\n    )\r\n",
                "title": "How to apply a function to all strings in record&#39;s structure recursively using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1501897589,
        "creation_date": 1456336626,
        "last_edit_date": 1456515170,
        "question_id": 35609548,
        "body_markdown": "Is it possible to apply a recursive transformation to a record to return the same record, but having all `string` values mapped?\r\n\r\nFor example:\r\n\r\n    {&quot;x&quot;:&quot;1&quot;, &quot;a&quot;: {&quot;b&quot;: 2, &quot;c&quot;: [&quot;a&quot;]}, &quot;d&quot;: {&quot;e&quot;: &quot;z&quot;}}\r\n\r\nwith a mapping of &quot;add prime&quot; applied:\r\n\r\n    {&quot;x&quot;:&quot;1&#39;&quot;, &quot;a&quot;: {&quot;b&quot;: 2, &quot;c&quot;: [&quot;a&#39;&quot;]}, &quot;d&quot;: {&quot;e&quot;: &quot;z&#39;&quot;}}\r\n\r\nI&#39;ve tried using a combination of `recurse`, `map`, `string` and `select` with little luck. Any ideas?",
        "link": "https://stackoverflow.com/questions/35609548/how-to-apply-a-function-to-all-strings-in-records-structure-recursively-using-j",
        "title": "How to apply a function to all strings in record&#39;s structure recursively using jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1456349680,
                "post_id": 35611660,
                "comment_id": 58910940,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7913156,
                    "reputation": 13,
                    "user_id": 5976537,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/eb1072ac3887260cbd6a0ee42d972ad7?s=256&d=identicon&r=PG",
                    "display_name": "zippo",
                    "link": "https://stackoverflow.com/users/5976537/zippo"
                },
                "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": 1456355477,
                "post_id": 35611660,
                "comment_id": 58913802,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1456349306,
                "creation_date": 1456349306,
                "answer_id": 35613508,
                "question_id": 35611660,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can simply verify that both tests return true with `all`:\r\n\r\n    echo &#39;{&quot;color&quot;: &quot;red&quot;, &quot;shapes&quot;: [ &quot;square&quot;, &quot;triangle&quot; ]}&#39; |\r\n      jq &#39;[(.[&quot;color&quot;] | test(&quot;red&quot;)),\r\n           (any(.shapes[]; contains(&quot;round&quot;))|not)\r\n          ] | all&#39;\r\n\r\nCreate an array containing the results of each test, then pipe that array to `all`.",
                "title": "Combining multiple tests in validating JSON content with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1456436756,
                "last_edit_date": 1456436756,
                "creation_date": 1456368843,
                "answer_id": 35617353,
                "question_id": 35611660,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A correct way to test a collection of conditions is using `and`.\r\n\r\nIn your case, a correct test would be:\r\n\r\n    (.color == &quot;red&quot;) and (.shapes|index(&quot;round&quot;) == null)\r\n\r\nExample (typescript):\r\n\r\n    jq &#39;(.color == &quot;red&quot;) and (.shapes|index(&quot;round&quot;) == null)&#39;\r\n    {&quot;color&quot;: &quot;red&quot;, &quot;shapes&quot;: [ &quot;square&quot;, &quot;triangle&quot; ]}\r\n    true\r\n\r\nIn jq, `not` is a syntactically ordinary filter, so you could write the second condition as: `(.shapes | index(&quot;round&quot;) | not)`.",
                "title": "Combining multiple tests in validating JSON content with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1456436756,
        "creation_date": 1456343351,
        "last_edit_date": 1456349551,
        "question_id": 35611660,
        "body_markdown": "I have following JSON object\r\n\r\n    {&quot;color&quot;: &quot;red&quot;, &quot;shapes&quot;: [ &quot;square&quot;, &quot;triangle&quot; ]}\r\n\r\nI would like to validate the JSON object using [jq][1] using following conditions:\r\n\r\n - *color* has value &quot;red&quot;\r\n - *shapes* does not contain value &quot;round&quot;\r\n\r\nThe returned result should be either **true** or **false**.\r\n\r\nI have 2 jq command which validate both conditions, but I&#39;m not sure how to combine this into 1 expression:\r\n\r\n    json=&#39;{&quot;color&quot;: &quot;red&quot;, &quot;shapes&quot;: [ &quot;square&quot;, &quot;triangle&quot; ]}&#39;\r\n    echo &quot;$json&quot; | jq &#39;.[&quot;color&quot;] | test(&quot;red&quot;)&#39;\r\n    echo &quot;$json&quot; | jq &#39;any(.shapes[]; contains(&quot;round&quot;))|not&#39;\r\n\r\nAny pointers or help would be appreciated.\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/35611660/combining-multiple-tests-in-validating-json-content-with-jq",
        "title": "Combining multiple tests in validating JSON content with jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "hierarchical-data",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 363026,
                    "reputation": 2465,
                    "user_id": 706532,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MKEAp.jpg?s=256",
                    "display_name": "Kordi",
                    "link": "https://stackoverflow.com/users/706532/kordi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1456394388,
                "post_id": 35623663,
                "comment_id": 58929842,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7497667,
                    "reputation": 547,
                    "user_id": 5697282,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/1b4115927261cdfb2af064b4a48906d2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "econ",
                    "link": "https://stackoverflow.com/users/5697282/econ"
                },
                "reply_to_user": {
                    "account_id": 363026,
                    "reputation": 2465,
                    "user_id": 706532,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MKEAp.jpg?s=256",
                    "display_name": "Kordi",
                    "link": "https://stackoverflow.com/users/706532/kordi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1456394612,
                "post_id": 35623663,
                "comment_id": 58930016,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3941049,
                    "reputation": 52992,
                    "user_id": 3255455,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df163b8a55fa3258785cca0bfe5f224c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "gnasher729",
                    "link": "https://stackoverflow.com/users/3255455/gnasher729"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1456394741,
                "post_id": 35623663,
                "comment_id": 58930101,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7497667,
                    "reputation": 547,
                    "user_id": 5697282,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/1b4115927261cdfb2af064b4a48906d2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "econ",
                    "link": "https://stackoverflow.com/users/5697282/econ"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1456394836,
                "post_id": 35623663,
                "comment_id": 58930168,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1456395624,
                "creation_date": 1456395624,
                "answer_id": 35624458,
                "question_id": 35623663,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use &#39;https://github.com/zemirco/json2csv&#39; with the `flatten` option. This will generate columns like `cod:e1!!@23.typeA.lsk:d##fjd.title`. \r\n\r\n    cat input.json | json2csv -F &gt;&gt; output.csv\r\n\r\n**EDIT**: This is not what you want. ",
                "title": "Extracting data from an unusual JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1456402967,
                "creation_date": 1456402967,
                "answer_id": 35627187,
                "question_id": 35623663,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a jq script that traverses the &quot;leaf elements&quot; in the input and makes a CSV column out of every key it goes through:\r\n\r\n    jq -r &#39;leaf_paths as $path | $path + [getpath($path)] | @csv&#39;\r\n    \r\nNote that this is not exactly what you&#39;re looking for:\r\n\r\n    &quot;cod:e1!!@23&quot;,&quot;typeA&quot;,&quot;lsk:d##fjd&quot;,&quot;title&quot;,&quot;slkdfjlkdjfd&quot;\r\n    &quot;cod:e1!!@23&quot;,&quot;typeA&quot;,&quot;lsk:d##fjd&quot;,&quot;year&quot;,&quot;2014&quot;\r\n    &quot;cod:e1!!@23&quot;,&quot;typeA&quot;,&quot;sdfdsfsd&quot;,&quot;title&quot;,&quot;slkdfjlkdjfddewfsdfd&quot;\r\n    &quot;cod:e1!!@23&quot;,&quot;typeA&quot;,&quot;sdfdsfsd&quot;,&quot;year&quot;,&quot;2015&quot;\r\n    &quot;cod:e1!!@23&quot;,&quot;Ct@ype&quot;,&quot;sd$!!fs:$dfds&quot;,&quot;title&quot;,&quot;slkdfjsdfsdfdsfsd&quot;\r\n    &quot;cod:e1!!@23&quot;,&quot;Ct@ype&quot;,&quot;sd$!!fs:$dfds&quot;,&quot;year&quot;,&quot;2012&quot;",
                "title": "Extracting data from an unusual JSON"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1456439100,
                "last_edit_date": 1456439100,
                "creation_date": 1456403754,
                "answer_id": 35627505,
                "question_id": 35623663,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A small modification to the script you provide in the initial post makes it work. Instead of using .[], I index by the specific key that is saved as variable from `keys_unsorted`. I also added a header to the CSV for convenience:\r\n\r\n    jq -r &#39;[&quot;x&quot;, &quot;y&quot;, &quot;z&quot;, &quot;title&quot;, &quot;year&quot;],\r\n      (keys_unsorted[] as $x\r\n       | .[$x] | keys_unsorted[] as $y\r\n       | .[$y] | keys_unsorted[] as $z\r\n       | .[$z] | [$x, $y, $z, .title, .year]) | @csv&#39;\r\n\r\nThis does provide the output you&#39;re looking for (with a header):\r\n\r\n    &quot;x&quot;,&quot;y&quot;,&quot;z&quot;,&quot;title&quot;,&quot;year&quot;\r\n    &quot;cod:e1!!@23&quot;,&quot;typeA&quot;,&quot;lsk:d##fjd&quot;,&quot;slkdfjlkdjfd&quot;,&quot;2014&quot;\r\n    &quot;cod:e1!!@23&quot;,&quot;typeA&quot;,&quot;sdfdsfsd&quot;,&quot;slkdfjlkdjfddewfsdfd&quot;,&quot;2015&quot;\r\n    &quot;cod:e1!!@23&quot;,&quot;Ct@ype&quot;,&quot;sd$!!fs:$dfds&quot;,&quot;slkdfjsdfsdfdsfsd&quot;,&quot;2012&quot;",
                "title": "Extracting data from an unusual JSON"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1456512818,
                "last_edit_date": 1456512818,
                "creation_date": 1456443130,
                "answer_id": 35640541,
                "question_id": 35623663,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following provides a general solution for regularly structured\r\nnested objects (loosely speaking, they can be thought of &quot;babushka objects&quot;, like the nested dolls); furthermore, the keys within objects can be ordered in any way.\r\n\r\nThe key concept is that of &quot;scalar objects&quot; -- objects all of whose\r\nkeys have scalar values.\r\n\r\nA template for the information to be extracted from the &quot;scalar\r\nobjects&quot; is provided as a parameter to the &#39;emit&#39; filter and is used\r\nto ensure that the appropriate order is maintained when producing\r\nthe CSV lines.\r\n\r\n    def emit(template):\r\n    \r\n      def is_scalar_object:\r\n        def is_scalar: type | ((. != &quot;object&quot;) and (. != &quot;array&quot;));\r\n        . as $in | (type == &quot;object&quot;) and all($in[] | is_scalar);\r\n    \r\n      . as $in\r\n      | paths as $path\r\n      | select(getpath($path) | is_scalar_object)\r\n      | $path + [ template + ($in | getpath($path)) | .[]]\r\n      ;\r\n      \r\n\r\n    data | emit( {title,  year} ) | @csv\r\n\r\nUsage:\r\n\r\n     jq -r emit.jq input.json\r\n\r\nOutput:\r\n\r\n    &quot;cod:e1!!@23&quot;,&quot;typeA&quot;,&quot;lsk:d##fjd&quot;,&quot;slkdfjlkdjfd&quot;,&quot;2014&quot;\r\n    &quot;cod:e1!!@23&quot;,&quot;typeA&quot;,&quot;sdfdsfsd&quot;,&quot;slkdfjlkdjfddewfsdfd&quot;,&quot;2015&quot;\r\n    &quot;cod:e1!!@23&quot;,&quot;Ct@ype&quot;,&quot;sd$!!fs:$dfds&quot;,&quot;slkdfjsdfsdfdsfsd&quot;,&quot;2012&quot;",
                "title": "Extracting data from an unusual JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1456549716,
        "creation_date": 1456393663,
        "last_edit_date": 1456549716,
        "question_id": 35623663,
        "body_markdown": "Is there a way to make a nice CSV out of the following JSON code?\r\n\r\n    {\r\n    \t&quot;cod:e1!!@23&quot; : {\r\n    \t\t&quot;typeA&quot; : {\r\n    \t\t\t&quot;lsk:d##fjd&quot;: {\r\n    \t\t\t\t&quot;title&quot; : &quot;slkdfjlkdjfd&quot;,\r\n    \t\t\t\t&quot;year&quot; : &quot;2014&quot;\r\n    \t\t\t},\r\n    \t\t&quot;sdfdsfsd&quot; : {\r\n    \t\t\t&quot;title&quot; : &quot;slkdfjlkdjfddewfsdfd&quot;,\r\n    \t\t\t&quot;year&quot; : &quot;2015&quot;\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t&quot;Ct@ype&quot; : {\r\n    \t\t\t&quot;sd$!!fs:$dfds&quot; : {\r\n    \t\t\t\t&quot;title&quot; : &quot;slkdfjsdfsdfdsfsd&quot;,\r\n    \t\t\t\t&quot;year&quot; : &quot;2012&quot;\r\n    \t\t\t}\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\nHere&#39;s what I tried in jq:\r\n\r\n    jq -rc &#39;keys[] as $x \r\n      | .[]|keys[] as $y\r\n      | .[]|keys[] as $z\r\n      |.[]\r\n      |[$x,$y,$z,.year] | @csv&#39;\r\n    \r\n    jq -rc &#39;keys_unsorted[] as $x\r\n      | .[]|keys_unsorted[] as $y\r\n      | .[]|keys_unsorted[] as $z\r\n      | .[]|[$x,$y,$z,.year] | @csv&#39;\r\n\r\nBut the output is not correct, because if there are several such records then  the keys come out as sorted and permuted. I also tried keys_unsorted, but it didn&#39;t resolve the issue.\r\n\r\nFixing the original JSON generation is not an option at this point in time, so any help will be appreciated.\r\n\r\nIdeally, I would get:\r\n\r\n    &quot;cod:e1!!@23&quot;,&quot;typeA&quot;,&quot;lsk:d##fjd&quot;,&quot;slkdfjlkdjfd&quot;,&quot;2014&quot;\r\n    &quot;cod:e1!!@23&quot;,&quot;typeA&quot;,&quot;sdfdsfsd&quot;,&quot;slkdfjlkdjfddewfsdfd&quot;,&quot;2015&quot;\r\n    &quot;cod:e1!!@23&quot;,&quot;Ct@ype&quot;,&quot;sd$!!fs:$dfds&quot;,&quot;slkdfjsdfsdfdsfsd&quot;,&quot;2012&quot;\r\n",
        "link": "https://stackoverflow.com/questions/35623663/extracting-data-from-an-unusual-json",
        "title": "Extracting data from an unusual JSON"
    },
    {
        "tags": [
            "iteration",
            "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": 1456627532,
                "post_id": 35677309,
                "comment_id": 59034658,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 112,
                "is_accepted": true,
                "score": 112,
                "last_activity_date": 1456681366,
                "last_edit_date": 1456681366,
                "creation_date": 1456621121,
                "answer_id": 35677443,
                "question_id": 35677309,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The command-line tool `jq` writes to STDOUT and/or STDERR.  If you want to write the .AssetId information to STDOUT, then one possibility would be as follows: \r\n\r\n    jq -r &quot;.[] | .AssetId&quot; input.json\r\n\r\nOutput:\r\n\r\n    14462955\r\n    114385498\r\n    29715011\r\n    98253651\r\n\r\nA more robust incantation would be: `.[] | .AssetId?` but your choice will depend on what you want if there is no key named &quot;AssetId&quot;.",
                "title": "Output specific key value in object for each element in array with jq for JSON"
            },
            {
                "up_vote_count": 30,
                "is_accepted": false,
                "score": 30,
                "last_activity_date": 1624889274,
                "last_edit_date": 1624889274,
                "creation_date": 1493367962,
                "answer_id": 43675516,
                "question_id": 35677309,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also do it via this command.\r\n```shell\r\njq &quot;.[].AssetId&quot; input.json\r\n```\r\n\r\nif array like be that which is in my case \r\n```json\r\n{  \r\n   &quot;resultCode&quot;:0,\r\n   &quot;resultMsg&quot;:&quot;SUCCESS&quot;,\r\n   &quot;uniqueRefNo&quot;:&quot;111222333&quot;,\r\n   &quot;list&quot;:[  \r\n      {  \r\n         &quot;cardType&quot;:&quot;CREDIT CARD&quot;,\r\n         &quot;isBusinessCard&quot;:&quot;N&quot;,\r\n         &quot;memberName&quot;:&quot;Bank A&quot;,\r\n         &quot;memberNo&quot;:10,\r\n         &quot;prefixNo&quot;:404591\r\n      },\r\n      {  \r\n         &quot;cardType&quot;:&quot;DEBIT CARD&quot;,\r\n         &quot;isBusinessCard&quot;:&quot;N&quot;,\r\n         &quot;memberName&quot;:&quot;Bank A&quot;,\r\n         &quot;memberNo&quot;:10,\r\n         &quot;prefixNo&quot;:407814\r\n      },\r\n      {  \r\n         &quot;cardType&quot;:&quot;CREDIT CARD&quot;,\r\n         &quot;isBusinessCard&quot;:&quot;N&quot;,\r\n         &quot;memberName&quot;:&quot;Bank A&quot;,\r\n         &quot;memberNo&quot;:10,\r\n         &quot;prefixNo&quot;:413226\r\n      }\r\n   ]\r\n}\r\n```\r\nyou can get the prefixNo with below jq command.\r\n```shell\r\njq &quot;.list[].prefixNo&quot; input.json\r\n```\r\nFor more specific case on array iterating on jq you can check [this blogpost][1]\r\n\r\n\r\n  [1]: http://arjanvandergaag.nl/blog/wrestling-json-with-jq.html",
                "title": "Output specific key value in object for each element in array with jq for JSON"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1554202874,
                "creation_date": 1554202874,
                "answer_id": 55473147,
                "question_id": 35677309,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "you have a couple of choices to do the loop itself. you can apply peak&#39;s awesome answer and wrap a shell loop around it. replace echo with the script you want to run. \r\n\r\n### via xargs\r\n\r\n    $ jq -r &quot;.[] | .AssetId&quot; input.json | xargs -n1 echo  # this would print\r\n    14462955\r\n    114385498\r\n    29715011\r\n    98253651\r\n\r\n### via raw loop\r\n    $ for i in $(jq -r &quot;.[] | .AssetId&quot; input.json)\r\n      do\r\n        echo $i\r\n      done\r\n    14462955\r\n    114385498\r\n    29715011\r\n    98253651\r\n",
                "title": "Output specific key value in object for each element in array with jq for JSON"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1575800100,
                "creation_date": 1575800100,
                "answer_id": 59234387,
                "question_id": 35677309,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An alternative using `map`:\r\n\r\n    jq &quot;map ( .AssetId ) | .[]&quot;",
                "title": "Output specific key value in object for each element in array with jq for JSON"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1657711095,
                "creation_date": 1657711095,
                "answer_id": 72965385,
                "question_id": 35677309,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For your case  `jq -r &#39;.[].AssetId&#39;` should work \r\n\r\nYou can also use online JQ Parser : https://jqplay.org/ \r\n\r\n[![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/hOD8n.png\r\n\r\nIf you want to loop through the each value then can use below  :\r\n\r\n```\r\nfor i in $(echo $api_response | jq -r &quot;.[].AssetId&quot;)\r\n  do\r\n    echo echo $i \r\n  done\r\n```",
                "title": "Output specific key value in object for each element in array with jq for JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 94,
        "last_activity_date": 1657711095,
        "creation_date": 1456619950,
        "last_edit_date": 1575799418,
        "question_id": 35677309,
        "body_markdown": "I have an array:\r\n\r\n    [\r\n        {\r\n            &quot;AssetId&quot;: 14462955,\r\n            &quot;Name&quot;: &quot;Cultural Item&quot;\r\n        },\r\n        {\r\n            &quot;AssetId&quot;: 114385498,\r\n            &quot;Name&quot;: &quot;Redspybot&quot;\r\n        },\r\n        {\r\n            &quot;AssetId&quot;: 29715011,\r\n            &quot;Name&quot;: &quot;American Cowboy&quot;\r\n        },\r\n        {\r\n            &quot;AssetId&quot;: 98253651,\r\n            &quot;Name&quot;: &quot;Mahem&quot;\r\n        }\r\n    ]\r\n\r\n\r\n   \r\nI would like to loop through each object in this array, and pick out the value of each key called `AssetId` and output it.\r\nHow would I do this using jq for the command line?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/35677309/output-specific-key-value-in-object-for-each-element-in-array-with-jq-for-json",
        "title": "Output specific key value in object for each element in array with jq for JSON"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1456859682,
                "creation_date": 1456859682,
                "answer_id": 35731478,
                "question_id": 35730999,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Specify the jq -C option explicitly.",
                "title": "How to add line numbers to JQ output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1456859853,
        "creation_date": 1456858228,
        "question_id": 35730999,
        "body_markdown": "I was curious if there is a clean way to add line numbers to `jq`&#39;s output while still retaining the coloring of the output. I have tried piping from `jq` to `cat -n` but unfortunately this removes the coloring which helps a lot when traversing the JSON tree.",
        "link": "https://stackoverflow.com/questions/35730999/how-to-add-line-numbers-to-jq-output",
        "title": "How to add line numbers to JQ output"
    },
    {
        "tags": [
            "json",
            "jq",
            "jsonlines"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1500392670,
                "post_id": 35750563,
                "comment_id": 77311097,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1456935592,
                "last_edit_date": 1456935592,
                "creation_date": 1456931643,
                "answer_id": 35751125,
                "question_id": 35750563,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If I&#39;m understanding correctly, the JSONL format just returns a stream of JSON objects which jq handles quite nicely.  Best case scenario that you wanted the first item, you could just utilize the [`input`][1] filter to grab the first item.\r\n\r\nI think you could just do this:\r\n\r\n    $ curl -s http://example.org/file.jsonl | jq -n &#39;input&#39;\r\n\r\nYou need the null input `-n` to not process the input immediately then `input` just gets one input from the stream.  No need to go through the rest of the input stream.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#input",
                "title": "Efficiently get the first record of a JSONL file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1457474067,
        "creation_date": 1456930287,
        "last_edit_date": 1457474067,
        "question_id": 35750563,
        "body_markdown": "Is it possible to efficiently get the first record of a [JSONL][1] file without consuming the entire stream / file? One way I have been able to inefficiently do so is the following:\r\n\r\n&gt; curl -s http://example.org/file.jsonl | jq -s &#39;.[0]&#39;\r\n\r\nI realize that `head` could be used here to extract the first line, but assume that the file may not use a newline as the record separator and may simply be concatenated objects or arrays. \r\n\r\n  [1]: http://jsonlines.org/",
        "link": "https://stackoverflow.com/questions/35750563/efficiently-get-the-first-record-of-a-jsonl-file",
        "title": "Efficiently get the first record of a JSONL file"
    },
    {
        "tags": [
            "json",
            "nagios",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1456960196,
                "creation_date": 1456960196,
                "answer_id": 35760057,
                "question_id": 35759488,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    $ cat extract.jq\r\n    .data.hostgroups[]\r\n    | .name as $Group\r\n    | .hosts[]\r\n    | [$Group, .name, .time_up, .time_down, .time_unreachable,\r\n       .scheduled_time_up, .scheduled_time_down, \r\n       .scheduled_time_unreachable, .time_indeterminate_nodata, \r\n       .time_indeterminate_notrunning]\r\n    | @csv\r\n    \r\n    \r\n    $ jq -r -f extract.jq in.json\r\n    &quot;ATL&quot;,&quot;ATL-SERVER1&quot;,2496629,8970,0,0,0,0,0,0\r\n    &quot;ATL&quot;,&quot;ATL-SERVER2&quot;,2505525,74,0,0,0,0,0,0\r\n    &quot;LAX&quot;,&quot;LAX-SERVER1&quot;,2505599,0,0,0,0,0,0,0\r\n    &quot;LAX&quot;,&quot;LAX-SERVER2&quot;,2505599,0,0,0,0,0,0,0",
                "title": "How to use jq to iterate through Nagios JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1456960196,
        "creation_date": 1456957872,
        "question_id": 35759488,
        "body_markdown": "I&#39;m trying to figure out how to parse the following JSON without having to explicitly indicate the array index in multiple commands.  I just need to associate the hostgroup on a single line with all of the host information.\r\n\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;selectors&quot;: {\r\n        },\r\n        &quot;hostgroups&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;ATL&quot;,\r\n            &quot;hosts&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;ATL-SERVER1&quot;,\r\n                &quot;time_up&quot;: 2496629,\r\n                &quot;time_down&quot;: 8970,\r\n                &quot;time_unreachable&quot;: 0,\r\n                &quot;scheduled_time_up&quot;: 0,\r\n                &quot;scheduled_time_down&quot;: 0,\r\n                &quot;scheduled_time_unreachable&quot;: 0,\r\n                &quot;time_indeterminate_nodata&quot;: 0,\r\n                &quot;time_indeterminate_notrunning&quot;: 0\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;ATL-SERVER2&quot;,\r\n                &quot;time_up&quot;: 2505525,\r\n                &quot;time_down&quot;: 74,\r\n                &quot;time_unreachable&quot;: 0,\r\n                &quot;scheduled_time_up&quot;: 0,\r\n                &quot;scheduled_time_down&quot;: 0,\r\n                &quot;scheduled_time_unreachable&quot;: 0,\r\n                &quot;time_indeterminate_nodata&quot;: 0,\r\n                &quot;time_indeterminate_notrunning&quot;: 0\r\n              }\r\n            ]\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;LAX&quot;,\r\n            &quot;hosts&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;LAX-SERVER1&quot;,\r\n                &quot;time_up&quot;: 2505599,\r\n                &quot;time_down&quot;: 0,\r\n                &quot;time_unreachable&quot;: 0,\r\n                &quot;scheduled_time_up&quot;: 0,\r\n                &quot;scheduled_time_down&quot;: 0,\r\n                &quot;scheduled_time_unreachable&quot;: 0,\r\n                &quot;time_indeterminate_nodata&quot;: 0,\r\n                &quot;time_indeterminate_notrunning&quot;: 0\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;LAX-SERVER2&quot;,\r\n                &quot;time_up&quot;: 2505599,\r\n                &quot;time_down&quot;: 0,\r\n                &quot;time_unreachable&quot;: 0,\r\n                &quot;scheduled_time_up&quot;: 0,\r\n                &quot;scheduled_time_down&quot;: 0,\r\n                &quot;scheduled_time_unreachable&quot;: 0,\r\n                &quot;time_indeterminate_nodata&quot;: 0,\r\n                &quot;time_indeterminate_notrunning&quot;: 0\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nThe following commands will get me what I need:\r\n\r\n    .data.hostgroups[0].name as $Group | {$Group} + .data.hostgroups[0].hosts[] | [.Group, .name, .time_up, .time_down, .time_unreachable, .scheduled_time_up, .scheduled_time_down, .scheduled_time_unreachable, .time_indeterminate_nodata, .time_indeterminate_notrunning] | @csv\r\n    .data.hostgroups[1].name as $Group | {$Group} + .data.hostgroups[1].hosts[] | [.Group, .name, .time_up, .time_down, .time_unreachable, .scheduled_time_up, .scheduled_time_down, .scheduled_time_unreachable, .time_indeterminate_nodata, .time_indeterminate_notrunning] | @csv\r\n\r\nBut I&#39;ve been trying to figure out how to do this in one line.  I have 20 hostgroups, so this is 20 commands in my script.\r\n\r\nAll of the comparable examples I&#39;ve found seem to apply to only pulling a single field out of the array (in my example it is host[]). For example, this will work fine:\r\n\r\n    map(.data.hostgroups | map({Group: .name, Host: .hosts[].name} | [.Group, .Host])) | add[] | @csv\r\n\r\nAnd the output is:\r\n\r\n    &quot;ATL&quot;,&quot;ATL-SERVER1&quot;\r\n    &quot;ATL&quot;,&quot;ATL-SERVER2&quot;\r\n    &quot;LAX&quot;,&quot;LAX-SERVER1&quot;\r\n    &quot;LAX&quot;,&quot;LAX-SERVER2&quot;\r\n\r\nBut when I add an additional field in, for example:\r\n\r\n    map(.data.hostgroups | map({Group: .name, Host: .hosts[].name, Uptime: .hosts[].time_up} | [.Group, .Host, .Uptime])) | add[] | @csv\r\n\r\nThe output is:\r\n\r\n    &quot;ATL&quot;,&quot;ATL-SERVER1&quot;,2496629\r\n    &quot;ATL&quot;,&quot;ATL-SERVER1&quot;,2505525\r\n    &quot;ATL&quot;,&quot;ATL-SERVER2&quot;,2496629\r\n    &quot;ATL&quot;,&quot;ATL-SERVER2&quot;,2505525\r\n    &quot;LAX&quot;,&quot;LAX-SERVER1&quot;,2505599\r\n    &quot;LAX&quot;,&quot;LAX-SERVER1&quot;,2505599\r\n    &quot;LAX&quot;,&quot;LAX-SERVER2&quot;,2505599\r\n    &quot;LAX&quot;,&quot;LAX-SERVER2&quot;,2505599\r\n\r\n\r\nFor every field I add, it basically multiplies them together. And I&#39;m pretty sure I understand why that is, but I&#39;m still trying to figure out how to one line this while avoiding the problem of exponentially combining the results.\r\n\r\nCan anyone help me out?\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/35759488/how-to-use-jq-to-iterate-through-nagios-json",
        "title": "How to use jq to iterate through Nagios JSON"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1457014232,
                "last_edit_date": 1457014232,
                "creation_date": 1456968292,
                "answer_id": 35761431,
                "question_id": 35760856,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One approach is to use `..`.  For example, provided the input is valid JSON:\r\n\r\n    $ jq &#39;.. | .url? | select(.)&#39; input.json\r\n    &quot;http://example.com&quot;\r\n\r\nOr equivalently (and easier to type):\r\n\r\n    $ jq &#39;.. | .url? // empty&#39; input.json\r\n",
                "title": "Getting the contents of an unknown key"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1503867844,
                "creation_date": 1503867844,
                "answer_id": 45909344,
                "question_id": 35760856,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **tostream**.  If `filter.jq` contains\r\n\r\n      tostream\r\n    | select(length==2) as [$p,$v]\r\n    | if $p[-1] == &quot;url&quot; and ($v|endswith(&quot;.zip&quot;)) then $v else empty end\r\n\r\nand if `data.json` contains (note outer { } added to make the example legal JSON and a second entry added to demonstrate excluding values not ending in `.zip` as asked in follow-up comment to [peak](https://stackoverflow.com/users/997358/peak)&#39;s answer)\r\n\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;bar&quot;: {\r\n          &quot;x1234&quot;: {\r\n            &quot;url&quot;: &quot;http://example.com&quot;\r\n          },\r\n          &quot;x1234xxx&quot;: {\r\n            &quot;url&quot;: &quot;http://example.com/file.zip&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nthen the command\r\n\r\n    jq -M -f filter.jq data.json\r\n\r\nproduces\r\n\r\n    &quot;http://example.com/file.zip&quot;",
                "title": "Getting the contents of an unknown key"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1542412200,
                "creation_date": 1542412200,
                "answer_id": 53346835,
                "question_id": 35760856,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming `foo` and `bar` are known, you could just do\r\n```\r\n.foo.bar[].url\r\n```\r\n\r\nLet&#39;s say if `bar` is also unknown, then do the following\r\n```\r\n.foo[][].url\r\n```",
                "title": "Getting the contents of an unknown key"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 5,
        "last_activity_date": 1542412200,
        "creation_date": 1456964566,
        "last_edit_date": 1539374839,
        "question_id": 35760856,
        "body_markdown": "I am trying to get the value of the &#39;url&#39; name which sits underneath a name that I do not know up front. e.g. it&#39;s not &#39;name&#39; or &#39;size&#39; - just a string that another tool generates - example &quot;x1234&quot; is not known to me by name:  \r\n\r\n    &quot;foo&quot;: {\r\n      &quot;bar&quot;: {\r\n        &quot;x1234&quot;: {\r\n          &quot;url&quot;: &quot;http://example.com&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nso jq &quot;.foo.bar&quot; returns the &quot;x1234&quot; fragment but what I need is the &quot;url&quot; value underneath it. I&#39;ve tried many things after reading the docs but I wasn&#39;t able to figure out the right syntax.\r\n\r\nCan anyone tell me where I&#39;m going wrong?",
        "link": "https://stackoverflow.com/questions/35760856/getting-the-contents-of-an-unknown-key",
        "title": "Getting the contents of an unknown key"
    },
    {
        "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": 1457059240,
                "post_id": 35785809,
                "comment_id": 59245137,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1457059748,
                "last_edit_date": 1457059748,
                "creation_date": 1457059203,
                "answer_id": 35787002,
                "question_id": 35785809,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There are many possibilities, some better than others.  Here&#39;s a reasonable approach, assuming you have a Mac or Linux-like shell:\r\n\r\n    $ var=&quot;value1:value2&quot;\r\n    $ jq --arg var &quot;$var&quot; &#39;select(.name==$var) | .EndDate&#39; test.json\r\n    &quot;2016-09-05T09:59:59Z&quot;\r\n\r\nTo see more clearly what&#39;s going on, here is an equivalent invocation:\r\n\r\n    $ jq --arg v &quot;$var&quot; &#39;select(.name==$v) | .EndDate&#39; test.json\r\n\r\n&lt;small&gt;\r\nYour approach can of course also be made to work, e.g.\r\n\r\n    $ jq &quot;select(.name==\\&quot;&quot;&quot;${var}&quot;&quot;\\&quot;) | .EndDate&quot; test.json\r\n    &quot;2016-09-05T09:59:59Z&quot;\r\n\r\nbut as you&#39;ve already seen, it&#39;s easy to get lost in the tangle of backslashes and quotation marks.\r\n   \r\n&lt;/small&gt;",
                "title": "jq select with variable that has colon"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1457059748,
        "creation_date": 1457051262,
        "question_id": 35785809,
        "body_markdown": "I have the following test.json file\r\n\r\n    {\r\n\t&quot;name&quot;: &quot;value1:value2&quot;,\r\n\t&quot;StartDate&quot;: &quot;2015-09-01T04:00:00Z&quot;,\r\n\t&quot;EndDate&quot;: &quot;2016-09-05T09:59:59Z&quot;\r\n    }\r\n\r\nThe following jq command works on command line:\r\n\r\n    jq &#39;select(.name==&quot;value1:value2&quot;) | .EndDate&#39; test.json\r\n\r\nHowever, if I try to execute same command in my bash script with a variable i.e.\r\n\r\n    var=&quot;value1:value2&quot;\r\n    endDateVar=$(jq &quot;select(.name==&quot;&quot;${var}&quot;) | .EndDate&quot; test.json)\r\n\r\nI get the following error: \r\n\r\n    error: syntax error, unexpected &#39;:&#39;\r\n    select(.name==value1:value2) | .EndDate                                            1 compile error\r\n\r\nAny ideas?\r\n",
        "link": "https://stackoverflow.com/questions/35785809/jq-select-with-variable-that-has-colon",
        "title": "jq select with variable that has colon"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 43,
                "is_accepted": true,
                "score": 43,
                "last_activity_date": 1457348950,
                "last_edit_date": 1495535380,
                "creation_date": 1457348950,
                "answer_id": 35842157,
                "question_id": 35841309,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use parentheses to evaluate `$key` early as in:\r\n\r\n     jq --null-input --arg key foobar &#39;{($key): &quot;value&quot;}&#39;\r\n\r\nSee also: https://stackoverflow.com/questions/33700997/parentheses-in-jq-for-key",
                "title": "Construct JSON with a variable key using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1639093367,
                "last_edit_date": 1639093367,
                "creation_date": 1588857286,
                "answer_id": 61658731,
                "question_id": 35841309,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also use [String interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-%5C(foo)) in `jq` which is of the form `&quot;\\(..)&quot;`. Inside the string, you can put an expression inside parens after a backslash. Whatever the expression returns will be interpolated into the string. \r\n\r\nYou can do below. The contents of the variable `key` is expanded and returned as a string by the interpolation sequence.\r\n\r\n    jq --null-input --arg key foobar &#39;{ &quot;\\($key)&quot;: &quot;value&quot;}&#39;",
                "title": "Construct JSON with a variable key using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 24,
        "last_activity_date": 1639093367,
        "creation_date": 1457346406,
        "last_edit_date": 1504670346,
        "question_id": 35841309,
        "body_markdown": "I am trying to use `jq` to construct a hash in which a key name comes from a variable. Something like this:\r\n\r\n\r\n    jq --null-input --arg key foobar &#39;{$key: &quot;value&quot;}&#39;\r\n\r\nThis doesn&#39;t work, however, and gives the following error:\r\n\r\n    error: syntax error, unexpected &#39;$&#39;\r\n    {$key: &quot;value&quot;} 1 compile error\r\n",
        "link": "https://stackoverflow.com/questions/35841309/construct-json-with-a-variable-key-using-jq",
        "title": "Construct JSON with a variable key using jq"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1457390463,
                "creation_date": 1457390463,
                "answer_id": 35855587,
                "question_id": 35855226,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The easiest way to convert an array into an object is arguably via the [`from_entries`](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries) function, like so:\r\n\r\n    map({key: .name, value: del(.name)}) | from_entries",
                "title": "Extract an object&#39;s property value and use that as the dictionary key"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1457391558,
                "creation_date": 1457391558,
                "answer_id": 35855853,
                "question_id": 35855226,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The simplest approach here would be to create the three objects in the array and then &quot;add&quot; them:\r\n\r\n     map( { (.name): del(.name) } ) | add\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;Product one&quot;: {\r\n        &quot;productId&quot;: &quot;12345&quot;,\r\n        &quot;itemCode&quot;: &quot;7037&quot;\r\n      },\r\n      &quot;Product two&quot;: {\r\n        &quot;productId&quot;: &quot;67890&quot;,\r\n        &quot;itemCode&quot;: &quot;9101&quot;\r\n      },\r\n      &quot;Product three&quot;: {\r\n        &quot;productId&quot;: &quot;111213&quot;,\r\n        &quot;itemCode&quot;: &quot;7047&quot;\r\n      }\r\n    }\r\n\r\n",
                "title": "Extract an object&#39;s property value and use that as the dictionary key"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501961016,
                "creation_date": 1501961016,
                "answer_id": 45525641,
                "question_id": 35855226,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using **reduce**:\r\n    \r\n    reduce .[] as $e (\r\n         {}\r\n       ; .[$e.name] = ($e | del(.name))\r\n    )\r\n",
                "title": "Extract an object&#39;s property value and use that as the dictionary key"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1501961016,
        "creation_date": 1457389067,
        "last_edit_date": 1457664698,
        "question_id": 35855226,
        "body_markdown": "I have input in this format:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;:&quot;Product one&quot;,\r\n        &quot;productId&quot;:&quot;12345&quot;,\r\n        &quot;itemCode&quot;:&quot;7037&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;:&quot;Product two&quot;,\r\n        &quot;productId&quot;:&quot;67890&quot;,\r\n        &quot;itemCode&quot;:&quot;9101&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;:&quot;Product three&quot;,\r\n        &quot;productId&quot;:&quot;111213&quot;,\r\n        &quot;itemCode&quot;:&quot;7047&quot;\r\n      }\r\n    ]\r\n\r\nFor each object in the array, I want to take the value of the name property, and use it as the property name for the resulting object. The output I want is:\r\n\r\n    {\r\n      &quot;Product one&quot;: {\r\n        &quot;productId&quot;:&quot;12345&quot;,\r\n        &quot;itemCode&quot;:&quot;7037&quot;\r\n      },\r\n      &quot;Product two&quot;: {\r\n        &quot;productId&quot;:&quot;67890&quot;,\r\n        &quot;itemCode&quot;:&quot;9101&quot;\r\n      },\r\n      &quot;Product three&quot;: {\r\n        &quot;productId&quot;:&quot;111213&quot;,\r\n        &quot;itemCode&quot;:&quot;7047&quot;\r\n      }\r\n    }\r\n\r\nHere&#39;s the closest I was able to get to it:\r\n\r\n    .[] |  { (.name) : { productId: .productId, vendorId: .vendorId } }\r\n\r\nHere&#39;s the output that produces:\r\n\r\n    {\r\n      &quot;Product one&quot;: {\r\n        &quot;productId&quot;: &quot;12345&quot;,\r\n        &quot;vendorId&quot;: null\r\n      }\r\n    }\r\n    {\r\n      &quot;Product two&quot;: {\r\n        &quot;productId&quot;: &quot;67890&quot;,\r\n        &quot;vendorId&quot;: null\r\n      }\r\n    }\r\n    {\r\n      &quot;Product three&quot;: {\r\n        &quot;productId&quot;: &quot;111213&quot;,\r\n        &quot;vendorId&quot;: null\r\n      }\r\n    }\r\n\r\nThat creates double-nested products, and doesn&#39;t include spaces between them.\r\n\r\nThanks for any help in advance.",
        "link": "https://stackoverflow.com/questions/35855226/extract-an-objects-property-value-and-use-that-as-the-dictionary-key",
        "title": "Extract an object&#39;s property value and use that as the dictionary key"
    },
    {
        "tags": [
            "json",
            "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": 1457466553,
                "post_id": 35876490,
                "comment_id": 59416747,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3805594,
                    "reputation": 937,
                    "user_id": 3158121,
                    "user_type": "registered",
                    "accept_rate": 27,
                    "profile_image": "https://www.gravatar.com/avatar/88ca93ab0058bc4a4a8af9bdcf460f47?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paul Ericson",
                    "link": "https://stackoverflow.com/users/3158121/paul-ericson"
                },
                "reply_to_user": {
                    "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": 1457467209,
                "post_id": 35876490,
                "comment_id": 59417123,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 21,
                "is_accepted": false,
                "score": 20,
                "last_activity_date": 1612626496,
                "last_edit_date": 1612626496,
                "creation_date": 1457467152,
                "answer_id": 35876912,
                "question_id": 35876490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In this particular case, the simplest would be:\r\n\r\n    del(.Array[1])\r\n\r\nMore generally, if you wanted to delete all items in the array except for the first:\r\n\r\n    .Array |= [.[0]]\r\n\r\n",
                "title": "How to remove an array element with jq?"
            },
            {
                "up_vote_count": 68,
                "is_accepted": false,
                "score": 68,
                "last_activity_date": 1503868483,
                "creation_date": 1503868483,
                "answer_id": 45909442,
                "question_id": 35876490,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Regarding the second part of [Paul Ericson](https://stackoverflow.com/users/3158121/paul-ericson)&#39;s question\r\n\r\n&gt; But more generically, I&#39;m trying to understand how jq would allow for selective array element control. Maybe next time I want to delete array elements 1,3,5 and 11.\r\n\r\nTo delete elements 1,3,5 and 11 just use\r\n\r\n    del(\r\n        .Array[1,3,5,11]\r\n    )\r\n\r\nbut in general you can use a more sophisticated filter as the argument to `del`.  For example, this filter removes the elements within `.Array` whose `.foobar2` key is `&quot;barfoo2&quot;`:\r\n\r\n    del(\r\n        .Array[]\r\n      | select(.foobar2 == &quot;barfoo2&quot;)\r\n    )\r\n\r\nproducing in this example\r\n\r\n    {\r\n      &quot;blah0&quot;: &quot;zeroblah&quot;,\r\n      &quot;Array&quot;: [\r\n        {\r\n          &quot;blah1&quot;: [\r\n            &quot;key1:val1&quot;\r\n          ],\r\n          &quot;foobar0&quot;: &quot;barfoo0&quot;,\r\n          &quot;foobar1&quot;: &quot;barfoo1&quot;\r\n        }\r\n      ]\r\n    }\r\n",
                "title": "How to remove an array element with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 48,
        "last_activity_date": 1612626496,
        "creation_date": 1457465803,
        "question_id": 35876490,
        "body_markdown": "I&#39;m trying to figure out how to remove an array element from some JSON using jq.\r\nBelow is the input and desired output.\r\n\r\n    jq .Array[0] \r\n\r\noutputs the array element I want. \r\n\r\n    {\r\n          &quot;blah1&quot;: [\r\n            &quot;key1:val1&quot;\r\n          ],\r\n          &quot;foobar0&quot;: &quot;barfoo0&quot;,\r\n          &quot;foobar1&quot;: &quot;barfoo1&quot;\r\n        }\r\n\r\n\r\nBut how do I re-wrap this with:\r\n\r\n    {\r\n      &quot;blah0&quot;: &quot;zeroblah&quot;,\r\n      &quot;Array&quot;: [\r\n    \r\nand\r\n\r\n      ]\r\n    }\r\n\r\nInput:\r\n\r\n    {\r\n      &quot;blah0&quot;: &quot;zeroblah&quot;,\r\n      &quot;Array&quot;: [\r\n        {\r\n          &quot;blah1&quot;: [\r\n            &quot;key1:val1&quot;\r\n          ],\r\n          &quot;foobar0&quot;: &quot;barfoo0&quot;,\r\n          &quot;foobar1&quot;: &quot;barfoo1&quot;\r\n        },\r\n        {\r\n          &quot;blah2&quot;: [\r\n            &quot;key2:val2&quot;\r\n          ],\r\n          &quot;foobar2&quot;: &quot;barfoo2&quot;,\r\n          &quot;foobar3&quot;: &quot;barfoo3&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nDesired output:\r\n\r\n    {\r\n      &quot;blah0&quot;: &quot;zeroblah&quot;,\r\n      &quot;Array&quot;: [\r\n        {\r\n          &quot;blah1&quot;: [\r\n            &quot;key1:val1&quot;\r\n          ],\r\n          &quot;foobar0&quot;: &quot;barfoo0&quot;,\r\n          &quot;foobar1&quot;: &quot;barfoo1&quot;\r\n        }\r\n      ]\r\n    }",
        "link": "https://stackoverflow.com/questions/35876490/how-to-remove-an-array-element-with-jq",
        "title": "How to remove an array element with jq?"
    },
    {
        "tags": [
            "json",
            "partitioning",
            "jq",
            "filesplitting"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1457491368,
                "post_id": 35881458,
                "comment_id": 59426798,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1457492675,
                "post_id": 35881458,
                "comment_id": 59427189,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2494190,
                    "reputation": 9049,
                    "user_id": 2171044,
                    "user_type": "registered",
                    "accept_rate": 66,
                    "profile_image": "https://www.gravatar.com/avatar/9b7dfc105c40f4d209589fe6a3b72939?s=256&d=identicon&r=PG",
                    "display_name": "Chris Conover",
                    "link": "https://stackoverflow.com/users/2171044/chris-conover"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1457496332,
                "post_id": 35881458,
                "comment_id": 59428107,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1457497748,
                "last_edit_date": 1457497748,
                "creation_date": 1457491899,
                "answer_id": 35882003,
                "question_id": 35881458,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;d recommend using jq to split-up the array into a stream of the JSON objects you want (one per line), and then using some other tool (e.g. awk) to populate the files.  Here&#39;s how the first part can be done:\r\n\r\n    def splitup(n):\r\n      def _split:\r\n        if length == 0 then empty\r\n        else .[0:n], (.[n:] | _split)\r\n        end;\r\n      if n == 0 then empty elif n &gt; 0 then _split else reverse|splitup(-n) end;\r\n    \r\n    # For the sake of illustration:\r\n    def data: { results: [range(0,20)]};\r\n    \r\n    data | .results | {results: splitup(5) }\r\n\r\nInvocation:\r\n\r\n    $ jq -nc -f splitup.jq\r\n    {&quot;results&quot;:[0,1,2,3,4]}\r\n    {&quot;results&quot;:[5,6,7,8,9]}\r\n    {&quot;results&quot;:[10,11,12,13,14]}\r\n    {&quot;results&quot;:[15,16,17,18,19]}\r\n\r\nFor the second part, you could (for example) pipe the jq output to:\r\n\r\n      awk &#39;{ file=&quot;file.&quot;++n; print &gt; file; close(file); }&#39;\r\n\r\nA variant you might be interested in would have the jq filter emit both the filename and the JSON on alternate lines; the awk script would then read the filename as well.\r\n\r\n",
                "title": "Splitting / chunking JSON files with JQ in Bash or Fish shell?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1457635242,
        "creation_date": 1457488007,
        "last_edit_date": 1457635242,
        "question_id": 35881458,
        "body_markdown": "I have been using the wonderful [JQ library](https://stedolan.github.io/jq/) to parse and extract JSON data to facilitate re-importing.  I am able to extract a range easily enough, but am unsure as to how you could loop through in a script and detect the end of the file, preferably in a bash or fish shell script.\r\n\r\nGiven a JSON file that is wrapped in a _&quot;results&quot;_ dictionary, how can I detect the end of the file?  \r\n\r\nFrom testing, I can see that I will get an empty array nested in my desired structure, but how can you detect the end of file condition?:\r\n\r\n    jq &#39;{ &quot;results&quot;: .results[0:500] }&#39; Foo.json &gt; 0000-0500/Foo.json\r\n\r\nThanks!\r\n",
        "link": "https://stackoverflow.com/questions/35881458/splitting-chunking-json-files-with-jq-in-bash-or-fish-shell",
        "title": "Splitting / chunking JSON files with JQ in Bash or Fish shell?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1457570135,
                "creation_date": 1457570135,
                "answer_id": 35905453,
                "question_id": 35904882,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I assume you mean `isSparse`.  The `select` filter takes in something that evaluates to a boolean value. `isSparse` is already a boolean so you just need to select it.  `contains` is used for checking if something is in another container (a string, array, object, etc.).\r\n\r\n    $ jq -c &#39;.[] | select(.isSparse)&#39; &lt;blob&gt;",
                "title": "Using jq to extract values in JSON array with a particular key boolean == true?"
            },
            {
                "up_vote_count": 24,
                "is_accepted": false,
                "score": 24,
                "last_activity_date": 1457576446,
                "creation_date": 1457576446,
                "answer_id": 35906432,
                "question_id": 35904882,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If the task is to &quot;print the IDs of all entries in the array that have isSparse == true&quot;, an appropriate jq filter would be:\r\n\r\n    .[] | select(.isSparse == true) | .id\r\n\r\nIf there is any possibility of duplicate .id values, then the following could be used to ensure only distinct values are emitted:\r\n\r\n    map( select(.isSparse == true) | .id ) | unique[]\r\n\r\nAs @JeffMercado pointed out, if .isSparse is strictly boolean, then select(.isSparse) would suffice. \r\n\r\n",
                "title": "Using jq to extract values in JSON array with a particular key boolean == true?"
            },
            {
                "up_vote_count": 12,
                "is_accepted": false,
                "score": 11,
                "last_activity_date": 1472727787,
                "creation_date": 1472727787,
                "answer_id": 39269819,
                "question_id": 35904882,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I add this answer as it may be helpful in future for a related scenario. - \r\nA specific example of this would be accessing a poorly written API which returns the same key/value pair differently depending on which endpoint or filters were used.  This is highly annoying when interfacing, and the value is a string sometimes and a boolean at other times (furthermore, sometimes even a number, or a number as a string :| )\r\n\r\n----\r\n\r\n\r\n\r\nAdding `| tostring` will compare the value as desired;\r\n\r\n`cat &lt;blob&gt; | jq -c &#39;.[] | select(.isSparse | tostring | contains(&quot;true&quot;))&#39;`\r\n\r\nor for an exact match, slight variant:\r\n\r\n`cat &lt;blob&gt; | jq -c &#39;.[] | select((.isSparse | tostring) == &quot;true&quot;)&#39;`\r\n\r\n\r\n",
                "title": "Using jq to extract values in JSON array with a particular key boolean == true?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 24,
        "last_activity_date": 1472727787,
        "creation_date": 1457566837,
        "question_id": 35904882,
        "body_markdown": "So I have a JSON blob as below:\r\n\r\n    [\r\n      {\r\n        &#39;id&#39;: &#39;something&#39;,\r\n        &#39;isSparse&#39;: true\r\n      },\r\n      ...\r\n    ]\r\n\r\nHow do I write a `jq` command that&#39;ll filter out this JSON blob and *print me the IDs of all entries in the array that have isSparse == true?*\r\n\r\nI tried the following:\r\n\r\n`cat &lt;blob&gt; | jq -c &#39;.[] | select(.operational | contains(&quot;true&quot;))&#39;`\r\n\r\nbut get the following, because obviously `true` is a boolean and not a string:\r\n\r\n`jq: error: boolean and string cannot have their containment checked`.",
        "link": "https://stackoverflow.com/questions/35904882/using-jq-to-extract-values-in-json-array-with-a-particular-key-boolean-true",
        "title": "Using jq to extract values in JSON array with a particular key boolean == true?"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1457640918,
                "creation_date": 1457640918,
                "answer_id": 35926355,
                "question_id": 35926285,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Something like:\r\n\r\n    jq &#39;to_entries[] | select(.value &gt; 10) | .key&#39;",
                "title": "jq command to filter keys based on value being &gt; a number?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1457643188,
                "last_edit_date": 1457643188,
                "creation_date": 1457641246,
                "answer_id": 35926453,
                "question_id": 35926285,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    to_entries[] | select( .value&gt;10 ) | .key\r\n\r\nproduces a stream of keys:\r\n\r\n    &quot;thing_one&quot;\r\n    &quot;thing_four&quot;\r\n    &quot;thing_five&quot;\r\n\r\nUse the -r command-line option to remove the quotation marks.\r\n\r\nTo widen your horizons, consider these alternatives:\r\n\r\n    keys[] as $key\r\n    | if .[$key] &gt; 10 then $key else empty end\r\n\r\nUsing `foreach`:\r\n\r\n    foreach keys[] as $key (.; .; if .[$key] &gt; 10 then $key else empty end)\r\n\r\nAs for the best, I think you&#39;ll find that the second alternative above is the most succinct of the best performing possibilities in jq. ",
                "title": "jq command to filter keys based on value being &gt; a number?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501901111,
                "creation_date": 1501901111,
                "answer_id": 45517701,
                "question_id": 35926285,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **delpaths** and **paths** to remove values &lt;= 10\r\n\r\n    delpaths([paths(. &lt;= 10)])\r\n",
                "title": "jq command to filter keys based on value being &gt; a number?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666129135,
                "creation_date": 1666129135,
                "answer_id": 74117728,
                "question_id": 35926285,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Building on [jq170727&#39;s answer](https://stackoverflow.com/a/45517701/112968), you can stream the paths, without having to invert the condition and delete everything else:\r\n\r\n```\r\npaths(.&gt;10)[]\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n&quot;thing_one&quot;\r\n&quot;thing_four&quot;\r\n&quot;thing_five&quot;\r\n```\r\n\r\nTo get the _exact_ output from your question, join the values:\r\n\r\n```\r\n[paths(.&gt;10)[]] | join(&quot;, &quot;)\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n&quot;thing_one, thing_four, thing_five&quot;\r\n```",
                "title": "jq command to filter keys based on value being &gt; a number?"
            }
        ],
        "is_answered": false,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1666129135,
        "creation_date": 1457640699,
        "last_edit_date": 1457642215,
        "question_id": 35926285,
        "body_markdown": "I have a simple JSON blob as below:\r\n\r\n    {\r\n      &quot;thing_one&quot;: 223,\r\n      &quot;thing_two&quot;: 0,\r\n      &quot;thing_three&quot;: 0,\r\n      &quot;thing_four&quot;: 69,\r\n      &quot;thing_five&quot;: 14,\r\n      &quot;thing_six&quot;: 0\r\n    }\r\n\r\nI want to select the keys whose value is &gt; 10. I want the output of my `jq` command to return a list containing just the keys that meet this criterion. In the above example, it would return `&quot;thing_one, thing_four, thing_five&quot;`. What is the best way to do this?",
        "link": "https://stackoverflow.com/questions/35926285/jq-command-to-filter-keys-based-on-value-being-a-number",
        "title": "jq command to filter keys based on value being &gt; a number?"
    },
    {
        "tags": [
            "bash",
            "amazon-web-services",
            "aws-cli",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1458157496,
                "creation_date": 1458157496,
                "answer_id": 36045536,
                "question_id": 36044151,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Probably not the best but, this worked\r\n\r\n    #!/usr/local/bin/bash\r\n    # aws ~/.aws/credentials and s3cmd must be configured first with proper creds\r\n\r\n    target=&#39;&#39;\r\n    for key in $(aws s3 ls s3://$target --recursive |awk &#39;{print$4}&#39;) ; do\r\n      [ &quot;${key: -1}&quot; == &quot;/&quot; ] || {\r\n        award=$(aws s3api get-object-acl --bucket $target --key $key |jq &#39;.Grants[].Grantee | .URI&#39; |grep -v &#39;null&#39; |grep AllUsers)\r\n\r\n        [ ! -z &quot;${award}&quot; ] &amp;&amp; {\r\n          policy=$(aws s3api get-object-acl --bucket $target --key $key)\r\n          echo &quot;$target: $key\\n$policy\\n\\n&quot; &gt;&gt; /tmp/policy-backup.json\r\n          echo -e &quot;Working on: $key&quot;\r\n\r\n          s3cmd setacl s3://$target/$key --acl-private  ## s3cmd must be comfigured to your env\r\n        }\r\n      }\r\n    done\r\n",
                "title": "Remove AllUsers from ACL policy in bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1458159004,
                "creation_date": 1458159004,
                "answer_id": 36045965,
                "question_id": 36044151,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a jq filter which will remove all the .Grants array elements for which .Grantee.URI is &quot;http://acs.amazonaws.com/groups/global/AllUsers&quot;:\r\n\r\n    .Grants |= map( select(.Grantee.URI != &quot;http://acs.amazonaws.com/groups/global/AllUsers&quot;) )\r\n\r\nOutput: as requested",
                "title": "Remove AllUsers from ACL policy in bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1458751250,
                "creation_date": 1458751250,
                "answer_id": 36183934,
                "question_id": 36044151,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can do using the built in `--query` option in the AWS CLI.  The benefit being you don&#39;t need any external tools:\r\n\r\n     aws s3api get-object-acl --bucket $BUCKET --key $KEY  \\\r\n       --query &quot;{Owner: Owners, \\\r\n                 Grants: Grants[?Grantee.URI != &#39;http://acs.amazonaws.com/groups/global/AllUsers&#39;]}&quot;",
                "title": "Remove AllUsers from ACL policy in bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503870164,
                "creation_date": 1503870164,
                "answer_id": 45909608,
                "question_id": 36044151,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In this problem the specified grant can also be removed directly with `del`. e.g\r\n\r\n    del(\r\n        .Grants[]\r\n      | select(.Grantee.URI == &quot;http://acs.amazonaws.com/groups/global/AllUsers&quot;)\r\n    )\r\n",
                "title": "Remove AllUsers from ACL policy in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1503870164,
        "creation_date": 1458153161,
        "last_edit_date": 1458157520,
        "question_id": 36044151,
        "body_markdown": "I have a response from aws like this\r\n\r\n\r\n    {\r\n      &quot;Owner&quot;: {\r\n        &quot;DisplayName&quot;: &quot;2414218.aws&quot;,\r\n        &quot;ID&quot;: &quot;xxxxxxxx&quot;\r\n      },\r\n      &quot;Grants&quot;: [\r\n        {\r\n          &quot;Grantee&quot;: {\r\n            &quot;DisplayName&quot;: &quot;2414218.aws&quot;,\r\n            &quot;ID&quot;: &quot;yyyyyyyyyy&quot;\r\n          },\r\n          &quot;Permission&quot;: &quot;FULL_CONTROL&quot;\r\n        },\r\n        {\r\n          &quot;Grantee&quot;: {\r\n            &quot;URI&quot;: &quot;http://acs.amazonaws.com/groups/global/AllUsers&quot;\r\n          },\r\n          &quot;Permission&quot;: &quot;READ&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nI am looking to update the files so AllUsers is removed (get-object-acl should look like the below)\r\n\r\n    {\r\n      &quot;Owner&quot;: {\r\n        &quot;DisplayName&quot;: &quot;2414218.aws&quot;,\r\n        &quot;ID&quot;: &quot;xxxxxxxx&quot;\r\n      },\r\n      &quot;Grants&quot;: [\r\n        {\r\n          &quot;Grantee&quot;: {\r\n            &quot;DisplayName&quot;: &quot;2414218.aws&quot;,\r\n            &quot;ID&quot;: &quot;yyyyyyyyyy&quot;\r\n          },\r\n          &quot;Permission&quot;: &quot;FULL_CONTROL&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nHow would I do this, not knowing what other grantees are available? I am specifically looking to remove a grantee when I see `http://acs.amazonaws.com/groups/global/AllUsers`\r\n\r\nI am currently using `aws s3api get-object-acl --bucket mhe-deployments-prod --key $keyFile | jq &#39;.&#39;` to locate the policies\r\n",
        "link": "https://stackoverflow.com/questions/36044151/remove-allusers-from-acl-policy-in-bash",
        "title": "Remove AllUsers from ACL policy in bash"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1458236145,
                "creation_date": 1458236145,
                "answer_id": 36067843,
                "question_id": 36066961,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to group the objects by their keys.  You can access the keys if you map the objects as entries.  Then with the group, build out the result objects.\r\n\r\nYou can use this filter:\r\n\r\n    map(to_entries | add)\r\n        | group_by(.key)\r\n        | map({ (.[0].key): map(.value) | add })\r\n",
                "title": "jq: Objects with array values not combining as expected"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1458327961,
                "last_edit_date": 1458327961,
                "creation_date": 1458318885,
                "answer_id": 36089673,
                "question_id": 36066961,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The implementation of `group_by/1` requires a sort, so here is an alternative approach that uses a generically useful filter, `addvalues`, that does not require any sorting.  Notice that the only requirement placed on the objects in the input array is that at each key, the values must be compatible with respect to `add`.\r\n\r\n    # Given an array of objects, combine keys using add/0.\r\n    # This implementation does not depend on sorting.\r\n    def addvalues:\r\n      reduce .[] as $o\r\n        ( {}; reduce ($o|keys[]) as $key\r\n          ( .; . + {($key): (.[$key] + $o[$key])} ));\r\n\r\n\r\n    addvalues\r\n",
                "title": "jq: Objects with array values not combining as expected"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501902449,
                "creation_date": 1501902449,
                "answer_id": 45517784,
                "question_id": 36066961,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a version similar to [peak](https://stackoverflow.com/users/997358/peak)&#39;s **addvalues** solution indented and commented a bit for clarity.  It uses += to combine the arrays\r\n\r\n    reduce .[] as $i (                 #     $i: {&quot;Name1&quot;:[{&quot;Item1&quot;:&quot;Val1&quot;,&quot;Item2&quot;:&quot;Val2&quot;}]}\r\n         {}                            #\r\n       ; reduce ($i|keys[]) as $k (    #     $k: &quot;Name1&quot;\r\n              .                        #\r\n            ; .[$k] += $i[$k]          # $i[$k]: [{&quot;Item1&quot;:&quot;Val1&quot;,&quot;Item2&quot;:&quot;Val2&quot;}]\r\n         )\r\n    )",
                "title": "jq: Objects with array values not combining as expected"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1501902449,
        "creation_date": 1458233630,
        "question_id": 36066961,
        "body_markdown": "I am having trouble using jq to combine multiple objects.  In this case, MY_OBJECTS is a stream of json objects with a single key each.  I combine them into a single array as follows:\r\n\r\n    $ echo ${MY_OBJECTS} | jq -s &#39;.&#39;\r\n    [\r\n      {\r\n        &quot;Name1&quot;: [\r\n          {\r\n            &quot;Item1&quot;: &quot;Val1&quot;,\r\n            &quot;Item2&quot;: &quot;Val2&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;Name1&quot;: [\r\n          {\r\n            &quot;Item1&quot;: &quot;Val3&quot;,\r\n            &quot;Item2&quot;: &quot;Val4&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;Name2&quot;: [\r\n          {\r\n            &quot;Item1&quot;: &quot;Val5&quot;,\r\n            &quot;Item2&quot;: &quot;Val6&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;Name2&quot;: [\r\n          {\r\n            &quot;Item1&quot;: &quot;Val7&quot;,\r\n            &quot;Item2&quot;: &quot;Val8&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nI would like to combine these into one object so that all the Item objects under one name are combined into one array.  Essentially, I would like to produce the following output:\r\n\r\n    $ echo ${MY_OBJECTS} | jq -s &lt;SOME_COMMAND&gt;\r\n    {\r\n      &quot;Name1&quot;: [\r\n        {\r\n          &quot;Item1&quot;: &quot;Val1&quot;,\r\n          &quot;Item2&quot;: &quot;Val2&quot;\r\n        },\r\n        {\r\n          &quot;Item1&quot;: &quot;Val3&quot;,\r\n          &quot;Item2&quot;: &quot;Val4&quot;\r\n        }\r\n      ],\r\n      &quot;Name2&quot;: [\r\n        {\r\n          &quot;Item1&quot;: &quot;Val5&quot;,\r\n          &quot;Item2&quot;: &quot;Val6&quot;\r\n        },\r\n        {\r\n          &quot;Item1&quot;: &quot;Val7&quot;,\r\n          &quot;Item2&quot;: &quot;Val8&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI had expected `echo ${MY_OBJECT} | jq -s add` to do this, but this overwrote each object with the following one instead of adding the arrays so that they were all in one array (as though the objects were being added instead of the arrays).  In other words, the entries looked like this:\r\n\r\n    &quot;Name1&quot;: [\r\n      {\r\n        &quot;Item1&quot;: &quot;Val3&quot;,\r\n        &quot;Item2&quot;: &quot;Val4&quot;\r\n      }\r\n    ]\r\n\r\nWhile I wanted them to look like this:\r\n\r\n    &quot;Name1&quot;: [\r\n      {\r\n        &quot;Item1&quot;: &quot;Val1&quot;,\r\n        &quot;Item2&quot;: &quot;Val2&quot;\r\n      },\r\n      {\r\n        &quot;Item1&quot;: &quot;Val3&quot;,\r\n        &quot;Item2&quot;: &quot;Val4&quot;\r\n      }\r\n    ]\r\n\r\nAny advice would be appreciated!",
        "link": "https://stackoverflow.com/questions/36066961/jq-objects-with-array-values-not-combining-as-expected",
        "title": "jq: Objects with array values not combining as expected"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1458628432,
                "last_edit_date": 1458628432,
                "creation_date": 1458627953,
                "answer_id": 36147530,
                "question_id": 36146782,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following produces the JSON object of interest in the particular case you give, but also provides a reasonable generalization in case there is more than one &quot;foobar&quot; prefix:\r\n\r\n    map( . as $o | .Key | split(&quot;/&quot;) | {(.[0]): {(.[1]): ($o|.Value) }} )\r\n    | reduce .[] as $o\r\n        ( {};\r\n          ($o|keys[0]) as $key | . + { ($key): (.[$key] + $o[$key]) } )\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;foobar&quot;: {\r\n        &quot;testing&quot;: &quot;xxxxx&quot;,\r\n        &quot;bazbar&quot;: &quot;xxxxx&quot;\r\n      }\r\n    }\r\n",
                "title": "Using jq to split a string into nested objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1503762118,
                "creation_date": 1503762118,
                "answer_id": 45897103,
                "question_id": 36146782,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that uses **reduce**, **split** and **setpath**\r\n\r\n    [\r\n      reduce (.[] | [(.Key | split(&quot;/&quot;)), .Value]) as [$p,$v] (\r\n        {}\r\n      ; setpath($p; $v)\r\n      )\r\n    ]",
                "title": "Using jq to split a string into nested objects"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1531615169,
                "creation_date": 1531615169,
                "answer_id": 51344425,
                "question_id": 36146782,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This simple solution uses `setpath` to handle any depth and works great for parsing Consul KV responses:\r\n\r\n        reduce .[] as $item ({}; setpath($item.Key | split(&quot;/&quot;); $item.Value))\r\n",
                "title": "Using jq to split a string into nested objects"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 11,
        "last_activity_date": 1531615169,
        "creation_date": 1458624528,
        "last_edit_date": 1504624359,
        "question_id": 36146782,
        "body_markdown": "I&#39;m trying to export data from consul kv into json with a nested object for each level of depth in consul.\r\n\r\nExample json returned from consul:\r\n\r\n    [\r\n      {\r\n        &quot;LockIndex&quot;: 0,\r\n        &quot;Key&quot;: &quot;foobar/testing&quot;,\r\n        &quot;Flags&quot;: 0,\r\n        &quot;Value&quot;: &quot;xxxxx&quot;,\r\n        &quot;CreateIndex&quot;: 833,\r\n        &quot;ModifyIndex&quot;: 833\r\n      },\r\n      {\r\n        &quot;LockIndex&quot;: 0,\r\n        &quot;Key&quot;: &quot;foobar/bazbar&quot;,\r\n        &quot;Flags&quot;: 0,\r\n        &quot;Value&quot;: &quot;xxxxx&quot;,\r\n        &quot;CreateIndex&quot;: 833,\r\n        &quot;ModifyIndex&quot;: 833\r\n      }\r\n    ]\r\n\r\nDesired JSON:\r\n\r\n    [\r\n      {\r\n        &quot;foobar&quot;: {\r\n          &quot;testing&quot;: &quot;xxxxx&quot;,\r\n          &quot;bazbar&quot;: &quot;xxxxx&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\nI&#39;m sort of close with `jq &#39;.[] | objects | {Key: .Key | split(&quot;/&quot;), Value: .Value}&#39;` but I&#39;m just not understanding how I can recurse based on a split() of .Key and create nested objects. I think I&#39;ll also need to sort_by(.Key) to handle out of order data, unless I can `| add` arbitrarily and have jq resolve the structure.\r\n\r\nI realize `xxxxx` is base64 encoded, and hopefully, `base64d` will get merged soon but until then I think I can handle decoding this with shell post-processing.",
        "link": "https://stackoverflow.com/questions/36146782/using-jq-to-split-a-string-into-nested-objects",
        "title": "Using jq to split a string into nested objects"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3365877,
                    "reputation": 1043,
                    "user_id": 2826506,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/14d5a0e20c007218346e36400c472c1c?s=256&d=identicon&r=PG",
                    "display_name": "Jaco B",
                    "link": "https://stackoverflow.com/users/2826506/jaco-b"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1458637040,
                "post_id": 36149725,
                "comment_id": 59937036,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1343463,
                    "reputation": 3675,
                    "user_id": 1284652,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/819a0eb4eca6449ab725a2e042ac00ca?s=256&d=identicon&r=PG",
                    "display_name": "fusio",
                    "link": "https://stackoverflow.com/users/1284652/fusio"
                },
                "reply_to_user": {
                    "account_id": 3365877,
                    "reputation": 1043,
                    "user_id": 2826506,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/14d5a0e20c007218346e36400c472c1c?s=256&d=identicon&r=PG",
                    "display_name": "Jaco B",
                    "link": "https://stackoverflow.com/users/2826506/jaco-b"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1458637569,
                "post_id": 36149725,
                "comment_id": 59937356,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2387472,
                    "reputation": 74949,
                    "user_id": 2088135,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://i.sstatic.net/YB10Q.jpg?s=256",
                    "display_name": "Tom Fenech",
                    "link": "https://stackoverflow.com/users/2088135/tom-fenech"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1458637904,
                "post_id": 36149725,
                "comment_id": 59937569,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1343463,
                    "reputation": 3675,
                    "user_id": 1284652,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/819a0eb4eca6449ab725a2e042ac00ca?s=256&d=identicon&r=PG",
                    "display_name": "fusio",
                    "link": "https://stackoverflow.com/users/1284652/fusio"
                },
                "reply_to_user": {
                    "account_id": 2387472,
                    "reputation": 74949,
                    "user_id": 2088135,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://i.sstatic.net/YB10Q.jpg?s=256",
                    "display_name": "Tom Fenech",
                    "link": "https://stackoverflow.com/users/2088135/tom-fenech"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1458638469,
                "post_id": 36149725,
                "comment_id": 59937929,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5795637,
                    "reputation": 7754,
                    "user_id": 4571544,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f5b3a72bbc628df5991519ef07da1fe7?s=256&d=identicon&r=PG",
                    "display_name": "unconditional",
                    "link": "https://stackoverflow.com/users/4571544/unconditional"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1458650897,
                "post_id": 36149725,
                "comment_id": 59946646,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1458650846,
                "creation_date": 1458650846,
                "answer_id": 36154819,
                "question_id": 36149725,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here you go.\r\n\r\n**Filter**\r\n\r\n    .foo |= with_entries( .value = if ([.key] | inside([&quot;bar&quot;, &quot;baz&quot;])) then &quot;X&quot; else .value end )\r\n\r\n**Input**\r\n\r\n    {\r\n        &quot;foo&quot;: {\r\n            &quot;bar&quot;: 1,\r\n            &quot;baz&quot;: 2,\r\n            &quot;qux&quot;: 3\r\n        }\r\n    }\r\n\r\n**Output**\r\n\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;bar&quot;: &quot;X&quot;,\r\n        &quot;baz&quot;: &quot;X&quot;,\r\n        &quot;qux&quot;: 3\r\n      }\r\n    }\r\n\r\nCheck out the cookbook for more recipies and techniques of ```jq``` usage:    \r\n  https://github.com/stedolan/jq/wiki/Cookbook",
                "title": "Modify JSON values based on array of keys using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1458672961,
                "creation_date": 1458672961,
                "answer_id": 36162907,
                "question_id": 36149725,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a slightly different approach using `--argjson` to parameterize update_keys, and `index/1`:\r\n\r\n    $ cat update.jq\r\n    .foo |= with_entries( . as $in \r\n              | if $update_keys | index($in.key) then .value = &quot;X&quot; else empty end)\r\n    \r\n    $ update_keys=&#39;[&quot;bar&quot;, &quot;baz&quot;]&#39;\r\n    \r\n    $ jq --argjson update_keys &quot;$update_keys&quot; -f update.jq input.json\r\n    \r\n    Output:\r\n    \r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;bar&quot;: &quot;X&quot;,\r\n        &quot;baz&quot;: &quot;X&quot;\r\n      }\r\n    }",
                "title": "Modify JSON values based on array of keys using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503869606,
                "creation_date": 1503869606,
                "answer_id": 45909568,
                "question_id": 36149725,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In this problem since `$update_keys` is just an array all that is needed is\r\n\r\n     .foo[ $update_keys[] ] = &quot;X&quot;\r\n\r\ne.g. if \r\n\r\n      [&quot;bar&quot;,&quot;baz&quot;] as $update_keys\r\n    | .foo[ $update_keys[] ] = &quot;X&quot;\r\n\r\nis in `filter.jq` and `data.json` contains the (slighty corrected) data\r\n\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;bar&quot;: 1,\r\n        &quot;baz&quot;: 2,\r\n        &quot;qux&quot;: 3\r\n      }\r\n    }\r\n\r\nthen\r\n\r\n    jq -M -f filter.jq data.json\r\n\r\nproduces\r\n\r\n    {\r\n      &quot;foo&quot;: {\r\n        &quot;bar&quot;: &quot;X&quot;,\r\n        &quot;baz&quot;: &quot;X&quot;,\r\n        &quot;qux&quot;: 3\r\n      }\r\n    }\r\n\r\nIf you want to pass in the value for update keys instead of defining it in your script you can easily use `--argjson` as [peak](https://stackoverflow.com/users/997358/peak)&#39;s answer shows.",
                "title": "Modify JSON values based on array of keys using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1504606765,
        "creation_date": 1458636364,
        "last_edit_date": 1504606765,
        "question_id": 36149725,
        "body_markdown": "I need to change the value of a set of keys (defined in a variable) in a JSON object using jq.\r\n\r\nAs example, I have this JSON object:\r\n\r\n    {\r\n        foo: {\r\n            bar: 1,\r\n            baz: 2,\r\n            qux: 3\r\n        }\r\n    }\r\n\r\nand the following variable: \r\n\r\n    update_keys = [&quot;bar&quot;, &quot;baz&quot;]\r\n\r\nI would like to say &#39;change the value of the keys in update_keys to X&#39;.\r\n\r\nThe following works:\r\n\r\n    .foo = (.foo | \r\n            to_entries | \r\n            map(if .key == &quot;bar&quot; or .key == &quot;baz&quot; \r\n            then . + { &quot;value&quot;:&quot;X&quot; } \r\n            else . \r\n            end) |\r\n            from_entries)\r\n\r\n\r\nBut instead of `if .key == &quot;bar&quot; or .key == &quot;baz&quot;` I am looking for a way to say `if .key in update_keys`, or a similar logic.",
        "link": "https://stackoverflow.com/questions/36149725/modify-json-values-based-on-array-of-keys-using-jq",
        "title": "Modify JSON values based on array of keys using jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1504380753,
                "creation_date": 1504380753,
                "answer_id": 46017462,
                "question_id": 36185558,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In [jq](https://stedolan.github.io/jq/) if you have an array e.g.\r\n\r\n    [1,2,3]\r\n    \r\nthen [string interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-\\\\\\(foo\\)) and [object construction](https://stedolan.github.io/jq/manual/#ObjectConstruction:{}) filters using `[]` array iteration will generate multiple strings or objects, e.g.\r\n\r\n    $ jq -Mnc &#39;[1,2,3] | {x:.[]}&#39;\r\n    {&quot;x&quot;:1}\r\n    {&quot;x&quot;:2}\r\n    {&quot;x&quot;:3}\r\n\r\n    $ jq -Mnc &#39;[1,2,3] | &quot;x:\\(.[])&quot;&#39;\r\n    &quot;x:1&quot;\r\n    &quot;x:2&quot;\r\n    &quot;x:3&quot;\r\n\r\nif multiple `[]` are present then a cartesian product of combinations will be produced.  e.g.\r\n\r\n    $ jq -Mnc &#39;[1,2,3] | &quot;x:\\(.[]) x:\\(.[])&quot;&#39;\r\n    &quot;x:1 x:1&quot;\r\n    &quot;x:2 x:1&quot;\r\n    &quot;x:3 x:1&quot;\r\n    &quot;x:1 x:2&quot;\r\n    &quot;x:2 x:2&quot;\r\n    &quot;x:3 x:2&quot;\r\n    &quot;x:1 x:3&quot;\r\n    &quot;x:2 x:3&quot;\r\n    &quot;x:3 x:3&quot;\r\n\r\nif this is not what you want, an easy way to avoid it is to move the `[]` out of the interpolation, e.g\r\n\r\n    $ jq -Mnc &#39;[1,2,3] | .[] | &quot;x:\\(.) x:\\(.)&quot;&#39;\r\n    &quot;x:1 x:1&quot;\r\n    &quot;x:2 x:2&quot;\r\n    &quot;x:3 x:3&quot;\r\n\r\nAlso, [variable binding](https://stedolan.github.io/jq/manual/#Variable/SymbolicBindingOperator:...as$identifier|...) is often helpful when working with a nested structure.  e.g.\r\n\r\n    $ jq -Mnc &#39;{a:100, b:[1,2,3]} | .a as $a | .b[] | &quot;a:\\($a) b:\\(.)&quot;&#39;\r\n    &quot;a:100 b:1&quot;\r\n    &quot;a:100 b:2&quot;\r\n    &quot;a:100 b:3&quot;\r\n\r\nFinally, here a filter which uses these features to solve this problem.  [Functions](https://stedolan.github.io/jq/manual/#DefiningFunctions) are used to keep the logic dealing with the initial message and conversation parts separate.\r\n\r\n    def initial:\r\n        .id as $id\r\n      | .initial_message\r\n      |   .type as $ity\r\n      |   .id   as $iid\r\n      |   .author\r\n      |     .type as $iaty\r\n      |     &quot;\\($id), \\($iid), \\($ity), \\($iaty)&quot;\r\n    ;\r\n\r\n    def parts:\r\n        .id as $id\r\n      | .conversation_parts.conversation_parts[]  # note [] here\r\n      |   .id as $cid\r\n      |   .part_type as $cpt\r\n      |   .author\r\n      |     .type as $caty\r\n      |     &quot;\\($id), \\($cid), \\($cpt), \\($caty)&quot;\r\n    ;\r\n\r\n      initial\r\n    , parts\r\n\r\n\r\nIf `filter.jq` contains this filter and `data.json` contains the sample data then\r\n\r\n    $ jq -M -r -f filter.jq data.json\r\n\r\nwill produce \r\n\r\n    1234, 567, initial_message, admin\r\n    1234, 6789, comment, user\r\n    1234, 9384, close, admin",
                "title": "How to make a csv from json with variable array lengths using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1504411116,
        "creation_date": 1458756320,
        "last_edit_date": 1504411116,
        "question_id": 36185558,
        "body_markdown": "I have a JSON with the following format\r\n\r\n    {\r\n        &quot;type&quot;: &quot;conversation&quot;,\r\n        &quot;id&quot;: &quot;1234&quot;,\r\n        &quot;created_at&quot;: 1425586662,\r\n        &quot;initial_message&quot;: {\r\n            &quot;type&quot;: &quot;initial_message&quot;,\r\n            &quot;id&quot;: &quot;567&quot;,\r\n            &quot;body&quot;: &quot;&lt;p&gt;Testing&lt;/p&gt;&quot;,\r\n            &quot;author&quot;: {\r\n                &quot;type&quot;: &quot;admin&quot;,\r\n                &quot;id&quot;: &quot;9382&quot;\r\n            }\r\n        },\r\n        &quot;conversation_parts&quot;: {\r\n            &quot;type&quot;: &quot;conversation_part.list&quot;,\r\n            &quot;conversation_parts&quot;: [\r\n                {\r\n                    &quot;type&quot;: &quot;conversation_part&quot;,\r\n                    &quot;id&quot;: &quot;6789&quot;,\r\n                    &quot;part_type&quot;: &quot;comment&quot;,\r\n                    &quot;body&quot;: &quot;&lt;p&gt;Good test&lt;/p&gt;&quot;,\r\n                    &quot;created_at&quot;: 1425586731,\r\n                    &quot;author&quot;: {\r\n                        &quot;type&quot;: &quot;user&quot;,\r\n                        &quot;id&quot;: &quot;029384&quot;\r\n                    }\r\n                },\r\n                {\r\n                    &quot;type&quot;: &quot;conversation_part&quot;,\r\n                    &quot;id&quot;: &quot;9384&quot;,\r\n                    &quot;part_type&quot;: &quot;close&quot;,\r\n                    &quot;body&quot;: null,\r\n                    &quot;created_at&quot;: 1425929944,\r\n                    &quot;author&quot;: {\r\n                        &quot;type&quot;: &quot;admin&quot;,\r\n                        &quot;id&quot;: &quot;9382&quot;\r\n                }\r\n            ]\r\n        }\r\n    }\r\n\r\nThere is always an initial_message, but there may or may not be anything in the array of conversation parts, and that array may have any number of members.\r\n\r\nI&#39;m trying to capture some of this information in a csv, though I&#39;ve had no luck with the @csv function\r\n\r\nI tried:\r\n\r\n    jq &#39;&quot;\\(.type), \\(.id), \\(.created_at), \\(.initial_message.type), \\(.initial_message.id), \\(.initial_message.author.type), \\(.conversation_parts.conversation_parts[].part), \\(.conversation_parts.conversation_parts[].id), \\(.conversation_parts.conversation_parts[].part_type), \\(.conversation_parts.conversation_parts[].created_at), \\(.conversation_parts.conversation_parts[].author.type)&quot;&#39; \\\r\n\r\nbut it gives me all possible combinations of things within the array (I get 32 lines of results from this one example). \r\n\r\nI&#39;m editing the total amount of info I&#39;m looking for for brevities sake, but my ideal would be to display\r\n\r\n    1234, 567, initial, admin\r\n    1234, 6789, comment, user\r\n    1234, 9384, close, admin\r\n\r\nthough I would be just fine if I could make it be \r\n\r\n    1234, 567, admin, 6789, comment, user\r\n    1234, 567, admin, 9384, close, admin\r\n\r\nwhat I can&#39;t have is \r\n\r\n    1234, 567, admin, 6789, comment, user\r\n    1234, 567, admin, 9384, comment, admin\r\n    1234, 567, admin, 6789, close, user\r\n    1234, 567, admin, 9384, close, admin\r\n\r\nwhich is what I&#39;m getting now\r\n\r\nI know there&#39;s a length function in jq and a foreach function, but then I get tangled up in my pipeline about how to loop through the array of conversation parts. Any help would be much appreciated!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/36185558/how-to-make-a-csv-from-json-with-variable-array-lengths-using-jq",
        "title": "How to make a csv from json with variable array lengths using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 94,
                "is_accepted": true,
                "score": 94,
                "last_activity_date": 1458940080,
                "creation_date": 1458940080,
                "answer_id": 36228054,
                "question_id": 36227245,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can provide a *stream* of paths to delete:\r\n\r\n    $ cat test.json | jq &#39;map(del(.Country, .number, .Language))&#39;\r\n\r\nAlso, consider that, instead of blacklisting specific keys, you might prefer to whitelist the ones you do want:\r\n\r\n    $ cat test.json | jq &#39;map({label, region, locale, currency})&#39;",
                "title": "Deleting multiple keys at once with jq"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1591792022,
                "last_edit_date": 1591792022,
                "creation_date": 1458968606,
                "answer_id": 36231817,
                "question_id": 36227245,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`delpaths` is also worth knowing about, and is perhaps a little less mysterious:\r\n\r\n    map( delpaths( [[&quot;Country&quot;], [&quot;number&quot;], [&quot;Language&quot;]] ))\r\n\r\nSince the argument to `delpaths` is simply JSON, this approach is particularly useful for programmatic deletions, e.g. if the key names are available as JSON strings.",
                "title": "Deleting multiple keys at once with jq"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1726436450,
                "last_edit_date": 1726436450,
                "creation_date": 1566457464,
                "answer_id": 57603738,
                "question_id": 36227245,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In addition to [@user3899165&#39;s answer](https://stackoverflow.com/a/36228054), I found that to delete a list of keys from &quot;sub-object&quot;\r\n\r\n```\r\nexample.json\r\n\r\n{\r\n    &quot;a&quot;: {\r\n        &quot;b&quot;: &quot;hello&quot;,\r\n        &quot;c&quot;: &quot;world&quot;,\r\n        &quot;d&quot;: &quot;here&#39;s&quot;,\r\n        &quot;e&quot;: &quot;the&quot;\r\n    },\r\n    &quot;f&quot;: {\r\n        &quot;g&quot;: &quot;song&quot;,\r\n        &quot;h&quot;: &quot;that&quot;,\r\n        &quot;i&quot;: &quot;I&#39;m&quot;,\r\n        &quot;j&quot;: &quot;singing&quot;\r\n    }\r\n}\r\n```\r\n`$ jq &#39;del(.a[&quot;d&quot;, &quot;e&quot;])&#39; example.json`",
                "title": "Deleting multiple keys at once with jq"
            },
            {
                "up_vote_count": 38,
                "is_accepted": false,
                "score": 38,
                "last_activity_date": 1591792749,
                "creation_date": 1591792749,
                "answer_id": 62303827,
                "question_id": 36227245,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is no need to use both `map` and `del`.\r\n\r\nYou can pass multiple paths to `del`, separated by commas.\r\n\r\nHere is a solution using &quot;dot-style&quot; path notation:\r\n\r\n```sh\r\njq &#39;del( .[] .Country, .[] .number, .[] .Language )&#39; test.json\r\n```\r\n\r\n- doesn&#39;t require quotation marks (which you may feel makes it more readable)\r\n- doesn&#39;t group the paths (requires you to retype `.[]` once per path)\r\n\r\nHere is an example using &quot;array-style&quot; path notation, which allows you to combine paths with a common prefix like so:\r\n\r\n```sh\r\njq &#39;del( .[] [&quot;Country&quot;, &quot;number&quot;, &quot;Language&quot;] )&#39; test.json\r\n```\r\n\r\n- Combines subpaths under the &quot;last-common ancestor&quot; (which in this case is the top-level list iterator `.[]`)\r\n\r\npeak&#39;s answer uses `map` and `delpaths`, though it seems you can also use `delpaths` on its own:\r\n\r\n```sh\r\njq &#39;[.[] | delpaths( [[&quot;Country&quot;], [&quot;number&quot;], [&quot;Language&quot;]] )]&#39; test.json\r\n```\r\n\r\n- Requires both quotation marks and array of singleton arrays\r\n- Requires you to put it back into a list (with the start and end square brackets)\r\n\r\nOverall, here I&#39;d go for the array-style notation for brevity, but it&#39;s always good to know multiple ways to do the same thing.",
                "title": "Deleting multiple keys at once with jq"
            },
            {
                "up_vote_count": 16,
                "is_accepted": false,
                "score": 16,
                "last_activity_date": 1607981391,
                "creation_date": 1607981391,
                "answer_id": 65296754,
                "question_id": 36227245,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A better compromise between &quot;array-style&quot; and &quot;dot-style&quot; notation mentioned in by Louis in his [answer][1].\r\n\r\n```\r\ndel(.[] | .Country, .number, .Language)\r\n```\r\n[jqplay][2]\r\n\r\n---\r\n\r\nThis form can also be used to delete a list of keys from a nested object (see russholio&#39;s [answer][3]):\r\n```\r\ndel(.a | .d, .e)\r\n```\r\nImplying that you can also pick a single index to delete keys from:\r\n```\r\ndel(.[1] | .Country, .number, .Language)\r\n```\r\nOr multiple:\r\n```\r\ndel(.[2,3,4] | .Country,.number,.Language)\r\n```\r\nYou can delete a range using the `range()` function (slice notation doesn&#39;t work):\r\n```\r\ndel(.[range(2;5)] | .Country,.number,.Language)  # same as targetting indices 2,3,4\r\n```\r\n\r\n---\r\n\r\n\r\nSome side notes:\r\n```\r\nmap(del(.Country,.number,.Language))\r\n# Is by definition equivalent to\r\n[.[] | del(.Country,.number,.Language)]\r\n```\r\n\r\n&gt; If the key contains special characters or starts with a digit, you need to surround it with double quotes like this: `.&quot;foo$&quot;`, or else `.[&quot;foo$&quot;]`.\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/62303827/7314180\r\n  [2]: https://jqplay.org/s/pL9zZ4YNpT\r\n  [3]: https://stackoverflow.com/a/57603738/7314180",
                "title": "Deleting multiple keys at once with jq"
            },
            {
                "up_vote_count": 22,
                "is_accepted": false,
                "score": 22,
                "last_activity_date": 1641410107,
                "creation_date": 1641410107,
                "answer_id": 70598436,
                "question_id": 36227245,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This question is very high in the google results, so I&#39;d like to note that some time in the intervening years, `del` has apparently been altered so that you can delete multiple keys with just:\r\n\r\n    del(.key1, .key2, ...)\r\n\r\nSo don&#39;t tear your hair out trying to figure out the syntax work-arounds, assuming your version of jq is reasonably current.",
                "title": "Deleting multiple keys at once with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 74,
        "last_activity_date": 1726436450,
        "creation_date": 1458936556,
        "last_edit_date": 1726436415,
        "question_id": 36227245,
        "body_markdown": "I need to delete multiple keys at once from some JSON (using `jq`), and I&#39;m trying to learn if there is a better way of doing this, than calling map and del every time. Here&#39;s my input data:\r\n\r\n**test.json**\r\n\r\n&lt;!-- language: json --&gt;\r\n    [\r\n      {\r\n        &quot;label&quot;: &quot;US : USA : English&quot;,\r\n        &quot;Country&quot;: &quot;USA&quot;,\r\n        &quot;region&quot;: &quot;US&quot;,\r\n        &quot;Language&quot;: &quot;English&quot;,\r\n        &quot;locale&quot;: &quot;en&quot;,\r\n        &quot;currency&quot;: &quot;USD&quot;,\r\n        &quot;number&quot;: &quot;USD&quot;\r\n      },\r\n      {\r\n        &quot;label&quot;: &quot;AU : Australia : English&quot;,\r\n        &quot;Country&quot;: &quot;Australia&quot;,\r\n        &quot;region&quot;: &quot;AU&quot;,\r\n        &quot;Language&quot;: &quot;English&quot;,\r\n        &quot;locale&quot;: &quot;en&quot;,\r\n        &quot;currency&quot;: &quot;AUD&quot;,\r\n        &quot;number&quot;: &quot;AUD&quot;\r\n      },\r\n      {\r\n        &quot;label&quot;: &quot;CA : Canada : English&quot;,\r\n        &quot;Country&quot;: &quot;Canada&quot;,\r\n        &quot;region&quot;: &quot;CA&quot;,\r\n        &quot;Language&quot;: &quot;English&quot;,\r\n        &quot;locale&quot;: &quot;en&quot;,\r\n        &quot;currency&quot;: &quot;CAD&quot;,\r\n        &quot;number&quot;: &quot;CAD&quot;\r\n      }\r\n    ]\r\n\r\nFor each item, I want to remove the number, Language, and Country keys. I can do that with this command:\r\n\r\n\r\n    $ cat test.json | jq &#39;map(del(.Country)) | map(del(.number)) | map(del(.Language))&#39;\r\n\r\nThat works fine, and I get the desired output:\r\n\r\n&lt;!-- language: json --&gt;\r\n    [\r\n      {\r\n        &quot;label&quot;: &quot;US : USA : English&quot;,\r\n        &quot;region&quot;: &quot;US&quot;,\r\n        &quot;locale&quot;: &quot;en&quot;,\r\n        &quot;currency&quot;: &quot;USD&quot;\r\n      },\r\n      {\r\n        &quot;label&quot;: &quot;AU : Australia : English&quot;,\r\n        &quot;region&quot;: &quot;AU&quot;,\r\n        &quot;locale&quot;: &quot;en&quot;,\r\n        &quot;currency&quot;: &quot;AUD&quot;\r\n      },\r\n      {\r\n        &quot;label&quot;: &quot;CA : Canada : English&quot;,\r\n        &quot;region&quot;: &quot;CA&quot;,\r\n        &quot;locale&quot;: &quot;en&quot;,\r\n        &quot;currency&quot;: &quot;CAD&quot;\r\n      }\r\n    ]\r\n\r\nHowever, I&#39;m trying to understand if there is a `jq` way of specifying multiple labels to delete, so I don&#39;t have to have multiple `map(del())` directives?",
        "link": "https://stackoverflow.com/questions/36227245/deleting-multiple-keys-at-once-with-jq",
        "title": "Deleting multiple keys at once with jq"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq",
            "pocket"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 215971,
                    "reputation": 6962,
                    "user_id": 470925,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/9a876909984def202886ad7f9b48a219?s=256&d=identicon&r=PG",
                    "display_name": "Ken Bellows",
                    "link": "https://stackoverflow.com/users/470925/ken-bellows"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1458997490,
                "post_id": 36235589,
                "comment_id": 60101759,
                "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"
                },
                "reply_to_user": {
                    "account_id": 215971,
                    "reputation": 6962,
                    "user_id": 470925,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/9a876909984def202886ad7f9b48a219?s=256&d=identicon&r=PG",
                    "display_name": "Ken Bellows",
                    "link": "https://stackoverflow.com/users/470925/ken-bellows"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1458997766,
                "post_id": 36235589,
                "comment_id": 60101843,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 215971,
                    "reputation": 6962,
                    "user_id": 470925,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/9a876909984def202886ad7f9b48a219?s=256&d=identicon&r=PG",
                    "display_name": "Ken Bellows",
                    "link": "https://stackoverflow.com/users/470925/ken-bellows"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1458997895,
                "post_id": 36235589,
                "comment_id": 60101877,
                "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": 1458998272,
                "post_id": 36235589,
                "comment_id": 60101981,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5625050,
                    "reputation": 11,
                    "user_id": 4453754,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f1c69f448c60f2072e7032acef75c2af?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Akhil Unnikrishnan",
                    "link": "https://stackoverflow.com/users/4453754/akhil-unnikrishnan"
                },
                "reply_to_user": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1459006216,
                "post_id": 36235589,
                "comment_id": 60104700,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1458998140,
                "creation_date": 1458998140,
                "answer_id": 36235738,
                "question_id": 36235589,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use the `.[]` operator to iterate over all elements in an array (or in this case all the keys).  The following will give you output with each field on a separate line:\r\n\r\n    cat &lt;file_with_json&gt; | jq &#39;.list | .[] | .resolved_title, .word_count&#39;\r\n\r\nThe first filter operates on only the `list` element.  The second filter says `for every element` and finally the output is just the `resolved_title` and `.word_count` fields.  This produces the following:\r\n\r\n    &quot;Title&quot;\r\n    &quot;3219&quot;\r\n    &quot;Title&quot;\r\n    &quot;10549&quot;",
                "title": "How to lift the value of a JSON object that is nested two levels deep?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1458998343,
                "creation_date": 1458998343,
                "answer_id": 36235769,
                "question_id": 36235589,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try `map()`:\r\n\r\n    $ cat myfile.json | jq &#39;.list | map({resolved_title: .resolved_title, word_count: .word_count})&#39;\r\n    [\r\n      {\r\n        &quot;resolved_title&quot;: &quot;Title&quot;,\r\n        &quot;word_count&quot;: &quot;10549&quot;\r\n      },\r\n      {\r\n        &quot;resolved_title&quot;: &quot;Title&quot;,\r\n        &quot;word_count&quot;: &quot;3219&quot;\r\n      }\r\n    ]",
                "title": "How to lift the value of a JSON object that is nested two levels deep?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1459485257,
                "creation_date": 1459485257,
                "answer_id": 36348112,
                "question_id": 36235589,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following can easily be extended and/or adapted:\r\n\r\n    &gt; jq &quot;.list[] | {resolved_title, word_count}&quot; input.json\r\n\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;resolved_title&quot;: &quot;Title&quot;,\r\n      &quot;word_count&quot;: &quot;10549&quot;\r\n    }\r\n    {\r\n      &quot;resolved_title&quot;: &quot;Title&quot;,\r\n      &quot;word_count&quot;: &quot;3219&quot;\r\n    }",
                "title": "How to lift the value of a JSON object that is nested two levels deep?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1484346375,
        "creation_date": 1458997171,
        "question_id": 36235589,
        "body_markdown": "Given the following `test.json` that I received as a response from the Pocket API,\r\n\r\n    {\r\n    &quot;complete&quot;: 1,\r\n    &quot;error&quot;: null,\r\n    &quot;list&quot;: {\r\n        &quot;1000055792&quot;: {\r\n            &quot;excerpt&quot;: &quot;Some Text&quot;,\r\n            &quot;favorite&quot;: &quot;0&quot;,\r\n            &quot;given_title&quot;: &quot;Some Title&quot;,\r\n            &quot;given_url&quot;: &quot;Some URL&quot;,\r\n            &quot;has_image&quot;: &quot;0&quot;,\r\n            &quot;has_video&quot;: &quot;0&quot;,\r\n            &quot;is_article&quot;: &quot;1&quot;,\r\n            &quot;is_index&quot;: &quot;0&quot;,\r\n            &quot;item_id&quot;: &quot;1000055792&quot;,\r\n            &quot;resolved_id&quot;: &quot;1000055792&quot;,\r\n            &quot;resolved_title&quot;: &quot;Title&quot;,\r\n            &quot;resolved_url&quot;: &quot;Some URL&quot;,\r\n            &quot;sort_id&quot;: 700,\r\n            &quot;status&quot;: &quot;1&quot;,\r\n            &quot;time_added&quot;: &quot;1438646514&quot;,\r\n            &quot;time_favorited&quot;: &quot;0&quot;,\r\n            &quot;time_read&quot;: &quot;1439025088&quot;,\r\n            &quot;time_updated&quot;: &quot;1439025090&quot;,\r\n            &quot;word_count&quot;: &quot;10549&quot;\r\n        },\r\n        &quot;1000102810&quot;: {\r\n            &quot;excerpt&quot;: &quot;Some Text&quot;,\r\n            &quot;favorite&quot;: &quot;0&quot;,\r\n            &quot;given_title&quot;: &quot;Title&quot;,\r\n            &quot;given_url&quot;: &quot;Some URL&quot;,\r\n            &quot;has_image&quot;: &quot;1&quot;,\r\n            &quot;has_video&quot;: &quot;0&quot;,\r\n            &quot;is_article&quot;: &quot;1&quot;,\r\n            &quot;is_index&quot;: &quot;0&quot;,\r\n            &quot;item_id&quot;: &quot;1000102810&quot;,\r\n            &quot;resolved_id&quot;: &quot;1000102810&quot;,\r\n            &quot;resolved_title&quot;: &quot;Title&quot;,\r\n            &quot;resolved_url&quot;: &quot;Resolved URL&quot;,\r\n            &quot;sort_id&quot;: 650,\r\n            &quot;status&quot;: &quot;1&quot;,\r\n            &quot;time_added&quot;: &quot;1440303789&quot;,\r\n            &quot;time_favorited&quot;: &quot;0&quot;,\r\n            &quot;time_read&quot;: &quot;1440320729&quot;,\r\n            &quot;time_updated&quot;: &quot;1440320731&quot;,\r\n            &quot;word_count&quot;: &quot;3219&quot;\r\n        }\r\nHow can I access the values of keys like `resolved_title` and `word_count`. They are nested inside an object which is a number, the same as the `id`, which in itself is nested inside `list`. I&#39;ve searched and found a way to access nested objects using jq. But how can I access the values that are nested inside another object within the main `list` object?\r\n\r\nAlso, the IDs are different and not sequential, so I don&#39;t think recursion is possible, but I could be wrong. What I&#39;m intending to do with this data is to only extract the `resolved_title` and `word_count` values for each item and save them to a two-column spreadsheet.\r\n\r\nThanks in advance!\r\n",
        "link": "https://stackoverflow.com/questions/36235589/how-to-lift-the-value-of-a-json-object-that-is-nested-two-levels-deep",
        "title": "How to lift the value of a JSON object that is nested two levels deep?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1459209995,
                "post_id": 36273218,
                "comment_id": 60173399,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7913306,
                    "reputation": 125,
                    "user_id": 5976636,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/a9bf685b8b0df7d409d2e0e92d60803d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "mjo",
                    "link": "https://stackoverflow.com/users/5976636/mjo"
                },
                "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": 1459210131,
                "post_id": 36273218,
                "comment_id": 60173442,
                "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": 1459210575,
                "post_id": 36273218,
                "comment_id": 60173566,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7913306,
                    "reputation": 125,
                    "user_id": 5976636,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/a9bf685b8b0df7d409d2e0e92d60803d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "mjo",
                    "link": "https://stackoverflow.com/users/5976636/mjo"
                },
                "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": 1459212096,
                "post_id": 36273218,
                "comment_id": 60174017,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1459214050,
                "post_id": 36273218,
                "comment_id": 60174419,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 21,
                "is_accepted": true,
                "score": 21,
                "last_activity_date": 1459216226,
                "last_edit_date": 1459216226,
                "creation_date": 1459210182,
                "answer_id": 36273303,
                "question_id": 36273218,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`-f`&#39;s argument is the file to read the filter to run from. If you want to read data from a file, that&#39;s a use for `--slurpfile`, not `-f`.\r\n\r\nThus:\r\n\r\n    jq --slurpfile countries test_id.txt &#39;.country=$countries&#39; &lt;myfile.json &gt;newfile.json\r\n\r\n---\r\n\r\nWhen run with your provided inputs, the resulting contents in `newfile.json` are:\r\n\r\n    {\r\n      &quot;scsRequestId&quot;: null,\r\n      &quot;includeMetadata&quot;: true,\r\n      &quot;includeHoldings&quot;: true,\r\n      &quot;country&quot;: [\r\n        &quot;NSC&quot;,\r\n        &quot;KZC&quot;,\r\n        &quot;KCC&quot;,\r\n        &quot;KZL&quot;,\r\n        &quot;NZG&quot;,\r\n        &quot;VRU&quot;,\r\n        &quot;ESM&quot;,\r\n        &quot;KZF&quot;,\r\n        &quot;SFU&quot;,\r\n        &quot;EWF&quot;,\r\n        &quot;KQY&quot;,\r\n        &quot;KQV&quot;\r\n      ],\r\n      &quot;region&quot;: [],\r\n      &quot;oclcSymbol&quot;: []\r\n    }",
                "title": "jq read .txt file and write the values to json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 10,
        "last_activity_date": 1581676138,
        "creation_date": 1459209611,
        "last_edit_date": 1581676138,
        "question_id": 36273218,
        "body_markdown": "I want to use `jq` to parse a `.txt` file with a list of country codes and write them to the value in a JSON object.\r\n\r\nHere is what I have so far:\r\n\r\n    cat myfile.json | \r\n    jq -R -f test_id.txt &#39;select(.country == []).country = &quot;test_id.txt&quot;&#39; &gt; newfile.json\r\n\r\nWhere `.txt` file looks like this:\r\n\r\n    &quot;NSC&quot;\r\n    &quot;KZC&quot;\r\n    &quot;KCC&quot;\r\n    &quot;KZL&quot;\r\n    &quot;NZG&quot;\r\n    &quot;VRU&quot;\r\n    &quot;ESM&quot;\r\n    &quot;KZF&quot;\r\n    &quot;SFU&quot;\r\n    &quot;EWF&quot;\r\n    &quot;KQY&quot;\r\n    &quot;KQV&quot;\r\n\r\nand my JSON looks like this:\r\n\r\n    {\r\n      &quot;scsRequestId&quot;: null,\r\n      &quot;includeMetadata&quot;: true,\r\n      &quot;includeHoldings&quot;: true,\r\n      &quot;country&quot;: [],\r\n      &quot;region&quot;: [],\r\n      &quot;oclcSymbol&quot;: []\r\n    }\r\n\r\nHere is the error I am getting:\r\n\r\n    jq: error: syntax error, unexpected QQSTRING_START, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 2:\r\n    &quot;KZC&quot;\r\n    jq: 1 compile error\r\n\r\nI want the list of country codes to go into the country array.",
        "link": "https://stackoverflow.com/questions/36273218/jq-read-txt-file-and-write-the-values-to-json-file",
        "title": "jq read .txt file and write the values to json file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1459270792,
                "creation_date": 1459270792,
                "answer_id": 36290557,
                "question_id": 36290459,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This works, but it looks ugly. Any better solutions?\r\n\r\n    custom_variables: (if (.custom_variables | length &gt; 0) \r\n                then (.custom_variables | .[]? | select(.name == &quot;variable_name&quot;) | .value | scan(&quot;\\\\d+&quot;))\r\n                else null\r\n                end)",
                "title": "jq: select without dropping items from array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1459277956,
                "creation_date": 1459277956,
                "answer_id": 36292901,
                "question_id": 36290459,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use the alternative operator (`//`) to transform a stream of zero elements (such as those which can be generated by `select` or `.[]`) into a value:\r\n\r\n    jq &#39;map(\r\n        {\r\n            xxx: .xxx, \r\n            xxx: .xxx, \r\n            xxx: .xxx, \r\n            xxx: .custom_variables | .[] | select(.name == &quot;variable_name&quot;) // null\r\n        } \r\n    )&#39;\r\n\r\nThis will have `.xxx` be `null` when there is a zero-element stream on the left side of `//`.\r\n\r\nYou can, of course, place the alternative operator at a different position to capture the zero-element stream at an earlier or later stage, such as at the object level:\r\n\r\n    jq &#39;map(\r\n        {\r\n            xxx: .xxx, \r\n            xxx: .xxx, \r\n            xxx: .xxx, \r\n            xxx: .custom_variables | .[] | select(.name == &quot;variable_name&quot;)\r\n        } // {}\r\n    )&#39;",
                "title": "jq: select without dropping items from array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1459458535,
                "creation_date": 1459458535,
                "answer_id": 36343820,
                "question_id": 36290459,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "\r\nThe following does what you&#39;ve indicated you want, as best as I can understand your\r\nrequirements.  \r\n\r\n\r\n\r\n    map( if .custom_variables\r\n         then .custom_variables |= (map(select(.name == &quot;variable_name&quot;) | .value)\r\n                                    | .[0]) \r\n         else .\r\n         end )\r\n\r\nExample input:\r\n\r\n    [{\r\n        &quot;custom_variables&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;xxx&quot;,\r\n                &quot;value&quot;: &quot;xxx&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;xxx&quot;,\r\n                &quot;value&quot;: &quot;xxx&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;variable_name&quot;,\r\n                &quot;value&quot;: &quot;123&quot;\r\n            }\r\n        ],\r\n        &quot;xxx1&quot;: &quot;xxx&quot;,\r\n        &quot;xxx2&quot;: &quot;xxx&quot;,\r\n        &quot;xxx3&quot;: &quot;xxx&quot;\r\n    },\r\n    \r\n    {\r\n        &quot;yyy1&quot;: &quot;yyy&quot;,\r\n        &quot;yyy2&quot;: &quot;yyy&quot;,\r\n        &quot;yyy3&quot;: &quot;yyy&quot;\r\n    }\r\n    ]\r\n\r\nOutput:\r\n\r\n    [\r\n      {\r\n        &quot;custom_variables&quot;: &quot;123&quot;,\r\n        &quot;xxx1&quot;: &quot;xxx&quot;,\r\n        &quot;xxx2&quot;: &quot;xxx&quot;,\r\n        &quot;xxx3&quot;: &quot;xxx&quot;\r\n      },\r\n      {\r\n        &quot;yyy1&quot;: &quot;yyy&quot;,\r\n        &quot;yyy2&quot;: &quot;yyy&quot;,\r\n        &quot;yyy3&quot;: &quot;yyy&quot;\r\n      }\r\n    ]\r\n",
                "title": "jq: select without dropping items from array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1459458535,
        "creation_date": 1459270474,
        "question_id": 36290459,
        "body_markdown": "I have a JSON file which looks like this (a rough schema):\r\n\r\n    [{\r\n        &quot;custom_variables&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;xxx&quot;,\r\n                &quot;value&quot;: &quot;xxx&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;xxx&quot;,\r\n                &quot;value&quot;: &quot;xxx&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;profile_id&quot;,\r\n                &quot;value&quot;: &quot;123&quot;\r\n            }\r\n        ],\r\n        // many fields\r\n        &quot;xxx&quot;: &quot;xxx&quot;,\r\n        &quot;xxx&quot;: &quot;xxx&quot;,\r\n        &quot;xxx&quot;: &quot;xxx&quot;\r\n    }]\r\n\r\nI am using jq to extract all the fields from the top level object. The custom_variables field constains an array of objects with name and value.\r\n\r\nI want to extract a specific object from custom_variables, given its name.\r\n\r\nSo what I am doing is this:\r\n\r\n    jq &#39;map(\r\n        {\r\n            xxx: .xxx, \r\n            xxx: .xxx, \r\n            xxx: .xxx, \r\n            xxx: .custom_variables | .[] | select(.name == &quot;variable_name&quot;)\r\n        } \r\n    )&#39;\r\n\r\nIt almost works; it gets the variable I want when it exists, but when it doesn&#39;t (or if custom_variables itself doesn&#39;t) it will drop the whole top-level object. So in the end I am getting less objects then I put into the script.\r\n\r\nHow can I just return null if I don&#39;t find that field but still keep the rest of the data?",
        "link": "https://stackoverflow.com/questions/36290459/jq-select-without-dropping-items-from-array",
        "title": "jq: select without dropping items from array"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1459333158,
                "last_edit_date": 1459333158,
                "creation_date": 1459315573,
                "answer_id": 36300375,
                "question_id": 36299028,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    cat rawjsonfile |jq -r  &#39;.Volumes[]|({VolumeId}+(.Tags|from_entries))|{VolumeId,Period,Start,Finish}|to_entries[]|(.key+&quot;=&quot;+.value)&#39;\r\n\r\nthe rawjsonfile is your &quot;-- Original JSON&quot;\r\n\r\nthis result is:\r\n\r\n\r\n    VolumeId=vol-11111111\r\n    Period=2\r\n    Start=00:00\r\n    Finish=00:20\r\n    VolumeId=vol-22222222\r\n    Period=2\r\n    Start=00:00\r\n    Finish=00:20\r\n    VolumeId=vol-33333333\r\n    Period=2\r\n    Start=00:00\r\n    Finish=00:20\r\n\r\n\r\n 1. first  unwind  the array to json units\r\n\r\n`cat rawjsonfile|jq -r  &#39;.Volumes[]|({VolumeId}+(.Tags|from_entries))&#39;`\r\n\r\nthe result of first step like this:\r\n\r\n\r\n     {\r\n      &quot;VolumeId&quot;: &quot;vol-11111111&quot;,\r\n      &quot;Name&quot;: &quot;volume1&quot;,\r\n      &quot;Start&quot;: &quot;00:00&quot;,\r\n      &quot;Finish&quot;: &quot;00:20&quot;,\r\n      &quot;Period&quot;: &quot;2&quot;\r\n    }\r\n    {\r\n      &quot;VolumeId&quot;: &quot;vol-22222222&quot;,\r\n      &quot;Name&quot;: &quot;volume2&quot;,\r\n      &quot;Start&quot;: &quot;00:00&quot;,\r\n      &quot;Finish&quot;: &quot;00:20&quot;,\r\n      &quot;Period&quot;: &quot;2&quot;\r\n    }\r\n    {\r\n      &quot;VolumeId&quot;: &quot;vol-33333333&quot;,\r\n      &quot;Name&quot;: &quot;volume3&quot;,\r\n      &quot;Start&quot;: &quot;00:00&quot;,\r\n      &quot;Finish&quot;: &quot;00:20&quot;,\r\n      &quot;Period&quot;: &quot;2&quot;\r\n    }\r\n\r\n\r\njq support join the json object .\r\n\r\n\r\n2. second choose the fields \r\n\r\n`|{VolumeId,Period,Start,Finish}`\r\n\r\n3.make it to key-value and join them \r\n\r\n \r\n\r\n    |to_entries[]|(.key+&quot;=&quot;+.value)",
                "title": "jq - Iterate over objects in bash like an array (aws volumes)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1498066275,
        "creation_date": 1459307998,
        "question_id": 36299028,
        "body_markdown": "I have some JSON that I have pulled from AWS and formatted with **jq** (the original code is at the bottom) to give me the following output:\r\n\r\n    {\r\n      &quot;VolumeId&quot;: &quot;vol-11111111&quot;,\r\n      &quot;Tags&quot;: {\r\n        &quot;Name&quot;: &quot;volume1&quot;,\r\n        &quot;Finish&quot;: &quot;00:00&quot;,\r\n        &quot;Start&quot;: &quot;00:20&quot;,\r\n        &quot;Period&quot;: &quot;2&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;VolumeId&quot;: &quot;vol-22222222&quot;,\r\n      &quot;Tags&quot;: {\r\n        &quot;Name&quot;: &quot;volume2&quot;,\r\n        &quot;Period&quot;: &quot;1&quot;,\r\n        &quot;Start&quot;: &quot;00:00&quot;,\r\n        &quot;Finish&quot;: &quot;00:20&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;VolumeId&quot;: &quot;vol-33333333&quot;,\r\n      &quot;Tags&quot;: {\r\n        &quot;Period&quot;: &quot;1&quot;,\r\n        &quot;Start&quot;: &quot;00:00&quot;,\r\n        &quot;Name&quot;: &quot;volume3&quot;,\r\n        &quot;Finish&quot;: &quot;00:20&quot;\r\n      }\r\n    }\r\n\r\n\r\nWhat I now need to do is to pull the &#39;VolumeId&#39;, &#39;Period&#39;, &#39;Start&#39; and &#39;Finish&#39;. I would like to iterate over these objects put these into 4 bash variables of the same name in a `for` loop.\r\n\r\ne.g.\r\n\r\n    VolumeId=&quot;vol-33333333&quot;\r\n    Period=&quot;1&quot;\r\n    Start=&quot;00:00&quot;\r\n    Finish=&quot;00:20&quot;\r\n\r\nThe problem is that if I put the entire JSON into a variable, it is treated as a single argument. I could use something like `mapfile`, however it would then turn it into too many arguments - e.g.\r\n    \r\n    }\r\n    &quot;Volumes&quot;: [\r\n    { \r\netc\r\n\r\nAny help in getting this to work would be greatly appreciated. The end result is to be able to take a snapshot of the volume and use the &#39;Period&#39; tag to calculate retention etc.\r\n\r\n-- \r\nOriginal JSON:\r\n\r\n    {\r\n    &quot;Volumes&quot;: [\r\n        {\r\n            &quot;Attachments&quot;: [],\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Value&quot;: &quot;volume1&quot;,\r\n                    &quot;Key&quot;: &quot;Name&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;00:00&quot;,\r\n                    &quot;Key&quot;: &quot;Start&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;00:20&quot;,\r\n                    &quot;Key&quot;: &quot;Finish&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;2&quot;,\r\n                    &quot;Key&quot;: &quot;Period&quot;\r\n                }\r\n            ],\r\n            &quot;VolumeId&quot;: &quot;vol-11111111&quot;\r\n        },\r\n        {\r\n            &quot;Attachments&quot;: [],\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Value&quot;: &quot;volume2&quot;,\r\n                    &quot;Key&quot;: &quot;Name&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;00:00&quot;,\r\n                    &quot;Key&quot;: &quot;Start&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;00:20&quot;,\r\n                    &quot;Key&quot;: &quot;Finish&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;2&quot;,\r\n                    &quot;Key&quot;: &quot;Period&quot;\r\n                }\r\n            ],\r\n            &quot;VolumeId&quot;: &quot;vol-22222222&quot;\r\n        },\r\n\t\t{\r\n            &quot;Attachments&quot;: [],\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Value&quot;: &quot;volume3&quot;,\r\n                    &quot;Key&quot;: &quot;Name&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;00:00&quot;,\r\n                    &quot;Key&quot;: &quot;Start&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;00:20&quot;,\r\n                    &quot;Key&quot;: &quot;Finish&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;2&quot;,\r\n                    &quot;Key&quot;: &quot;Period&quot;\r\n                }\r\n            ],\r\n            &quot;VolumeId&quot;: &quot;vol-33333333&quot;\r\n        }\r\n    ]\r\n    }\r\n\r\nand the **jq** command:\r\n\r\n    jq -r &#39;.Volumes[] | {&quot;VolumeId&quot;: .VolumeId, &quot;Tags&quot;: [.Tags[]] | from_entries}&#39; ",
        "link": "https://stackoverflow.com/questions/36299028/jq-iterate-over-objects-in-bash-like-an-array-aws-volumes",
        "title": "jq - Iterate over objects in bash like an array (aws volumes)"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1459542867,
                "creation_date": 1459542867,
                "answer_id": 36365414,
                "question_id": 36364858,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The input shown in the question is not valid JSON.  After making some minor changes to make it valid JSON, the following filter produces the output as shown below:\r\n\r\n    map( (.arr[]|.x) as $x | {id, &quot;x&quot;: $x} )\r\n\r\nOutput:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;x&quot;: 1\r\n      },\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;x&quot;: 2\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;x&quot;: 3\r\n      },\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;x&quot;: 4\r\n      }\r\n    ]",
                "title": "jq: unnesting records and mixing fields from both record levels"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1459544300,
                "creation_date": 1459544300,
                "answer_id": 36365737,
                "question_id": 36364858,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming it doesn&#39;t get any more complex than that, you could simply do this:\r\n\r\n    map(del(.arr) + .arr[])\r\n\r\nThis is under the assumption that you&#39;re replacing the `arr` property of each object with the contents of the items in `arr`. It&#39;s unclear what you&#39;re trying to do exactly.",
                "title": "jq: unnesting records and mixing fields from both record levels"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1459544300,
        "creation_date": 1459540753,
        "question_id": 36364858,
        "body_markdown": "I have the following file:\r\n\r\n    [\r\n        {\r\n            &#39;id&#39;: 1,\r\n            &#39;arr&#39;: [{&#39;x&#39;: 1,\r\n                    {&#39;x&#39;: 2}]\r\n        },\r\n        {\r\n            &#39;id&#39;: 2,\r\n            &#39;arr&#39;: [{&#39;x&#39;: 3},\r\n                    {&#39;x&#39;: 4}]\r\n        }\r\n    ]\r\n\r\nHow can I transform it into the following form using jq?\r\n\r\n    [\r\n        {&#39;id&#39;: 1, &#39;x&#39;: 1},\r\n        {&#39;id&#39;: 1, &#39;x&#39;: 2},\r\n        {&#39;id&#39;: 2, &#39;x&#39;: 3},\r\n        {&#39;id&#39;: 2, &#39;x&#39;: 4},\r\n    ]",
        "link": "https://stackoverflow.com/questions/36364858/jq-unnesting-records-and-mixing-fields-from-both-record-levels",
        "title": "jq: unnesting records and mixing fields from both record levels"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1459692737,
                "post_id": 36386399,
                "comment_id": 60389687,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1365444,
                    "reputation": 84884,
                    "user_id": 1301972,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://i.sstatic.net/T5G7N.jpg?s=256",
                    "display_name": "Todd A. Jacobs",
                    "link": "https://stackoverflow.com/users/1301972/todd-a-jacobs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1459692816,
                "post_id": 36386399,
                "comment_id": 60389713,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1459702961,
                "post_id": 36386399,
                "comment_id": 60393453,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1459739593,
                "last_edit_date": 1459739593,
                "creation_date": 1459699449,
                "answer_id": 36387734,
                "question_id": 36386399,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Something along the lines of\r\n\r\n    curl -s &quot;http://www.worldtides.info/api?extremes&amp;lat=my_latitude&amp;lon=my_longitude&amp;key=my‌​_api_key&quot;| jq -r &quot;.extremes[] | .date + .type&quot;\r\n\r\nShould give you **both** the date/time and High/Low tide output for each entry.\r\n\r\n---\r\n\r\n**Basically**, you need to use `extremes` NOT `result`.  There is **no** `result` key, hence `jq` is giving you messages about `null`.",
                "title": "How to parse JSON tidal information from worldtides.info?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1459750488,
        "creation_date": 1459692390,
        "last_edit_date": 1459750488,
        "question_id": 36386399,
        "body_markdown": "My goal is to parse the result of [www.worldtides.info](http://www.worldtides.info).  I have a Raspberry Pi 2 and I&#39;m scripting with Linux.\r\n\r\nI have an API key and the curl request is something like:\r\n\r\n    curl -s &quot;http://www.worldtides.info/api?extremes&amp;lat=my_latitude&amp;lon=my_longitude&amp;key=my_api_key&quot;\r\n\r\nWhich gets a result like this:\r\n\r\n    {\r\n      &quot;status&quot;: 200,\r\n      &quot;requestLat&quot;: &quot;my_latitude&quot;,\r\n      &quot;requestLon&quot;: &quot;my_longitude&quot;,\r\n      &quot;extremes&quot;: [\r\n        {\r\n          &quot;dt&quot;: 1459680132,\r\n          &quot;date&quot;: &quot;2016-04-03T10:42+0000&quot;,\r\n          &quot;height&quot;: 0.7343567325036922,\r\n          &quot;type&quot;: &quot;High&quot;\r\n        },\r\n        {\r\n          &quot;dt&quot;: 1459702028,\r\n          &quot;date&quot;: &quot;2016-04-03T16:47+0000&quot;,\r\n          &quot;height&quot;: -0.8438121322770741,\r\n          &quot;type&quot;: &quot;Low&quot;\r\n        },\r\n        {\r\n          &quot;dt&quot;: 1459724478,\r\n          &quot;date&quot;: &quot;2016-04-03T23:01+0000&quot;,\r\n          &quot;height&quot;: 1.0419712550773803,\r\n          &quot;type&quot;: &quot;High&quot;\r\n        },\r\n        {\r\n          &quot;dt&quot;: 1459747135,\r\n          &quot;date&quot;: &quot;2016-04-04T05:18+0000&quot;,\r\n          &quot;height&quot;: -1.1049607153344834,\r\n          &quot;type&quot;: &quot;Low&quot;\r\n        },\r\n        {\r\n          &quot;dt&quot;: 1459769354,\r\n          &quot;date&quot;: &quot;2016-04-04T11:29+0000&quot;,\r\n          &quot;height&quot;: 1.1012796430343657,\r\n          &quot;type&quot;: &quot;High&quot;\r\n        },\r\n        {\r\n          &quot;dt&quot;: 1459791366,\r\n          &quot;date&quot;: &quot;2016-04-04T17:36+0000&quot;,\r\n          &quot;height&quot;: -1.204313872235808,\r\n          &quot;type&quot;: &quot;Low&quot;\r\n        },\r\n        {\r\n          &quot;dt&quot;: 1459813613,\r\n          &quot;date&quot;: &quot;2016-04-04T23:46+0000&quot;,\r\n          &quot;height&quot;: 1.3452661348073778,\r\n          &quot;type&quot;: &quot;High&quot;\r\n        },\r\n        {\r\n          &quot;dt&quot;: 1459835931,\r\n          &quot;date&quot;: &quot;2016-04-05T05:58+0000&quot;,\r\n          &quot;height&quot;: -1.4062688322894952,\r\n          &quot;type&quot;: &quot;Low&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nUsing jq, I want to get the times of high and low tides for the current day and tomorrow, but when I try this:\r\n\r\n    .result[].type\r\n\r\nBut it gives me an error:\r\n\r\n    jq: error (at &lt;stdin&gt;:0): Cannot iterate over null (null)`\r\n\r\n---\r\n\r\nI know I can get the type of tide it is using this:\r\n\r\n    .extremes[].type\r\n\r\nthe result is:\r\n\r\n    High\r\n    Low\r\n    etc...\r\n\r\nand the time of the tide using this:\r\n\r\n    .extremes[].date\r\n\r\nthe result is:     \r\n\r\n    2016-04-03T10:42+0000\r\n    2016-04-03T16:47+0000\r\n    etc...\r\n\r\nSo, how do I combine the results together to get an output like this?\r\n\r\n    2016-04-03T10:42+0000 High\r\n    2016-04-03T16:47+0000 Low\r\n    etc...",
        "link": "https://stackoverflow.com/questions/36386399/how-to-parse-json-tidal-information-from-worldtides-info",
        "title": "How to parse JSON tidal information from worldtides.info?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1459739087,
                "post_id": 36393805,
                "comment_id": 60404606,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8135869,
                    "reputation": 317,
                    "user_id": 6127511,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/2ea00f91a8174e24aec445f87a454b3c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user6127511",
                    "link": "https://stackoverflow.com/users/6127511/user6127511"
                },
                "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": 1459743059,
                "post_id": 36393805,
                "comment_id": 60405444,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1459751255,
                "last_edit_date": 1459751255,
                "creation_date": 1459749788,
                "answer_id": 36395505,
                "question_id": 36393805,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Ultimately, the problem is that you&#39;re using `from_entries` on the `Attachments` array when it wouldn&#39;t work.  `from_entries` takes an array of key/value pair objects to create an object with those values.  However, you don&#39;t have key/value pairs, but objects.  If you&#39;re just trying to combine them, you should use `add`.\r\n\r\nAlso, there is no property named `DeviceId`, it&#39;s `Device`.  If you want to select the `Device` property and get it as `DeviceId`, you need to provide the correct name.\r\n\r\n    .Volumes | map(\r\n        ({ VolumeId } + (.Attachments | add) + (.Tags | from_entries))\r\n          | { VolumeId, Finish, Start, Period, DeviceId: .Device }\r\n    )",
                "title": "jq - extract additional JSON object into new array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1504638608,
        "creation_date": 1459737594,
        "last_edit_date": 1504638608,
        "question_id": 36393805,
        "body_markdown": "I have some JSON. It looks like this:\r\n\r\n    {\r\n    &quot;Volumes&quot;: [\r\n        {\r\n            &quot;Attachments&quot;: [\r\n                {\r\n                    &quot;VolumeId&quot;: &quot;vol-11111111&quot;,\r\n                    &quot;State&quot;: &quot;attached&quot;,\r\n                    &quot;DeleteOnTermination&quot;: false,\r\n                    &quot;Device&quot;: &quot;/dev/sdz&quot;\r\n                }\r\n            ],\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Value&quot;: &quot;volume1&quot;,\r\n                    &quot;Key&quot;: &quot;Name&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;00:00&quot;,\r\n                    &quot;Key&quot;: &quot;Start&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;00:20&quot;,\r\n                    &quot;Key&quot;: &quot;Finish&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;2&quot;,\r\n                    &quot;Key&quot;: &quot;Period&quot;\r\n                }\r\n            ],\r\n            &quot;VolumeId&quot;: &quot;vol-11111111&quot;\r\n        },\r\n        {\r\n            &quot;Attachments&quot;: [\r\n                {\r\n                    &quot;VolumeId&quot;: &quot;vol-22222222&quot;,\r\n                    &quot;State&quot;: &quot;attached&quot;,\r\n                    &quot;DeleteOnTermination&quot;: false,\r\n                    &quot;Device&quot;: &quot;/dev/sdz&quot;\r\n                }\r\n            ],\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Value&quot;: &quot;volume2&quot;,\r\n                    &quot;Key&quot;: &quot;Name&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;00:00&quot;,\r\n                    &quot;Key&quot;: &quot;Start&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;00:20&quot;,\r\n                    &quot;Key&quot;: &quot;Finish&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;2&quot;,\r\n                    &quot;Key&quot;: &quot;Period&quot;\r\n                }\r\n            ],\r\n            &quot;VolumeId&quot;: &quot;vol-22222222&quot;\r\n        },\r\n        {\r\n            &quot;Attachments&quot;: [\r\n                {\r\n                    &quot;VolumeId&quot;: &quot;vol-333333333&quot;,\r\n                    &quot;State&quot;: &quot;attached&quot;,\r\n                    &quot;DeleteOnTermination&quot;: false,\r\n                    &quot;Device&quot;: &quot;/dev/sdz&quot;\r\n                }\r\n            ],\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Value&quot;: &quot;volume3&quot;,\r\n                    &quot;Key&quot;: &quot;Name&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;00:00&quot;,\r\n                    &quot;Key&quot;: &quot;Start&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;00:20&quot;,\r\n                    &quot;Key&quot;: &quot;Finish&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;2&quot;,\r\n                    &quot;Key&quot;: &quot;Period&quot;\r\n                }\r\n            ],\r\n            &quot;VolumeId&quot;: &quot;vol-33333333&quot;\r\n        }\r\n    ]\r\n    }\r\n\r\nUsing jq, I am able to extract the following information:\r\n\r\nVolumeId,Finish,Start,Period \r\n\r\nusing the jq command\r\n\r\n\r\n    cat json | jq -r &#39;[.Volumes[]|({VolumeId}+(.Tags|from_entries))|{VolumeId,Finish,Start,Period}]&#39;\r\n\r\n    [\r\n      {\r\n        &quot;VolumeId&quot;: &quot;vol-11111111&quot;,\r\n        &quot;Finish&quot;: &quot;00:20&quot;,\r\n        &quot;Start&quot;: &quot;00:00&quot;,\r\n        &quot;Period&quot;: &quot;2&quot;\r\n      },\r\n      {\r\n        &quot;VolumeId&quot;: &quot;vol-22222222&quot;,\r\n        &quot;Finish&quot;: &quot;00:20&quot;,\r\n        &quot;Start&quot;: &quot;00:00&quot;,\r\n        &quot;Period&quot;: &quot;2&quot;\r\n      },\r\n      {\r\n        &quot;VolumeId&quot;: &quot;vol-33333333&quot;,\r\n        &quot;Finish&quot;: &quot;00:20&quot;,\r\n        &quot;Start&quot;: &quot;00:00&quot;,\r\n        &quot;Period&quot;: &quot;2&quot;\r\n      }\r\n    ]\r\n\r\n----------------\r\n\r\nAll this works fine. However I have the need to additional extract .Attachments.Device. I am looking for output for each array similar to:\r\n\r\n     [\r\n      {\r\n        &quot;VolumeId&quot;: &quot;vol-11111111&quot;,\r\n        &quot;Finish&quot;: &quot;00:20&quot;,\r\n        &quot;Start&quot;: &quot;00:00&quot;,\r\n        &quot;Period&quot;: &quot;2&quot;,\r\n        &quot;DeviceId&quot;: &quot;/dev/sdz&quot;\r\n      },\r\n      {\r\n        &quot;VolumeId&quot;: &quot;vol-22222222&quot;,\r\n        &quot;Finish&quot;: &quot;00:20&quot;,\r\n        &quot;Start&quot;: &quot;00:00&quot;,\r\n        &quot;Period&quot;: &quot;2&quot;,\r\n        &quot;DeviceId&quot;: &quot;/dev/sdz&quot;\r\n      },\r\n      {\r\n        &quot;VolumeId&quot;: &quot;vol-33333333&quot;,\r\n        &quot;Finish&quot;: &quot;00:20&quot;,\r\n        &quot;Start&quot;: &quot;00:00&quot;,\r\n        &quot;Period&quot;: &quot;2&quot;,\r\n        &quot;DeviceId&quot;: &quot;/dev/sdz&quot;\r\n      }\r\n    ]\r\n\r\nHowever I can&#39;t figure out how to do this without getting an error. The most logical approach for me would be to do something like:\r\n\r\n    cat json | jq -r &#39;[.Volumes[]|({VolumeId}+(.Attachments|from_entries)+(.Tags|from_entries))|{VolumeId,Finish,Start,Period,DeviceId}]&#39;\r\n\r\nHowever I get the error:\r\n\r\n    jq: error (at &lt;stdin&gt;:91): Cannot use null (null) as object key\r\n\r\n\r\nAny help figuring out what I am not doing correct and how to fix it would be greatly appreciated.\r\n\r\nthanks\r\n",
        "link": "https://stackoverflow.com/questions/36393805/jq-extract-additional-json-object-into-new-array",
        "title": "jq - extract additional JSON object into new array"
    },
    {
        "tags": [
            "bash",
            "awk",
            "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": 1459867691,
                "post_id": 36428666,
                "comment_id": 60473796,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1459865722,
                "creation_date": 1459865722,
                "answer_id": 36428960,
                "question_id": 36428666,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    $ cat tst.awk\r\n    BEGIN { FS=&quot;\\&quot;: \\&quot;&quot;; OFS=&quot;\\t&quot; }\r\n    { gsub(/^&quot;|&quot;,$/,&quot;&quot;); f[$1] = $2 }\r\n    /}/ { print f[&quot;country&quot;], f[&quot;city&quot;]; delete f }\r\n\r\n    $ awk -f tst.awk file\r\n    CN      Beijing\r\n\r\nSince you didn&#39;t provide the &quot;other file&quot; to add the output of this to or provide any details on how you want to do that, it&#39;s not clear what you want to do with that so it&#39;s left to you...",
                "title": "Parse json object to column in linux"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1459866041,
                "creation_date": 1459866041,
                "answer_id": 36429091,
                "question_id": 36428666,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    curl  -s ipinfo.io/0.0.0.0 | jq -r &#39;.country +&quot;\\t&quot;+  .city&#39;",
                "title": "Parse json object to column in linux"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1459980360,
                "creation_date": 1459980360,
                "answer_id": 36463185,
                "question_id": 36428666,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can first put to two fields you&#39;re interested in into an array:\r\n\r\n    $ curl -s ipinfo.io | jq &#39;[.country, .city]&#39;\r\n    [\r\n      &quot;US&quot;,\r\n      &quot;Mountain View&quot;\r\n    ]\r\n\r\nAnd then convert to csv with `@csv`:\r\n\r\n    $ curl -s ipinfo.io | jq &#39;[.country, .city] | @csv&#39;\r\n    &quot;\\&quot;US\\&quot;,\\&quot;Mountain View\\&quot;&quot;\r\n\r\nThe `-r` (raw) argument cleans up some of that escaping:\r\n\r\n    $ curl -s ipinfo.io | jq -r &#39;[.country, .city] | @csv&#39;\r\n    &quot;US&quot;,&quot;Mountain View&quot;\r\n\r\nYou can then use `paste` to combine the output with another file.",
                "title": "Parse json object to column in linux"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1459980360,
        "creation_date": 1459865056,
        "last_edit_date": 1459865529,
        "question_id": 36428666,
        "body_markdown": "I have a output of json format as below\r\n\r\n    {\r\n    &quot;ip&quot;: &quot;0.0.0.0&quot;,\r\n    &quot;hostname&quot;: &quot;No Hostname&quot;,\r\n    &quot;city&quot;: &quot;Beijing&quot;,\r\n    &quot;region&quot;: &quot;Beijing Shi&quot;,\r\n    &quot;country&quot;: &quot;CN&quot;,\r\n    &quot;loc&quot;: &quot;39.9289,116.3883&quot;,\r\n    &quot;org&quot;: &quot;AS55967 Beijing Baidu Netcom Science and Technology Co., Ltd.&quot;\r\n    }\r\n i need values of country and city as below \r\n\r\n    CN        Beijing\r\n\r\n\r\ni have used below jq command and sed command to display country but dont know how to display city as another column. \r\n\r\n**jq**\r\n\r\n     curl  -s ipinfo.io/0.0.0.0 | jq &#39;.country&#39;\r\n**sed**\r\n\r\n     curl  -s ipinfo.io/0.0.0.0 | sed &#39;/country/!d&#39; | sed s/\\&quot;country\\&quot;:\\ //g | sed &#39;s/\\&quot;//g&#39; | sed &#39;s/\\,//g&#39;\r\n\r\n\r\nThe output of this country and city columns should be added to 4th &amp; 5th column of another csv file sample below\r\n\r\n    2016-03-29 00:05:23 0.0.0.0 CN Beijing 10.0.0.197 \r\n    2016-03-29 00:56:37 1.1.1.1 FR France 10.0.1.117\r\n    2016-03-29 00:57:20 2.2.2.2 FR France 10.0.0.197\r\n\r\n    ",
        "link": "https://stackoverflow.com/questions/36428666/parse-json-object-to-column-in-linux",
        "title": "Parse json object to column in linux"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1459872328,
                "creation_date": 1459872328,
                "answer_id": 36431574,
                "question_id": 36431371,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`awk` to the rescue!\r\n\r\na template `awk` solution can be\r\n\r\n    $ awk &#39;BEGIN{print &quot;header&quot;} \r\n         NR==FNR{c=NR;next} \r\n                {print &quot;prefix&quot;,$1,&quot;suffix&quot; (FNR&lt;c?&quot;,&quot;:&quot;]&quot;)}\r\n             END{print &quot;footer&quot;}&#39; myseedips{,}\r\n\r\n    header\r\n    prefix 10.204.99.15 suffix,\r\n    prefix 10.204.99.12 suffix,\r\n    prefix 10.204.99.41 suffix]\r\n    footer\r\n\r\nyou can replace the header,footer,prefix, and suffix. ",
                "title": "Bash Script to create a JSON file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1459877931,
                "creation_date": 1459877931,
                "answer_id": 36433345,
                "question_id": 36431371,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using `jq`, you&#39;ll need an extra pass to convert from raw text to a workable array but simple:\r\n\r\n    $ jq -R &#39;.&#39; myseedips | jq -s &#39;{cassandra:{nodes:map({ip_address:.,type:&quot;seed&quot;})}}&#39;\r\n\r\nThis yields the following:\r\n\r\n    {\r\n      &quot;cassandra&quot;: {\r\n        &quot;nodes&quot;: [\r\n          {\r\n            &quot;ip_address&quot;: &quot;10.204.99.15&quot;,\r\n            &quot;type&quot;: &quot;seed&quot;\r\n          },\r\n          {\r\n            &quot;ip_address&quot;: &quot;10.204.99.12&quot;,\r\n            &quot;type&quot;: &quot;seed&quot;\r\n          },\r\n          {\r\n            &quot;ip_address&quot;: &quot;10.204.99.41&quot;,\r\n            &quot;type&quot;: &quot;seed&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\n",
                "title": "Bash Script to create a JSON file"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1459893615,
                "creation_date": 1459893615,
                "answer_id": 36437836,
                "question_id": 36431371,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Further to Jeff&#39;s answer, please note that the transformation can be accomplished with a single invocation of jq.  If your jq has the `inputs` filter:\r\n\r\n    jq -Rn &#39;[inputs] | {cassandra:{nodes:map({ip_address:.,type:&quot;seed&quot;})}}&#39; \r\n\r\nOtherwise:\r\n\r\n    jq -Rs &#39;split(&quot;\\n&quot;) | {cassandra:{nodes:map({ip_address:.,type:&quot;seed&quot;})}}&#39; ips.txt",
                "title": "Bash Script to create a JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1459893615,
        "creation_date": 1459871758,
        "last_edit_date": 1459872128,
        "question_id": 36431371,
        "body_markdown": "**Input:**\r\nI have a filename called &#39;myseedips&#39; with a set of Ip addresses in it in the below structure \r\n\r\n&lt;!-- language: lang-html --&gt;\r\n\r\n    10.204.99.15\r\n    10.204.99.12\r\n    10.204.99.41\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\nThese can be &#39;n&#39; number of IP addressess line by line.\r\n\r\n**Output**\r\nI have no idea on bash programming. But I have to write a bash script to create a JSON file in the below structure. These IP addresses has to be in a loop, so that the JSON will change/extend depending on the length of myseedips file.\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    &quot;cassandra&quot;: {\r\n    \t\t&quot;nodes&quot;: [\r\n    \t\t {&quot;ip_address&quot;: &quot;10.204.99.15&quot;,&quot;type&quot;: &quot;seed&quot;},\r\n    \t\t {&quot;ip_address&quot;: &quot;10.204.99.12&quot;,&quot;type&quot;: &quot;seed&quot;},\r\n    \t\t {&quot;ip_address&quot;: &quot;10.204.99.41&quot;,&quot;type&quot;: &quot;seed&quot;}]\r\n    \t},\r\n\r\n&lt;!-- end snippet --&gt;\r\nAlso need to add logic to add comma at the end of each node for all nodes except the last. Do not append comma if there is only one node.\r\n\r\n\r\n**Example:**\r\nMay be be something like the below code logic, but in bash programming.\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    j string\r\n    j = `&quot;cassandra&quot;: {&quot;nodes&quot;: [`\r\n    for i =0;i&lt;len(ips);i++ {\r\n        j = j + `{&quot;ip_address&quot;: &quot;` + ips[i] + `&quot;,&quot;type&quot;: &quot;seed&quot;},`\r\n    }\r\n    j = j + `}]}`\r\n\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n\r\n\r\nThanks\r\nNissar Sheik\r\n ",
        "link": "https://stackoverflow.com/questions/36431371/bash-script-to-create-a-json-file",
        "title": "Bash Script to create a JSON file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3915452,
                    "reputation": 4109,
                    "user_id": 5216668,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/UUnxO.jpg?s=256",
                    "display_name": "Will Barnwell",
                    "link": "https://stackoverflow.com/users/5216668/will-barnwell"
                },
                "reply_to_user": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1504654674,
                "post_id": 36438548,
                "comment_id": 79090275,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "reply_to_user": {
                    "account_id": 3915452,
                    "reputation": 4109,
                    "user_id": 5216668,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/UUnxO.jpg?s=256",
                    "display_name": "Will Barnwell",
                    "link": "https://stackoverflow.com/users/5216668/will-barnwell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1504659842,
                "post_id": 36438548,
                "comment_id": 79091308,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3915452,
                    "reputation": 4109,
                    "user_id": 5216668,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/UUnxO.jpg?s=256",
                    "display_name": "Will Barnwell",
                    "link": "https://stackoverflow.com/users/5216668/will-barnwell"
                },
                "reply_to_user": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1504661324,
                "post_id": 36438548,
                "comment_id": 79091619,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "reply_to_user": {
                    "account_id": 3915452,
                    "reputation": 4109,
                    "user_id": 5216668,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/UUnxO.jpg?s=256",
                    "display_name": "Will Barnwell",
                    "link": "https://stackoverflow.com/users/5216668/will-barnwell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1504662744,
                "post_id": 36438548,
                "comment_id": 79091959,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1460220480,
                "last_edit_date": 1460220480,
                "creation_date": 1459899978,
                "answer_id": 36439013,
                "question_id": 36438548,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You should think of it as updating the `firmwares` arrays.  We&#39;re updating it with a filtered version where it the max version is selected.\r\n\r\n    .[].firmwares |= [ max_by(.version | split(&quot;.&quot;) | map(tonumber)) // empty ]",
                "title": "Filter JSON outer objects including only one maximal object from inner array with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1501906386,
                "creation_date": 1501906386,
                "answer_id": 45518113,
                "question_id": 36438548,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **reduce** to visit each key of the object and update corresponding `.firmwares` to the latest version\r\n\r\n    reduce keys[] as $i (\r\n        .\r\n      ; .[$i].firmwares |= [max_by(.version)]\r\n    )",
                "title": "Filter JSON outer objects including only one maximal object from inner array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1504650287,
        "creation_date": 1459897134,
        "last_edit_date": 1504650287,
        "question_id": 36438548,
        "body_markdown": "I have a slightly modified JSON file with iOS firmware information from [https://api.ipsw.me/v2.1/firmwares.json][1]. This is a simplified version:\r\n\r\n**Input**\r\n\r\n    {\r\n      &quot;AppleTV5,3&quot;: {\r\n        &quot;firmwares&quot;: [\r\n          {\r\n            &quot;version&quot;: &quot;9.2&quot;,\r\n            &quot;buildid&quot;: &quot;13Y234&quot;\r\n          },\r\n          {\r\n            &quot;version&quot;: &quot;9.1.1&quot;,\r\n            &quot;buildid&quot;: &quot;13U717&quot;\r\n          },\r\n          {\r\n            &quot;version&quot;: &quot;9.1&quot;,\r\n            &quot;buildid&quot;: &quot;13U85&quot;\r\n          }\r\n        ],\r\n        &quot;bdid&quot;: 52,\r\n        &quot;name&quot;: &quot;Apple TV 4 (2015)&quot;\r\n      },\r\n      &quot;AppleTV3,2&quot;: {\r\n        &quot;firmwares&quot;: [\r\n          {\r\n            &quot;version&quot;: &quot;8.4.1&quot;,\r\n            &quot;buildid&quot;: &quot;12H523&quot;\r\n          },\r\n          {\r\n            &quot;version&quot;: &quot;8.3&quot;,\r\n            &quot;buildid&quot;: &quot;12F69&quot;\r\n          }\r\n        ],\r\n        &quot;bdid&quot;: 0,\r\n        &quot;name&quot;: &quot;Apple TV 3 (2013)&quot;\r\n      },\r\n      &quot;AppleTV3,1&quot;: {\r\n        &quot;firmwares&quot;: [\r\n          {\r\n            &quot;version&quot;: &quot;8.4.1&quot;,\r\n            &quot;buildid&quot;: &quot;12H523&quot;\r\n          },\r\n          {\r\n            &quot;version&quot;: &quot;8.3&quot;,\r\n            &quot;buildid&quot;: &quot;12F69&quot;\r\n          },\r\n          {\r\n            &quot;version&quot;: &quot;8.2&quot;,\r\n            &quot;buildid&quot;: &quot;12D508&quot;\r\n          }\r\n        ],\r\n        &quot;bdid&quot;: 0,\r\n        &quot;name&quot;: &quot;Apple TV 3&quot;\r\n      }\r\n    }\r\n\r\nI want to write a jq query that returns each outer object with only the latest firmware object in the `firmwares` array. E.g.:\r\n\r\n**Desired output**\r\n\r\n    {\r\n      &quot;AppleTV5,3&quot;: {\r\n        &quot;firmwares&quot;: [\r\n          {\r\n            &quot;version&quot;: &quot;9.2&quot;,\r\n            &quot;buildid&quot;: &quot;13Y234&quot;\r\n          }\r\n        ],\r\n        &quot;bdid&quot;: 52,\r\n        &quot;name&quot;: &quot;Apple TV 4 (2015)&quot;\r\n      },\r\n      &quot;AppleTV3,2&quot;: {\r\n        &quot;firmwares&quot;: [\r\n          {\r\n            &quot;version&quot;: &quot;8.4.1&quot;,\r\n            &quot;buildid&quot;: &quot;12H523&quot;\r\n          }\r\n        ],\r\n        &quot;bdid&quot;: 0,\r\n        &quot;name&quot;: &quot;Apple TV 3 (2013)&quot;\r\n      },\r\n      &quot;AppleTV3,1&quot;: {\r\n        &quot;firmwares&quot;: [\r\n          {\r\n            &quot;version&quot;: &quot;8.4.1&quot;,\r\n            &quot;buildid&quot;: &quot;12H523&quot;\r\n          }\r\n        ],\r\n        &quot;bdid&quot;: 0,\r\n        &quot;name&quot;: &quot;Apple TV 3&quot;\r\n      }\r\n    }\r\n\r\nI can get a list of the latest `firmwares` objects with:\r\n\r\n    .[].firmwares | max_by(.version)\r\n\r\nI can get just the values from `version` with:\r\n\r\n    .[].firmwares | map(.version | values) | max\r\n\r\nAnd I can get the outer AppleTV objects with `firmwares` matching a particular `version`:\r\n\r\n    [ . | to_entries[] | .value.firmwares |= map ( select ( .version == &quot;8.3&quot; ) ) ] | from_entries\r\n\r\nBut I can&#39;t seem to combine the techniques to get my desired output. Can anyone help out?\r\n\r\n\r\n  [1]: https://api.ipsw.me/v2.1/firmwares.json",
        "link": "https://stackoverflow.com/questions/36438548/filter-json-outer-objects-including-only-one-maximal-object-from-inner-array-wit",
        "title": "Filter JSON outer objects including only one maximal object from inner array with jq"
    },
    {
        "tags": [
            "docker",
            "docker-compose",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 15,
                "last_activity_date": 1459948146,
                "last_edit_date": 1459948146,
                "creation_date": 1459906832,
                "answer_id": 36439979,
                "question_id": 36439800,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could pipe the output of `docker inspect` to `jq`.  Given content like this:\r\n\r\n    ...\r\n            &quot;Labels&quot;: {\r\n                &quot;com.docker.compose.config-hash&quot;: &quot;a804d541a5828f4aaf17df862b650e58ac5bae77b70ff5ebdb2f0f3682326954&quot;,\r\n                &quot;com.docker.compose.container-number&quot;: &quot;1&quot;,\r\n                &quot;com.docker.compose.oneoff&quot;: &quot;False&quot;,\r\n                &quot;com.docker.compose.project&quot;: &quot;postgis&quot;,\r\n                &quot;com.docker.compose.service&quot;: &quot;postgis&quot;,\r\n                &quot;com.docker.compose.version&quot;: &quot;1.7.0rc1&quot;\r\n            }\r\n    ...\r\n\r\nI can extract an individual label value like this:\r\n\r\n    docker inspect mycontainer |\r\n    jq -r &#39;.[0].Config.Labels[&quot;com.docker.compose.project&quot;]&#39;\r\n\r\nWhich gets me:\r\n\r\n    postgis\r\n",
                "title": "get label value from docker inspect"
            },
            {
                "up_vote_count": 77,
                "is_accepted": true,
                "score": 77,
                "last_activity_date": 1546642153,
                "last_edit_date": 1546642153,
                "creation_date": 1459908118,
                "answer_id": 36440163,
                "question_id": 36439800,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `index` to get the value of that key (wrapped for readability);\r\n\r\n\r\n    docker inspect \\\r\n      --format &#39;{{ index .Config.Labels &quot;com.docker.compose.project&quot;}}&#39; \\\r\n      new_sc2_1\r\n\r\nThat should give you the name of the project",
                "title": "get label value from docker inspect"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 47,
        "last_activity_date": 1629839950,
        "creation_date": 1459905529,
        "last_edit_date": 1629839950,
        "question_id": 36439800,
        "body_markdown": "I had problem to get the value from the map list due to the key has &quot;.&quot; inside.\r\n\r\n```sh\r\ndocker inspect jenkins\r\n```\r\n\r\n```json\r\n  Config: {\r\n  ..\r\n      &quot;Labels&quot;: {\r\n            &quot;com.docker.compose.config-hash&quot;: &quot;85bcf1e0bcd708120185a303e2a8d8e65543c1ec77ec0c6762fc057dc10320aa&quot;,\r\n            &quot;com.docker.compose.container-number&quot;: &quot;1&quot;,\r\n            &quot;com.docker.compose.oneoff&quot;: &quot;False&quot;,\r\n            &quot;com.docker.compose.project&quot;: &quot;new&quot;,\r\n            &quot;com.docker.compose.service&quot;: &quot;sc2&quot;,\r\n            &quot;com.docker.compose.version&quot;: &quot;1.5.2&quot;\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nI can get map list \r\n\r\n&lt;pre&gt;\r\ndocker inspect -f {{.Config.Labels}} new_sc2_1\r\nmap[com.docker.compose.config-hash:85bcf1e0bcd708120185a303e2a8d8e65543c1ec77ec0c6762fc057dc10320aa com.docker.compose.container-number:1 com.docker.compose.oneoff:False com.docker.compose.project:new com.docker.compose.service:sc2 com.docker.compose.version:1.5.2]\r\n&lt;/pre&gt;\r\n\r\nBut how can I get the project name `new` from key `com.docker.compose.project`\r\n\r\n    docker inspect -f {{.Config.Labels.com.docker.compose.project}} new_sc2_1\r\n    &lt;no value&gt;",
        "link": "https://stackoverflow.com/questions/36439800/get-label-value-from-docker-inspect",
        "title": "get label value from docker inspect"
    },
    {
        "tags": [
            "json",
            "ubuntu",
            "upgrade",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5705411,
                    "reputation": 471,
                    "user_id": 4509141,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/7a95816661456342b2fcdfa5c5309f7a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "TheCrimulo",
                    "link": "https://stackoverflow.com/users/4509141/thecrimulo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1459979712,
                "post_id": 36462955,
                "comment_id": 60537973,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4287698,
                    "reputation": 365,
                    "user_id": 3504880,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/73441e673952abb9fc699500276fdafd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "programbyexception",
                    "link": "https://stackoverflow.com/users/3504880/programbyexception"
                },
                "reply_to_user": {
                    "account_id": 5705411,
                    "reputation": 471,
                    "user_id": 4509141,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/7a95816661456342b2fcdfa5c5309f7a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "TheCrimulo",
                    "link": "https://stackoverflow.com/users/4509141/thecrimulo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1459980162,
                "post_id": 36462955,
                "comment_id": 60538153,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5705411,
                    "reputation": 471,
                    "user_id": 4509141,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/7a95816661456342b2fcdfa5c5309f7a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "TheCrimulo",
                    "link": "https://stackoverflow.com/users/4509141/thecrimulo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1459980348,
                "post_id": 36462955,
                "comment_id": 60538226,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4287698,
                    "reputation": 365,
                    "user_id": 3504880,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/73441e673952abb9fc699500276fdafd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "programbyexception",
                    "link": "https://stackoverflow.com/users/3504880/programbyexception"
                },
                "reply_to_user": {
                    "account_id": 5705411,
                    "reputation": 471,
                    "user_id": 4509141,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/7a95816661456342b2fcdfa5c5309f7a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "TheCrimulo",
                    "link": "https://stackoverflow.com/users/4509141/thecrimulo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1459980454,
                "post_id": 36462955,
                "comment_id": 60538275,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5705411,
                    "reputation": 471,
                    "user_id": 4509141,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/7a95816661456342b2fcdfa5c5309f7a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "TheCrimulo",
                    "link": "https://stackoverflow.com/users/4509141/thecrimulo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1459980645,
                "post_id": 36462955,
                "comment_id": 60538346,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4287698,
                    "reputation": 365,
                    "user_id": 3504880,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/73441e673952abb9fc699500276fdafd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "programbyexception",
                    "link": "https://stackoverflow.com/users/3504880/programbyexception"
                },
                "reply_to_user": {
                    "account_id": 5705411,
                    "reputation": 471,
                    "user_id": 4509141,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/7a95816661456342b2fcdfa5c5309f7a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "TheCrimulo",
                    "link": "https://stackoverflow.com/users/4509141/thecrimulo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1459988738,
                "post_id": 36462955,
                "comment_id": 60540776,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5775319,
                    "reputation": 1419,
                    "user_id": 4557537,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/71a1136f6d0025e59d1b0b1e42ef86cd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Fadi",
                    "link": "https://stackoverflow.com/users/4557537/fadi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502470829,
                "post_id": 36462955,
                "comment_id": 78240108,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1460016868,
                "creation_date": 1460016868,
                "answer_id": 36470379,
                "question_id": 36462955,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You&#39;re using Ubuntu LTS. The latest version of Ubuntu does have jq 1.5.",
                "title": "Upgrading jq to 1.5 on Ubuntu"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1473147458,
                "creation_date": 1473147458,
                "answer_id": 39343183,
                "question_id": 36462955,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I think you were missing the correct repo: http://installion.co.uk/ubuntu/vivid/universe/j/jq/install/index.html",
                "title": "Upgrading jq to 1.5 on Ubuntu"
            },
            {
                "up_vote_count": 45,
                "is_accepted": true,
                "score": 45,
                "last_activity_date": 1489042694,
                "last_edit_date": 1489042694,
                "creation_date": 1488795414,
                "answer_id": 42622937,
                "question_id": 36462955,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I ended up here when googling on why my Debian 8 instance does not upgrade `jq` 1.4 to 1.5.\r\n\r\nHere&#39;s my solution for anyone struggling with Debian 8 jq: Download `jq` from https://github.com/stedolan/jq/releases and copy it manually over the currently installed jq. In my case:\r\n\r\n    wget https://github.com/stedolan/jq/releases/download/jq-1.5/jq-linux64\r\n    chmod +x jq-linux64\r\n    sudo mv jq-linux64 $(which jq)",
                "title": "Upgrading jq to 1.5 on Ubuntu"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 27,
        "last_activity_date": 1489042694,
        "creation_date": 1459979202,
        "question_id": 36462955,
        "body_markdown": "So it reads [here][1]:\r\n\r\njq 1.5 is in the official Debian and Ubuntu repositories. Install using sudo apt-get install jq.\r\n\r\nyet:\r\n\r\n    $ sudo apt-get install jq\r\n    Reading package lists... Done\r\n    Building dependency tree       \r\n    Reading state information... Done\r\n    jq is already the newest version.\r\n    0 upgraded, 0 newly installed, 0 to remove and 1 not upgraded.\r\n\r\nAND:\r\n\r\n    $ jq --version\r\n    jq version 1.3\r\n\r\n    Description:\tUbuntu 14.04 LTS\r\n    Release:\t14.04\r\n    Codename:\ttrusty\r\n\r\nWhat am I missing?\r\n\r\nthanks\r\n\r\n  [1]: https://stedolan.github.io/jq/download/\r\n",
        "link": "https://stackoverflow.com/questions/36462955/upgrading-jq-to-1-5-on-ubuntu",
        "title": "Upgrading jq to 1.5 on Ubuntu"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1459992082,
                "creation_date": 1459992082,
                "answer_id": 36465067,
                "question_id": 36463450,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you need the names for the author of the last commits, you can use:\r\n\r\n    curl -s https://api.github.com/repos/mycompany/$repo/commits | jq &#39;.[].author.login&#39;\r\n\r\nIf you need the names for the committer of the last commits, you can use:\r\n\r\n    curl -s https://api.github.com/repos/mycompany/$repo/commits | jq &#39;.[].committer.login&#39;\r\n\r\nor if you need the unique names for that last call:\r\n\r\n    curl -s https://api.github.com/repos/mycompany/$repo/commits | jq &#39;[.[].committer.login] | unique&#39;\r\n\r\nYou can use pagination for more/less results as documented in https://developer.github.com/v3/#pagination",
                "title": "Proper syntax for jq while filtering github commit"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1459997109,
        "creation_date": 1459981751,
        "last_edit_date": 1459997109,
        "question_id": 36463450,
        "body_markdown": "I am struggling with the proper jq syntax for pulling out all the names from a curl call that looks like this:\r\n\r\n&gt; my  @repo = `curl -s -R -D $tmp_fh_header -u $o_user:$o_auth https://api.github.com/repos/mycompany/$repo/commits| jq &#39;.[].login&#39;`;\r\n\r\nIn my case, it should report 10 names, but it only comes back with 5 nulls.\r\n\r\nCan you point me in the right direction?",
        "link": "https://stackoverflow.com/questions/36463450/proper-syntax-for-jq-while-filtering-github-commit",
        "title": "Proper syntax for jq while filtering github commit"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "in-place",
            "edit-in-place"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1534398219,
                "post_id": 36565295,
                "comment_id": 90691969,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 108913,
                    "reputation": 18805,
                    "user_id": 288875,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/516193e369370693f2991ccec37b4dfc?s=256&d=identicon&r=PG",
                    "display_name": "Andre Holzner",
                    "link": "https://stackoverflow.com/users/288875/andre-holzner"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1608667155,
                "post_id": 36565295,
                "comment_id": 115651326,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 16,
                "is_accepted": false,
                "score": 15,
                "last_activity_date": 1460445998,
                "last_edit_date": 1460445998,
                "creation_date": 1460444677,
                "answer_id": 36565891,
                "question_id": 36565295,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You&#39;ll want to update the action objects without changing the context.  By having the pipe there, you&#39;re changing the context to each individual action.  You can control that with some parentheses.\r\n\r\n    $ jq --arg age &quot;3&quot; \\\r\n    &#39;(.Actions[] | select(.properties.age == $age).properties.other) = &quot;no-test&quot;&#39; sample.json\r\n\r\nThis should yield:\r\n\r\n    {\r\n      &quot;Actions&quot;: [\r\n        {\r\n          &quot;value&quot;: &quot;1&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;name&quot;: &quot;abc&quot;,\r\n            &quot;age&quot;: &quot;2&quot;,\r\n            &quot;other &quot;: &quot;test1&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;value&quot;: &quot;2&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;name&quot;: &quot;def&quot;,\r\n            &quot;age&quot;: &quot;3&quot;,\r\n            &quot;other&quot;: &quot;no-test&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nYou can redirect the results to a file to replace the input file. It won&#39;t do in-place updates to a file as sed does.\r\n",
                "title": "jq to replace text directly on file (like sed -i)"
            },
            {
                "up_vote_count": 145,
                "is_accepted": false,
                "score": 144,
                "last_activity_date": 1704394665,
                "last_edit_date": 1704394665,
                "creation_date": 1460474391,
                "answer_id": 36577521,
                "question_id": 36565295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This post addresses the question about the absence of the equivalent of sed&#39;s &quot;-i&quot; option, and in particular the situation described:\r\n\r\n&gt; I have a bunch of files and writing each one to a separate file wouldn&#39;t be easy.  \r\n\r\nThere are several options, at least if you are working in a Mac or Linux or similar environment.  Their pros and cons are discussed at\r\nhttp://backreference.org/2011/01/29/in-place-editing-of-files/\r\nso I&#39;ll focus on just three techniques:\r\n\r\nOne is simply to use &quot;&amp;&amp;&quot; along the lines of:\r\n\r\n    jq ... INPUT &gt; INPUT.tmp &amp;&amp; mv INPUT.tmp INPUT\r\n  \r\nAnother is to use the `sponge` utility (part of GNU `moreutils`):\r\n\r\n    jq ... INPUT | sponge INPUT\r\n\r\nThe third option might be useful if it is advantageous to avoid updating a file if there are no changes to it. Here is a script which illustrates such a function:\r\n\r\n\r\n    #!/bin/bash\r\n    \r\n    function maybeupdate {\r\n        local f=&quot;$1&quot;\r\n        cmp -s &quot;$f&quot; &quot;$f.tmp&quot;\r\n        if [ $? = 0 ] ; then\r\n    \t  /bin/rm &quot;$f.tmp&quot;\r\n        else\r\n    \t  /bin/mv &quot;$f.tmp&quot; &quot;$f&quot;\r\n        fi\r\n    }\r\n    \r\n    for f\r\n    do\r\n        jq . &quot;$f&quot; &gt; &quot;$f.tmp&quot;\r\n        maybeupdate &quot;$f&quot;\r\n    done\r\n",
                "title": "jq to replace text directly on file (like sed -i)"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1461344339,
                "last_edit_date": 1592644375,
                "creation_date": 1460749840,
                "answer_id": 36655724,
                "question_id": 36565295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[Using my answer to a duplicate question][1]\n\n&gt;Assignment prints the whole object with the assignment executed so you could assign a new value to `.Actions` of the modified Actions array\n&gt;\n&gt;     .Actions=([.Actions[] | if .properties.age == &quot;3&quot; then .properties.other = &quot;no-test&quot; else . end])\n&gt;\n&gt;I used an if statement but we can use your code to do the same thing\n&gt;\n&gt;     .Actions=[.Actions[] | select (.properties.age == &quot;3&quot;).properties.other = &quot;no-test&quot;]\n\nThe above will output the entire json with `.Actions` edited.\njq does not had `sed -i` like functionality, but all you need to do is pipe it back into a [sponge][2] to the file with `| sponge`\n\n     jq &#39;.Actions=([.Actions[] | if .properties.age == &quot;3&quot; then .properties.other = &quot;no-test&quot; else . end])&#39; sample.json | sponge sample.json\n\n\n  [1]: https://stackoverflow.com/questions/36607650/how-to-rewrite-the-exact-value-on-jq-referencing-the-top-element/36608845#36608845\n  [2]: http://linux.die.net/man/1/sponge",
                "title": "jq to replace text directly on file (like sed -i)"
            },
            {
                "up_vote_count": 86,
                "is_accepted": false,
                "score": 75,
                "last_activity_date": 1584552439,
                "creation_date": 1584552439,
                "answer_id": 60744617,
                "question_id": 36565295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "instead of `sponge` :\r\n```\r\ncat &lt;&lt;&lt; $(jq &#39;QUERY&#39; sample.json) &gt; sample.json\r\n```",
                "title": "jq to replace text directly on file (like sed -i)"
            },
            {
                "up_vote_count": 22,
                "is_accepted": false,
                "score": 22,
                "last_activity_date": 1585343692,
                "creation_date": 1585343692,
                "answer_id": 60894210,
                "question_id": 36565295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You ran into two issues:\r\n\r\n - This is a common problem for text processing, not solved in the base Linux distribution.\r\n - *jq* did not write special code to overcome this problem.\r\n\r\nOne good solution:\r\n\r\n  - Install [moreutils](http://joeyh.name/code/moreutils/) using `brew install moreutils` or your favorite package manager.  This contains the handy program `sponge`, for just this purpose.\r\n  - Use `cat myfile | jq blahblahblah | sponge myfile`.  That is, run *jq*, capturing the standard out, when *jq* has finished, then write the standard output over `myfile` (the input file).",
                "title": "jq to replace text directly on file (like sed -i)"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1637784711,
                "last_edit_date": 1637784711,
                "creation_date": 1634770790,
                "answer_id": 69653942,
                "question_id": 36565295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s possible to do something  like:\r\n\r\n    echo &quot;$(jq &#39;. + {&quot;registry-mirrors&quot;: [&quot;https://docker-mirror&quot;]}&#39; /etc/docker/daemon.json)&quot; &gt; /etc/docker/daemon.json\r\n\r\nSo it gets text in sub-shell using jq and echoes it to file in &#39;main&#39; shell.\r\n\r\nNote: The main idea here is to illustrate how it can be achieved without additional tools like `sponge` or so. Instead of `echo` you can use any command which can write to stdout e.g. `printf &#39;%s&#39; &quot;$(jq ... file)&quot; &gt; file`.\r\n\r\nP.S Issue in jq project is still open: https://github.com/stedolan/jq/issues/105\r\n\r\n\r\n",
                "title": "jq to replace text directly on file (like sed -i)"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1635418330,
                "creation_date": 1635418330,
                "answer_id": 69752749,
                "question_id": 36565295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "use tee command\r\n\r\n```\r\n➜ cat config.json|jq &#39;.Actions[] | select (.properties.age == &quot;3&quot;) .properties.other = &quot;no-test&quot;&#39;|tee config.json\r\n{\r\n  &quot;value&quot;: &quot;1&quot;,\r\n  &quot;properties&quot;: {\r\n    &quot;name&quot;: &quot;abc&quot;,\r\n    &quot;age&quot;: &quot;2&quot;,\r\n    &quot;other &quot;: &quot;test1&quot;\r\n  }\r\n}\r\n{\r\n  &quot;value&quot;: &quot;2&quot;,\r\n  &quot;properties&quot;: {\r\n    &quot;name&quot;: &quot;def&quot;,\r\n    &quot;age&quot;: &quot;3&quot;,\r\n    &quot;other&quot;: &quot;no-test&quot;\r\n  }\r\n}\r\n\r\n➜ cat config.json\r\n{\r\n  &quot;value&quot;: &quot;1&quot;,\r\n  &quot;properties&quot;: {\r\n    &quot;name&quot;: &quot;abc&quot;,\r\n    &quot;age&quot;: &quot;2&quot;,\r\n    &quot;other &quot;: &quot;test1&quot;\r\n  }\r\n}\r\n{\r\n  &quot;value&quot;: &quot;2&quot;,\r\n  &quot;properties&quot;: {\r\n    &quot;name&quot;: &quot;def&quot;,\r\n    &quot;age&quot;: &quot;3&quot;,\r\n    &quot;other&quot;: &quot;no-test&quot;\r\n  }\r\n}\r\n```",
                "title": "jq to replace text directly on file (like sed -i)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1636153514,
                "last_edit_date": 1636153514,
                "creation_date": 1636133539,
                "answer_id": 69857148,
                "question_id": 36565295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This `bash` (probably `sh` compatible) function `jqi` will take care of everything.\r\n\r\nUsage: `jqi [-i] &lt;filename&gt; [jq options] &lt;jq filter&gt;`  \r\n\r\ne.g.: \r\n\r\n```bash\r\nfix-node-sass() \r\n{ \r\n    jqi -i package.json &#39;.resolutions += {&quot;node-sass&quot;: &quot;6.0.1&quot;}&#39; \\\r\n                  &#39;| .devDependencies += {&quot;node-sass&quot;: &quot;6.0.1&quot;}&#39;\r\n\r\n}\r\n```\r\n\r\n\r\nMuch like `sed` or `perl`, specify `-i` as the leading argument to force rewriting of the original file.  If `-i` is not specified, it will be a &quot;dry run&quot; and output will go to `stdout`.\r\n\r\nIf for some arcane reason you want to do something weird like:\r\n\r\n`cat in.json | jq -i - &gt; out.json`\r\n\r\nThen `out.json` will hold either the result, or the original contents of `in.json` on error -- i.e., `out.json` should be valid json.\r\n\r\nNote: an output of less than 7 characters (e.g. `null`) is considered an error, and will not overwrite.  You can disable this safety feature if you wish.\r\n\r\n```bash\r\njqi () \r\n{ \r\n    local filename=$1;\r\n    shift;\r\n    local inplace=;\r\n    local stdin=;\r\n    if [[ $filename == &quot;-i&quot; ]]; then\r\n        echo &quot;jqi: in-place editing enabled&quot; 1&gt;&amp;2;\r\n        inplace=y;\r\n        filename=$1;\r\n        shift;\r\n    fi;\r\n    if [[ $filename == &quot;-&quot; ]]; then\r\n        echo &quot;jqi: reading/writing from stdin/stdout&quot; 1&gt;&amp;2;\r\n        if [ -n &quot;$inplace&quot; ]; then\r\n            stdin=y;\r\n            inplace=;\r\n        fi;\r\n        filename=&quot;/dev/stdin&quot;;\r\n    fi;\r\n    local tempname=&quot;$( mktemp --directory --suffix __jq )/$( dirname &quot;$filename&quot; ).$$.json&quot;;\r\n    local timestamp=&quot;${tempname%json}timestamp&quot;;\r\n    local -i error=0;\r\n    cat &quot;$filename&quot; &gt; &quot;$tempname&quot;;\r\n    touch &quot;$timestamp&quot;;\r\n    while :; do\r\n        if jq &quot;${*}&quot; &quot;$filename&quot; &gt; &quot;$tempname&quot;; then\r\n            if test &quot;$tempname&quot; -nt &quot;$timestamp&quot;; then\r\n                local ls_output=($( ls -Lon &quot;$tempname&quot; ));\r\n                filesize=${ls_output[3]};\r\n                if [[ $filesize -lt 7 ]]; then\r\n                    echo &quot;jqi: read only $filesize bytes, not overwriting&quot; 1&gt;&amp;2;\r\n                    error=1;\r\n                    break;\r\n                fi;\r\n                if [ -n &quot;$inplace&quot; ]; then\r\n                    cat &quot;$tempname&quot; &gt; &quot;$filename&quot;;\r\n                else\r\n                    echo &quot;jqi: output from dry run&quot; 1&gt;&amp;2;\r\n                    cat &quot;$tempname&quot;;\r\n                fi;\r\n                error=0;\r\n                break;\r\n            else\r\n                echo &quot;jqi: output not newer, not overwriting&quot; 1&gt;&amp;2;\r\n                error=1;\r\n                break;\r\n            fi;\r\n        else\r\n            echo &quot;jqi: jq error, not overwriting&quot; 1&gt;&amp;2;\r\n            error=1;\r\n            break;\r\n        fi;\r\n    done;\r\n    if [ -n &quot;$stdin&quot; ] &amp;&amp; [ $error -eq 1 ]; then\r\n        echo &quot;jqi: output original to stdout&quot; 1&gt;&amp;2;\r\n        cat &quot;$filename&quot;;\r\n    fi;\r\n    rm &quot;$tempname&quot; &quot;$timestamp&quot;;\r\n    rmdir &quot;$( dirname &quot;$tempname&quot; )&quot;\r\n}\r\n```",
                "title": "jq to replace text directly on file (like sed -i)"
            },
            {
                "up_vote_count": 32,
                "is_accepted": false,
                "score": 32,
                "last_activity_date": 1725842981,
                "last_edit_date": 1725842981,
                "creation_date": 1650189618,
                "answer_id": 71900930,
                "question_id": 36565295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I use [`yq`][1].\r\nFor advanced users this `-i` (in-place update) is needed, hope be added to `jq`\r\n```BASH\r\nyq -iP &#39;.Email.Port=3030&#39; config.json -o json\r\n```\r\n - `-i` in place update\r\n - `-P` pretty print\r\n - `-o` output should be json\r\n\r\n\r\n  [1]: https://github.com/mikefarah/yq",
                "title": "jq to replace text directly on file (like sed -i)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1699317819,
                "last_edit_date": 1699317819,
                "creation_date": 1681273239,
                "answer_id": 75991875,
                "question_id": 36565295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest way of accomplishing it is to load the file into a variable first and then send it into jq.\r\n\r\n    content=$(cat sample.json) &amp;&amp; \r\n    jq &#39;&lt;your jq script&gt;&#39; &lt;&lt;&lt;$content &gt;sample.json\r\n",
                "title": "jq to replace text directly on file (like sed -i)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1684174488,
                "creation_date": 1684174488,
                "answer_id": 76256921,
                "question_id": 36565295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "in one line : `cat file.json | jq &#39;.&#39; | tee file.json.json &gt;/dev/null`",
                "title": "jq to replace text directly on file (like sed -i)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1733574208,
                "last_edit_date": 1733574208,
                "creation_date": 1733568506,
                "answer_id": 79260456,
                "question_id": 36565295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One more workaround:\r\n\r\n    RES=$(jq &#39;.test = &quot;test_val&quot;&#39; sample.json) &amp;&amp; echo &quot;$RES&quot; &gt; sample.json\r\n\r\n1. Save result of `jq` usage to variable,\r\n2. If (1) was successfull - echo variable, keeping linebreaks,\r\n3. Write terminal output to original file.",
                "title": "jq to replace text directly on file (like sed -i)"
            }
        ],
        "is_answered": true,
        "answer_count": 12,
        "score": 176,
        "last_activity_date": 1740483941,
        "creation_date": 1460442964,
        "last_edit_date": 1740483941,
        "question_id": 36565295,
        "body_markdown": "I have a json file that needs to be updated on a certain condition. \r\n\r\nSample json\r\n\r\n    {\r\n       &quot;Actions&quot; : [\r\n          {\r\n             &quot;value&quot; : &quot;1&quot;,\r\n             &quot;properties&quot; : {\r\n                &quot;name&quot; : &quot;abc&quot;,\r\n                &quot;age&quot; : &quot;2&quot;,\r\n                &quot;other &quot;: &quot;test1&quot;\r\n              }\r\n          },\r\n          {\r\n             &quot;value&quot; : &quot;2&quot;,\r\n             &quot;properties&quot; : {\r\n                &quot;name&quot; : &quot;def&quot;,\r\n                &quot;age&quot; : &quot;3&quot;,\r\n                &quot;other&quot; : &quot;test2&quot;\r\n              }\r\n          }\r\n       ]\r\n    }\r\n\r\nI am writing a script that makes use of Jq to match a value and update, as shown below\r\n\r\n    cat sample.json |  jq &#39;.Actions[] | select (.properties.age == &quot;3&quot;) .properties.other = &quot;no-test&quot;&#39;\r\n\r\nOutput (printed to terminal)\r\n\r\n    {\r\n      &quot;value&quot;: &quot;1&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;name&quot;: &quot;abc&quot;,\r\n        &quot;age&quot;: &quot;2&quot;,\r\n        &quot;other &quot;: &quot;test1&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;value&quot;: &quot;2&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;name&quot;: &quot;def&quot;,\r\n        &quot;age&quot;: &quot;3&quot;,\r\n        &quot;other&quot;: &quot;no-test&quot;\r\n      }\r\n    }\r\n\r\nWhile this command makes the needed change, it outputs the entire json on the terminal and does not make change to the file itself. \r\n\r\nPlease advise if there is an option to have jq make changes on the file directly (similar to sed -i).",
        "link": "https://stackoverflow.com/questions/36565295/jq-to-replace-text-directly-on-file-like-sed-i",
        "title": "jq to replace text directly on file (like sed -i)"
    },
    {
        "tags": [
            "json",
            "csv",
            "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": 1460553119,
                "post_id": 36599040,
                "comment_id": 60795947,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 107149,
                    "reputation": 6701,
                    "user_id": 2169388,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ddf78817d7f585ea57abecb28b851283?s=256&d=identicon&r=PG",
                    "display_name": "bennythejudge",
                    "link": "https://stackoverflow.com/users/2169388/bennythejudge"
                },
                "reply_to_user": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1460555637,
                "post_id": 36599040,
                "comment_id": 60798150,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1460564538,
                "creation_date": 1460564538,
                "answer_id": 36604264,
                "question_id": 36599040,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use [`gsub/2`](https://stedolan.github.io/jq/manual/#gsub(regex;string),gsub(regex;string;flags)) to perform the replacements using regular expressions. So for the description part, do the replacement.\r\n\r\n    (.description | gsub(&quot;,&quot;; &quot;&quot;))",
                "title": "jq: edit a single field while converting to CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1460566166,
        "creation_date": 1460552056,
        "last_edit_date": 1460566166,
        "question_id": 36599040,
        "body_markdown": "#Intro\r\nI have researched and tried this for 2 days. I haven&#39;t been successful in either finding a similar question or in finding an answer myself.\r\n\r\nI have the following JSON payload (from VRA APIs)\r\n\r\n\r\n    { &quot;content&quot;: [\r\n     {\r\n      &quot;@type&quot;: &quot;CatalogResource&quot;,\r\n      &quot;id&quot;: &quot;ccc&quot;,\r\n      &quot;iconId&quot;: &quot;xxx&quot;,\r\n      &quot;resourceTypeRef&quot;: {\r\n        &quot;id&quot;: &quot;Infrastructure.Virtual&quot;,\r\n        &quot;label&quot;: &quot;Virtual Machine&quot;\r\n     },\r\n      &quot;name&quot;: &quot;name01&quot;,\r\n      &quot;description&quot;: &quot;example01&quot;,\r\n      &quot;status&quot;: &quot;ACTIVE&quot;,\r\n      &quot;catalogItem&quot;: {\r\n        &quot;id&quot;: &quot;xxxxx&quot;,\r\n        &quot;label&quot;: &quot;xxxxx&quot;\r\n     },\r\n      &quot;requestId&quot;: &quot;xxxxx&quot;,\r\n      &quot;providerBinding&quot;: {\r\n        &quot;bindingId&quot;: &quot;xxxx&quot;,\r\n        &quot;providerRef&quot;: {\r\n          &quot;id&quot;: &quot;xxxxx&quot;,\r\n          &quot;label&quot;: &quot;xxxxx&quot;\r\n        }\r\n     },\r\n      &quot;owners&quot;: [\r\n        {\r\n          &quot;tenantName&quot;: &quot;xxxxx&quot;,\r\n          &quot;ref&quot;: &quot;xxxxxxxx&quot;,\r\n          &quot;type&quot;: &quot;USER&quot;,\r\n          &quot;value&quot;: &quot;xxxxxxxxx&quot;\r\n        }\r\n      ],\r\n      &quot;organization&quot;: {\r\n        &quot;tenantRef&quot;: &quot;xxxx&quot;,\r\n        &quot;tenantLabel&quot;: &quot;xxxxxxx&quot;,\r\n        &quot;subtenantRef&quot;: &quot;xxxxxx&quot;,\r\n        &quot;subtenantLabel&quot;: &quot;xxxxxxxxx&quot;\r\n     },\r\n      &quot;dateCreated&quot;: &quot;2015-10-05T08:58:35.133Z&quot;,\r\n      &quot;lastUpdated&quot;: &quot;2015-12-03T13:23:54.187Z&quot;,\r\n      &quot;hasLease&quot;: true,\r\n      &quot;lease&quot;: {\r\n        &quot;start&quot;: &quot;2015-10-05T08:21:31.000Z&quot;\r\n     },\r\n      &quot;leaseForDisplay&quot;: null,\r\n      &quot;hasCosts&quot;: true,\r\n      &quot;costs&quot;: {\r\n        &quot;leaseRate&quot;: {\r\n          &quot;type&quot;: &quot;moneyTimeRate&quot;,\r\n          &quot;cost&quot;: {\r\n            &quot;type&quot;: &quot;money&quot;,\r\n            &quot;currencyCode&quot;: &quot;GBP&quot;,\r\n            &quot;amount&quot;: 99999\r\n          },\r\n          &quot;basis&quot;: {\r\n            &quot;type&quot;: &quot;timeSpan&quot;,\r\n            &quot;unit&quot;: &quot;DAYS&quot;,\r\n            &quot;amount&quot;: 1\r\n          }\r\n        }\r\n     },\r\n      &quot;costToDate&quot;: {\r\n        &quot;type&quot;: &quot;money&quot;,\r\n        &quot;currencyCode&quot;: &quot;GBP&quot;,\r\n        &quot;amount&quot;: 19181\r\n     },\r\n      &quot;totalCost&quot;: null,\r\n      &quot;childResources&quot;: [],\r\n      &quot;operations&quot;: null,\r\n      &quot;forms&quot;: {\r\n        &quot;catalogResourceInfoHidden&quot;: true,\r\n        &quot;details&quot;: {\r\n          &quot;type&quot;: &quot;extension&quot;,\r\n          &quot;extensionId&quot;: &quot;xxxxxx&quot;,\r\n          &quot;extensionPointId&quot;: null\r\n        }\r\n      },\r\n      &quot;resourceData&quot;: {\r\n        &quot;entries&quot;: []\r\n      }\r\n    },\r\n    {\r\n      &quot;@type&quot;: &quot;CatalogResource&quot;,\r\n      &quot;id&quot;: &quot;ccc&quot;,\r\n      &quot;iconId&quot;: &quot;xxx&quot;,\r\n      &quot;resourceTypeRef&quot;: {\r\n        &quot;id&quot;: &quot;Infrastructure.Virtual&quot;,\r\n        &quot;label&quot;: &quot;Virtual Machine&quot;\r\n      },\r\n      &quot;name&quot;: &quot;name01&quot;,\r\n      &quot;description&quot;: &quot;this, is, my, problem&quot;,\r\n      &quot;status&quot;: &quot;ACTIVE&quot;,\r\n      &quot;catalogItem&quot;: {\r\n        &quot;id&quot;: &quot;xxxxx&quot;,\r\n        &quot;label&quot;: &quot;xxxxx&quot;\r\n      },\r\n      &quot;requestId&quot;: &quot;xxxxx&quot;,\r\n      &quot;providerBinding&quot;: {\r\n        &quot;bindingId&quot;: &quot;xxxx&quot;,\r\n        &quot;providerRef&quot;: {\r\n          &quot;id&quot;: &quot;xxxxx&quot;,\r\n          &quot;label&quot;: &quot;xxxxx&quot;\r\n        }\r\n      },\r\n      &quot;owners&quot;: [\r\n        {\r\n          &quot;tenantName&quot;: &quot;xxxxx&quot;,\r\n          &quot;ref&quot;: &quot;xxxxxxxx&quot;,\r\n          &quot;type&quot;: &quot;USER&quot;,\r\n          &quot;value&quot;: &quot;xxxxxxxxx&quot;\r\n        }\r\n      ],\r\n      &quot;organization&quot;: {\r\n        &quot;tenantRef&quot;: &quot;xxxx&quot;,\r\n        &quot;tenantLabel&quot;: &quot;xxxxxxx&quot;,\r\n        &quot;subtenantRef&quot;: &quot;xxxxxx&quot;,\r\n        &quot;subtenantLabel&quot;: &quot;xxxxxxxxx&quot;\r\n      },\r\n      &quot;dateCreated&quot;: &quot;2015-10-05T08:58:35.133Z&quot;,\r\n      &quot;lastUpdated&quot;: &quot;2015-12-03T13:23:54.187Z&quot;,\r\n      &quot;hasLease&quot;: true,\r\n      &quot;lease&quot;: {\r\n        &quot;start&quot;: &quot;2015-10-05T08:21:31.000Z&quot;\r\n      },\r\n      &quot;leaseForDisplay&quot;: null,\r\n      &quot;hasCosts&quot;: true,\r\n      &quot;costs&quot;: {\r\n        &quot;leaseRate&quot;: {\r\n          &quot;type&quot;: &quot;moneyTimeRate&quot;,\r\n          &quot;cost&quot;: {\r\n            &quot;type&quot;: &quot;money&quot;,\r\n            &quot;currencyCode&quot;: &quot;GBP&quot;,\r\n            &quot;amount&quot;: 99999\r\n          },\r\n          &quot;basis&quot;: {\r\n            &quot;type&quot;: &quot;timeSpan&quot;,\r\n            &quot;unit&quot;: &quot;DAYS&quot;,\r\n            &quot;amount&quot;: 1\r\n          }\r\n        }\r\n      },\r\n      &quot;costToDate&quot;: {\r\n        &quot;type&quot;: &quot;money&quot;,\r\n        &quot;currencyCode&quot;: &quot;GBP&quot;,\r\n        &quot;amount&quot;: 19181\r\n      },\r\n      &quot;totalCost&quot;: null,\r\n      &quot;childResources&quot;: [],\r\n      &quot;operations&quot;: null,\r\n      &quot;forms&quot;: {\r\n        &quot;catalogResourceInfoHidden&quot;: true,\r\n        &quot;details&quot;: {\r\n          &quot;type&quot;: &quot;extension&quot;,\r\n          &quot;extensionId&quot;: &quot;xxxxxx&quot;,\r\n          &quot;extensionPointId&quot;: null\r\n        }\r\n      },\r\n      &quot;resourceData&quot;: {\r\n        &quot;entries&quot;: []\r\n      }\r\n    }\r\n    ]\r\n    }\r\n\r\nI convert it to CSV as follows:\r\n\r\n    jq --raw-output -r &#39;.content[0] | [.name,.id,.resourceTypeRef.label,.description,.status,.catalogItem.label,.owners[0].value,.dateCreated,.costs.leaseRate.cost.amount,.costToDate.amount] | @csv&#39;\r\n\r\n\r\n#Question\r\nI need to edit the .description field and remove commas when present.\r\n\r\nI am looking for a *jq* way to do it; I could do it at shell level using *sed* or *awk* but I would like to know if it&#39;s possible using jq within the same command I use to generate the CSV.\r\n\r\nThanks!!\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/36599040/jq-edit-a-single-field-while-converting-to-csv",
        "title": "jq: edit a single field while converting to CSV"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1460649991,
                "last_edit_date": 1460649991,
                "creation_date": 1460576115,
                "answer_id": 36607951,
                "question_id": 36607327,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following filter for jq &gt;= 1.5 meets your requirements:\r\n\r\n    del(.access)\r\n    | .references |= [.[0]]\r\n    | del(.&quot;cvss-time&quot;)\r\n    | del(.vulnerable_configuration_cpe_2_2)\r\n\r\n\r\nIf you are using jq 1.4, use `del(.[&quot;cvss-time&quot;])` instead of `del(.&quot;cvss-time&quot;)`.",
                "title": "Delete or parse data in JSON file with JQ or any Linux Tool"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1460649991,
        "creation_date": 1460574151,
        "last_edit_date": 1460575163,
        "question_id": 36607327,
        "body_markdown": "I have this JSON file:\r\n\r\n    {\r\n      &quot;vulnerable_configuration_cpe_2_2&quot;: [\r\n        &quot;cpe:/o:apple:apple_tv:9.1&quot;,\r\n        &quot;cpe:/o:apple:watchos:2.1&quot;,\r\n        &quot;cpe:/o:apple:iphone_os:9.2&quot;,\r\n        &quot;cpe:/o:apple:mac_os_x:10.11.2&quot;\r\n      ],\r\n      &quot;vulnerable_configuration&quot;: [\r\n        {\r\n          &quot;title&quot;: &quot;cpe:2.3:o:apple:apple_tv:9.1&quot;,\r\n          &quot;id&quot;: &quot;cpe:2.3:o:apple:apple_tv:9.1&quot;\r\n        },\r\n        {\r\n          &quot;title&quot;: &quot;cpe:2.3:o:apple:watchos:2.1&quot;,\r\n          &quot;id&quot;: &quot;cpe:2.3:o:apple:watchos:2.1&quot;\r\n        },\r\n        {\r\n          &quot;title&quot;: &quot;cpe:2.3:o:apple:iphone_os:9.2&quot;,\r\n          &quot;id&quot;: &quot;cpe:2.3:o:apple:iphone_os:9.2&quot;\r\n        },\r\n        {\r\n          &quot;title&quot;: &quot;cpe:2.3:o:apple:mac_os_x:10.11.2&quot;,\r\n          &quot;id&quot;: &quot;cpe:2.3:o:apple:mac_os_x:10.11.2&quot;\r\n        }\r\n      ],\r\n      &quot;summary&quot;: &quot;The Disk Images component in Apple iOS before 9.2.1, OS X before 10.11.3, and tvOS before 9.1.1 allows local users to gain privileges or cause a denial of service (memory corruption) via unspecified vectors.&quot;,\r\n      &quot;references&quot;: [\r\n        &quot;https://support.apple.com/HT206168&quot;,\r\n        &quot;https://support.apple.com/HT205732&quot;,\r\n        &quot;https://support.apple.com/HT205731&quot;,\r\n        &quot;https://support.apple.com/HT205729&quot;,\r\n        &quot;http://lists.apple.com/archives/security-announce/2016/Mar/msg00001.html&quot;,\r\n        &quot;http://lists.apple.com/archives/security-announce/2016/Jan/msg00005.html&quot;,\r\n        &quot;http://lists.apple.com/archives/security-announce/2016/Jan/msg00003.html&quot;,\r\n        &quot;http://lists.apple.com/archives/security-announce/2016/Jan/msg00002.html&quot;\r\n      ],\r\n      &quot;Modified&quot;: &quot;2016-03-29T19:01:26.810-04:00&quot;,\r\n      &quot;Published&quot;: &quot;2016-02-01T06:59:01.090-05:00&quot;,\r\n      &quot;access&quot;: {\r\n        &quot;vector&quot;: &quot;LOCAL&quot;,\r\n        &quot;complexity&quot;: &quot;LOW&quot;,\r\n        &quot;authentication&quot;: &quot;NONE&quot;\r\n      },\r\n      &quot;cvss&quot;: 7.2,\r\n      &quot;cvss-time&quot;: &quot;2016-03-29T09:43:55.537-04:00&quot;,\r\n      &quot;cwe&quot;: &quot;CWE-119&quot;,\r\n      &quot;id&quot;: &quot;CVE-2016-1717&quot;,\r\n      &quot;impact&quot;: {\r\n        &quot;integrity&quot;: &quot;COMPLETE&quot;,\r\n        &quot;confidentiality&quot;: &quot;COMPLETE&quot;,\r\n        &quot;availability&quot;: &quot;COMPLETE&quot;\r\n      }\r\n\r\nI want to delete the following data using JQ or any Linux Tool\r\n\r\n - access (including vector, complexity, authentication)\r\n  \r\n - references: only first or 1 reference\r\n   \r\n - cvss-time\r\n   \r\n - vulnerable_configuration_cpe_2_2 (Incluide cpe:/o:apple:apple_tv:9.1,\r\n   etc)\r\n\r\nThe result, I want it to be this:\r\n\r\n    {\r\n      &quot;vulnerable_configuration&quot;: [\r\n        {\r\n          &quot;title&quot;: &quot;cpe:2.3:o:apple:apple_tv:9.1&quot;,\r\n          &quot;id&quot;: &quot;cpe:2.3:o:apple:apple_tv:9.1&quot;\r\n        },\r\n        {\r\n          &quot;title&quot;: &quot;cpe:2.3:o:apple:watchos:2.1&quot;,\r\n          &quot;id&quot;: &quot;cpe:2.3:o:apple:watchos:2.1&quot;\r\n        },\r\n        {\r\n          &quot;title&quot;: &quot;cpe:2.3:o:apple:iphone_os:9.2&quot;,\r\n          &quot;id&quot;: &quot;cpe:2.3:o:apple:iphone_os:9.2&quot;\r\n        },\r\n        {\r\n          &quot;title&quot;: &quot;cpe:2.3:o:apple:mac_os_x:10.11.2&quot;,\r\n          &quot;id&quot;: &quot;cpe:2.3:o:apple:mac_os_x:10.11.2&quot;\r\n        }\r\n      ],\r\n      &quot;summary&quot;: &quot;The Disk Images component in Apple iOS before 9.2.1, OS X before 10.11.3, and tvOS before 9.1.1 allows local users to gain privileges or cause a denial of service (memory corruption) via unspecified vectors.&quot;,\r\n      &quot;references&quot;: [\r\n        &quot;https://support.apple.com/HT206168&quot;,\r\n       ],\r\n      &quot;Modified&quot;: &quot;2016-03-29T19:01:26.810-04:00&quot;,\r\n      &quot;Published&quot;: &quot;2016-02-01T06:59:01.090-05:00&quot;,\r\n      &quot;cvss&quot;: 7.2,\r\n      &quot;cwe&quot;: &quot;CWE-119&quot;,\r\n      &quot;id&quot;: &quot;CVE-2016-1717&quot;,\r\n      &quot;impact&quot;: {\r\n        &quot;integrity&quot;: &quot;COMPLETE&quot;,\r\n        &quot;confidentiality&quot;: &quot;COMPLETE&quot;,\r\n        &quot;availability&quot;: &quot;COMPLETE&quot;\r\n      }\r\n\r\n\r\n\r\nI try\r\n\r\n    cat file.json | jq (&#39;del(.cvss-time)&#39; and &#39;access&#39;)\r\n\r\nbut no work\r\n\r\nWhat is the command JQ I have to use? Or what tool can I use?\r\n\r\nTanks!\r\n",
        "link": "https://stackoverflow.com/questions/36607327/delete-or-parse-data-in-json-file-with-jq-or-any-linux-tool",
        "title": "Delete or parse data in JSON file with JQ or any Linux Tool"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8243680,
                    "reputation": 51,
                    "user_id": 6200535,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://www.gravatar.com/avatar/b0ee93132d171e81933dd367c71bd46b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Pradeep BS",
                    "link": "https://stackoverflow.com/users/6200535/pradeep-bs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1460596101,
                "post_id": 36607650,
                "comment_id": 60820999,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1460579971,
                "last_edit_date": 1460579971,
                "creation_date": 1460578945,
                "answer_id": 36608845,
                "question_id": 36607650,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assignment prints the whole object with the assignment executed so you could assign a new value to `.Actions` of the modified Actions array\r\n\r\n    .Actions=([.Actions[] | if .properties.age == &quot;3&quot; then .properties.other = &quot;no-test&quot; else . end])\r\n\r\nI used an if statement but we can use your code to do the same thing\r\n\r\n    .Actions=[.Actions[] | select (.properties.age == &quot;3&quot;).properties.other = &quot;no-test&quot;]\r\n\r\nI created these using [jqplay.org](https://jqplay.org) which is a tool the dev put up, makes these really quick to debug",
                "title": "How to rewrite the exact value on jq, referencing the top element"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1460596137,
        "creation_date": 1460575102,
        "last_edit_date": 1460596137,
        "question_id": 36607650,
        "body_markdown": "I have a large json that looks similar to this\r\n\r\n    {\r\n       &quot;Report&quot; : [\r\n       {&quot;blah&quot; : &quot;...&quot;}\r\n       ],\r\n       &quot;Actions&quot; : [\r\n          {\r\n             &quot;value&quot; : &quot;1&quot;,\r\n             &quot;properties&quot; : {\r\n                &quot;name&quot; : &quot;abc&quot;,\r\n                &quot;age&quot; : &quot;2&quot;,\r\n                &quot;other&quot;: &quot;test1&quot;\r\n              }\r\n          },\r\n          {\r\n             &quot;value&quot; : &quot;2&quot;,\r\n             &quot;properties&quot; : {\r\n                &quot;name&quot; : &quot;def&quot;,\r\n                &quot;age&quot; : &quot;3&quot;,\r\n                &quot;other&quot; : &quot;test2&quot;\r\n              }\r\n          }\r\n       ]\r\n    }\r\n\r\nand I need to change the value of &quot;other&quot; depending on the value of &quot;age&quot;.  \r\n\r\nNow, I want the complete json to be output on the terminal, so I can move it to tmp file.\r\n\r\nThis command works but outputs only the Action block on the terminal\r\n\r\n     jq &#39;(.Actions[] | select (.properties.age == &quot;3&quot;).properties.other = &quot;no-test&quot;)&#39;\r\n\r\nThis command prints the complete json, but rewrites the value for keys that should not be modified (notice &quot;no-test&quot; gets re-written for both ages 2 and 3).\r\n\r\n    jq &#39;(. | select (.Actions[].properties.age == &quot;3&quot;).Actions[].properties.other = &quot;no-test&quot;)&#39;\r\n\r\nPlease advise if there is a way to zone in on the block to the changed, yet output the complete json on the terminal.",
        "link": "https://stackoverflow.com/questions/36607650/how-to-rewrite-the-exact-value-on-jq-referencing-the-top-element",
        "title": "How to rewrite the exact value on jq, referencing the top element"
    },
    {
        "tags": [
            "json",
            "shell",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1498852102,
                "last_edit_date": 1498852102,
                "creation_date": 1460578756,
                "answer_id": 36608798,
                "question_id": 36607970,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There are several ways to &quot;add&quot; two JSON objects.  In your particular case, the following suffices:\r\n \r\n    $ jq --argfile override file1.json &#39;. + $override&#39; file2.json\r\n   \r\nOutput:\r\n\r\n    {\r\n      &quot;username&quot;: &quot;Bob&quot;,\r\n      &quot;password&quot;: &quot;verytrickipwd&quot;,\r\n      &quot;windows&quot;: 6,\r\n      &quot;doors&quot;: &quot;&quot;\r\n    }\r\n\r\nIf your jq does not support the --argfile option, the following should suffice:\r\n\r\n    $ jq -s add file2.json file1.json \r\n\r\nNote that in the case of key-name collisions, the contents of the second file (file1.json in this example) will take precedence.",
                "title": "Merge with jq command the fields of two json files"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501907855,
                "creation_date": 1501907855,
                "answer_id": 45518256,
                "question_id": 36607970,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following solution should do what you requested assuming you correct `file2.json` so that it is valid JSON (&quot;doors&quot; is missing a value), e.g.\r\n\r\n    {\r\n        &quot;username&quot;: &quot;&quot;,\r\n        &quot;password&quot;: &quot;&quot;,\r\n        &quot;windows&quot;: 6,\r\n        &quot;doors&quot;: &quot;doors&quot;\r\n    }\r\n\r\n\r\nand run jq with the `-s` option\r\n\r\n    jq -s -f filter.jq file1.json file2.json\r\n\r\nwhere `filter.jq` contains the filter below which uses **reduce** to merge objects by updating only keys the first time they are encountered.  \r\n\r\n    reduce .[] as $i (\r\n         {}\r\n       ; reduce ($i|keys[]) as $k (\r\n              .\r\n            ; if .[$k] == null then .[$k] = $i[$k] else . end\r\n         )\r\n    )",
                "title": "Merge with jq command the fields of two json files"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1501907855,
        "creation_date": 1460576165,
        "last_edit_date": 1460576551,
        "question_id": 36607970,
        "body_markdown": "I try to using the jq tools (jq-json-processor) in shell script to merge the fields two json.\r\n\r\nHere the content of files:\r\n\r\n**First file**\r\n\r\n    { &quot;username&quot;: &quot;Bob&quot;,\r\n    &quot;password&quot;: &quot;verytrickipwd&quot;,\r\n    &quot;windows&quot;: 6}\r\n\r\n**Second file** (the problem now is I have a new fields)\r\n\r\n    { &quot;username&quot;: &quot;&quot;,\r\n    &quot;password&quot;: &quot;&quot;,\r\n    &quot;windows&quot;: 6,\r\n    &quot;doors&quot;: \r\n    }\r\n\r\nmy expected result\r\n\r\n    { &quot;username&quot;: &quot;Bob&quot;,\r\n    &quot;password&quot;: &quot;verytrickipwd&quot;,\r\n    &quot;windows&quot;: 6,\r\n    &quot;doors&quot;: \r\n    }\r\n\r\n\r\nUsing this command:\r\n`jq -f file1.json file2.json`",
        "link": "https://stackoverflow.com/questions/36607970/merge-with-jq-command-the-fields-of-two-json-files",
        "title": "Merge with jq command the fields of two json files"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1460659869,
                "last_edit_date": 1460659869,
                "creation_date": 1460610726,
                "answer_id": 36614320,
                "question_id": 36613420,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following jq filter produces a stream of JSON objects as requested.\r\nIf you really need a JSON array, then simply wrap the entire expression in square brackets.\r\n\r\n    .Reservations[] | .Instances[]\r\n    | { InstanceId }\r\n      + (.BlockDeviceMappings[]\r\n         | { DeviceName,\r\n             &quot;VolumeId&quot;: .Ebs.VolumeId } )\r\n      + (.Tags\r\n         | { &quot;TAG1&quot;: ( map( select(.Value == &quot;TAG1&quot;))[] | .Key),\r\n             &quot;TAG2&quot;: ( map( select(.Value == &quot;TAG2&quot;))[] | .Key) } )\r\n\r\nHere is the output (once the input JSON has been corrected):\r\n\r\n    {\r\n      &quot;InstanceId&quot;: &quot;i-11111111&quot;,\r\n      &quot;DeviceName&quot;: &quot;/dev/sda1&quot;,\r\n      &quot;VolumeId&quot;: &quot;vol-1111111a&quot;,\r\n      &quot;TAG1&quot;: &quot;VALUE1&quot;,\r\n      &quot;TAG2&quot;: &quot;VALUE2&quot;\r\n    }\r\n    {\r\n      &quot;InstanceId&quot;: &quot;i-11111111&quot;,\r\n      &quot;DeviceName&quot;: &quot;xvdf&quot;,\r\n      &quot;VolumeId&quot;: &quot;vol-1111111b&quot;,\r\n      &quot;TAG1&quot;: &quot;VALUE1&quot;,\r\n      &quot;TAG2&quot;: &quot;VALUE2&quot;\r\n    }\r\n    {\r\n      &quot;InstanceId&quot;: &quot;i-11111111&quot;,\r\n      &quot;DeviceName&quot;: &quot;xvdg&quot;,\r\n      &quot;VolumeId&quot;: &quot;vol-11111111c&quot;,\r\n      &quot;TAG1&quot;: &quot;VALUE1&quot;,\r\n      &quot;TAG2&quot;: &quot;VALUE2&quot;\r\n    }\r\n    {\r\n      &quot;InstanceId&quot;: &quot;i-22222222&quot;,\r\n      &quot;DeviceName&quot;: &quot;/dev/sda1&quot;,\r\n      &quot;VolumeId&quot;: &quot;vol-2222222a&quot;,\r\n      &quot;TAG1&quot;: &quot;VALUE1&quot;,\r\n      &quot;TAG2&quot;: &quot;VALUE2&quot;\r\n    }\r\n    {\r\n      &quot;InstanceId&quot;: &quot;i-22222222&quot;,\r\n      &quot;DeviceName&quot;: &quot;/dev/sdb&quot;,\r\n      &quot;VolumeId&quot;: &quot;vol-2222222b&quot;,\r\n      &quot;TAG1&quot;: &quot;VALUE1&quot;,\r\n      &quot;TAG2&quot;: &quot;VALUE2&quot;\r\n    }\r\n    {\r\n      &quot;InstanceId&quot;: &quot;i-22222222&quot;,\r\n      &quot;DeviceName&quot;: &quot;/dev/sdc&quot;,\r\n      &quot;VolumeId&quot;: &quot;vol-2222222c&quot;,\r\n      &quot;TAG1&quot;: &quot;VALUE1&quot;,\r\n      &quot;TAG2&quot;: &quot;VALUE2&quot;\r\n    }\r\n\r\n",
                "title": "jq - extract nested JSON into multiple arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1460659869,
        "creation_date": 1460604922,
        "last_edit_date": 1460606254,
        "question_id": 36613420,
        "body_markdown": "I have some (redacted) JSON at the bottom of this post, a result of running ec2-describe-instances in AWS. The sample JSON has 2 arrays, however this could be larger. I have used jq before but I am having trouble pulling out values that are deeply nested in the JSON. In particular, I am interested in:\r\n\r\n- InstanceId [&quot;Reservations&quot;: [ &quot;Instances&quot;: [ &quot;InstanceId&quot;: \r\n- DeviceName [&quot;Reservations&quot;: [ &quot;Instances&quot;: [ &quot;BlockDeviceMappings&quot;: [ &quot;DeviceName&quot;:\r\n- VolumeId [&quot;Reservations&quot;: [ &quot;Instances&quot;: [ &quot;BlockDeviceMappings&quot;: [ &quot;Ebs&quot;: { &quot;VolumeId&quot;:\r\n- TAG1 Value/Key\r\n- TAG2 Value/Key\r\n\r\nSummarised, I want a JSON array I can iterate over that will give me an InstanceID, tags on that instance and a _single_ volume. You will notice that each instance has 3 volumes attached (could be more, or less). I&#39;d like to be able to iterate over each one individually. The end result I am hoping would look something like this:\r\n\r\n    [\r\n    {\r\n    &quot;InstanceId&quot;: &quot;i-11111111&quot;,\r\n    &quot;DeviceName&quot;: &quot;/dev/sda1&quot;,\r\n    &quot;VolumeId&quot;: &quot;vol-1111111a&quot;,\r\n    &quot;TAG1&quot;: &quot;VALUE1&quot;,\r\n    &quot;TAG2&quot;: &quot;VALUE2&quot;\r\n    },\r\n    {\r\n    &quot;InstanceId&quot;: &quot;i-11111111&quot;,\r\n    &quot;DeviceName&quot;: &quot;xvdf&quot;,\r\n    &quot;VolumeId&quot;: &quot;vol-1111111b&quot;,\r\n    &quot;TAG1&quot;: &quot;VALUE1&quot;,\r\n    &quot;TAG2&quot;: &quot;VALUE2&quot;\r\n    },\r\n    {\r\n    &quot;InstanceId&quot;: &quot;i-11111111&quot;,\r\n    &quot;DeviceName&quot;: &quot;xvdg&quot;,\r\n    &quot;VolumeId&quot;: &quot;vol-1111111c&quot;,\r\n    &quot;TAG1&quot;: &quot;VALUE1&quot;,\r\n    &quot;TAG2&quot;: &quot;VALUE2&quot;\r\n    },\r\n    {\r\n    &quot;InstanceId&quot;: &quot;i-22222222&quot;,\r\n    &quot;DeviceName&quot;: &quot;/dev/sda1&quot;,\r\n    &quot;VolumeId&quot;: &quot;vol-2222222a&quot;,\r\n    &quot;TAG1&quot;: &quot;VALUE1&quot;,\r\n    &quot;TAG2&quot;: &quot;VALUE2&quot;\r\n    },\r\n    {\r\n    &quot;InstanceId&quot;: &quot;i-22222222&quot;,\r\n    &quot;DeviceName&quot;: &quot;/dev/sdb&quot;,\r\n    &quot;VolumeId&quot;: &quot;vol-2222222b&quot;,\r\n    &quot;TAG1&quot;: &quot;VALUE1&quot;,\r\n    &quot;TAG2&quot;: &quot;VALUE2&quot;\r\n    },\r\n    {\r\n    &quot;InstanceId&quot;: &quot;i-22222222&quot;,\r\n    &quot;DeviceName&quot;: &quot;/dev/sdc&quot;,\r\n    &quot;VolumeId&quot;: &quot;vol-2222222c&quot;,\r\n    &quot;TAG1&quot;: &quot;VALUE1&quot;,\r\n    &quot;TAG2&quot;: &quot;VALUE2&quot;\r\n    }\r\n    ]\r\n\r\nThis is similar to another question I have posted [here on stackoverflow][1]. I have tried so many different combinations but cannot get this to work. Any help is really appreciated.\r\n\r\nHere&#39;s the JSON:\r\n\r\n    {\r\n      &quot;Reservations&quot;: [\r\n        {\r\n          &quot;OwnerId&quot;: &quot;xx&quot;,\r\n          &quot;ReservationId&quot;: &quot;xx&quot;,\r\n          &quot;Groups&quot;: [],\r\n          &quot;Instances&quot;: [\r\n            {\r\n              &quot;Monitoring&quot;: {\r\n                &quot;State&quot;: &quot;xx&quot;\r\n              },\r\n              &quot;PublicDnsName&quot;: &quot;&quot;,\r\n              &quot;Platform&quot;: &quot;xx&quot;,\r\n              &quot;State&quot;: {\r\n                &quot;Code&quot;: xx,\r\n                &quot;Name&quot;: &quot;xx&quot;\r\n              },\r\n              &quot;EbsOptimized&quot;: xx,\r\n              &quot;LaunchTime&quot;: &quot;xx&quot;,\r\n              &quot;PrivateIpAddress&quot;: &quot;xx&quot;,\r\n              &quot;ProductCodes&quot;: [],\r\n              &quot;VpcId&quot;: &quot;xx&quot;,\r\n              &quot;StateTransitionReason&quot;: &quot;&quot;,\r\n              &quot;InstanceId&quot;: &quot;i-11111111&quot;,\r\n              &quot;ImageId&quot;: &quot;xx&quot;,\r\n              &quot;PrivateDnsName&quot;: &quot;xx&quot;,\r\n              &quot;KeyName&quot;: &quot;xx&quot;,\r\n              &quot;SecurityGroups&quot;: [\r\n                {\r\n                  &quot;GroupName&quot;: &quot;xx&quot;,\r\n                  &quot;GroupId&quot;: &quot;xx&quot;\r\n                },\r\n                {\r\n                  &quot;GroupName&quot;: &quot;xx&quot;,\r\n                  &quot;GroupId&quot;: &quot;xx&quot;\r\n                }\r\n              ],\r\n              &quot;ClientToken&quot;: &quot;xx&quot;,\r\n              &quot;SubnetId&quot;: &quot;xx&quot;,\r\n              &quot;InstanceType&quot;: &quot;xx&quot;,\r\n              &quot;NetworkInterfaces&quot;: [\r\n                {\r\n                  &quot;Status&quot;: &quot;xx&quot;,\r\n                  &quot;MacAddress&quot;: &quot;xx&quot;,\r\n                  &quot;SourceDestCheck&quot;: xx,\r\n                  &quot;VpcId&quot;: &quot;xx&quot;,\r\n                  &quot;Description&quot;: &quot;xx&quot;,\r\n                  &quot;NetworkInterfaceId&quot;: &quot;xx&quot;,\r\n                  &quot;PrivateIpAddresses&quot;: [\r\n                    {\r\n                      &quot;PrivateDnsName&quot;: &quot;xx&quot;,\r\n                      &quot;Primary&quot;: xx,\r\n                      &quot;PrivateIpAddress&quot;: &quot;xx&quot;\r\n                    }\r\n                  ],\r\n                  &quot;PrivateDnsName&quot;: &quot;xx&quot;,\r\n                  &quot;Attachment&quot;: {\r\n                    &quot;Status&quot;: &quot;xx&quot;,\r\n                    &quot;DeviceIndex&quot;: xx,\r\n                    &quot;DeleteOnTermination&quot;: xx,\r\n                    &quot;AttachmentId&quot;: &quot;xx&quot;,\r\n                    &quot;AttachTime&quot;: &quot;xx&quot;\r\n                  },\r\n                  &quot;Groups&quot;: [\r\n                    {\r\n                      &quot;GroupName&quot;: &quot;xx&quot;,\r\n                      &quot;GroupId&quot;: &quot;xx&quot;\r\n                    },\r\n                    {\r\n                      &quot;GroupName&quot;: &quot;xx&quot;,\r\n                      &quot;GroupId&quot;: &quot;xx&quot;\r\n                    }\r\n                  ],\r\n                  &quot;SubnetId&quot;: &quot;xx&quot;,\r\n                  &quot;OwnerId&quot;: &quot;xx&quot;,\r\n                  &quot;PrivateIpAddress&quot;: &quot;xx&quot;\r\n                }\r\n              ],\r\n              &quot;SourceDestCheck&quot;: xx,\r\n              &quot;Placement&quot;: {\r\n                &quot;Tenancy&quot;: &quot;xx&quot;,\r\n                &quot;GroupName&quot;: &quot;xx&quot;,\r\n                &quot;AvailabilityZone&quot;: &quot;xx&quot;\r\n              },\r\n              &quot;Hypervisor&quot;: &quot;xx&quot;,\r\n              &quot;BlockDeviceMappings&quot;: [\r\n                {\r\n                  &quot;DeviceName&quot;: &quot;/dev/sda1&quot;,\r\n                  &quot;Ebs&quot;: {\r\n                    &quot;Status&quot;: &quot;attached&quot;,\r\n                    &quot;DeleteOnTermination&quot;: xx,\r\n                    &quot;VolumeId&quot;: &quot;vol-1111111a&quot;,\r\n                    &quot;AttachTime&quot;: &quot;xx&quot;\r\n                  }\r\n                },\r\n                {\r\n                  &quot;DeviceName&quot;: &quot;xvdf&quot;,\r\n                  &quot;Ebs&quot;: {\r\n                    &quot;Status&quot;: &quot;attached&quot;,\r\n                    &quot;DeleteOnTermination&quot;: xx,\r\n                    &quot;VolumeId&quot;: &quot;vol-1111111b&quot;,\r\n                    &quot;AttachTime&quot;: &quot;xx&quot;\r\n                  }\r\n                },\r\n                {\r\n                  &quot;DeviceName&quot;: &quot;xvdg&quot;,\r\n                  &quot;Ebs&quot;: {\r\n                    &quot;Status&quot;: &quot;attached&quot;,\r\n                    &quot;DeleteOnTermination&quot;: xx,\r\n                    &quot;VolumeId&quot;: &quot;vol-11111111c&quot;,\r\n                    &quot;AttachTime&quot;: &quot;xx&quot;\r\n                  }\r\n                }\r\n              ],\r\n              &quot;Architecture&quot;: &quot;xx&quot;,\r\n              &quot;RootDeviceType&quot;: &quot;xx&quot;,\r\n              &quot;RootDeviceName&quot;: &quot;xx&quot;,\r\n              &quot;VirtualizationType&quot;: &quot;hvm&quot;,\r\n              &quot;Tags&quot;: [\r\n                {\r\n                  &quot;Value&quot;: &quot;TAG1&quot;,\r\n                  &quot;Key&quot;: &quot;VALUE1&quot;\r\n                },\r\n                {\r\n                  &quot;Value&quot;: &quot;TAG2&quot;,\r\n                  &quot;Key&quot;: &quot;VALUE2&quot;\r\n                },\r\n                {\r\n                  &quot;Value&quot;: &quot;TAG3&quot;,\r\n                  &quot;Key&quot;: &quot;VALUE3&quot;\r\n                },\r\n                {\r\n                  &quot;Value&quot;: &quot;TAG4&quot;,\r\n                  &quot;Key&quot;: &quot;VALUE4&quot;\r\n                },\r\n                {\r\n                  &quot;Value&quot;: &quot;TAG5&quot;,\r\n                  &quot;Key&quot;: &quot;VALUE5&quot;\r\n                },\r\n                {\r\n                  &quot;Value&quot;: &quot;TAG6&quot;,\r\n                  &quot;Key&quot;: &quot;Value6&quot;\r\n                }\r\n              ],\r\n              &quot;AmiLaunchIndex&quot;: xx\r\n            }\r\n          ]\r\n        },\r\n    \t{\r\n          &quot;OwnerId&quot;: &quot;xx&quot;,\r\n          &quot;ReservationId&quot;: &quot;xx&quot;,\r\n          &quot;Groups&quot;: [],\r\n          &quot;Instances&quot;: [\r\n            {\r\n              &quot;Monitoring&quot;: {\r\n                &quot;State&quot;: &quot;xx&quot;\r\n              },\r\n              &quot;PublicDnsName&quot;: &quot;&quot;,\r\n              &quot;Platform&quot;: &quot;xx&quot;,\r\n              &quot;State&quot;: {\r\n                &quot;Code&quot;: xx,\r\n                &quot;Name&quot;: &quot;xx&quot;\r\n              },\r\n              &quot;EbsOptimized&quot;: xx,\r\n              &quot;LaunchTime&quot;: &quot;xx&quot;,\r\n              &quot;PrivateIpAddress&quot;: &quot;xx&quot;,\r\n              &quot;ProductCodes&quot;: [],\r\n              &quot;VpcId&quot;: &quot;xx&quot;,\r\n              &quot;StateTransitionReason&quot;: &quot;&quot;,\r\n              &quot;InstanceId&quot;: &quot;i-22222222&quot;,\r\n              &quot;ImageId&quot;: &quot;xx&quot;,\r\n              &quot;PrivateDnsName&quot;: &quot;xx&quot;,\r\n              &quot;KeyName&quot;: &quot;xx&quot;,\r\n              &quot;SecurityGroups&quot;: [\r\n                {\r\n                  &quot;GroupName&quot;: &quot;xx&quot;,\r\n                  &quot;GroupId&quot;: &quot;xx&quot;\r\n                },\r\n                {\r\n                  &quot;GroupName&quot;: &quot;xx&quot;,\r\n                  &quot;GroupId&quot;: &quot;xx&quot;\r\n                }\r\n              ],\r\n              &quot;ClientToken&quot;: &quot;xx&quot;,\r\n              &quot;SubnetId&quot;: &quot;xx&quot;,\r\n              &quot;InstanceType&quot;: &quot;xx&quot;,\r\n              &quot;NetworkInterfaces&quot;: [\r\n                {\r\n                  &quot;Status&quot;: &quot;xx&quot;,\r\n                  &quot;MacAddress&quot;: &quot;xx&quot;,\r\n                  &quot;SourceDestCheck&quot;: xx,\r\n                  &quot;VpcId&quot;: &quot;xx&quot;,\r\n                  &quot;Description&quot;: &quot;xx&quot;,\r\n                  &quot;NetworkInterfaceId&quot;: &quot;xx&quot;,\r\n                  &quot;PrivateIpAddresses&quot;: [\r\n                    {\r\n                      &quot;PrivateDnsName&quot;: &quot;xx&quot;,\r\n                      &quot;Primary&quot;: xx,\r\n                      &quot;PrivateIpAddress&quot;: &quot;xx&quot;\r\n                    }\r\n                  ],\r\n                  &quot;PrivateDnsName&quot;: &quot;xx&quot;,\r\n                  &quot;Attachment&quot;: {\r\n                    &quot;Status&quot;: &quot;xx&quot;,\r\n                    &quot;DeviceIndex&quot;: xx,\r\n                    &quot;DeleteOnTermination&quot;: xx,\r\n                    &quot;AttachmentId&quot;: &quot;xx&quot;,\r\n                    &quot;AttachTime&quot;: &quot;xx&quot;\r\n                  },\r\n                  &quot;Groups&quot;: [\r\n                    {\r\n                      &quot;GroupName&quot;: &quot;xx&quot;,\r\n                      &quot;GroupId&quot;: &quot;xx&quot;\r\n                    },\r\n                    {\r\n                      &quot;GroupName&quot;: &quot;xx&quot;,\r\n                      &quot;GroupId&quot;: &quot;xx&quot;\r\n                    }\r\n                  ],\r\n                  &quot;SubnetId&quot;: &quot;xx&quot;,\r\n                  &quot;OwnerId&quot;: &quot;xx&quot;,\r\n                  &quot;PrivateIpAddress&quot;: &quot;xx&quot;\r\n                }\r\n              ],\r\n              &quot;SourceDestCheck&quot;: xx,\r\n              &quot;Placement&quot;: {\r\n                &quot;Tenancy&quot;: &quot;xx&quot;,\r\n                &quot;GroupName&quot;: &quot;xx&quot;,\r\n                &quot;AvailabilityZone&quot;: &quot;xx&quot;\r\n              },\r\n              &quot;Hypervisor&quot;: &quot;xx&quot;,\r\n              &quot;BlockDeviceMappings&quot;: [\r\n                {\r\n                  &quot;DeviceName&quot;: &quot;/dev/sda1&quot;,\r\n                  &quot;Ebs&quot;: {\r\n                    &quot;Status&quot;: &quot;attached&quot;,\r\n                    &quot;DeleteOnTermination&quot;: xx,\r\n                    &quot;VolumeId&quot;: &quot;vol-2222222a&quot;,\r\n                    &quot;AttachTime&quot;: &quot;xx&quot;\r\n                  }\r\n                },\r\n                {\r\n                  &quot;DeviceName&quot;: &quot;/dev/sdb&quot;,\r\n                  &quot;Ebs&quot;: {\r\n                    &quot;Status&quot;: &quot;attached&quot;,\r\n                    &quot;DeleteOnTermination&quot;: xx,\r\n                    &quot;VolumeId&quot;: &quot;vol-2222222b&quot;,\r\n                    &quot;AttachTime&quot;: &quot;xx&quot;\r\n                  }\r\n                },\r\n                {\r\n                  &quot;DeviceName&quot;: &quot;/dev/sdc&quot;,\r\n                  &quot;Ebs&quot;: {\r\n                    &quot;Status&quot;: &quot;attached&quot;,\r\n                    &quot;DeleteOnTermination&quot;: xx,\r\n                    &quot;VolumeId&quot;: &quot;vol-2222222c&quot;,\r\n                    &quot;AttachTime&quot;: &quot;xx&quot;\r\n                  }\r\n                }\r\n              ],\r\n              &quot;Architecture&quot;: &quot;xx&quot;,\r\n              &quot;RootDeviceType&quot;: &quot;xx&quot;,\r\n              &quot;RootDeviceName&quot;: &quot;xx&quot;,\r\n              &quot;VirtualizationType&quot;: &quot;hvm&quot;,\r\n              &quot;Tags&quot;: [\r\n                {\r\n                  &quot;Value&quot;: &quot;TAG1&quot;,\r\n                  &quot;Key&quot;: &quot;VALUE1&quot;\r\n                },\r\n                {\r\n                  &quot;Value&quot;: &quot;TAG2&quot;,\r\n                  &quot;Key&quot;: &quot;VALUE2&quot;\r\n                },\r\n                {\r\n                  &quot;Value&quot;: &quot;TAG3&quot;,\r\n                  &quot;Key&quot;: &quot;VALUE3&quot;\r\n                },\r\n                {\r\n                  &quot;Value&quot;: &quot;TAG4&quot;,\r\n                  &quot;Key&quot;: &quot;VALUE4&quot;\r\n                },\r\n                {\r\n                  &quot;Value&quot;: &quot;TAG5&quot;,\r\n                  &quot;Key&quot;: &quot;VALUE5&quot;\r\n                },\r\n                {\r\n                  &quot;Value&quot;: &quot;TAG6&quot;,\r\n                  &quot;Key&quot;: &quot;Value6&quot;\r\n                }\r\n              ],\r\n              &quot;AmiLaunchIndex&quot;: xx\r\n            }\r\n          ]\r\n        }\r\n    ]\r\n\r\nEdit: an example of something I have tried (this one is not trying to get the tags for simplicities sake:\r\n\r\n    jq -r &#39;.Reservations.Instances | map(({ InstanceId } + (.BlockDeviceMappings | add) + (.BlockDeviceMappings.Ebs | Add))| { InstanceId, DeviceName, VolumeId })&#39; &lt;(echo &quot;$json_array_windows&quot;)\r\n    \r\n    jq: error: Add/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .Reservations.Instances | map(({ InstanceId } + (.BlockDeviceMappings | add) + (.BlockDeviceMappings.Ebs | Add))| { InstanceId, DeviceName, VolumeId })                                      \r\n    jq: 1 compile error\r\n\r\n\t\r\n  [1]: https://stackoverflow.com/questions/36393805/jq-extract-additional-json-object-into-new-array &quot;here on stackoverflow&quot;",
        "link": "https://stackoverflow.com/questions/36613420/jq-extract-nested-json-into-multiple-arrays",
        "title": "jq - extract nested JSON into multiple arrays"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1460650296,
                "creation_date": 1460650296,
                "answer_id": 36628480,
                "question_id": 36625131,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you&#39;re going to filter, you need to drill down to the property that you want to check for and see if it matches your criteria. You can&#39;t expect to just give a name and you&#39;ll magically be presented with the results you want.\r\n\r\nSearching by hostname, it is found on the `.nodeinfo.hostname` property of each node:\r\n\r\n    $ jq -c --arg hostname &quot;Antoniusweg12&quot; \\\r\n    &#39;.nodes[] | select(.nodeinfo.hostname == $hostname)&#39; nodes.json\r\n\r\nSimilarly for the mac address, it&#39;s found on the `.nodeinfo.network.mac` property:\r\n\r\n    $ jq -c --arg mac &quot;aa:bb:cc:dd:ee:ff&quot; \\\r\n    &#39;.nodes[] | select(.nodeinfo.network.mac == $mac)&#39; nodes.json\r\n\r\nFor the ip addresses, there&#39;s an array of them but it&#39;s not that much different in the query.  They&#39;re found on the `.nodeinfo.network.addresses` property:\r\n\r\n    $ jq -c --arg ip &quot;aaaa:bbbb:cccc:dddd::1&quot; \\\r\n    &#39;.nodes[] | select(.nodeinfo.network.addresses[] == $ip)&#39; nodes.json",
                "title": "How to search a json with jq for values?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1460668065,
                "creation_date": 1460668065,
                "answer_id": 36634020,
                "question_id": 36625131,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s another take on the question.  Suppose you want to find all occurrences of the key &quot;hostname&quot; for which the value is &quot;Antoniusweg12&quot;,\r\nno matter where the key/value combination occurs.\r\n\r\nThe following will reveal the path to the key/value combination of interest:\r\n\r\n    paths as $p\r\n    | select ( $p[-1] == &quot;hostname&quot; and getpath($p) == &quot;Antoniusweg12&quot; )\r\n    | $p\r\n\r\nThe result for the given input JSON:\r\n\r\n    [\r\n      &quot;nodes&quot;,\r\n      &quot;60e327ee58a0&quot;,\r\n      &quot;nodeinfo&quot;,\r\n      &quot;hostname&quot;\r\n    ]\r\n\r\nIf you wanted the path to the containing object, then replace the final `$p` with `$p[0:-1]`; and if you want the containing object itself:  `getpath($p[0:-1])`\r\n\r\n",
                "title": "How to search a json with jq for values?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1505970944,
                "last_edit_date": 1505970944,
                "creation_date": 1501911311,
                "answer_id": 45518604,
                "question_id": 36625131,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which searches for nodes where the specified `$needle` is present in any of the `addresses`, `mac` or `hostname` fields.\r\n\r\n      &quot;&lt;ipv6 removed&gt;&quot; as $needle   # set to whatever you like\r\n\r\n    | foreach (.nodes|keys[]) as $k (\r\n         .\r\n       ; .\r\n       ;    (      .nodes[$k].nodeinfo.network.addresses?\r\n             + [   .nodes[$k].nodeinfo.network.mac?\r\n                 , .nodes[$k].nodeinfo.hostname?\r\n               ]\r\n            ) as $haystack\r\n\r\n         | if $haystack | index($needle)\r\n           then {($k): .nodes[$k]}\r\n           else empty\r\n           end\r\n      )\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      &quot;&lt;ipv6 removed&gt;&quot; as $needle\r\n\r\n    | (.nodes|keys[]) as $k\r\n    | (      .nodes[$k].nodeinfo.network.addresses?\r\n       + [   .nodes[$k].nodeinfo.network.mac?\r\n           , .nodes[$k].nodeinfo.hostname?\r\n         ]\r\n      ) as $haystack\r\n\r\n    | if $haystack | index($needle)\r\n      then {($k): .nodes[$k]}\r\n      else empty\r\n      end",
                "title": "How to search a json with jq for values?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1505970944,
        "creation_date": 1460641672,
        "question_id": 36625131,
        "body_markdown": "I have a json of this structure:\r\n\r\n    {\r\n      &quot;nodes&quot;: {\r\n        &quot;60e327ee58a0&quot;: {\r\n          &quot;nodeinfo&quot;: {\r\n            &quot;network&quot;: {\r\n              &quot;mesh&quot;: {\r\n                &quot;bat0&quot;: {\r\n                  &quot;interfaces&quot;: {\r\n                    &quot;wireless&quot;: [\r\n                      &quot;&lt;mac-address-removed&gt;&quot;\r\n                    ],\r\n                    &quot;tunnel&quot;: [\r\n                      &quot;&lt;mac-address-removed&gt;&quot;\r\n                    ]\r\n                  }\r\n                }\r\n              },\r\n              &quot;mac&quot;: &quot;&lt;mac removed&gt;&quot;,\r\n              &quot;addresses&quot;: [\r\n                &quot;&lt;ipv6 removed&gt;&quot;,\r\n                &quot;&lt;ipv6 removed&gt;&quot;\r\n              ]\r\n            },\r\n            &quot;hardware&quot;: {\r\n              &quot;model&quot;: &quot;TP-Link TL-WR841N/ND v10&quot;,\r\n              &quot;nproc&quot;: 1\r\n            },\r\n            &quot;software&quot;: {\r\n              &quot;batman-adv&quot;: {\r\n                &quot;compat&quot;: 15,\r\n                &quot;version&quot;: &quot;2015.1&quot;\r\n              },\r\n              &quot;autoupdater&quot;: {\r\n                &quot;branch&quot;: &quot;stable&quot;,\r\n                &quot;enabled&quot;: true\r\n              },\r\n              &quot;firmware&quot;: {\r\n                &quot;release&quot;: &quot;v2016.1+1.0.1&quot;,\r\n                &quot;base&quot;: &quot;gluon-v2016.1&quot;\r\n              },\r\n              &quot;status-page&quot;: {\r\n                &quot;api&quot;: 1\r\n              },\r\n              &quot;fastd&quot;: {\r\n                &quot;enabled&quot;: true,\r\n                &quot;version&quot;: &quot;v17&quot;\r\n              }\r\n            },\r\n            &quot;hostname&quot;: &quot;Antoniusweg12&quot;,\r\n            &quot;system&quot;: {\r\n              &quot;site_code&quot;: &quot;ffmsd03&quot;\r\n            },\r\n            &quot;node_id&quot;: &quot;60e327ee58a0&quot;\r\n          },\r\n          &quot;lastseen&quot;: &quot;2016-04-14T12:39:04&quot;,\r\n          &quot;flags&quot;: {\r\n            &quot;gateway&quot;: false,\r\n            &quot;online&quot;: true\r\n          },\r\n          &quot;firstseen&quot;: &quot;2016-03-16T15:14:04&quot;,\r\n          &quot;statistics&quot;: {\r\n            &quot;clients&quot;: 1,\r\n            &quot;gateway&quot;: &quot;de:ad:be:ef:43:02&quot;,\r\n            &quot;rootfs_usage&quot;: 0.6041666666666667,\r\n            &quot;loadavg&quot;: 0.09,\r\n            &quot;uptime&quot;: 1822037.41,\r\n            &quot;memory_usage&quot;: 0.8124737210932025,\r\n            &quot;traffic&quot;: {\r\n              &quot;rx&quot;: {\r\n                &quot;packets&quot;: 50393821,\r\n                &quot;bytes&quot;: 5061895206\r\n              },\r\n              &quot;forward&quot;: {\r\n                &quot;packets&quot;: 173,\r\n                &quot;bytes&quot;: 17417\r\n              },\r\n              &quot;mgmt_rx&quot;: {\r\n                &quot;packets&quot;: 47453745,\r\n                &quot;bytes&quot;: 6623785282\r\n              },\r\n              &quot;tx&quot;: {\r\n                &quot;packets&quot;: 1205695,\r\n                &quot;bytes&quot;: 173509528,\r\n                &quot;dropped&quot;: 5683\r\n              },\r\n              &quot;mgmt_tx&quot;: {\r\n                &quot;packets&quot;: 37906725,\r\n                &quot;bytes&quot;: 11475209742\r\n              }\r\n            }\r\n          }\r\n        },\r\n        &quot;30b5c2b042f4&quot;: {\r\n    &lt;next block...&gt;\r\n\r\nAnd I want to query it with jq for the hostname, the mac or the IPv6.\r\n\r\n    cat nodes.json |jq -c &#39;.nodes[] | select(.nodes[]| contains(&quot;Antoniusweg12&quot;))&#39;\r\n\r\nMost examples do not fit this kind of json structure as the objects have an index\r\n\r\nThanks for help in advance.",
        "link": "https://stackoverflow.com/questions/36625131/how-to-search-a-json-with-jq-for-values",
        "title": "How to search a json with jq for values?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1461174666,
                "last_edit_date": 1461174666,
                "creation_date": 1460733040,
                "answer_id": 36650820,
                "question_id": 36649328,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You haven&#39;t specified exactly how you want the arrays to be combined, but one approach is to use `transpose`, which in this case is effectively a kind of `zip`.  For example:\r\n\r\n    $ jq -n -c &#39;[[&quot;a&quot;,&quot;b&quot;], [1,2]] | transpose&#39;\r\n\r\nyields: `[[&quot;a&quot;,1],[&quot;b&quot;,2]]`\r\n\r\nIf you wanted an array of objects, then with the same input,\r\n\r\n    transpose | map( { (.[0]) : .[1] } )\r\n\r\nwould yield: `[{&quot;a&quot;:1},{&quot;b&quot;:2}]`\r\n\r\nIf your jq does not have `transpose`, here is its definition:\r\n\r\n    # transpose a possibly jagged matrix, quickly;\r\n    # rows are padded with nulls so the result is always rectangular.\r\n    def transpose:\r\n      [range(0; (map(length) | max)) as $j \r\n       | [range(0; length) as $i | .[$i][$j] ] ] ;\r\n\r\nAlternatively, if you would prefer a very brief `zip`:\r\n\r\n    def zip: [range(0; .[0]|length) as $i | [.[0][$i], .[1][$i]]];",
                "title": "Parse netdata json output (mulltiple arrays) with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503764833,
                "creation_date": 1503764833,
                "answer_id": 45897489,
                "question_id": 36649328,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that handles the general case where the first array contains the key names and the following arrays contain values using **transpose** and **from_entries**\r\n\r\n      {h:.[0], v:.[1:][]}                        # {h:[keys], v:[values]}\r\n    | [.h, .v]                                   # [ [keys], [values] ] ...\r\n    | [ transpose[] | {key:.[0], value:.[1]} ]   # [ {&quot;key&quot;:key, &quot;value&quot;:value}, ... ]\r\n    | from_entries                               # { key:value, key:value, ... }\r\n    \r\nFor example, if this filter is in `filter.jq` and `data.json` contains \r\n\r\n    [&quot;time&quot;,&quot;guest_nice&quot;,&quot;guest&quot;,&quot;steal&quot;,&quot;softirq&quot;,&quot;irq&quot;,&quot;user&quot;,&quot;system&quot;,&quot;nice&quot;,&quot;iowait&quot;]\r\n    [1460728600,0,0,0,0.45731,0,0.25108,11.74702,48.22465,0]\r\n    [1460728601,0,0,0,0.45732,0,0.25109,12.74703,49,0]\r\n\r\nthen the command \r\n\r\n    jq -M -s -c -f filter.jq data.json\r\n\r\nproduces\r\n\r\n    {&quot;time&quot;:1460728600,&quot;guest_nice&quot;:0,&quot;guest&quot;:0,&quot;steal&quot;:0,&quot;softirq&quot;:0.45731,&quot;irq&quot;:0,&quot;user&quot;:0.25108,&quot;system&quot;:11.74702,&quot;nice&quot;:48.22465,&quot;iowait&quot;:0}\r\n    {&quot;time&quot;:1460728601,&quot;guest_nice&quot;:0,&quot;guest&quot;:0,&quot;steal&quot;:0,&quot;softirq&quot;:0.45732,&quot;irq&quot;:0,&quot;user&quot;:0.25109,&quot;system&quot;:12.74703,&quot;nice&quot;:49,&quot;iowait&quot;:0}\r\n    \r\n",
                "title": "Parse netdata json output (mulltiple arrays) with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1503764833,
        "creation_date": 1460729010,
        "last_edit_date": 1460731871,
        "question_id": 36649328,
        "body_markdown": "I&#39;m trying to use jq to combine two arrays and running into a bit of trouble.\r\n\r\nI&#39;m attempting to parse out the data from netdata (netdata.firehol.org) and the two pieces of data within the json response that I&quot;m interested in are both part of an array. The first array is labels for the datapoints in the second array.  \r\n\r\n**Sample Input**\r\n\r\n    [\r\n      &quot;time&quot;,\r\n      &quot;guest_nice&quot;, \r\n      &quot;guest&quot;,\r\n      &quot;steal&quot;,\r\n      &quot;softirq&quot;,\r\n      &quot;irq&quot;,\r\n      &quot;user&quot;,\r\n      &quot;system&quot;,\r\n      &quot;nice&quot;,\r\n      &quot;iowait&quot;\r\n    ]\r\n    [\r\n      1460728600,\r\n      0,\r\n      0,\r\n      0,\r\n      0.45731,\r\n      0,\r\n      0.25108,\r\n      11.74702,\r\n      48.22465,\r\n      0\r\n    ]\r\n\r\n**Input**\r\n\r\nIf you want to grab fresh data yourself to test against, you can use the following:\r\n\r\n    curl -s -X GET --header &#39;Accept: application/json&#39; \r\n    &#39;http://netdata.firehol.org/api/v1/data?chart=system.cpu&amp;after=-10&amp;before=0&amp;points=1&amp;group=average&amp;format=json&amp;options=seconds%2Cjsonwrap&#39; | jq &#39;.result.labels, .result.data[]&#39;\r\n\r\n\r\nI&#39;ve tried to use map() as well as trying to assign vars to both arrays and then print out the objects together, but have been unsuccessful (below).\r\n\r\n**Code**\r\n\r\n     | jq &#39;.result.labels as $labels | .result.data[] as $data | .result.data[] | Label: $labels[.], data: $data[.]}&#39;\r\n\r\nI appreciate anyone&#39;s insight in advance as I&#39;m a little stuck, and would prefer to be able to do this all in jq rather than using for loops in bash (if possible).\r\n\r\n**Expected Ouput**\r\n\r\n{\r\n      &quot;time&quot;: &quot;1460728600&quot;,\r\n      &quot;guest_nice&quot;: &quot;0&quot;,\r\n      ...\r\n} \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/36649328/parse-netdata-json-output-mulltiple-arrays-with-jq",
        "title": "Parse netdata json output (mulltiple arrays) with jq"
    },
    {
        "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": 1461077599,
                "post_id": 36721223,
                "comment_id": 61028612,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1259023,
                    "reputation": 1189,
                    "user_id": 1217856,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://www.gravatar.com/avatar/8a54782c26b32dd10766189b5417e64d?s=256&d=identicon&r=PG",
                    "display_name": "Xianlin",
                    "link": "https://stackoverflow.com/users/1217856/xianlin"
                },
                "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": 1461078336,
                "post_id": 36721223,
                "comment_id": 61029178,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1461088524,
                "post_id": 36721223,
                "comment_id": 61035783,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1461122155,
                "last_edit_date": 1461122155,
                "creation_date": 1461097055,
                "answer_id": 36728594,
                "question_id": 36721223,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Conditionally adding the lat/long pair should be simple.  Just check if you have a `GeoCoordinate` value and add the pair.  Your `created_at` property is invalid at that location, so here&#39;s the closest that we can do:\r\n\r\n    {\r\n        created_at: now | todate,\r\n        results: map(\r\n            if .GeoCoordinate then\r\n                .loc = (.GeoCoordinate | { lon: .longitude, lat: .latitude })\r\n            else\r\n                .\r\n            end\r\n        )\r\n    }\r\n\r\nThis would yield the following results:\r\n\r\n    {\r\n      &quot;created_at&quot;: &quot;2016-04-19T20:09:35Z&quot;,\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;macAddress&quot;: &quot;22:00:10:21:ca:54&quot;,\r\n          &quot;GeoCoordinate&quot;: {\r\n            &quot;latitude&quot;: 1.2345,\r\n            &quot;longitude&quot;: 123.4567,\r\n            &quot;unit&quot;: &quot;DEGREES&quot;\r\n          },\r\n          &quot;loc&quot;: {\r\n            &quot;lon&quot;: 123.4567,\r\n            &quot;lat&quot;: 1.2345\r\n          }\r\n        },\r\n        {\r\n          &quot;macAddress&quot;: &quot;44:00:10:21:ca:14&quot;\r\n        },\r\n        {\r\n          &quot;macAddress&quot;: &quot;33:00:11:21:ca:54&quot;,\r\n          &quot;GeoCoordinate&quot;: {\r\n            &quot;latitude&quot;: 2.1345544523,\r\n            &quot;longitude&quot;: 123.45678,\r\n            &quot;unit&quot;: &quot;DEGREES&quot;\r\n          },\r\n          &quot;loc&quot;: {\r\n            &quot;lon&quot;: 123.45678,\r\n            &quot;lat&quot;: 2.1345544523\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n",
                "title": "jq json parser appends JSON field based on conditions"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1461122155,
        "creation_date": 1461075775,
        "last_edit_date": 1461078297,
        "question_id": 36721223,
        "body_markdown": "I have the below input file:\r\n\r\n    [\r\n    {\r\n        &quot;macAddress&quot;: &quot;22:00:10:21:ca:54&quot;,\r\n        &quot;GeoCoordinate&quot;: {\r\n            &quot;latitude&quot;: 1.2345,\r\n            &quot;longitude&quot;: 123.4567,\r\n            &quot;unit&quot;: &quot;DEGREES&quot;\r\n        }\r\n    },\r\n    {\r\n        &quot;macAddress&quot;: &quot;44:00:10:21:ca:14&quot;\r\n    },\r\n    {\r\n        &quot;macAddress&quot;: &quot;33:00:11:21:ca:54&quot;,\r\n        &quot;GeoCoordinate&quot;: {\r\n            &quot;latitude&quot;: 2.1345544523,\r\n            &quot;longitude&quot;: 123.45678,\r\n            &quot;unit&quot;: &quot;DEGREES&quot;\r\n        }\r\n    },\r\n    ...\r\n    ]\r\n\r\nI would like to use `jq` program to parse the JSON to get the below output\r\n\r\n    [\r\n    &quot;created_at&quot;: &quot;2016-04-13T14:50:03+0800&quot;, \r\n    {\r\n        &quot;macAddress&quot;: &quot;22:00:10:21:ca:54&quot;,\r\n        &quot;GeoCoordinate&quot;: {\r\n            &quot;latitude&quot;: 1.2345,\r\n            &quot;longitude&quot;: 123.4567,\r\n            &quot;unit&quot;: &quot;DEGREES&quot;\r\n        },\r\n        &quot;loc&quot;: {\r\n            &quot;lon&quot;: 123.4567,\r\n            &quot;lat&quot;: 1.2345\r\n        }\r\n    },\r\n    {\r\n        &quot;macAddress&quot;: &quot;44:00:10:21:ca:14&quot;\r\n    },\r\n    {\r\n        &quot;macAddress&quot;: &quot;33:00:11:21:ca:54&quot;,\r\n        &quot;GeoCoordinate&quot;: {\r\n            &quot;latitude&quot;: 2.1345544523,\r\n            &quot;longitude&quot;: 123.45678,\r\n            &quot;unit&quot;: &quot;DEGREES&quot;\r\n        },\r\n        &quot;loc&quot;: {\r\n            &quot;lon&quot;: 123.45678,\r\n            &quot;lat&quot;: 2.1345544523\r\n        }\r\n    },\r\n    ...\r\n    ]\r\n\r\nYou can see that I have inserted `created_at` field.\r\n\r\nI have also added lat/long pair based on the condition of the `GeoCoordinate` field exist or not.\r\n\r\nHow to use `jq` to achieve that?",
        "link": "https://stackoverflow.com/questions/36721223/jq-json-parser-appends-json-field-based-on-conditions",
        "title": "jq json parser appends JSON field based on conditions"
    },
    {
        "tags": [
            "json",
            "bash",
            "while-loop",
            "printf",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3559561,
                    "reputation": 659,
                    "user_id": 2972353,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/X366v.png?s=256",
                    "display_name": "jandob",
                    "link": "https://stackoverflow.com/users/2972353/jandob"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1461176993,
                "post_id": 36751549,
                "comment_id": 61084768,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7497667,
                    "reputation": 547,
                    "user_id": 5697282,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/1b4115927261cdfb2af064b4a48906d2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "econ",
                    "link": "https://stackoverflow.com/users/5697282/econ"
                },
                "reply_to_user": {
                    "account_id": 3559561,
                    "reputation": 659,
                    "user_id": 2972353,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/X366v.png?s=256",
                    "display_name": "jandob",
                    "link": "https://stackoverflow.com/users/2972353/jandob"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1461177215,
                "post_id": 36751549,
                "comment_id": 61084914,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1461197106,
                "last_edit_date": 1461197106,
                "creation_date": 1461177244,
                "answer_id": 36752306,
                "question_id": 36751549,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "\r\n\r\n    echo &quot;{\\&quot;key\\&quot;:\\&quot;value with a \\\\\\&quot;quote\\\\\\&quot; inside\\&quot;}&quot; | while read -r line\r\n    do \r\n        echo &quot;$line&quot;\r\n    done\r\n\r\nworks for me. With the -r switch read does not interpret backslashes. But \r\n\r\n    echo &#39;{&quot;key&quot;:&quot;value with a \\&quot;quote\\&quot; inside&quot;}&#39; | while read -r line\r\n    do \r\n        echo &quot;$line&quot;\r\n    done\r\n\r\nworks as well",
                "title": "bash: exact reproduction of escaped quotes in a JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1461197106,
        "creation_date": 1461174841,
        "last_edit_date": 1495541772,
        "question_id": 36751549,
        "body_markdown": "How is it possible to reproduce a string exactly as it is in a while-read loop?\r\n\r\nHere&#39;s the specific example.\r\n\r\nI am reading a JSON file:\r\n`{&quot;key&quot;:&quot;value with a \\&quot;quote\\&quot; inside&quot;}` and piping this into a while-read loop:\r\n\r\n    echo &quot;{\\&quot;key\\&quot;:\\&quot;value with a \\\\\\&quot;quote\\\\\\&quot; inside\\&quot;}&quot; | jq -rc &#39;.&#39; | while read line; do echo &quot;$line&quot;; done\r\n\r\nThis is the output I see:\r\n\r\n    {&quot;key&quot;:&quot;value with a &quot;quote&quot; inside&quot;}\r\n\r\nThe quotes inside the field disappear after being echo-ed. I would like to preserve those escape characters, so I looked at possible solutions and I suspect that `printf` can help (https://stackoverflow.com/questions/5608112/escape-filenames-using-the-same-way-bash-do-it). By changing `echo` to `printf &#39;%q&#39;`:\r\n\r\n    echo &quot;{\\&quot;key\\&quot;:\\&quot;value with a \\\\\\&quot;quote\\\\\\&quot; inside\\&quot;}&quot; | jq -rc &#39;.&#39; | while read line; do printf &#39;%q&#39; &quot;$line&quot;; done\r\n\r\nI get the following:\r\n\r\n    \\{\\&quot;key\\&quot;:\\&quot;value\\ with\\ a\\ \\&quot;quote\\&quot;\\ inside\\&quot;\\}\r\n\r\nUnfortunately, now the previously unescaped quotes are also escaped (in addition to all the other escapes). Could you tell me how can I achieve the following output within a `while read` loop?\r\n\r\n    {&quot;key&quot;:&quot;value with a \\&quot;quote\\&quot; inside&quot;}",
        "link": "https://stackoverflow.com/questions/36751549/bash-exact-reproduction-of-escaped-quotes-in-a-json-file",
        "title": "bash: exact reproduction of escaped quotes in a JSON file"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1461335632,
                "last_edit_date": 1461335632,
                "creation_date": 1461333262,
                "answer_id": 36795723,
                "question_id": 36795571,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It would seem that you are after:\r\n\r\n    jq &#39;.end&#39; ipres.txt\r\n\r\nIf you are still getting the same erroneous output - then you may be using an older / badly built version of jq.",
                "title": "unable to filter object with name `end` using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1461335378,
                "creation_date": 1461335378,
                "answer_id": 36796518,
                "question_id": 36795571,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You are evidently using an early version of jq -- perhaps jq 1.3, which is well out-of-date and which has some limitations with respect to the abbreviated syntax: `.foo`.\r\n\r\nThat is, you would have to write `.[&quot;end&quot;]` in jq 1.3, since &quot;end&quot; is a keyword (as in: `if ... then ... else ... end`).\r\n\r\nIn jq 1.4 and jq 1.5, one can write `.end`",
                "title": "unable to filter object with name `end` using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1461377048,
        "creation_date": 1461332824,
        "last_edit_date": 1461377048,
        "question_id": 36795571,
        "body_markdown": "I am trying to parse a json file using jq. \r\n\r\n    $cat ipres.txt\r\n    {\r\n    \t&quot;start&quot;:\t{\r\n    \t\t&quot;connected&quot;:\t[{\r\n    \t\t\t\t&quot;socket&quot;:\t5,\r\n    \t\t\t\t&quot;local_host&quot;:\t&quot;10.8.0.3&quot;,\r\n    \t\t\t\t&quot;local_port&quot;:\t36068,\r\n    \t\t\t\t&quot;remote_host&quot;:\t&quot;10.8.0.2&quot;,\r\n    \t\t\t\t&quot;remote_port&quot;:\t5201\r\n    \t\t\t}],\r\n    \t\t&quot;version&quot;:\t&quot;iperf 3.1.2&quot;,\r\n    \t\t&quot;system_info&quot;:\t&quot;Linux sid-Vostro-3700 3.13.0-77-generic #121-Ubuntu SMP Wed Jan 20 10:50:42 UTC 2016 x86_64&quot;,\r\n    \t\t&quot;timestamp&quot;:\t{\r\n    \t\t\t&quot;time&quot;:\t&quot;Fri, 22 Apr 2016 13:08:10 GMT&quot;,\r\n    \t\t\t&quot;timesecs&quot;:\t1461330490\r\n    \t\t},\r\n    \t\t&quot;connecting_to&quot;:\t{\r\n    \t\t\t&quot;host&quot;:\t&quot;10.8.0.2&quot;,\r\n    \t\t\t&quot;port&quot;:\t5201\r\n    \t\t},\r\n    \t\t&quot;cookie&quot;:\t&quot;sid-Vostro-3700.1461330486.892347.18&quot;,\r\n    \t\t&quot;test_start&quot;:\t{\r\n    \t\t\t&quot;protocol&quot;:\t&quot;UDP&quot;,\r\n    \t\t\t&quot;num_streams&quot;:\t1,\r\n    \t\t\t&quot;blksize&quot;:\t8192,\r\n    \t\t\t&quot;omit&quot;:\t0,\r\n    \t\t\t&quot;duration&quot;:\t2,\r\n    \t\t\t&quot;bytes&quot;:\t0,\r\n    \t\t\t&quot;blocks&quot;:\t0,\r\n    \t\t\t&quot;reverse&quot;:\t0\r\n    \t\t}\r\n    \t},\r\n    \t&quot;intervals&quot;:\t[{\r\n    \t\t\t&quot;streams&quot;:\t[{\r\n    \t\t\t\t\t&quot;socket&quot;:\t5,\r\n    \t\t\t\t\t&quot;start&quot;:\t0,\r\n    \t\t\t\t\t&quot;end&quot;:\t2.0002,\r\n    \t\t\t\t\t&quot;seconds&quot;:\t2.0002,\r\n    \t\t\t\t\t&quot;bytes&quot;:\t253952,\r\n    \t\t\t\t\t&quot;bits_per_second&quot;:\t1.01571e+06,\r\n    \t\t\t\t\t&quot;packets&quot;:\t31,\r\n    \t\t\t\t\t&quot;omitted&quot;:\tfalse\r\n    \t\t\t\t}],\r\n    \t\t\t&quot;sum&quot;:\t{\r\n    \t\t\t\t&quot;start&quot;:\t0,\r\n    \t\t\t\t&quot;end&quot;:\t2.0002,\r\n    \t\t\t\t&quot;seconds&quot;:\t2.0002,\r\n    \t\t\t\t&quot;bytes&quot;:\t253952,\r\n    \t\t\t\t&quot;bits_per_second&quot;:\t1.01571e+06,\r\n    \t\t\t\t&quot;packets&quot;:\t31,\r\n    \t\t\t\t&quot;omitted&quot;:\tfalse\r\n    \t\t\t}\r\n    \t\t}],\r\n    \t&quot;end&quot;:\t{\r\n    \t\t&quot;streams&quot;:\t[{\r\n    \t\t\t\t&quot;udp&quot;:\t{\r\n    \t\t\t\t\t&quot;socket&quot;:\t5,\r\n    \t\t\t\t\t&quot;start&quot;:\t0,\r\n    \t\t\t\t\t&quot;end&quot;:\t2.0002,\r\n    \t\t\t\t\t&quot;seconds&quot;:\t2.0002,\r\n    \t\t\t\t\t&quot;bytes&quot;:\t253952,\r\n    \t\t\t\t\t&quot;bits_per_second&quot;:\t1.01571e+06,\r\n    \t\t\t\t\t&quot;jitter_ms&quot;:\t828.078,\r\n    \t\t\t\t\t&quot;lost_packets&quot;:\t0,\r\n    \t\t\t\t\t&quot;packets&quot;:\t24,\r\n    \t\t\t\t\t&quot;lost_percent&quot;:\t0,\r\n    \t\t\t\t\t&quot;out_of_order&quot;:\t0\r\n    \t\t\t\t}\r\n    \t\t\t}],\r\n    \t\t&quot;sum&quot;:\t{\r\n    \t\t\t&quot;start&quot;:\t0,\r\n    \t\t\t&quot;end&quot;:\t2.0002,\r\n    \t\t\t&quot;seconds&quot;:\t2.0002,\r\n    \t\t\t&quot;bytes&quot;:\t253952,\r\n    \t\t\t&quot;bits_per_second&quot;:\t1.01571e+06,\r\n    \t\t\t&quot;jitter_ms&quot;:\t828.078,\r\n    \t\t\t&quot;lost_packets&quot;:\t0,\r\n    \t\t\t&quot;packets&quot;:\t24,\r\n    \t\t\t&quot;lost_percent&quot;:\t0\r\n    \t\t},\r\n    \t\t&quot;cpu_utilization_percent&quot;:\t{\r\n    \t\t\t&quot;host_total&quot;:\t7.7914,\r\n    \t\t\t&quot;host_user&quot;:\t1.09745,\r\n    \t\t\t&quot;host_system&quot;:\t6.69392,\r\n    \t\t\t&quot;remote_total&quot;:\t0,\r\n    \t\t\t&quot;remote_user&quot;:\t0,\r\n    \t\t\t&quot;remote_system&quot;:\t0\r\n    \t\t}\r\n    \t},\r\n    \t&quot;test&quot;: 0\r\n    }\r\nBut when i try to filter the end object, my command fails.\r\n\r\n    $cat ipres.txt | jq .end\r\n    error: syntax error, unexpected end, expecting $end\r\n    .end\r\n     ^^^\r\n    1 compile error\r\nIf i change the `end` object to some other name for example `end1`, i can able to filter. What could be the problem?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/36795571/unable-to-filter-object-with-name-end-using-jq",
        "title": "unable to filter object with name `end` using JQ"
    },
    {
        "tags": [
            "json",
            "unix",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 33,
                "is_accepted": false,
                "score": 33,
                "last_activity_date": 1523412341,
                "last_edit_date": 1523412341,
                "creation_date": 1461630083,
                "answer_id": 36853325,
                "question_id": 36853202,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "jq 1.5 has standard time-and-date functions such as strftime, as documented in the online manual. However support for TZ is extremely limited and/or unreliable, as illustrated here: \r\n\r\n    $ echo $TZ\r\n    \r\n    $ jq -n &#39;123 | strftime(&quot;%B %d %Y %I:%M%p %Z&quot;)&#39;\r\n    &quot;January 01 1970 12:02AM EST&quot;\r\n    \r\n    TZ=&#39;Asia/Kolkata&#39; jq -n &#39;123 | strftime(&quot;%B %d %Y %I:%M%p %Z&quot;)&#39;\r\n    &quot;January 01 1970 12:02AM IST&quot;\r\n\r\n## strflocaltime\r\nIf your jq has `strflocaltime`:\r\n\r\n    TZ=Asia/Kolkata jq -n &#39;123|strflocaltime(&quot;%Y-%m-%dT%H:%M:%S %Z&quot;)&#39;\r\n    &quot;1970-01-01T05:32:03 IST&quot;\r\n",
                "title": "jq dates and unix timestamps"
            },
            {
                "up_vote_count": 86,
                "is_accepted": false,
                "score": 86,
                "last_activity_date": 1461692887,
                "creation_date": 1461692887,
                "answer_id": 36872180,
                "question_id": 36853202,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Sure! Your provided input is not valid JSON, but I&#39;m going to assume the trailing commas on those objects are removed and the objects are wrapped in an array, which would be the root object of the JSON document.\r\n\r\nFirst, we can transform the millisecond-precision UNIX dates into second-precision, which is what jq&#39;s date functions expect, and then convert that to the human-readable dates you expect:\r\n\r\n    .[].published_at |= (. / 1000 | strftime(&quot;%Y-%m-%d&quot;))\r\n\r\nThen, we select only those elements whose dates match:\r\n\r\n    map(select(.published_at == $date))\r\n\r\nLastly, we put it all together, taking the `$date` variable from the command-line:\r\n\r\n    jq --arg date &quot;2016-04-25&quot; &#39;.[].published_at |= (. / 1000 | strftime(&quot;%Y-%m-%d&quot;)) | map(select(.published_at == $date))&#39; stuff.json",
                "title": "jq dates and unix timestamps"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 66,
        "last_activity_date": 1538573673,
        "creation_date": 1461629237,
        "last_edit_date": 1461629722,
        "question_id": 36853202,
        "body_markdown": "So I have a data with bunch of unix timestamp values (in milliseconds). Something like this:\r\n\r\n    {\r\n\t    &quot;id&quot;: &quot;f6922fd5-4f97-4113-820e-b45eba0ae236&quot;,\r\n\t    &quot;published_at&quot;: 1461624333859,\r\n\t    &quot;tracking_id&quot;: &quot;a85d5ed5-5efa-461b-aae0-beb2098c0ff7&quot;,\r\n    }, {\r\n\t    &quot;id&quot;: &quot;835d412f-5162-440c-937b-7276f22c4eb9&quot;,\r\n\t    &quot;published_at&quot;: 1461625249934,\r\n\t    &quot;tracking_id&quot;: &quot;86472ba2-ce5f-400f-b42a-5a0ac155c42c&quot;,\r\n    }, {\r\n\t    &quot;id&quot;: &quot;bc2efcac-67a0-4855-856a-f31ce5e4618e&quot;,\r\n\t    &quot;published_at&quot;: 1461625253393,\r\n\t    &quot;tracking_id&quot;: &quot;c005398f-07f8-4a37-b96d-9ab019d586c2&quot;,\r\n    }\r\n    \r\nAnd very often we need to search for rows within a certain date. Is it possible to query with jq, providing human readable dates e.g. `2016-04-25`. Also I wonder if the other way around possible, to make jq show `published_at` values in human readable form? \r\n\r\nFor example this works:\r\n\r\n    $ echo 1461624333 | jq &#39;todate&#39;   \r\n    &quot;2016-04-25T22:45:33Z&quot;\r\n\r\nalthough it has to be in seconds, not milliseconds\r\n\r\n",
        "link": "https://stackoverflow.com/questions/36853202/jq-dates-and-unix-timestamps",
        "title": "jq dates and unix timestamps"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1461723501,
                "creation_date": 1461723501,
                "answer_id": 36879139,
                "question_id": 36878970,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is an example showing how a stream of values (here, a stream of arrays) can be combined into a JSON array of objects:\r\n\r\n    (cat &lt;&lt; EOF\r\n    [&quot;VolumeId1&quot;, &quot;Tag1Value1&quot;, &quot;Tag2Value1&quot;, &quot;Tag3Value1&quot;]\r\n    [&quot;VolumeId2&quot;, &quot;Tag1Value2&quot;, &quot;Tag2Value2&quot;, &quot;Tag3Value2&quot;]\r\n    [&quot;VolumeId3&quot;, &quot;Tag1Value3&quot;, &quot;Tag2Value3&quot;, &quot;Tag3Value3&quot;]\r\n    EOF\r\n    ) | jq -s &#39;map( {VolumeId: .[0], Tag1Value: .[1], Tag2Value: .[2],  Tag3Value: .[3] }) &#39;\r\n\r\nOutput:\r\n\r\n    [\r\n      {\r\n        &quot;VolumeId&quot;: &quot;VolumeId1&quot;,\r\n        &quot;Tag1Value&quot;: &quot;Tag1Value1&quot;,\r\n        &quot;Tag2Value&quot;: &quot;Tag2Value1&quot;,\r\n        &quot;Tag3Value&quot;: &quot;Tag3Value1&quot;\r\n      },\r\n      {\r\n        &quot;VolumeId&quot;: &quot;VolumeId2&quot;,\r\n        &quot;Tag1Value&quot;: &quot;Tag1Value2&quot;,\r\n        &quot;Tag2Value&quot;: &quot;Tag2Value2&quot;,\r\n        &quot;Tag3Value&quot;: &quot;Tag3Value2&quot;\r\n      },\r\n      {\r\n        &quot;VolumeId&quot;: &quot;VolumeId3&quot;,\r\n        &quot;Tag1Value&quot;: &quot;Tag1Value3&quot;,\r\n        &quot;Tag2Value&quot;: &quot;Tag2Value3&quot;,\r\n        &quot;Tag3Value&quot;: &quot;Tag3Value3&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "jq - in for loop, create a single new array, then append key/value pairs"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1461723501,
        "creation_date": 1461722327,
        "question_id": 36878970,
        "body_markdown": "I need to loop through an array (of AWS instance Ids&#39;), then pull tags out and add them into an array using jq. \r\n\r\nI have variables defining my needs. In this case:\r\n\r\n    VolumeId\r\n    Tag1Value\r\n    Tag2Value\r\n    Tag3Value\r\n\r\nThey change as I iterate through in a for loop. I know how to create a new array:\r\n\r\n    jq -n --arg v &quot;$VolumeId&quot; &#39;[{&quot;VolumeId&quot;: $v}]&#39;\r\n\r\nHowever this creates a new JSON array every time. I need it created once, and then append to it as I progress through the loop.\r\n\r\nThe output I am looking for is a newly create JSON array:\r\n\r\n    [\r\n      {\r\n        &quot;VolumeId&quot;: $VolumeId,\r\n        &quot;Tag1&quot;: $Tag1Value,\r\n        &quot;Tag2&quot;: $Tag2Value,\r\n        &quot;Tag3&quot;: $Tag3Value\r\n      },\r\n      {\r\n        &quot;VolumeId&quot;: $VolumeId,\r\n        &quot;Tag1&quot;: $Tag1Value,\r\n        &quot;Tag2&quot;: $Tag2Value,\r\n        &quot;Tag3&quot;: $Tag3Value\r\n      },\r\n      {\r\n        &quot;VolumeId&quot;: $VolumeId,\r\n        &quot;Tag1&quot;: $Tag1Value,\r\n        &quot;Tag2&quot;: $Tag2Value,\r\n        &quot;Tag3&quot;: $Tag3Value\r\n      }\r\n    ]\r\n\r\nAny help is really appreciated.",
        "link": "https://stackoverflow.com/questions/36878970/jq-in-for-loop-create-a-single-new-array-then-append-key-value-pairs",
        "title": "jq - in for loop, create a single new array, then append key/value pairs"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1461737415,
                "creation_date": 1461737415,
                "answer_id": 36881642,
                "question_id": 36880891,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "What you should rather do:\r\n\r\n**File1**\r\n\r\n    {\r\n      &quot;vol-xxxxxxx1&quot;: {\r\n        &quot;Tag1&quot;: &quot;Tag1Value&quot;,\r\n        &quot;Tag2&quot;: &quot;Tag2Value&quot;,\r\n        &quot;Tag3&quot;: &quot;Tag3Value&quot;,\r\n        &quot;Tag4&quot;: &quot;Tag4Value&quot;,\r\n        &quot;Tag5&quot;: &quot;Tag5Value&quot;,\r\n        &quot;Tag6&quot;: &quot;Tag6Value&quot;\r\n      },\r\n      &quot;vol-xxxxxxx2&quot;: {\r\n        &quot;Tag1&quot;: &quot;Tag1Value&quot;,\r\n        &quot;Tag2&quot;: &quot;null&quot;,\r\n        &quot;Tag3&quot;: &quot;null&quot;,\r\n        &quot;Tag4&quot;: &quot;Tag4Value&quot;,\r\n        &quot;Tag5&quot;: &quot;null&quot;,\r\n        &quot;Tag6&quot;: &quot;Tag6Value&quot;\r\n      },\r\n      &quot;vol-xxxxxxx3&quot;: {\r\n        &quot;Tag1&quot;: &quot;null&quot;,\r\n        &quot;Tag2&quot;: &quot;null&quot;,\r\n        &quot;Tag3&quot;: &quot;null&quot;,\r\n        &quot;Tag4&quot;: &quot;null&quot;,\r\n        &quot;Tag5&quot;: &quot;null&quot;,\r\n        &quot;Tag6&quot;: &quot;null&quot;\r\n      }\r\n    }\r\n\r\n**File2**\r\n\r\n    {\r\n      &quot;vol-xxxxxxx1&quot;: {\r\n        &quot;Tag7&quot;: &quot;Tag7Value&quot;\r\n      },\r\n      &quot;vol-xxxxxxx2&quot;: {\r\n        &quot;Tag7&quot;: &quot;Tag7Value&quot;\r\n      },\r\n      &quot;vol-xxxxxxx3&quot;: {\r\n        &quot;Tag7&quot;: &quot;null&quot;\r\n      }\r\n    }\r\n\r\n\r\nNow the command\r\n\r\n    jq -s &#39;.[0] * .[1]&#39; /path/to/file1 /path/to/file2\r\n\r\ngives the following:\r\n\r\n    {\r\n      &quot;vol-xxxxxxx1&quot;: {\r\n        &quot;Tag1&quot;: &quot;Tag1Value&quot;,\r\n        &quot;Tag2&quot;: &quot;Tag2Value&quot;,\r\n        &quot;Tag3&quot;: &quot;Tag3Value&quot;,\r\n        &quot;Tag4&quot;: &quot;Tag4Value&quot;,\r\n        &quot;Tag5&quot;: &quot;Tag5Value&quot;,\r\n        &quot;Tag6&quot;: &quot;Tag6Value&quot;,\r\n        &quot;Tag7&quot;: &quot;Tag7Value&quot;\r\n      },\r\n      &quot;vol-xxxxxxx2&quot;: {\r\n        &quot;Tag1&quot;: &quot;Tag1Value&quot;,\r\n        &quot;Tag2&quot;: &quot;null&quot;,\r\n        &quot;Tag3&quot;: &quot;null&quot;,\r\n        &quot;Tag4&quot;: &quot;Tag4Value&quot;,\r\n        &quot;Tag5&quot;: &quot;null&quot;,\r\n        &quot;Tag6&quot;: &quot;Tag6Value&quot;,\r\n        &quot;Tag7&quot;: &quot;Tag7Value&quot;\r\n      },\r\n      &quot;vol-xxxxxxx3&quot;: {\r\n        &quot;Tag1&quot;: &quot;null&quot;,\r\n        &quot;Tag2&quot;: &quot;null&quot;,\r\n        &quot;Tag3&quot;: &quot;null&quot;,\r\n        &quot;Tag4&quot;: &quot;null&quot;,\r\n        &quot;Tag5&quot;: &quot;null&quot;,\r\n        &quot;Tag6&quot;: &quot;null&quot;,\r\n        &quot;Tag7&quot;: &quot;null&quot;\r\n      }\r\n    }\r\n",
                "title": "jq - error when merging two JSON files &quot;cannot be multiplied&quot;"
            },
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1461743203,
                "creation_date": 1461743203,
                "answer_id": 36883507,
                "question_id": 36880891,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;m assuming you want to merge all entries that have the same `.VolumeId` into one. To do so, first we `flatten` the array of arrays of objects into an array of objects. Then, we `group_by(.VolumeId)`. Finally, we `map` over each group and `reduce` it by calculating the product of all its elements. The final results looks like this:\r\n\r\n    jq -s &#39;flatten | group_by(.VolumeId) | map(reduce .[] as $x ({}; . * $x))&#39; /path/to/file1 /path/to/file2",
                "title": "jq - error when merging two JSON files &quot;cannot be multiplied&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1461743203,
        "creation_date": 1461734263,
        "last_edit_date": 1461736707,
        "question_id": 36880891,
        "body_markdown": "I have two files containing some JSON.\r\n\r\nFile1 - some values can be a string, some might be null, VolumeId is always set.\r\n\r\n    [\r\n      {\r\n        &quot;VolumeId&quot;: &quot;vol-xxxxxxx1&quot;,\r\n        &quot;Tag1&quot;: &quot;Tag1Value&quot;,\r\n        &quot;Tag2&quot;: &quot;Tag2Value&quot;,\r\n        &quot;Tag3&quot;: &quot;Tag3Value&quot;,\r\n        &quot;Tag4&quot;: &quot;Tag4Value&quot;,\r\n        &quot;Tag5&quot;: &quot;Tag5Value&quot;,\r\n        &quot;Tag6&quot;: &quot;Tag6Value&quot;\r\n      },\r\n      {\r\n        &quot;VolumeId&quot;: &quot;vol-xxxxxxx2&quot;,\r\n        &quot;Tag1&quot;: &quot;Tag1Value&quot;,\r\n        &quot;Tag2&quot;: &quot;null&quot;,\r\n        &quot;Tag3&quot;: &quot;null&quot;,\r\n        &quot;Tag4&quot;: &quot;Tag4Value&quot;,\r\n        &quot;Tag5&quot;: &quot;null&quot;,\r\n        &quot;Tag6&quot;: &quot;Tag6Value&quot;\r\n      },\r\n      {\r\n        &quot;VolumeId&quot;: &quot;vol-xxxxxxx3&quot;,\r\n        &quot;Tag1&quot;: &quot;null&quot;,\r\n        &quot;Tag2&quot;: &quot;null&quot;,\r\n        &quot;Tag3&quot;: &quot;null&quot;,\r\n        &quot;Tag4&quot;: &quot;null&quot;,\r\n        &quot;Tag5&quot;: &quot;null&quot;,\r\n        &quot;Tag6&quot;: &quot;null&quot;\r\n      }\r\n    ]\r\n\r\nFile2 - VolumeId will always match as those in File1, and Tag7 may or may not be null.\r\n\r\n    [\r\n      {\r\n        &quot;VolumeId&quot;: &quot;vol-xxxxxxx1&quot;,\r\n        &quot;Tag7&quot;: &quot;Tag7Value&quot;\r\n      },\r\n      {\r\n        &quot;VolumeId&quot;: &quot;vol-xxxxxxx2&quot;,\r\n        &quot;Tag7&quot;: &quot;Tag7Value&quot;\r\n      },\r\n      {\r\n        &quot;VolumeId&quot;: &quot;vol-xxxxxxx3&quot;,\r\n        &quot;Tag7&quot;: &quot;null&quot;\r\n      }\r\n    ]\r\n\r\nI need to combine these into one JSON array:\r\n\r\n    [\r\n      {\r\n        &quot;VolumeId&quot;: &quot;vol-xxxxxxx1&quot;,\r\n        &quot;Tag1&quot;: &quot;Tag1Value&quot;,\r\n        &quot;Tag2&quot;: &quot;Tag2Value&quot;,\r\n        &quot;Tag3&quot;: &quot;Tag3Value&quot;,\r\n        &quot;Tag4&quot;: &quot;Tag4Value&quot;,\r\n        &quot;Tag5&quot;: &quot;Tag5Value&quot;,\r\n        &quot;Tag6&quot;: &quot;Tag6Value&quot;,\r\n        &quot;Tag7&quot;: &quot;Tag7Value&quot;\r\n      },\r\n      {\r\n        &quot;VolumeId&quot;: &quot;vol-xxxxxxx2&quot;,\r\n        &quot;Tag1&quot;: &quot;Tag1Value&quot;,\r\n        &quot;Tag2&quot;: &quot;null&quot;,\r\n        &quot;Tag3&quot;: &quot;null&quot;,\r\n        &quot;Tag4&quot;: &quot;Tag4Value&quot;,\r\n        &quot;Tag5&quot;: &quot;null&quot;,\r\n        &quot;Tag6&quot;: &quot;Tag6Value&quot;,\r\n        &quot;Tag7&quot;: &quot;Tag7Value&quot;\r\n      },\r\n      {\r\n        &quot;VolumeId&quot;: &quot;vol-xxxxxxx3&quot;,\r\n        &quot;Tag1&quot;: &quot;null&quot;,\r\n        &quot;Tag2&quot;: &quot;null&quot;,\r\n        &quot;Tag3&quot;: &quot;null&quot;,\r\n        &quot;Tag4&quot;: &quot;null&quot;,\r\n        &quot;Tag5&quot;: &quot;null&quot;,\r\n        &quot;Tag6&quot;: &quot;null&quot;,\r\n        &quot;Tag7&quot;: &quot;null&quot;\r\n      }\r\n    ]\r\n\r\nI get an error when trying to use the below command:\r\n\r\n    jq -s &#39;.[0] * .[1]&#39; /path/to/file1 /path/to/file2\r\n    array ([{&quot;VolumeId...) and array ([{&quot;VolumeId...) cannot be multiplied\r\n\r\nAny help is appreciated.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/36880891/jq-error-when-merging-two-json-files-cannot-be-multiplied",
        "title": "jq - error when merging two JSON files &quot;cannot be multiplied&quot;"
    },
    {
        "tags": [
            "json",
            "bash",
            "variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5007131,
                    "reputation": 4679,
                    "user_id": 4024473,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://lh4.googleusercontent.com/-b-GZ3XweM6Y/AAAAAAAAAAI/AAAAAAAAAa8/sjVrj3-Rmz0/s256-rj/photo.jpg",
                    "display_name": "Michael Jaros",
                    "link": "https://stackoverflow.com/users/4024473/michael-jaros"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1461754753,
                "post_id": 36887134,
                "comment_id": 61339911,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2258167,
                    "reputation": 2481,
                    "user_id": 1988874,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7fe769ae26b50048fb7a1220d682b0ad?s=256&d=identicon&r=PG",
                    "display_name": "Cyrille Pontvieux",
                    "link": "https://stackoverflow.com/users/1988874/cyrille-pontvieux"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1461754761,
                "post_id": 36887134,
                "comment_id": 61339919,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5007131,
                    "reputation": 4679,
                    "user_id": 4024473,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://lh4.googleusercontent.com/-b-GZ3XweM6Y/AAAAAAAAAAI/AAAAAAAAAa8/sjVrj3-Rmz0/s256-rj/photo.jpg",
                    "display_name": "Michael Jaros",
                    "link": "https://stackoverflow.com/users/4024473/michael-jaros"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1461755105,
                "post_id": 36887134,
                "comment_id": 61340150,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1461755109,
                "creation_date": 1461755109,
                "answer_id": 36887957,
                "question_id": 36887134,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You are calling `curl` once and this suffices. Then you have the content in a variable, so you can access it without calling `curl` again.\r\n\r\nRegarding your code, your approach is fine but you are missing `$` when you are echoing the variable:\r\n\r\n    server_name=$(echo $instance_info | /usr/bin/jq --raw-output &#39;.server&#39;)\r\n    #                  ^\r\n\r\nSee a sample. Here I hardcode the JSON:\r\n\r\n    your_json=&#39;\r\n    {\r\n    &quot;basePath&quot;: &quot;/install&quot;, \r\n    &quot;metadata&quot;: {\r\n        &quot;deployed_artifact&quot;: &quot;app01&quot;, \r\n        &quot;docker&quot;: &quot;True&quot;,  \r\n        &quot;http_port&quot;: &quot;7471&quot;,\r\n        &quot;url&quot;: &quot;www.google.com&quot;\r\n    }, \r\n    &quot;name&quot;: &quot;app-01&quot;, \r\n    &quot;server&quot;: &quot;webserver1&quot;\r\n    }&#39;\r\n\r\nfor the `server`:\r\n\r\n    $ echo &quot;$your_json&quot; | jq --raw-output &#39;.server&#39;\r\n    webserver1\r\n\r\nFor the `url` you need to indicate the block where it lies on. That is, `metadata`:\r\n\r\n    $ echo &quot;$your_json&quot; | jq --raw-output &#39;.metadata.url&#39;\r\n    www.google.com\r\n\r\nTo store into a variable, say:\r\n\r\n    your_field=$(echo &quot;$your_json&quot; | jq --raw-output &#39;XXXX&#39;)\r\n    #                                                 ^^^^",
                "title": "Bash store json response in another variable"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1461755583,
                "creation_date": 1461755583,
                "answer_id": 36888134,
                "question_id": 36887134,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    sed -rn &#39;s/[ ]*&quot;([^&quot;]*)&quot;[^&quot;]*(&quot;[^&quot;]*&quot;).*/\\1=\\2/gp&#39;&#39; file.json\r\nO/P:\r\n\r\n    basePath=&quot;/install&quot;\r\n    deployed_artifact=&quot;app01&quot;\r\n    docker=&quot;True&quot;\r\n    http_port=&quot;7471&quot;\r\n    url=&quot;www.google.com&quot;\r\n    name=&quot;app-01&quot;\r\n    server=&quot;webserver1&quot;\r\n\r\n\r\n`eval` this output you can get the variable\r\n\r\n    eval $(sed -rn &#39;s/[ ]*&quot;([^&quot;]*)&quot;[^&quot;]*(&quot;[^&quot;]*&quot;).*/\\1=\\2/gp&#39; file.json )\r\n    echo $name $server\r\nO/p:\r\n\r\n    app-01 webserver1",
                "title": "Bash store json response in another variable"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1461793226,
                "last_edit_date": 1461793226,
                "creation_date": 1461761906,
                "answer_id": 36890567,
                "question_id": 36887134,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Read the values with one `jq` pass then there&#39;s no need to store the json:\r\n\r\n\tread name server url http_port &lt; &lt;(\r\n\t\tcurl -sk https://internal.admin.com/app/instance | \\\r\n\t\tjq --raw-output &#39;[.name, .server, .metadata.url, .metadata.http_port] | join(&quot; &quot;)&#39;\r\n\t)\r\n\r\n\techo -e &quot;\\$name: $name\\n\\$server: $server\\n\\$url: $url\\n\\$http_port $http_port&quot;\r\n\t$name: app-01\r\n\t$server: webserver1\r\n\t$url: www.google.com\r\n\t$http_port 7471",
                "title": "Bash store json response in another variable"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1503767589,
                "creation_date": 1503767589,
                "answer_id": 45897854,
                "question_id": 36887134,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a script which demonstrates how to use jq&#39;s `@sh` formatting directive along with bash `eval` to set bash variables using the output of a filter.  In this case we hardcode the json which presumably would have come from `curl`.\r\n\r\n    #!/bin/bash\r\n    instance_info=&#39;\r\n    {\r\n    &quot;basePath&quot;: &quot;/install&quot;, \r\n    &quot;metadata&quot;: {\r\n        &quot;deployed_artifact&quot;: &quot;app01&quot;, \r\n        &quot;docker&quot;: &quot;True&quot;,  \r\n        &quot;http_port&quot;: &quot;7471&quot;,\r\n        &quot;url&quot;: &quot;www.google.com&quot;\r\n    }, \r\n    &quot;name&quot;: &quot;app-01&quot;, \r\n    &quot;server&quot;: &quot;webserver1&quot;\r\n    }&#39;\r\n    \r\n    eval &quot;$(jq -M -r &#39;@sh &quot;server_name=\\(.server) url=\\(.metadata.url)&quot;&#39; &lt;&lt;&lt; &quot;$instance_info&quot;)&quot;\r\n    \r\n    echo $server_name\r\n    echo $url\r\n\r\nWhen run this produces the output\r\n\r\n    webserver1\r\n    www.google.com\r\n\r\nThe [Extract data and set shell variables](https://github.com/stedolan/jq/wiki/Cookbook#extract-data-and-set-shell-variables) section of the [JQ Cookbook](https://github.com/stedolan/jq/wiki/Cookbook) has more examples of `@sh`.",
                "title": "Bash store json response in another variable"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 4,
        "last_activity_date": 1503767589,
        "creation_date": 1461752748,
        "last_edit_date": 1461754458,
        "question_id": 36887134,
        "body_markdown": "I&#39;m curling an endpoint:\r\n\r\n    #!/bin/bash\r\n    instance_info=$(curl -sk https://internal.admin.com/app/instance)\r\n\r\n\r\nwhich gives a json response:\r\n\r\n    {\r\n    &quot;basePath&quot;: &quot;/install&quot;, \r\n    &quot;metadata&quot;: {\r\n        &quot;deployed_artifact&quot;: &quot;app01&quot;, \r\n        &quot;docker&quot;: &quot;True&quot;,  \r\n        &quot;http_port&quot;: &quot;7471&quot;,\r\n        &quot;url&quot;: &quot;www.google.com&quot;\r\n    }, \r\n    &quot;name&quot;: &quot;app-01&quot;, \r\n    &quot;server&quot;: &quot;webserver1&quot;\r\n    }\r\n\r\nI&#39;m trying to avoid curling more than once to get the variables I need from the json using JQ.\r\n\r\nUsing bash I&#39;d really appreciate if someone can show me how to store the response as another var and then use this to variablize name: server: url: http_port:\r\n\r\nThe following seems to run the curl twice: \r\n\r\n    #!/bin/bash\r\n    instance_info=$(curl -sk https://internal.admin.com/app/instance)\r\n    \r\n    server_name=$(echo instance_info | /usr/bin/jq --raw-output &#39;.server&#39;)\r\n    url=$(echo instance_info | /usr/bin/jq --raw-output &#39;.url&#39;)\r\n\r\n",
        "link": "https://stackoverflow.com/questions/36887134/bash-store-json-response-in-another-variable",
        "title": "Bash store json response in another variable"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1461764236,
                "creation_date": 1461764236,
                "answer_id": 36891496,
                "question_id": 36891006,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try specifying the jq filter explicitly, along the lines of:\r\n\r\n    jq -c . INPUTFILE | json2csv ...\r\n\r\nor:\r\n\r\n    &lt;INPUTFILE jq -c . | json2csv ...\r\n\r\nBy the way, chances are you can accomplish whatever you&#39;re trying to do using json2csv by using features of jq. For example, have you looked at @csv?",
                "title": "Using jq output within json2csv"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1461768199,
        "creation_date": 1461763061,
        "last_edit_date": 1461768199,
        "question_id": 36891006,
        "body_markdown": "i would like to use the output of jq as input for json2csv (https://github.com/jehiah/json2csv).\r\nBy using the following command, i&#180;m getting the expected output on the screen: `&lt;import5.json jq -c`\r\n\r\nBut how can i use this output for another command (e.g. json2csv)? Is there a chance to safe the ouput to a file or even nicer using the output directly within json2csv?\r\nI tried \r\n`&lt;import5.json jq -c | json2csv value,timestamp -o output.csv` to use the output of jq as input for json2csv.\r\nAlso i tried `&lt;import5.json jq -c &gt;ouput.json` to safe the output to a file.\r\n\r\nI&#180;m a total newbie in this field and would appreciate any help\r\n\r\nThanks in advance\r\n\r\nEdit:\r\nHere is how my input looks like:\r\n{\r\n&quot;One&quot;: &quot;Result&quot;,\r\n&quot;Two&quot;: 3,\r\n&quot;three&quot;: 4000,\r\n},\r\n{\r\n&quot;One&quot;: &quot;B&quot;,\r\n&quot;Two&quot;: 1,\r\n&quot;three&quot;: 9088,\r\n}\r\n\r\nMy expected output would be a csv file which includes the data, one line should look like that &quot;One&quot;,Two&quot;,&quot;three&quot;.",
        "link": "https://stackoverflow.com/questions/36891006/using-jq-output-within-json2csv",
        "title": "Using jq output within json2csv"
    },
    {
        "tags": [
            "unix-timestamp",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1461871148,
                "post_id": 36916440,
                "comment_id": 61408646,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8334135,
                    "reputation": 31,
                    "user_id": 6261656,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/1085444898181490/picture?type=large",
                    "display_name": "Pa Ul",
                    "link": "https://stackoverflow.com/users/6261656/pa-ul"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1461914620,
                "post_id": 36916440,
                "comment_id": 61423863,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1461895683,
                "creation_date": 1461895683,
                "answer_id": 36928396,
                "question_id": 36916440,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you want every occurrence of the &quot;timestamp&quot; converted (no matter where it occurs), then if your jq has `walk/1` you can use the filter illustrated by the following:\r\n\r\n    jq -n &#39;[{timestamp: (24*60*60)}] | walk(if type == &quot;object&quot; and .timestamp then .timestamp |= todate else . end)&#39;\r\n    [\r\n      {\r\n        &quot;timestamp&quot;: &quot;1970-01-02T00:00:00Z&quot;\r\n      }\r\n    ]\r\n\r\nIf your jq does not have `walk/1`, then you can copy its definition from https://github.com/stedolan/jq/blob/master/src/builtin.jq",
                "title": "reformat Timestamp from unix to iso"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1461956462,
                "creation_date": 1461956462,
                "answer_id": 36945686,
                "question_id": 36916440,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With your input:\r\n\r\n     &lt;input.json jq &#39;map(if .timestamp then .timestamp |= todate else . end)&#39;  \r\n\r\nthe output is:\r\n\r\n    [\r\n      {\r\n        &quot;channelId&quot;: 9088,\r\n        &quot;errorCode&quot;: 0,\r\n        &quot;value&quot;: 0,\r\n        &quot;timestamp&quot;: &quot;2016-04-10T03:18:29Z&quot;\r\n      },\r\n      {\r\n        &quot;channelId&quot;: 10087,\r\n        &quot;errorCode&quot;: 0,\r\n        &quot;value&quot;: 1000,\r\n        &quot;timestamp&quot;: &quot;2016-04-10T03:18:14Z&quot;\r\n      },\r\n      {\r\n        &quot;channelId&quot;: 10086,\r\n        &quot;errorCode&quot;: 0,\r\n        &quot;value&quot;: 90,\r\n        &quot;timestamp&quot;: &quot;2016-04-10T03:18:14Z&quot;\r\n      },\r\n      {\r\n        &quot;errorCode&quot;: 0,\r\n        &quot;errorLine&quot;: &quot;&quot;\r\n      }\r\n    ]\r\n\r\n\r\n",
                "title": "reformat Timestamp from unix to iso"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1461956462,
        "creation_date": 1461850760,
        "last_edit_date": 1461914047,
        "question_id": 36916440,
        "body_markdown": "I&#180;ve got Json input data, where i need to reformat the timestamp from unix-time to ISO 8601 (to process the file afterwards).\r\nI tried to do this by using: \r\n`&lt;input.json jq .[2].timestamp |= jq todate &gt;output.json` \r\nThis is reformating the timestamp in the right way, but how do i get the reformated timestamp back into the original file? I aim to get the original file with all its information, but reformated timestamp.\r\n\r\nIt works as i would like to have it at https://jqplay.org/ , but not in the command-line.\r\nI appreciate your help!\r\n\r\nSample Input:\r\n\r\n    [\r\n    {\r\n    &quot;channelId&quot;: 9088,\r\n    &quot;errorCode&quot;: 0,\r\n    &quot;value&quot;: 0,\r\n    &quot;timestamp&quot;: 1460258309\r\n    },\r\n    {\r\n    &quot;channelId&quot;: 10087,\r\n    &quot;errorCode&quot;: 0,\r\n    &quot;value&quot;: 1000,\r\n    &quot;timestamp&quot;: 1460258294\r\n    },\r\n    {\r\n    &quot;channelId&quot;: 10086,\r\n    &quot;errorCode&quot;: 0,\r\n    &quot;value&quot;: 90,\r\n    &quot;timestamp&quot;: 1460258294\r\n    },\r\n    {\r\n    &quot;errorCode&quot;: 0,\r\n    &quot;errorLine&quot;: &quot;&quot;\r\n     }\r\n    ]\r\n\r\nWanted Output:\r\n\r\n    [\r\n    {\r\n    &quot;channelId&quot;: 9088,\r\n    &quot;errorCode&quot;: 0,\r\n    &quot;value&quot;: 0,\r\n    &quot;timestamp&quot;: 2016-04-10T03:18:14Z\r\n    },\r\n    {\r\n    &quot;channelId&quot;: 10087,\r\n    &quot;errorCode&quot;: 0,\r\n    &quot;value&quot;: 1000,\r\n    &quot;timestamp&quot;: 2016-04-10T03:18:14Z\r\n    },\r\n    {\r\n    &quot;channelId&quot;: 10086,\r\n    &quot;errorCode&quot;: 0,\r\n    &quot;value&quot;: 90,\r\n    &quot;timestamp&quot;: 2016-04-10T03:18:14Z\r\n    },\r\n    {\r\n    &quot;errorCode&quot;: 0,\r\n    &quot;errorLine&quot;: &quot;&quot;\r\n     }\r\n    ]",
        "link": "https://stackoverflow.com/questions/36916440/reformat-timestamp-from-unix-to-iso",
        "title": "reformat Timestamp from unix to iso"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "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": 1461942427,
                "post_id": 36941755,
                "comment_id": 61442496,
                "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": 1461942478,
                "post_id": 36941755,
                "comment_id": 61442530,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3407469,
                    "reputation": 45,
                    "user_id": 2858210,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/50fd028688ef58206c0845b0b0e98bd5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Narrabit10",
                    "link": "https://stackoverflow.com/users/2858210/narrabit10"
                },
                "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": 1461942636,
                "post_id": 36941755,
                "comment_id": 61442656,
                "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": 1461942721,
                "post_id": 36941755,
                "comment_id": 61442720,
                "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": 1461942808,
                "post_id": 36941755,
                "comment_id": 61442776,
                "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": 1461942936,
                "post_id": 36941755,
                "comment_id": 61442852,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3407469,
                    "reputation": 45,
                    "user_id": 2858210,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/50fd028688ef58206c0845b0b0e98bd5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Narrabit10",
                    "link": "https://stackoverflow.com/users/2858210/narrabit10"
                },
                "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": 1461942947,
                "post_id": 36941755,
                "comment_id": 61442857,
                "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": 1461943264,
                "post_id": 36941755,
                "comment_id": 61443056,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1461944225,
                "post_id": 36941755,
                "comment_id": 61443616,
                "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": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1461944269,
                "post_id": 36941755,
                "comment_id": 61443643,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "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": 1461944376,
                "post_id": 36941755,
                "comment_id": 61443712,
                "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": 1461944536,
                "post_id": 36941755,
                "comment_id": 61443803,
                "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": 1461944607,
                "post_id": 36941755,
                "comment_id": 61443845,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1461943357,
                "last_edit_date": 1461943357,
                "creation_date": 1461942666,
                "answer_id": 36941874,
                "question_id": 36941755,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One sane implementation might look something like this:\r\n\r\n    retries=10\r\n    instance=server1\r\n    response_file=filename\r\n\r\n    # define a function, since you want to run this code multiple times\r\n    # the old version only ran curl once and reused that result\r\n    fetch() { curl -sk https://my-app-api.com; }\r\n    \r\n    instance_info=\r\n    for (( retries_left=retries; retries_left &gt; 0; retries_left-- )); do\r\n      content=$(fetch)\r\n      server=$(jq --raw-output &#39;.server&#39; &lt;&lt;&lt;&quot;$content&quot;)\r\n      if [[ $server = &quot;$instance&quot; ]]; then\r\n        # Writing isn&#39;t atomic, but renaming is; doing it this way makes sure that no\r\n        # incomplete response will ever exist in response_file.  If working in a directory\r\n        # like /tmp where others users may have write, use $(mktemp) to create a tempfile with\r\n        # a random name to avoid security risk.\r\n        printf &#39;%s\\n&#39; &quot;$content&quot; &gt;&quot;$response_file.tmp&quot; \\\r\n          &amp;&amp; mv &quot;$response_file.tmp&quot; &quot;$response_file&quot;\r\n        instance_info=$content\r\n        break\r\n      fi\r\n    done\r\n    [[ $instance_info ]] || { echo &quot;ERROR: Giving up after $retries retries&quot; &gt;&amp;2; }\r\n\r\n",
                "title": "Bash: Check json response and write to a file if string exists"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1461943357,
        "creation_date": 1461942303,
        "question_id": 36941755,
        "body_markdown": "I curl an endpoint for a json response and write the response to a file. \r\nSo far I&#39;ve got a script that:\r\n\r\n1). does the curl if the file does not exist and\r\n2). else sets a variable\r\n\r\n    #!/bin/bash\r\n    instance=&quot;server1&quot;\r\n    curl=$(curl -sk https://my-app-api.com | python -m json.tool)\r\n    json_response_file=&quot;/tmp/file&quot;\r\n    \r\n    if [ ! -f ${json_response_file} ] ; then\r\n      ${curl} &gt; ${json_response_file}\r\n      instance_info=$(cat ${json_response_file})\r\n     else\r\n      instance_info=$(cat ${json_response_file})\r\n    fi\r\n\r\nThe problem is, the file may exist with a bad response or is empty. \r\nPossibly using bash until, I&#39;d like to \r\n\r\n(1). check (using JQ) that a field in the curl response contains $instance and only then write the file. \r\n\r\n(2). retry the curl XX number of times until the response contains $instance\r\n\r\n(3). write the file once the response contains $instance\r\n\r\n(4). set the variable instance_info=$(cat ${json_response_file}) when the above is done correctly.  \r\n\r\nI started like this... then got stuck...\r\n\r\n    until [[ $(/usr/bin/jq --raw-output &#39;.server&#39; &lt;&lt;&lt; ${curl}) = $instance ]]\r\n    do\r\n\r\n",
        "link": "https://stackoverflow.com/questions/36941755/bash-check-json-response-and-write-to-a-file-if-string-exists",
        "title": "Bash: Check json response and write to a file if string exists"
    },
    {
        "tags": [
            "json",
            "duplicates",
            "key",
            "jq",
            "on-duplicate-key"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6429500,
                    "reputation": 6816,
                    "user_id": 4983290,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KRFpp.jpg?s=256",
                    "display_name": "Shovalt",
                    "link": "https://stackoverflow.com/users/4983290/shovalt"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1462030072,
                "post_id": 36956590,
                "comment_id": 61471054,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7497667,
                    "reputation": 547,
                    "user_id": 5697282,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/1b4115927261cdfb2af064b4a48906d2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "econ",
                    "link": "https://stackoverflow.com/users/5697282/econ"
                },
                "reply_to_user": {
                    "account_id": 6429500,
                    "reputation": 6816,
                    "user_id": 4983290,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KRFpp.jpg?s=256",
                    "display_name": "Shovalt",
                    "link": "https://stackoverflow.com/users/4983290/shovalt"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1462030168,
                "post_id": 36956590,
                "comment_id": 61471084,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6429500,
                    "reputation": 6816,
                    "user_id": 4983290,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KRFpp.jpg?s=256",
                    "display_name": "Shovalt",
                    "link": "https://stackoverflow.com/users/4983290/shovalt"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1462030475,
                "post_id": 36956590,
                "comment_id": 61471188,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6429500,
                    "reputation": 6816,
                    "user_id": 4983290,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KRFpp.jpg?s=256",
                    "display_name": "Shovalt",
                    "link": "https://stackoverflow.com/users/4983290/shovalt"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1462030507,
                "post_id": 36956590,
                "comment_id": 61471209,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7497667,
                    "reputation": 547,
                    "user_id": 5697282,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/1b4115927261cdfb2af064b4a48906d2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "econ",
                    "link": "https://stackoverflow.com/users/5697282/econ"
                },
                "reply_to_user": {
                    "account_id": 6429500,
                    "reputation": 6816,
                    "user_id": 4983290,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KRFpp.jpg?s=256",
                    "display_name": "Shovalt",
                    "link": "https://stackoverflow.com/users/4983290/shovalt"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1462031610,
                "post_id": 36956590,
                "comment_id": 61471592,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1462032206,
                "post_id": 36956590,
                "comment_id": 61471787,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7497667,
                    "reputation": 547,
                    "user_id": 5697282,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/1b4115927261cdfb2af064b4a48906d2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "econ",
                    "link": "https://stackoverflow.com/users/5697282/econ"
                },
                "reply_to_user": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1462033333,
                "post_id": 36956590,
                "comment_id": 61472140,
                "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": 1462033756,
                "post_id": 36956590,
                "comment_id": 61472294,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1462045264,
                "post_id": 36956590,
                "comment_id": 61476351,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7497667,
                    "reputation": 547,
                    "user_id": 5697282,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/1b4115927261cdfb2af064b4a48906d2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "econ",
                    "link": "https://stackoverflow.com/users/5697282/econ"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1462045323,
                "post_id": 36956590,
                "comment_id": 61476373,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1462045722,
                "creation_date": 1462045722,
                "answer_id": 36959474,
                "question_id": 36956590,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If your input is really a flat JSON object with primitives as values, this should work:\r\n\r\n    jq -s --stream &#39;group_by(.[0]) | map({&quot;key&quot;: .[0][0][0], &quot;value&quot;: map(.[1])}) | from_entries&#39;\r\n\r\n    {\r\n      &quot;a&quot;: [\r\n        &quot;1&quot;,\r\n        &quot;3&quot;\r\n      ],\r\n      &quot;b&quot;: [\r\n        &quot;2&quot;\r\n      ]\r\n    }\r\n\r\nFor more complex outputs, that would require actually understanding how `--stream` is supposed to be used, which is beyond me.",
                "title": "JSON fields have the same name"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1462222357,
                "last_edit_date": 1462222357,
                "creation_date": 1462157506,
                "answer_id": 36974355,
                "question_id": 36956590,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Building on Santiago&#39;s answer using `-s --stream`, the following filter builds up the object one step at a time, thus preserving the order of the keys and of the values for a specific key:\r\n\r\n    reduce (.[] | select(length==2)) as $kv ({};\r\n          $kv[0][0] as $k\r\n          |$kv[1] as $v\r\n          | (.[$k]|type) as $t\r\n          | if $t == &quot;null&quot; then .[$k] = $v\r\n            elif $t == &quot;array&quot; then .[$k] += [$v]\r\n    \t    else .[$k] = [ .[$k], $v ]\r\n    \t    end)\r\n\r\nFor the given input, the result is:\r\n\r\n    {\r\n      &quot;a&quot;: [\r\n        &quot;1&quot;,\r\n        &quot;3&quot;\r\n      ],\r\n      &quot;b&quot;: &quot;2&quot;\r\n    }\r\n\r\nTo illustrate that the ordering of values for each key is preserved, consider the following input:\r\n\r\n    {\r\n        &quot;c&quot; : &quot;C&quot;,\r\n        &quot;a&quot; : &quot;1&quot;,\r\n        &quot;b&quot; : &quot;2&quot;,\r\n        &quot;a&quot; : &quot;3&quot;,\r\n        &quot;b&quot; : &quot;1&quot;\r\n    }\r\n\r\nThe output produced by the filter above is:\r\n\r\n    {\r\n      &quot;c&quot;: &quot;C&quot;,\r\n      &quot;a&quot;: [\r\n        &quot;1&quot;,\r\n        &quot;3&quot;\r\n      ],\r\n      &quot;b&quot;: [\r\n        &quot;2&quot;,\r\n        &quot;1&quot;\r\n      ]\r\n    }\r\n\r\n",
                "title": "JSON fields have the same name"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1487854051,
                "creation_date": 1487854051,
                "answer_id": 42416195,
                "question_id": 36956590,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Building up on peak&#39;s answer, the following filter also **works on multi object-input**, **with nested objects** and **without the slurp-Option** (*-s*).\r\n\r\nThis is not an answer to the initial question, but because the jq-FAQ links here it might be useful for some visitors\r\n\r\nFile *jqmergekeys.txt*\r\n\r\n    def consumestream($arr): # Reads stream elements from stdin until we have enough elements to build one object and returns them as array\r\n    input as $inp \r\n    | if $inp|has(1) then consumestream($arr+[$inp]) # input=keyvalue pair =&gt; Add to array and consume more\r\n      elif ($inp[0]|has(1)) then consumestream($arr) # input=closing subkey =&gt; Skip and consume more\r\n      else $arr end; # input=closing root object =&gt; return array\r\n    \r\n    def convert2obj($stream): # Converts an object in stream notation into an object, and merges the values of duplicate keys into arrays\r\n    reduce ($stream[]) as $kv ({}; # This function is based on http://stackoverflow.com/a/36974355/2606757\r\n          $kv[0] as $k\r\n          | $kv[1] as $v\r\n          | (getpath($k)|type) as $t # type of existing value under the given key\r\n          | if $t == &quot;null&quot; then setpath($k;$v) # value not existing =&gt; set value\r\n            elif $t == &quot;array&quot; then setpath($k; getpath($k) + [$v] ) # value is already an array =&gt; add value to array\r\n            else setpath($k; [getpath($k), $v ]) # single value =&gt; put existing and new value into an array\r\n            end);\r\n    \r\n    def mainloop(f):  (convert2obj(consumestream([input]))|f),mainloop(f); # Consumes streams forever, converts them into an object and applies the user provided filter\r\n    def mergeduplicates(f): try mainloop(f) catch if .==&quot;break&quot; then empty else error end; # Catches the &quot;break&quot; thrown by jq if there&#39;s no more input\r\n    \r\n    #---------------- User code below --------------------------    \r\n    \r\n    mergeduplicates(.) # merge duplicate keys in input, without any additional filters\r\n    \r\n    #mergeduplicates(select(.layers)|.layers.frame) # merge duplicate keys in input and apply some filter afterwards\r\n\r\nExample:\r\n\r\n    tshark -T ek | jq -nc --stream -f ./jqmergekeys.txt",
                "title": "JSON fields have the same name"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1573871560,
                "creation_date": 1573871560,
                "answer_id": 58887031,
                "question_id": 36956590,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a simple alternative that generalizes well:\r\n\r\n## reshape.jq\r\n\r\n```\r\ndef augmentpath($path; $value):\r\n  getpath($path) as $v\r\n  | setpath($path; $v + [$value]);\r\n\r\nreduce (inputs | select(length==2)) as $pv\r\n  ({}; augmentpath($pv[0]; $pv[1]) )\r\n```\r\n\r\n## Usage \r\n\r\n    jq -n -f reshape.jq input.json\r\n\r\n## Output\r\nWith the given input:\r\n\r\n```\r\n{\r\n  &quot;a&quot;: [\r\n    &quot;1&quot;,\r\n    &quot;3&quot;\r\n  ],\r\n  &quot;b&quot;: [\r\n    &quot;2&quot;\r\n  ]\r\n}\r\n```\r\n\r\n## Postscript\r\nIf it&#39;s important to avoid arrays of singletons, either the def of `augmentpath` could be modified, or a postprocessing step could be added.",
                "title": "JSON fields have the same name"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 4,
        "last_activity_date": 1573871579,
        "creation_date": 1462029281,
        "last_edit_date": 1573871579,
        "question_id": 36956590,
        "body_markdown": "In practice, keys have to be unique within a JSON object (e.g. https://stackoverflow.com/questions/21832701/does-json-syntax-allow-duplicate-keys-in-an-object). However, suppose I have a file with the following contents:\r\n\r\n    {\r\n    \t&quot;a&quot; : &quot;1&quot;,\r\n    \t&quot;b&quot; : &quot;2&quot;,\r\n    \t&quot;a&quot; : &quot;3&quot;\r\n    }\r\n\r\nIs there a simple way of converting the repeated keys to an array? So that the file becomes:\r\n\r\n    {\r\n    \t&quot;a&quot; : [ {&quot;key&quot;: &quot;1&quot;}, {&quot;key&quot;: &quot;3&quot;}],\r\n    \t&quot;b&quot; : &quot;2&quot;\r\n    }\r\n\r\nOr something similar, but which combines the repeated keys into an array (or finds and alternative way to extract the repeated key values).\r\n\r\nHere&#39;s a solution in Java: https://stackoverflow.com/questions/24416960/convert-json-object-with-duplicate-keys-to-json-array\r\n\r\nIs there any way to do it with awk/bash/python?",
        "link": "https://stackoverflow.com/questions/36956590/json-fields-have-the-same-name",
        "title": "JSON fields have the same name"
    },
    {
        "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": 0,
                "creation_date": 1462192819,
                "post_id": 36982666,
                "comment_id": 61520234,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7187504,
                    "reputation": 141,
                    "user_id": 5488998,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://lh3.googleusercontent.com/-juPqxO6GPsk/AAAAAAAAAAI/AAAAAAAAAHA/klI-DsG3gi8/s256-rj/photo.jpg",
                    "display_name": "Sandeep Sharma",
                    "link": "https://stackoverflow.com/users/5488998/sandeep-sharma"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1462193440,
                "post_id": 36982666,
                "comment_id": 61520639,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 225157,
                    "reputation": 265,
                    "user_id": 2469813,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/82928ad826ad114025ee783c916b80f0?s=256&d=identicon&r=PG",
                    "display_name": "redoc",
                    "link": "https://stackoverflow.com/users/2469813/redoc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1462193480,
                "post_id": 36982666,
                "comment_id": 61520676,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7187504,
                    "reputation": 141,
                    "user_id": 5488998,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://lh3.googleusercontent.com/-juPqxO6GPsk/AAAAAAAAAAI/AAAAAAAAAHA/klI-DsG3gi8/s256-rj/photo.jpg",
                    "display_name": "Sandeep Sharma",
                    "link": "https://stackoverflow.com/users/5488998/sandeep-sharma"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1462195367,
                "post_id": 36982666,
                "comment_id": 61521898,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1462195409,
                "last_edit_date": 1462195409,
                "creation_date": 1462194928,
                "answer_id": 36983390,
                "question_id": 36982666,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This does it\r\n\r\n    python3 -c &#39;import json; print(&quot;\\n&quot;.join([&quot;{}={}&quot;.format(x[&quot;Value&quot;], x[&quot;Name&quot;]) for x in json.load(open(&quot;file.json&quot;))]))&#39;\r\n\r\nresult\r\n\r\n    a=1\r\n    b=2\r\n    c=3\r\n\r\n",
                "title": "Parse JSON data into a variable assignment format"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1462196132,
                "last_edit_date": 1462196132,
                "creation_date": 1462195254,
                "answer_id": 36983495,
                "question_id": 36982666,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using `jq`:\r\n\r\n    jq &#39;map({(.Name):.Value})|add|.//={}&#39; &lt; data.json\r\n\r\nProduces:\r\n\r\n    {\r\n      &quot;a&quot;: &quot;1&quot;,\r\n      &quot;b&quot;: &quot;2&quot;,\r\n      &quot;c&quot;: &quot;3&quot;\r\n    }\r\n\r\nIf you have `jq` version 1.5+, you can use `from_entries` instead.",
                "title": "Parse JSON data into a variable assignment format"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1462195668,
                "last_edit_date": 1462195668,
                "creation_date": 1462195407,
                "answer_id": 36983544,
                "question_id": 36982666,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use the following `jq` command:\r\n\r\n    jq -r &#39;.[]|[.Name,.Value]|join(&quot;=&quot;)&#39; file.json\r\n\r\nOutput:\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    a=1\r\n    b=2\r\n    c=3\r\n",
                "title": "Parse JSON data into a variable assignment format"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1462199825,
                "creation_date": 1462199825,
                "answer_id": 36985085,
                "question_id": 36982666,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since you&#39;re only printing out two values, it might just be easier to print out the strings directly.\r\n\r\n    $ jq -r &#39;.[] | &quot;\\(.Name)=\\(.Value)&quot;&#39; file.txt",
                "title": "Parse JSON data into a variable assignment format"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1462231374,
        "creation_date": 1462192714,
        "last_edit_date": 1462231374,
        "question_id": 36982666,
        "body_markdown": "I am trying to parse JSON data into variable format\r\n\r\n    [\r\n      {\r\n        &quot;Name&quot; : &quot;a&quot;,\r\n        &quot;Value&quot; : &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;Name&quot; : &quot;b&quot;,\r\n        &quot;Value&quot; : &quot;2&quot;\r\n      },\r\n      {\r\n        &quot;Name&quot; : &quot;c&quot;,\r\n        &quot;Value&quot; : &quot;3&quot;\r\n      }\r\n    ]\r\n\r\noutput should be like \r\n\r\n    a=1\r\n    b=2\r\n    c=3\r\n\r\nThis is what I tried, but it is not giving the expected result:\r\n\r\n    jq &#39;.[].Value&#39; file.txt ",
        "link": "https://stackoverflow.com/questions/36982666/parse-json-data-into-a-variable-assignment-format",
        "title": "Parse JSON data into a variable assignment format"
    },
    {
        "tags": [
            "json",
            "key",
            "special-characters",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 130,
                "is_accepted": false,
                "score": 127,
                "last_activity_date": 1648712171,
                "last_edit_date": 1648712171,
                "creation_date": 1462337279,
                "answer_id": 37018703,
                "question_id": 37018393,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When a key contains characters that are invalid for identifiers, you&#39;ll have to quote the name.\r\n\r\n    .&quot;OPEN.BTC&quot;\r\n\r\nOr for older versions of jq, use an index.\r\n\r\n    .[&quot;OPEN.BTC&quot;]\r\n\r\n#### Example\r\n```bash\r\n... | jq &#39;.&quot;OPEN.BTC&quot;&#39;\r\n```",
                "title": "How to use jq when the variable has reserved characters?"
            },
            {
                "up_vote_count": 29,
                "is_accepted": false,
                "score": 29,
                "last_activity_date": 1594805867,
                "creation_date": 1594805867,
                "answer_id": 62911938,
                "question_id": 37018393,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another answer didn&#39;t work for me but the comment written by [@jeff-mercado][1] worked for me. So, adding it as an answer here. \r\n\r\nIf your key has dots like &quot;OPEN.BTC&quot; then your `jq` command should be\r\n\r\n    curl -s &#39;https://cryptofresh.com/api/asset/markets?asset=MKR&#39; | jq &#39;.&quot;OPEN.BTC&quot;&#39;\r\n\r\nPut the key first in double quotes and then escape the first dot by wrapping it using single quotes.\r\n\r\n\r\n  [1]: https://stackoverflow.com/users/390278/jeff-mercado",
                "title": "How to use jq when the variable has reserved characters?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666857551,
                "creation_date": 1666857551,
                "answer_id": 74218628,
                "question_id": 37018393,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "None of these work for me as the field in question is called &quot;end&quot;.  The only way to do it was to replace the word &quot;end&quot; with something else e.g. EndIt using sed - and then use EndIt as a field for jq to parse to.",
                "title": "How to use jq when the variable has reserved characters?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 80,
        "last_activity_date": 1725803171,
        "creation_date": 1462335616,
        "last_edit_date": 1725803171,
        "question_id": 37018393,
        "body_markdown": "I&#39;m trying to get the following to work and it&#39;s not, help me please:\r\n\r\n&lt;!-- language: shell --&gt;\r\n    curl -s &#39;https://cryptofresh.com/api/asset/markets?asset=MKR&#39; | jq .OPEN.BTC\r\n\r\nThe variable in question includes a period, I tried just about everything to escape the period &amp;&amp; also tried surrounding it in quotes; no go ; this is the variable I&#39;m looking to pull from (I ran jq without any filters, and truncated the output here to show what I need. Thanks in advance future problem solver!\r\n\r\n    curl -s &#39;https://cryptofresh.com/api/asset/markets?asset=MKR&#39; | jq\r\n    ....\r\n     &quot;OPEN.BTC&quot;: {\r\n    &quot;volume24&quot;: 0.932166,\r\n    &quot;price&quot;: 0.09995,\r\n    &quot;updated&quot;: &quot;2016-05-04T03:03:29.000Z&quot;\r\n    },\r\n    ....",
        "link": "https://stackoverflow.com/questions/37018393/how-to-use-jq-when-the-variable-has-reserved-characters",
        "title": "How to use jq when the variable has reserved characters?"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1462360798,
                "creation_date": 1462360798,
                "answer_id": 37026330,
                "question_id": 37020712,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Sure, jq can do this!\r\n\r\nFirst, we use the recurse operator, `..`, to recursively iterate through everything. Then, we get all the `.nodes` and `.floating_nodes`, and we use `?` to ignore errors that would arise from trying to get properties from numbers, strings or objects. Then, we get all the elements in these arrays with `[]`. Again, ignoring the errors in the previous step left some `null`s, so we ignore the errors from trying to use `[]` on `null`s with a `?`. Lastly, we pipe everything to `select(.window != null)`, and we wrap every result in an array for easier treatment.\r\n\r\n    jq &#39;[.. | .floating_nodes?, .nodes? | .[]? | select(.window != null)]&#39;\r\n\r\n",
                "title": "Can jq handle nested JSON data?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1462376105,
                "creation_date": 1462376105,
                "answer_id": 37032239,
                "question_id": 37020712,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If the `window` property can only appear on `node` or `floating_node` objects, you could simplify things by just searching for all objects that have `window` properties.\r\n\r\n    .. | objects | select(.window != null)",
                "title": "Can jq handle nested JSON data?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1462446105,
                "creation_date": 1462446105,
                "answer_id": 37048906,
                "question_id": 37020712,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Working off Santiago&#39;s solution and trying to backfill for what may be lacking in jq-1.3 I got this to work:\r\n\r\n    jq &#39;recurse(.[]) | .floating_nodes, .nodes | .[] | select(.window != null) | select(.focused == true) | .name&#39;\r\n\r\n... it also gave lots of error messages such as:\r\n\r\n    jq: error: Cannot iterate over number\r\n    jq: error: Cannot iterate over null\r\n    jq: error: Cannot iterate over null\r\n    jq: error: Cannot index number with string\r\n",
                "title": "Can jq handle nested JSON data?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1463046002,
                "last_edit_date": 1463046002,
                "creation_date": 1463045162,
                "answer_id": 37182695,
                "question_id": 37020712,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following has been tested with jq 1.3, 1.4, and 1.5:\r\n\r\n    recurse(if type == &quot;object&quot; or type == &quot;array&quot; then .[] else empty end)\r\n    | select(type == &quot;object&quot;)\r\n    | ( select(.nodes|type == &quot;array&quot;) | .nodes[]),\r\n      ( select(.floating_nodes|type == &quot;array&quot;) | .floating_nodes[])\r\n    | select( .window != null ) \r\n\r\nUsing the &quot;full version&quot; of the given input, jq 1.3 produces the following output:\r\n\r\n    {\r\n      &quot;swallows&quot;: [],\r\n      &quot;floating&quot;: &quot;auto_off&quot;,\r\n      &quot;sticky&quot;: false,\r\n      &quot;fullscreen_mode&quot;: 0,\r\n      &quot;focus&quot;: [],\r\n      &quot;floating_nodes&quot;: [],\r\n      &quot;nodes&quot;: [],\r\n      &quot;window_properties&quot;: {\r\n        &quot;transient_for&quot;: null,\r\n        &quot;title&quot;: &quot;16:11 bhepple:.../~ — Konsole&quot;,\r\n        &quot;instance&quot;: &quot;konsole&quot;,\r\n        &quot;class&quot;: &quot;konsole&quot;\r\n      },\r\n      &quot;window&quot;: 8388613,\r\n      &quot;name&quot;: &quot;16:11 bhepple:.../~ — Konsole&quot;,\r\n      &quot;layout&quot;: &quot;splith&quot;,\r\n      &quot;focused&quot;: true,\r\n      &quot;urgent&quot;: false,\r\n      &quot;percent&quot;: 1,\r\n      &quot;scratchpad_state&quot;: &quot;none&quot;,\r\n      &quot;orientation&quot;: &quot;none&quot;,\r\n      &quot;type&quot;: &quot;con&quot;,\r\n      &quot;id&quot;: 10895664,\r\n      &quot;workspace_layout&quot;: &quot;default&quot;,\r\n      &quot;last_split_layout&quot;: &quot;splith&quot;,\r\n      &quot;border&quot;: &quot;pixel&quot;,\r\n      &quot;current_border_width&quot;: 1,\r\n      &quot;rect&quot;: {\r\n        &quot;height&quot;: 1061,\r\n        &quot;width&quot;: 1920,\r\n        &quot;y&quot;: 0,\r\n        &quot;x&quot;: 0\r\n      },\r\n      &quot;deco_rect&quot;: {\r\n        &quot;height&quot;: 0,\r\n        &quot;width&quot;: 0,\r\n        &quot;y&quot;: 0,\r\n        &quot;x&quot;: 0\r\n      },\r\n      &quot;window_rect&quot;: {\r\n        &quot;height&quot;: 1059,\r\n        &quot;width&quot;: 1918,\r\n        &quot;y&quot;: 1,\r\n        &quot;x&quot;: 1\r\n      },\r\n      &quot;geometry&quot;: {\r\n        &quot;height&quot;: 1059,\r\n        &quot;width&quot;: 958,\r\n        &quot;y&quot;: 0,\r\n        &quot;x&quot;: 0\r\n      }\r\n    }\r\n    {\r\n      &quot;swallows&quot;: [],\r\n      &quot;floating&quot;: &quot;auto_off&quot;,\r\n      &quot;sticky&quot;: false,\r\n      &quot;fullscreen_mode&quot;: 0,\r\n      &quot;focus&quot;: [],\r\n      &quot;floating_nodes&quot;: [],\r\n      &quot;nodes&quot;: [],\r\n      &quot;window_properties&quot;: {\r\n        &quot;transient_for&quot;: null,\r\n        &quot;title&quot;: &quot;i3bar for output VNC-0&quot;,\r\n        &quot;instance&quot;: &quot;i3bar&quot;,\r\n        &quot;class&quot;: &quot;i3bar&quot;\r\n      },\r\n      &quot;window&quot;: 14680070,\r\n      &quot;name&quot;: &quot;i3bar for output VNC-0&quot;,\r\n      &quot;layout&quot;: &quot;splith&quot;,\r\n      &quot;focused&quot;: false,\r\n      &quot;urgent&quot;: false,\r\n      &quot;percent&quot;: 1,\r\n      &quot;scratchpad_state&quot;: &quot;none&quot;,\r\n      &quot;orientation&quot;: &quot;none&quot;,\r\n      &quot;type&quot;: &quot;con&quot;,\r\n      &quot;id&quot;: 10891392,\r\n      &quot;workspace_layout&quot;: &quot;default&quot;,\r\n      &quot;last_split_layout&quot;: &quot;splith&quot;,\r\n      &quot;border&quot;: &quot;pixel&quot;,\r\n      &quot;current_border_width&quot;: 1,\r\n      &quot;rect&quot;: {\r\n        &quot;height&quot;: 19,\r\n        &quot;width&quot;: 1920,\r\n        &quot;y&quot;: 1061,\r\n        &quot;x&quot;: 0\r\n      },\r\n      &quot;deco_rect&quot;: {\r\n        &quot;height&quot;: 0,\r\n        &quot;width&quot;: 0,\r\n        &quot;y&quot;: 0,\r\n        &quot;x&quot;: 0\r\n      },\r\n      &quot;window_rect&quot;: {\r\n        &quot;height&quot;: 19,\r\n        &quot;width&quot;: 1920,\r\n        &quot;y&quot;: 0,\r\n        &quot;x&quot;: 0\r\n      },\r\n      &quot;geometry&quot;: {\r\n        &quot;height&quot;: 19,\r\n        &quot;width&quot;: 3840,\r\n        &quot;y&quot;: 1061,\r\n        &quot;x&quot;: 0\r\n      }\r\n    }\r\n\r\n",
                "title": "Can jq handle nested JSON data?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1505970596,
                "last_edit_date": 1505970596,
                "creation_date": 1501962625,
                "answer_id": 45525825,
                "question_id": 37020712,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **tostream** to scan a stream of [path,value] arrays from the given input.  It then uses **select** to pick out only paths ending in &quot;window&quot; and whose corresponding value is not null.  Finally it uses **foreach** and **getpath** to produce a stream of the containing objects. \r\n\r\n    foreach (   tostream\r\n              | select(length == 2 and .[0][-1] == &quot;window&quot; and .[1] != null)\r\n            ) as $p (\r\n        .\r\n      ; .\r\n      ; getpath($p[0][:-1])\r\n    )\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      ( tostream | select(length == 2 and .[0][-1] == &quot;window&quot; and .[1] != null) ) as $p\r\n    |  getpath($p[0][:-1])",
                "title": "Can jq handle nested JSON data?"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 2,
        "last_activity_date": 1505970596,
        "creation_date": 1462345514,
        "last_edit_date": 1462358756,
        "question_id": 37020712,
        "body_markdown": "Maybe this is too much of a stretch for &#39;jq&#39; and I need to jump into the python json module, but let&#39;s throw down a challenge for the gurus!!\r\n\r\nI have some JSON data (from the i3 window manager) that looks a bit like this (simplified). I want to dig down through an arbitrary number of levels of .nodes/.floating_nodes and pull out .nodes or .floating_nodes that have &quot;window&quot; set to non-null. :\r\n\r\n    {\r\n      &quot;floating_nodes&quot;: [],\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;floating_nodes&quot;: [],\r\n          &quot;nodes&quot;: [\r\n            {\r\n              &quot;floating_nodes&quot;: [],\r\n              &quot;nodes&quot;: [\r\n                {\r\n                  &quot;floating_nodes&quot;: [],\r\n                  &quot;nodes&quot;: [],\r\n                  &quot;window&quot;: null,\r\n                  &quot;name&quot;: &quot;__i3_scratch&quot;,\r\n                }\r\n              ],\r\n              &quot;window&quot;: null,\r\n              &quot;name&quot;: &quot;foobar&quot;,\r\n            }\r\n          ],\r\n          &quot;window&quot;: null,\r\n          &quot;name&quot;: &quot;__i3&quot;,\r\n        },\r\n        {\r\n          &quot;floating_nodes&quot;: [],\r\n          &quot;nodes&quot;: [\r\n            {\r\n              &quot;floating_nodes&quot;: [],\r\n              &quot;nodes&quot;: [],\r\n              &quot;window&quot;: null,\r\n              &quot;name&quot;: &quot;topdock&quot;,\r\n            },\r\n            {\r\n              &quot;floating_nodes&quot;: [],\r\n              &quot;nodes&quot;: [\r\n                {\r\n                  &quot;floating_nodes&quot;: [],\r\n                  &quot;nodes&quot;: [\r\n                    {\r\n                      &quot;floating_nodes&quot;: [],\r\n                      &quot;nodes&quot;: [],\r\n                      &quot;window&quot;: 8388613,\r\n                      &quot;name&quot;: &quot;16:11 bhepple:.../~ — Konsole&quot;,\r\n                      &quot;rect&quot;: {\r\n                        &quot;height&quot;: 1061,\r\n                        &quot;width&quot;: 1920,\r\n                        &quot;y&quot;: 0,\r\n                        &quot;x&quot;: 0\r\n                      },\r\n                  ],\r\n                  &quot;window&quot;: null,\r\n                  &quot;name&quot;: &quot;1&quot;,\r\n                }\r\n              ],\r\n              &quot;window&quot;: null,\r\n              &quot;name&quot;: &quot;content&quot;,\r\n            },\r\n            {\r\n              &quot;floating_nodes&quot;: [],\r\n              &quot;nodes&quot;: [\r\n                {\r\n                  &quot;floating_nodes&quot;: [],\r\n                  &quot;nodes&quot;: [],\r\n                  &quot;window&quot;: 14680070,\r\n                  &quot;name&quot;: &quot;i3bar for output VNC-0&quot;,\r\n                }\r\n              ],\r\n              &quot;window&quot;: null,\r\n              &quot;name&quot;: &quot;bottomdock&quot;,\r\n            }\r\n          ],\r\n          &quot;window&quot;: null,\r\n          &quot;name&quot;: &quot;VNC-0&quot;,\r\n        }\r\n      ],\r\n      &quot;window&quot;: null,\r\n      &quot;name&quot;: &quot;root&quot;,\r\n    }\r\n\r\nMy sample JSON was a bit broken by my simplifications so here&#39;s the full version:\r\n\r\n    {&quot;id&quot;:10883136,&quot;type&quot;:&quot;root&quot;,&quot;orientation&quot;:&quot;horizontal&quot;,&quot;scratchpad_state&quot;:&quot;none&quot;,&quot;percent&quot;:null,&quot;urgent&quot;:false,&quot;focused&quot;:false,&quot;layout&quot;:&quot;splith&quot;,&quot;workspace_layout&quot;:&quot;default&quot;,&quot;last_split_layout&quot;:&quot;splith&quot;,&quot;border&quot;:&quot;pixel&quot;,&quot;current_border_width&quot;:-1,&quot;rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:1920,&quot;height&quot;:1080},&quot;deco_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;window_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;geometry&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;name&quot;:&quot;root&quot;,&quot;window&quot;:null,&quot;nodes&quot;:[{&quot;id&quot;:10883568,&quot;type&quot;:&quot;output&quot;,&quot;orientation&quot;:&quot;none&quot;,&quot;scratchpad_state&quot;:&quot;none&quot;,&quot;percent&quot;:0.5,&quot;urgent&quot;:false,&quot;focused&quot;:false,&quot;layout&quot;:&quot;output&quot;,&quot;workspace_layout&quot;:&quot;default&quot;,&quot;last_split_layout&quot;:&quot;splith&quot;,&quot;border&quot;:&quot;pixel&quot;,&quot;current_border_width&quot;:-1,&quot;rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:1920,&quot;height&quot;:1080},&quot;deco_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;window_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;geometry&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;name&quot;:&quot;__i3&quot;,&quot;window&quot;:null,&quot;nodes&quot;:[{&quot;id&quot;:10884128,&quot;type&quot;:&quot;con&quot;,&quot;orientation&quot;:&quot;horizontal&quot;,&quot;scratchpad_state&quot;:&quot;none&quot;,&quot;percent&quot;:null,&quot;urgent&quot;:false,&quot;focused&quot;:false,&quot;layout&quot;:&quot;splith&quot;,&quot;workspace_layout&quot;:&quot;default&quot;,&quot;last_split_layout&quot;:&quot;splith&quot;,&quot;border&quot;:&quot;pixel&quot;,&quot;current_border_width&quot;:-1,&quot;rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;deco_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;window_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;geometry&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;name&quot;:&quot;content&quot;,&quot;window&quot;:null,&quot;nodes&quot;:[{&quot;id&quot;:10884720,&quot;type&quot;:&quot;workspace&quot;,&quot;orientation&quot;:&quot;none&quot;,&quot;scratchpad_state&quot;:&quot;none&quot;,&quot;percent&quot;:null,&quot;urgent&quot;:false,&quot;focused&quot;:false,&quot;layout&quot;:&quot;splith&quot;,&quot;workspace_layout&quot;:&quot;default&quot;,&quot;last_split_layout&quot;:&quot;splith&quot;,&quot;border&quot;:&quot;pixel&quot;,&quot;current_border_width&quot;:-1,&quot;rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;deco_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;window_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;geometry&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;name&quot;:&quot;__i3_scratch&quot;,&quot;num&quot;:-1,&quot;window&quot;:null,&quot;nodes&quot;:[],&quot;floating_nodes&quot;:[],&quot;focus&quot;:[],&quot;fullscreen_mode&quot;:1,&quot;sticky&quot;:false,&quot;floating&quot;:&quot;auto_off&quot;,&quot;swallows&quot;:[]}],&quot;floating_nodes&quot;:[],&quot;focus&quot;:[10884720],&quot;fullscreen_mode&quot;:0,&quot;sticky&quot;:false,&quot;floating&quot;:&quot;auto_off&quot;,&quot;swallows&quot;:[]}],&quot;floating_nodes&quot;:[],&quot;focus&quot;:[10884128],&quot;fullscreen_mode&quot;:0,&quot;sticky&quot;:false,&quot;floating&quot;:&quot;auto_off&quot;,&quot;swallows&quot;:[]},{&quot;id&quot;:10886256,&quot;type&quot;:&quot;output&quot;,&quot;orientation&quot;:&quot;none&quot;,&quot;scratchpad_state&quot;:&quot;none&quot;,&quot;percent&quot;:0.5,&quot;urgent&quot;:false,&quot;focused&quot;:false,&quot;layout&quot;:&quot;output&quot;,&quot;workspace_layout&quot;:&quot;default&quot;,&quot;last_split_layout&quot;:&quot;splith&quot;,&quot;border&quot;:&quot;pixel&quot;,&quot;current_border_width&quot;:-1,&quot;rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:1920,&quot;height&quot;:1080},&quot;deco_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;window_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;geometry&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;name&quot;:&quot;VNC-0&quot;,&quot;window&quot;:null,&quot;nodes&quot;:[{&quot;id&quot;:10886944,&quot;type&quot;:&quot;dockarea&quot;,&quot;orientation&quot;:&quot;none&quot;,&quot;scratchpad_state&quot;:&quot;none&quot;,&quot;percent&quot;:null,&quot;urgent&quot;:false,&quot;focused&quot;:false,&quot;layout&quot;:&quot;dockarea&quot;,&quot;workspace_layout&quot;:&quot;default&quot;,&quot;last_split_layout&quot;:&quot;splith&quot;,&quot;border&quot;:&quot;pixel&quot;,&quot;current_border_width&quot;:-1,&quot;rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:1920,&quot;height&quot;:0},&quot;deco_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;window_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;geometry&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;name&quot;:&quot;topdock&quot;,&quot;window&quot;:null,&quot;nodes&quot;:[],&quot;floating_nodes&quot;:[],&quot;focus&quot;:[],&quot;fullscreen_mode&quot;:0,&quot;sticky&quot;:false,&quot;floating&quot;:&quot;auto_off&quot;,&quot;swallows&quot;:[{&quot;dock&quot;:2,&quot;insert_where&quot;:2}]},{&quot;id&quot;:10887648,&quot;type&quot;:&quot;con&quot;,&quot;orientation&quot;:&quot;horizontal&quot;,&quot;scratchpad_state&quot;:&quot;none&quot;,&quot;percent&quot;:null,&quot;urgent&quot;:false,&quot;focused&quot;:false,&quot;layout&quot;:&quot;splith&quot;,&quot;workspace_layout&quot;:&quot;default&quot;,&quot;last_split_layout&quot;:&quot;splith&quot;,&quot;border&quot;:&quot;pixel&quot;,&quot;current_border_width&quot;:-1,&quot;rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:1920,&quot;height&quot;:1061},&quot;deco_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;window_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;geometry&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;name&quot;:&quot;content&quot;,&quot;window&quot;:null,&quot;nodes&quot;:[{&quot;id&quot;:10889056,&quot;type&quot;:&quot;workspace&quot;,&quot;orientation&quot;:&quot;horizontal&quot;,&quot;scratchpad_state&quot;:&quot;none&quot;,&quot;percent&quot;:null,&quot;urgent&quot;:false,&quot;focused&quot;:false,&quot;layout&quot;:&quot;splith&quot;,&quot;workspace_layout&quot;:&quot;default&quot;,&quot;last_split_layout&quot;:&quot;splith&quot;,&quot;border&quot;:&quot;pixel&quot;,&quot;current_border_width&quot;:-1,&quot;rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:1920,&quot;height&quot;:1061},&quot;deco_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;window_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;geometry&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;name&quot;:&quot;1&quot;,&quot;num&quot;:1,&quot;window&quot;:null,&quot;nodes&quot;:[{&quot;id&quot;:10895664,&quot;type&quot;:&quot;con&quot;,&quot;orientation&quot;:&quot;none&quot;,&quot;scratchpad_state&quot;:&quot;none&quot;,&quot;percent&quot;:1.0,&quot;urgent&quot;:false,&quot;focused&quot;:true,&quot;layout&quot;:&quot;splith&quot;,&quot;workspace_layout&quot;:&quot;default&quot;,&quot;last_split_layout&quot;:&quot;splith&quot;,&quot;border&quot;:&quot;pixel&quot;,&quot;current_border_width&quot;:1,&quot;rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:1920,&quot;height&quot;:1061},&quot;deco_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;window_rect&quot;:{&quot;x&quot;:1,&quot;y&quot;:1,&quot;width&quot;:1918,&quot;height&quot;:1059},&quot;geometry&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:958,&quot;height&quot;:1059},&quot;name&quot;:&quot;16:11 bhepple:.../~ — Konsole&quot;,&quot;window&quot;:8388613,&quot;window_properties&quot;:{&quot;class&quot;:&quot;konsole&quot;,&quot;instance&quot;:&quot;konsole&quot;,&quot;title&quot;:&quot;16:11 bhepple:.../~ — Konsole&quot;,&quot;transient_for&quot;:null},&quot;nodes&quot;:[],&quot;floating_nodes&quot;:[],&quot;focus&quot;:[],&quot;fullscreen_mode&quot;:0,&quot;sticky&quot;:false,&quot;floating&quot;:&quot;auto_off&quot;,&quot;swallows&quot;:[]}],&quot;floating_nodes&quot;:[],&quot;focus&quot;:[10895664],&quot;fullscreen_mode&quot;:1,&quot;sticky&quot;:false,&quot;floating&quot;:&quot;auto_off&quot;,&quot;swallows&quot;:[]}],&quot;floating_nodes&quot;:[],&quot;focus&quot;:[10889056],&quot;fullscreen_mode&quot;:0,&quot;sticky&quot;:false,&quot;floating&quot;:&quot;auto_off&quot;,&quot;swallows&quot;:[]},{&quot;id&quot;:10888352,&quot;type&quot;:&quot;dockarea&quot;,&quot;orientation&quot;:&quot;none&quot;,&quot;scratchpad_state&quot;:&quot;none&quot;,&quot;percent&quot;:null,&quot;urgent&quot;:false,&quot;focused&quot;:false,&quot;layout&quot;:&quot;dockarea&quot;,&quot;workspace_layout&quot;:&quot;default&quot;,&quot;last_split_layout&quot;:&quot;splith&quot;,&quot;border&quot;:&quot;pixel&quot;,&quot;current_border_width&quot;:-1,&quot;rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:1061,&quot;width&quot;:1920,&quot;height&quot;:19},&quot;deco_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;window_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;geometry&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;name&quot;:&quot;bottomdock&quot;,&quot;window&quot;:null,&quot;nodes&quot;:[{&quot;id&quot;:10891392,&quot;type&quot;:&quot;con&quot;,&quot;orientation&quot;:&quot;none&quot;,&quot;scratchpad_state&quot;:&quot;none&quot;,&quot;percent&quot;:1.0,&quot;urgent&quot;:false,&quot;focused&quot;:false,&quot;layout&quot;:&quot;splith&quot;,&quot;workspace_layout&quot;:&quot;default&quot;,&quot;last_split_layout&quot;:&quot;splith&quot;,&quot;border&quot;:&quot;pixel&quot;,&quot;current_border_width&quot;:1,&quot;rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:1061,&quot;width&quot;:1920,&quot;height&quot;:19},&quot;deco_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:0,&quot;height&quot;:0},&quot;window_rect&quot;:{&quot;x&quot;:0,&quot;y&quot;:0,&quot;width&quot;:1920,&quot;height&quot;:19},&quot;geometry&quot;:{&quot;x&quot;:0,&quot;y&quot;:1061,&quot;width&quot;:3840,&quot;height&quot;:19},&quot;name&quot;:&quot;i3bar for output VNC-0&quot;,&quot;window&quot;:14680070,&quot;window_properties&quot;:{&quot;class&quot;:&quot;i3bar&quot;,&quot;instance&quot;:&quot;i3bar&quot;,&quot;title&quot;:&quot;i3bar for output VNC-0&quot;,&quot;transient_for&quot;:null},&quot;nodes&quot;:[],&quot;floating_nodes&quot;:[],&quot;focus&quot;:[],&quot;fullscreen_mode&quot;:0,&quot;sticky&quot;:false,&quot;floating&quot;:&quot;auto_off&quot;,&quot;swallows&quot;:[]}],&quot;floating_nodes&quot;:[],&quot;focus&quot;:[10891392],&quot;fullscreen_mode&quot;:0,&quot;sticky&quot;:false,&quot;floating&quot;:&quot;auto_off&quot;,&quot;swallows&quot;:[{&quot;dock&quot;:3,&quot;insert_where&quot;:2}]}],&quot;floating_nodes&quot;:[],&quot;focus&quot;:[10887648,10886944,10888352],&quot;fullscreen_mode&quot;:0,&quot;sticky&quot;:false,&quot;floating&quot;:&quot;auto_off&quot;,&quot;swallows&quot;:[]}],&quot;floating_nodes&quot;:[],&quot;focus&quot;:[10886256,10883568],&quot;fullscreen_mode&quot;:0,&quot;sticky&quot;:false,&quot;floating&quot;:&quot;auto_off&quot;,&quot;swallows&quot;:[]}\r\n",
        "link": "https://stackoverflow.com/questions/37020712/can-jq-handle-nested-json-data",
        "title": "Can jq handle nested JSON data?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1462360973,
                "post_id": 37020974,
                "comment_id": 61602681,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8375797,
                    "reputation": 21,
                    "user_id": 6289294,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a3542a0fbcb67e89629242e914894be8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Mark McCorkle",
                    "link": "https://stackoverflow.com/users/6289294/mark-mccorkle"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1462398818,
                "post_id": 37020974,
                "comment_id": 61627433,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1462494604,
                "post_id": 37020974,
                "comment_id": 61671548,
                "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": 1,
                "creation_date": 1463080101,
                "post_id": 37020974,
                "comment_id": 61923398,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1462503474,
                "creation_date": 1462503474,
                "answer_id": 37063503,
                "question_id": 37020974,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "you can use python json ,\r\nIt works,I have tested it.\r\n\r\n",
                "title": "jq rounding large integers when it shouldn&#39;t"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1462503474,
        "creation_date": 1462346418,
        "question_id": 37020974,
        "body_markdown": "I&#39;m trying to use jq where my data has a large integer in it.  Example:\r\n\r\n\r\n    $ cat door.json\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Sliding Door 2&quot;,\r\n        &quot;type&quot;: &quot;MyAirtightSlideDoor&quot;,\r\n        &quot;id&quot;: 130597706006447927,\r\n        &quot;properties&quot;: {\r\n          &quot;OnOff&quot;: &quot;True&quot;,\r\n          &quot;ShowInTerminal&quot;: &quot;True&quot;,\r\n          &quot;ShowInToolbarConfig&quot;: &quot;True&quot;,\r\n          &quot;ShowOnHUD&quot;: &quot;False&quot;,\r\n          &quot;Open&quot;: &quot;True&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\nOkay, that is a valid json file, I think.  But then when I ask jq to parse it, it destroys the ID integer:\r\n\r\n    $ cat door.json | jq &#39;.&#39;\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Sliding Door 2&quot;,\r\n        &quot;type&quot;: &quot;MyAirtightSlideDoor&quot;,\r\n        &quot;id&quot;: 130597706006447920,\r\n        &quot;properties&quot;: {\r\n          &quot;OnOff&quot;: &quot;True&quot;,\r\n          &quot;ShowInTerminal&quot;: &quot;True&quot;,\r\n          &quot;ShowInToolbarConfig&quot;: &quot;True&quot;,\r\n          &quot;ShowOnHUD&quot;: &quot;False&quot;,\r\n          &quot;Open&quot;: &quot;True&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\nMy end goal is to be able to get id out and use it to query deeper into an API, but 130597706006447920 != 130597706006447927.  \r\n\r\nI tested this with the 64 bit binary for versions 1.5, 1.4, and 1.3 on a centos 7 x86_64 AWS instance. \r\n\r\nAny input would be awesome.  ",
        "link": "https://stackoverflow.com/questions/37020974/jq-rounding-large-integers-when-it-shouldnt",
        "title": "jq rounding large integers when it shouldn&#39;t"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1462494382,
                "post_id": 37040055,
                "comment_id": 61671495,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1462425193,
                "last_edit_date": 1462425193,
                "creation_date": 1462424532,
                "answer_id": 37042735,
                "question_id": 37040055,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use this:\r\n\r\n    IFS=$&#39;\\n&#39; read -d &#39;&#39; -a titles &lt; &lt;(jq -r &#39;.[] | select (.link[0]!=null) | .title[0]&#39; items.json);\r\n    IFS=$&#39;\\n&#39; read -d &#39;&#39; -a links  &lt; &lt;(jq -r &#39;.[] | select (.link[0]!=null) | .link[0]&#39; items.json);\r\n\r\n\r\n\r\n\r\nThen you can iterate over arrays `&quot;${title[@]}&quot;` &amp; `${links[@]}`...\r\n\r\n    for i in ${!titles[@]}; do\r\n        wget -O &quot;${titles[i]}&quot; &quot;${links[@]}&quot;\r\n    done\r\n\r\n\r\n\r\nEDIT: Easier &amp; safer approach:\r\n\r\n    jq -r &#39;.[] | select (.link[0]!=null) | @sh &quot;wget -O \\(.title[0]) \\(.link[0])&quot;&#39; items.json | bash",
                "title": "Selection of multiple json keys using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503770455,
                "creation_date": 1503770455,
                "answer_id": 45898269,
                "question_id": 37040055,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a bash script demonstrating reading the result of a jq filter into bash variables.\r\n\r\n    #!/bin/bash\r\n    jq -M -r &#39;\r\n        .[] \r\n      | select(.link[0]!=null) \r\n      | .title[0], .link[0]\r\n    &#39; items.json | \\\r\n    while read -r title; read -r url; do\r\n        echo &quot;$title: $url&quot; # replace with wget command\r\n    done\r\n ",
                "title": "Selection of multiple json keys using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1503770455,
        "creation_date": 1462406103,
        "question_id": 37040055,
        "body_markdown": "As a newbee to bash and jq, I was trying to download several urls from a json file using jq command in bash scripts.\r\n\r\nMy items.json file looks like this : \r\n\r\n    ［\r\n       {&quot;title&quot; : [bob], &quot;link&quot; :[a.b.c]}, \r\n       {&quot;title&quot; : [alice], &quot;link&quot; :[d.e.f]}, \r\n       {&quot;title&quot; : [carol], &quot;link&quot; :[]} \r\n     ]\r\n\r\nwhat I was initially doing was just filter the non-empty link and put them in an array and then download the array:\r\n\r\n    #!/bin/bash\r\n    lnk=( $(jq -r &#39;.[].link[0] | select (.!=null)&#39; items.json) )\r\n    for element in ${lnk[@]}\r\n    do\r\n\t    wget $element\r\n    done\r\n\r\nBut the problem of this approach is that all the files downloaded use the link as the file names.\r\n\r\nI wish to filter json file but still keeps the title name with the link so that i can rename the file in the wget command. But I dont have any idea on what structure should I use here. So how can i keep the title to in the filter and use it after?\r\n",
        "link": "https://stackoverflow.com/questions/37040055/selection-of-multiple-json-keys-using-jq",
        "title": "Selection of multiple json keys using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1462415699,
                "post_id": 37041324,
                "comment_id": 61632149,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4537008,
                    "reputation": 103,
                    "user_id": 3685928,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/945aebb8de978fbd560d55086cb9379c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3685928",
                    "link": "https://stackoverflow.com/users/3685928/user3685928"
                },
                "reply_to_user": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1462418640,
                "post_id": 37041324,
                "comment_id": 61632793,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1462416372,
                "creation_date": 1462416372,
                "answer_id": 37041457,
                "question_id": 37041324,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try the following:\r\n\r\n    ID=$(echo &quot;${CLUSTER}&quot; | sed &#39;s/{ &quot;ClusterId&quot;: &quot;//&#39; | sed &#39;s/&quot; }//&#39;)\r\n\r\nThat will isolate `j-9YWMBYN98LN7`, or whatever is between the last set of quotes, into the variable `$ID`.\r\n\r\nI get the feeling there is more to what you need as you are probably planning on using the contents of `$ID` for something and there may be more efficient ways to capture that value for you. Maybe if you can explain a bit more how you plan on using the value we can provide even more actionable answers.\r\n",
                "title": "Extract value of json-like variable in bash"
            },
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1462827527,
                "last_edit_date": 1462827527,
                "creation_date": 1462416417,
                "answer_id": 37041465,
                "question_id": 37041324,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If\r\n\r\n    echo $CLUSTER\r\n\r\ngives you\r\n\r\n    { &quot;ClusterId&quot;: &quot;j-9YWMBYN98LN7&quot; }\r\n\r\nthen\r\n\r\n    ID=$(awk  &#39;BEGIN{FS=&quot;\\&quot;&quot;}{print $4}&#39; &lt;&lt;&lt; &quot;${CLUSTER}&quot;)\r\n\r\nshould do it.\r\n\r\n    echo &quot;$ID&quot;\r\n    j-9YWMBYN98LN7\r\n\r\n\r\n\r\n\r\n",
                "title": "Extract value of json-like variable in bash"
            },
            {
                "up_vote_count": 14,
                "is_accepted": false,
                "score": 13,
                "last_activity_date": 1462419658,
                "last_edit_date": 1462419658,
                "creation_date": 1462416761,
                "answer_id": 37041521,
                "question_id": 37041324,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you want to use `jq`, you can do it this way\r\n\r\n     ID=`echo ${CLUSTER} | jq -r &#39;.ClusterId&#39;`",
                "title": "Extract value of json-like variable in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1462827527,
        "creation_date": 1462415348,
        "question_id": 37041324,
        "body_markdown": "I have a variable in bash that is an output of Amazon EMR create command;\r\n\r\n    CLUSTER=$(aws emr create-cluster ...)\r\n    echo $CLUSTER\r\n\r\nthe output is like this:\r\n\r\n    { &quot;ClusterId&quot;: &quot;j-9YWMBYN98LN7&quot; }\r\n\r\nWhat I need to do is to extract the value `j-9YWMBYN98LN7` to a new variable, something like:\r\n\r\n    ID=$CLUSTER.(ClusterId)\r\n\r\nOf course the above command doesn&#39;t work. I have tried with jq but no luck.\r\n\r\n    ID=$(jq -r &#39;.ClusterId&#39; $CLUSTER)\r\n\r\n The thing is I&#39;m not even sure what type $CLUSTER is. How do I extract the value `j-9YWMBYN98LN7` there? Thanks",
        "link": "https://stackoverflow.com/questions/37041324/extract-value-of-json-like-variable-in-bash",
        "title": "Extract value of json-like variable in bash"
    },
    {
        "tags": [
            "json",
            "parsing",
            "scripting",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1463021526,
                "last_edit_date": 1463021526,
                "creation_date": 1462985231,
                "answer_id": 37168763,
                "question_id": 37167676,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A naive approach would just collect all the keys and get the unique values.\r\n\r\n    [.. | objects | keys[]] | unique\r\n\r\nBut with that data, it&#39;s a bit on the slow side since the keys need to be collected and sorted.\r\n\r\nWe could do a little better with this. Since we&#39;re trying to determine all the distinct keys, we&#39;d use a hashmap of some sort to be more efficient. Well, we have objects that can act as such.\r\n\r\n    reduce (.. | objects | keys[]) as $k ({}; .[$k] = true) | keys\r\n\r\nI didn&#39;t measure the time on this but it&#39;s magnitudes faster than the other version.  I didn&#39;t even wait for the other to finish, this one was well within 10 seconds on my work machine (i5-2400@3.1GHz).",
                "title": "Extract all unique keys from arbitrarily nested json data with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1463041232,
                "creation_date": 1463041232,
                "answer_id": 37181169,
                "question_id": 37167676,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I think you&#39;ll find the following variant of the OP&#39;s all_keys is actually slightly faster than the version using `..`; this is probably to be expected -- for jeopardy.json, `..` generates altogether 1,731,807 JSON entities whereas there are only 216,930 JSON objects:\r\n\r\n    def all_keys:\r\n      def uniquely(f): reduce f as $x ({}; .[$x] = true) | keys;\r\n      def rkeys:\r\n        if type == &quot;object&quot; then keys[] as $k | ($k, (.[$k]|rkeys))\r\n        elif type == &quot;array&quot; then .[]|rkeys\r\n        else empty\r\n        end;\r\n      uniquely(rkeys);\r\n",
                "title": "Extract all unique keys from arbitrarily nested json data with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1463041232,
        "creation_date": 1462981992,
        "last_edit_date": 1462985187,
        "question_id": 37167676,
        "body_markdown": "As the subject states, my goal is to write an `all_keys` function to extract all keys from an arbitrarily nested json blob, traversing contained arrays and objects as needed, and outputting an array containing the keys, without duplicates.\r\n\r\nFor instance, given the following input:\r\n\r\n    [\r\n        {&quot;name&quot;: &quot;/&quot;, &quot;children&quot;: [\r\n          {&quot;name&quot;: &quot;/bin&quot;, &quot;children&quot;: [\r\n            {&quot;name&quot;: &quot;/bin/ls&quot;, &quot;children&quot;: []},\r\n            {&quot;name&quot;: &quot;/bin/sh&quot;, &quot;children&quot;: []}]},\r\n          {&quot;name&quot;: &quot;/home&quot;, &quot;children&quot;: [\r\n            {&quot;name&quot;: &quot;/home/stephen&quot;, &quot;children&quot;: [\r\n              {&quot;name&quot;: &quot;/home/stephen/jq&quot;, &quot;children&quot;: []}]}]}]},\r\n        {&quot;name&quot;: &quot;/&quot;, &quot;children&quot;: [\r\n          {&quot;name&quot;: &quot;/bin&quot;, &quot;children&quot;: [\r\n            {&quot;name&quot;: &quot;/bin/ls&quot;, &quot;children&quot;: []},\r\n            {&quot;name&quot;: &quot;/bin/sh&quot;, &quot;children&quot;: []}]},\r\n          {&quot;name&quot;: &quot;/home&quot;, &quot;children&quot;: [\r\n            {&quot;name&quot;: &quot;/home/stephen&quot;, &quot;children&quot;: [\r\n              {&quot;name&quot;: &quot;/home/stephen/jq&quot;, &quot;children&quot;: []}]}]}]}      \r\n    ]\r\n\r\nThe `all_keys` fuction should produce this output:\r\n\r\n    [\r\n      &quot;children&quot;,\r\n      &quot;name&quot;\r\n    ]\r\n\r\n\r\n\r\nTo this end, I devised the following function, but it&#39;s as slow as it is convoluted, so I was wondering whether you could come up with a more concise and faster way of obtaining the same result.\r\n\r\n\r\n    def all_keys: \r\n        . as $in |\r\n        if type == &quot;object&quot; then \r\n            reduce keys[] as $k (\r\n                [];\r\n                . + [$k, ($in[$k] | all_keys)[]]\r\n            ) | unique\r\n        elif type == &quot;array&quot; then (\r\n            reduce .[] as $i (\r\n                [];\r\n                . + ($i | all_keys)\r\n            ) | unique\r\n        ) \r\n        else\r\n            empty\r\n        end\r\n    ;\r\n\r\nFor reference, running that function on [this 53MB json file](https://github.com/nlohmann/json/blob/develop/benchmarks/files/jeopardy/jeopardy.json) takes roughly 22 seconds on my Intel T9300@2.50GHz CPU (I know, it&#39;s quite ancient but still works fine).\r\n",
        "link": "https://stackoverflow.com/questions/37167676/extract-all-unique-keys-from-arbitrarily-nested-json-data-with-jq",
        "title": "Extract all unique keys from arbitrarily nested json data with jq"
    },
    {
        "tags": [
            "regex",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 262968,
                    "reputation": 789094,
                    "user_id": 548225,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/dab08478b226280d4a30894c9a7ed719?s=256&d=identicon&r=PG",
                    "display_name": "anubhava",
                    "link": "https://stackoverflow.com/users/548225/anubhava"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1463673595,
                "post_id": 37328327,
                "comment_id": 62176003,
                "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": 262968,
                    "reputation": 789094,
                    "user_id": 548225,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/dab08478b226280d4a30894c9a7ed719?s=256&d=identicon&r=PG",
                    "display_name": "anubhava",
                    "link": "https://stackoverflow.com/users/548225/anubhava"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1463674268,
                "post_id": 37328327,
                "comment_id": 62176436,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1463674537,
                "last_edit_date": 1463674537,
                "creation_date": 1463674472,
                "answer_id": 37328806,
                "question_id": 37328327,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In your BASH script you can take output of `jq` and use BASH string manipulation:\r\n\r\n    s=&#39;arn:aws:ecs:eu-west-1:foo:task/blablabla&#39;\r\n    r=&quot;${s##*task/}&quot;\r\n    \r\n    # check output\r\n    echo &quot;$r&quot;\r\n    blablabla\r\n\r\n`${s##*task/}` will remove longest part upto `task/` from start.\r\n\r\nOr you can use `sed`:\r\n\r\n    jq &#39;.selector&#39; | sed &#39;s~.*task/~~&#39;",
                "title": "Apply regex on JQ"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1463675542,
                "creation_date": 1463675542,
                "answer_id": 37329163,
                "question_id": 37328327,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    json_string=&#39;&quot;arn:aws:ecs:eu-west-1:foo:task/blablabla&quot;&#39;\r\n    jq &#39;match(&quot;^(.*task?)\\/(.*$)&quot;, .) | .captures[1].string | select(.)&#39; &lt;&lt;&lt;&quot;$json_string&quot;\r\n\r\n...emits as output:\r\n\r\n    &quot;blablabla&quot;\r\n\r\nTo emit that as a raw string, without the literal quotes, use the `-r` argument to `jq`.",
                "title": "Apply regex on JQ"
            },
            {
                "up_vote_count": 16,
                "is_accepted": true,
                "score": 16,
                "last_activity_date": 1463675610,
                "creation_date": 1463675610,
                "answer_id": 37329187,
                "question_id": 37328327,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "On jq 1.5, you can pass the regex to `match` and then get the `string` property of `captures`&#39; second element.\r\n\r\n    jq &#39;match(&quot;(.*task?)\\/(.*$)&quot;).captures[1].string&#39;\r\n\r\n",
                "title": "Apply regex on JQ"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1463690848,
                "creation_date": 1463690848,
                "answer_id": 37333733,
                "question_id": 37328327,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Why not just use `sub/2`?  For example (in line with the OP&#39;s regex):\r\n\r\n    $ jq -r &#39;sub(&quot;.*task/&quot;; &quot;&quot;)&#39; &lt;&lt;&lt; &#39;&quot;arn:aws:ecs:eu-west-1:foo:task/blablabla&quot;&#39;\r\n    blablabla\r\n\r\nIt may be better to handle the case where the input string does not contain &quot;:task/&quot;, e.g. filtering using `test/1`:\r\n\r\n    select(test(&quot;:task/&quot;)) | sub( &quot;.*:task/&quot;; &quot;&quot;)\r\n\r\nConsider also using a named-capture group:\r\n\r\n    jq -r &#39;sub(&quot;.*:task/(?&lt;x&gt;.*)&quot;; &quot;\\(.x)&quot;)&#39; &lt;&lt;&lt; &#39;&quot;arn:aws:ecs:eu-west-1:foo:task/blablabla&quot;&#39;\r\n    blablabla\r\n\r\nEtc.",
                "title": "Apply regex on JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 18,
        "last_activity_date": 1463690848,
        "creation_date": 1463673097,
        "last_edit_date": 1463675120,
        "question_id": 37328327,
        "body_markdown": "I&#180;m using jq to get a json and get some values.\r\n\r\nI have this string \r\n\r\n\r\n       &quot;arn:aws:ecs:eu-west-1:foo:task/blablabla&quot;\r\nAnd I want to get the substring from task/ and then return just blablabla\r\n\r\nFor now I have this regex.\r\n\r\n     (.*task?)\\/(.*$)\r\n\r\nWhich give me two groups.\r\n\r\nAny idea how using jq I can apply this regex and get the second group?\r\n\r\nRegards",
        "link": "https://stackoverflow.com/questions/37328327/apply-regex-on-jq",
        "title": "Apply regex on JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 187,
                "is_accepted": true,
                "score": 186,
                "last_activity_date": 1592609695,
                "last_edit_date": 1592609695,
                "creation_date": 1463740660,
                "answer_id": 37344498,
                "question_id": 37344329,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to enclose in brackets and double quotes:\r\n\r\n    jq &#39;.&quot;component-status&quot;&#39;\r\n\r\nWith your given input it returns:\r\n\r\n    [\r\n      {\r\n        &quot;status&quot;: &quot;OK&quot;,\r\n        &quot;component&quot;: &quot;Service1&quot;,\r\n        &quot;status-code&quot;: 200\r\n      },\r\n      {\r\n        &quot;status&quot;: &quot;OK&quot;,\r\n        &quot;component&quot;: &quot;Service2&quot;,\r\n        &quot;status-code&quot;: 200\r\n      }\r\n    ]\r\n\r\nThe [jq Manual (development) --&gt; Basic filters][1]:\r\n\r\n&gt;     .foo, .foo.bar\r\n&gt; \r\n&gt; The simplest useful filter is `.foo`. When given a JSON object (aka\r\n&gt; dictionary or hash) as input, it produces the value at the key “foo”,\r\n&gt; or null if there’s none present.\r\n&gt; \r\n&gt; If the key contains special characters, you need to surround it with\r\n&gt; double quotes like this: `.&quot;foo$&quot;`.\r\n\r\nFrom the github issue [Cannot select field if field name has dashes][2]:\r\n\r\n\r\n&gt; Currently, that gets parsed as a subtraction. You can always\r\n&gt; explicitly use strings for when your keys don&#39;t fit identifier syntax.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Basicfilters\r\n  [2]: https://github.com/stedolan/jq/issues/38#issuecomment-9770240",
                "title": "jq not working on tag name with dashes and numbers"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1625592792,
                "last_edit_date": 1625592792,
                "creation_date": 1625528272,
                "answer_id": 68263020,
                "question_id": 37344329,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The [option suggested by rjurney][1] or the commenters to his answers did not work for me (probably because I used PowerShell), however in [the answer from github issue][2] there was a solution, which did the trick - escaping double quotation marks with \\\r\n\r\n    jq &#39;.\\&quot;component-status\\&quot;&#39;\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/37344329/jq-not-working-on-tag-name-with-dashes-and-numbers/37344498#37344498\r\n  [2]: https://github.com/stedolan/jq/issues/38#issuecomment-65294088",
                "title": "jq not working on tag name with dashes and numbers"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 97,
        "last_activity_date": 1661415046,
        "creation_date": 1463740174,
        "last_edit_date": 1661415046,
        "question_id": 37344329,
        "body_markdown": "I am using `jq` but having &quot;-&quot; in my json tag make `jq` not compile. I cannot escape it to make it works. Here is the command:\r\n\r\n\r\n```shell\r\ncurl -X GET -H &quot;X-AppKey:foo&quot; &quot;foo/v2/_status&quot; | jq &#39;.component-status[]&#39;\r\n```\r\n\r\nI have read in the github of `jq` this post https://github.com/stedolan/jq/issues/202 but I cannot make it work. \r\n\r\nThis is the output of the `curl`:\r\n\r\n    {\r\n      &quot;status&quot;: &quot;ok&quot;,\r\n      &quot;hostname&quot;: &quot;0b0b495a46db&quot;,\r\n      &quot;component-status&quot;: [\r\n       {\r\n         &quot;status-code&quot;: 200,\r\n         &quot;component&quot;: &quot;Service1&quot;,\r\n         &quot;status&quot;: &quot;OK&quot;\r\n       },\r\n       {\r\n         &quot;status-code&quot;: 200,\r\n         &quot;component&quot;: &quot;Service2&quot;,\r\n         &quot;status&quot;: &quot;OK&quot;\r\n       }\r\n      ]\r\n     }\r\n\r\nAny idea?",
        "link": "https://stackoverflow.com/questions/37344329/jq-not-working-on-tag-name-with-dashes-and-numbers",
        "title": "jq not working on tag name with dashes and numbers"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1463762279,
                "last_edit_date": 1463762279,
                "creation_date": 1463757616,
                "answer_id": 37350184,
                "question_id": 37348865,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You&#39;ll have to escape the newline characters. They are valid JSON characters so it won&#39;t be treated differently.\r\n\r\n    [.a, .b] | map(sub(&quot;\\n&quot;; &quot;\\\\n&quot;)) | @csv\r\n\r\nThis would give you\r\n\r\n    &quot;She said: &quot;&quot;Yes!&quot;&quot;\\n&quot;,&quot;We said: &quot;&quot;Hello!&quot;&quot;\\n&quot;\r\n\r\nNote that the inner quotes are doubled, that&#39;s how you escape double quotes within a CSV line. It is not escaped using backslashes.\r\n\r\nIn case there are multiple `\\n` symbols then using `gsub` instead of `sub` will do the trick.",
                "title": "jq - raw output without evaluating new line character"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1463757692,
                "last_edit_date": 1495542239,
                "creation_date": 1463757692,
                "answer_id": 37350210,
                "question_id": 37348865,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Based on the answer to a related question (https://stackoverflow.com/questions/32125603/processing-json-array-with-jq-and-quoted-values?rq=1), I can do the following:\r\n\r\n     while read -r a; read -r b; do echo &quot;$a,$b&quot;; done &lt; &lt;(jq -c &#39;.&#39;a,.b test.txt)\r\n\r\nThis gives:\r\n\r\n&gt;    &quot;She said: \\&quot;Yes!\\&quot;\\n&quot;,&quot;We said: \\&quot;Hello!\\&quot;\\n&quot;\r\n\r\nThis is not very general, though, since it must be adjusted to fit the number of fields.\r\n",
                "title": "jq - raw output without evaluating new line character"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1463762279,
        "creation_date": 1463753288,
        "last_edit_date": 1463753635,
        "question_id": 37348865,
        "body_markdown": "The json files that I am processing contain newline characters `\\n` in the value fields. For example:\r\n    {\r\n      &quot;a&quot;: &quot;b\\n&quot;\r\n    }\r\n\r\n I am trying to generate csv files that contain output, which includes such values. However, when I try `jq -r &#39;[.a]|@csv&#39;`, I get:\r\n\r\n    &quot;b\r\n    &quot;\r\nThe `\\n` character is evaluated. I believe this is how `-r` option is intended to work, so I tried the output without it,`jq &#39;[.a]|@csv&#39;`, and I get:\r\n\r\n    &quot;\\&quot;b\\n\\&quot;&quot;\r\n\r\nThis is closer to what I want, but the output is quoted and csv-quotes are escaped. My desired output is:\r\n\r\n&gt;&quot;b\\n&quot;\r\n\r\n\r\n\r\nThis becomes troublesome on my actual files, because my csv output contains values with double quotes.\r\n\r\nFor example:\r\n\r\n    {\r\n      &quot;a&quot;: &quot;She said: \\&quot;Yes!\\&quot;\\n&quot;,\r\n      &quot;b&quot;: &quot;We said: \\&quot;Hello!\\&quot;\\n&quot;\r\n    }\r\n\r\nMy desired output in this case is:\r\n\r\n&gt;    &quot;She said: \\&quot;Yes!\\&quot;\\n&quot;,&quot;We said: \\&quot;Hello!\\&quot;\\n&quot;",
        "link": "https://stackoverflow.com/questions/37348865/jq-raw-output-without-evaluating-new-line-character",
        "title": "jq - raw output without evaluating new line character"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1463773903,
                "creation_date": 1463773903,
                "answer_id": 37354804,
                "question_id": 37353918,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following is illustrative of what can be done if your version of jq supports &quot;--argjson&quot;.  Similar things can be done with `--arg` and `--argfile`.\r\n\r\n    #!/bin/bash\r\n    \r\n    function bigblob {\r\n    cat &lt;&lt;EOF \r\n    big blob of text\r\n    EOF\r\n    }\r\n    \r\n    item=&#39;{&quot;a&quot;: &quot;a&quot;}&#39;\r\n    \r\n    bigblob | jq -R --argjson item &quot;$item&quot; &#39;$item + {&quot;readme&quot;: .}&#39;\r\n\r\nResult:\r\n\r\n    {\r\n      &quot;a&quot;: &quot;a&quot;,\r\n      &quot;readme&quot;: &quot;big blob of text&quot;\r\n    }\r\n\r\n",
                "title": "jq add large value to existing json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1504636148,
        "creation_date": 1463770291,
        "last_edit_date": 1504636148,
        "question_id": 37353918,
        "body_markdown": "I have a large existing json object and I&#39;d like to add a new key/value to the object where the value can be very large (many K).\r\n\r\nUsing jq I can do something like this:\r\n\r\n`echo $item | jq &#39;. + {readme:&quot;big blob of text&quot;}&#39;`\r\n\r\nIs there a good way to replace `big blob of text` with a shell or jq variable?",
        "link": "https://stackoverflow.com/questions/37353918/jq-add-large-value-to-existing-json",
        "title": "jq add large value to existing json"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1464022443,
                "creation_date": 1464022443,
                "answer_id": 37396517,
                "question_id": 37396184,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If they&#39;re simply arrays of arrays of the objects you&#39;re interested in, you can flatten it down to just the objects by traversing each of the arrays.  Then get the properties you want.\r\n\r\n    .[][] | { State, Env, Name }",
                "title": "Extracting objects using JQ for a nested json file with no named attributes"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1464023756,
                "creation_date": 1464023756,
                "answer_id": 37396869,
                "question_id": 37396184,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you want the three attributes for all objects that have any of them, no matter where the objects occur, you can use `..`.  E.g., for the given input,\r\n\r\n    jq &#39;.. | objects | select(has(&quot;State&quot;) or has(&quot;Env&quot;) or has(&quot;Name&quot;)) | {State, Env, Name}&#39; \r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;State&quot;: &quot;running&quot;,\r\n      &quot;Env&quot;: [\r\n        &quot;prd&quot;\r\n      ],\r\n      &quot;Name&quot;: [\r\n        &quot;some url here&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;State&quot;: &quot;stopped&quot;,\r\n      &quot;Env&quot;: [\r\n        &quot;prd&quot;\r\n      ],\r\n      &quot;Name&quot;: [\r\n        &quot;some url here&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;State&quot;: &quot;running&quot;,\r\n      &quot;Env&quot;: [\r\n        &quot;prd&quot;\r\n      ],\r\n      &quot;Name&quot;: [\r\n        &quot;some url here&quot;\r\n      ]\r\n    }\r\n",
                "title": "Extracting objects using JQ for a nested json file with no named attributes"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1464023756,
        "creation_date": 1464021320,
        "last_edit_date": 1464021676,
        "question_id": 37396184,
        "body_markdown": "I have a generated file (from amazon CLI) and wish to pull out some of the attributes.  Normally this would be simple with JQ, however the JSON file has no named top level attributes. \r\n\r\n    [\r\n        [\r\n            {\r\n                &quot;State&quot;: &quot;running&quot;, \r\n                &quot;Type&quot;: &quot;c4.xlarge&quot;, \r\n                &quot;ID&quot;: &quot;i-somehere&quot;, \r\n                &quot;Env&quot;: [\r\n                    &quot;prd&quot;\r\n                ], \r\n                &quot;Name&quot;: [\r\n                    &quot;some url here&quot;\r\n                ]\r\n            }\r\n        ],\r\n        [\r\n            {\r\n                &quot;State&quot;: &quot;stopped&quot;, \r\n                &quot;Type&quot;: &quot;c4.xlarge&quot;, \r\n                &quot;ID&quot;: &quot;i-somehere&quot;, \r\n                &quot;Env&quot;: [\r\n                    &quot;prd&quot;\r\n                ], \r\n                &quot;Name&quot;: [\r\n                    &quot;some url here&quot;\r\n                ]\r\n            }\r\n        ], \r\n    [\r\n            {\r\n                &quot;State&quot;: &quot;running&quot;, \r\n                &quot;Type&quot;: &quot;c4.2xlarge&quot;, \r\n                &quot;ID&quot;: &quot;i-somehere&quot;, \r\n                &quot;Env&quot;: [\r\n                    &quot;prd&quot;\r\n                ], \r\n                &quot;Name&quot;: [\r\n                    &quot;some url here&quot;\r\n                ]\r\n            }\r\n        ]\r\n    ]\r\n\r\n..... I would like to extract the state, Env and Name .... this should be simple   jq &quot;.[].State&quot;   ... however the State is nested in an object which isn&#39;t named.  How can I extract with JQ?  \r\n",
        "link": "https://stackoverflow.com/questions/37396184/extracting-objects-using-jq-for-a-nested-json-file-with-no-named-attributes",
        "title": "Extracting objects using JQ for a nested json file with no named attributes"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316578,
                    "reputation": 4611,
                    "user_id": 632827,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://i.sstatic.net/nkmeD.png?s=256",
                    "display_name": "AXE Labs",
                    "link": "https://stackoverflow.com/users/632827/axe-labs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1464364591,
                "post_id": 37487740,
                "comment_id": 62471915,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1464367877,
                "creation_date": 1464367877,
                "answer_id": 37488711,
                "question_id": 37487740,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Convert the object to entries first then generate the strings.  Just make sure you get the raw output.\r\n\r\n    $ ... | jq -r &#39;.thing | to_entries[] | &quot;\\(.key | tojson): \\(.value)&quot;&#39;",
                "title": "How to get the raw content of a hash with jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1501978502,
                "creation_date": 1501978502,
                "answer_id": 45527476,
                "question_id": 37487740,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that uses `-r` and **keys_unsorted**:\r\n\r\n    $ echo &#39;{&quot;thing&quot;:{&quot;one&quot;:1,&quot;two&quot;:2,&quot;three&quot;:3}}&#39; \\\r\n    | jq -r &#39;.thing | keys_unsorted[] as $k | &quot;\\&quot;\\($k)\\&quot;: \\(.[$k])&quot;&#39;\r\n\r\nwhich produces the following output:\r\n\r\n    &quot;one&quot;: 1\r\n    &quot;two&quot;: 2\r\n    &quot;three&quot;: 3\r\n",
                "title": "How to get the raw content of a hash with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1501978502,
        "creation_date": 1464364408,
        "question_id": 37487740,
        "body_markdown": "\r\n\r\nGiven the following:\r\n\r\n    &gt; echo &#39;{&quot;thing&quot;:{&quot;one&quot;:1,&quot;two&quot;:2,&quot;three&quot;:3}}&#39;|jq .thing\r\n    {\r\n      &quot;one&quot;: 1,\r\n      &quot;two&quot;: 2,\r\n      &quot;three&quot;: 3\r\n    }\r\nHow do I get the command to output that?\r\n\r\n    &quot;one&quot;: 1\r\n    &quot;two&quot;: 2\r\n    &quot;three&quot;: 3",
        "link": "https://stackoverflow.com/questions/37487740/how-to-get-the-raw-content-of-a-hash-with-jq",
        "title": "How to get the raw content of a hash with jq?"
    },
    {
        "tags": [
            "linux",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1464456930,
                "last_edit_date": 1464456930,
                "creation_date": 1464453439,
                "answer_id": 37501445,
                "question_id": 37501404,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Filter it out first, then get the first (assuming it&#39;s sorted with most recent first).\r\n\r\n    jq &#39;map(select(.name != &quot;yarv_migration_base&quot; and\r\n            (.name | contains(&quot;preview&quot;) | not)\r\n        ))[0].tarball_url&#39; ruby.json",
                "title": "Excluding unwanted names from json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1464457196,
        "creation_date": 1464453138,
        "last_edit_date": 1464457196,
        "question_id": 37501404,
        "body_markdown": "Suppose I curl a json file, like so: ` curl https://api.github.com/repos/ruby/ruby/tags -o ruby.json`\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;yarv_migration_base&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/yarv_migration_base&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/yarv_migration_base&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;20c8803697df39a086175a5eb2f8e8ee00bf1e2f&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/20c8803697df39a086175a5eb2f8e8ee00bf1e2f&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_3_1&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_3_1&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_3_1&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;5827d8e887d881eb3a6e6ea7410590261c90545f&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/5827d8e887d881eb3a6e6ea7410590261c90545f&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_3_0&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_3_0&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_3_0&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;a837be87fdf580ac4fd58c4cb2f1ee16bab11b99&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/a837be87fdf580ac4fd58c4cb2f1ee16bab11b99&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_3_0_preview2&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_3_0_preview2&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_3_0_preview2&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;e3434401aca2e331132652d4458366267e8cf378&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/e3434401aca2e331132652d4458366267e8cf378&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_3_0_preview1&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_3_0_preview1&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_3_0_preview1&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;9993701c7d3d83e24699177fef3238d8bf7bbbab&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/9993701c7d3d83e24699177fef3238d8bf7bbbab&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_2_5&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_2_5&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_2_5&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;449169fd8cfe4253381c40f595097ed50932bdae&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/449169fd8cfe4253381c40f595097ed50932bdae&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_2_4&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_2_4&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_2_4&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;9081c2c61ac9f7f9bdcbf054f33b2dc42740e85f&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/9081c2c61ac9f7f9bdcbf054f33b2dc42740e85f&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_2_3&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_2_3&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_2_3&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;acaf2ee762b08a4ccb23fef46cd93da1616d4d32&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/acaf2ee762b08a4ccb23fef46cd93da1616d4d32&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_2_2&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_2_2&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_2_2&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;a9721a259665149b1b9ff0beabcf5f8dc0136120&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/a9721a259665149b1b9ff0beabcf5f8dc0136120&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_2_1&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_2_1&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_2_1&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;10bc9b85cba61af65dea858a2952ae04126a5d4d&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/10bc9b85cba61af65dea858a2952ae04126a5d4d&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_2_0&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_2_0&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_2_0&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;7393bf6a5cfff63683f36535e293caaa0d4c5be0&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/7393bf6a5cfff63683f36535e293caaa0d4c5be0&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_2_0_rc1&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_2_0_rc1&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_2_0_rc1&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;050b43acced48e2699f4c57df65e207da4f0aa5a&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/050b43acced48e2699f4c57df65e207da4f0aa5a&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_2_0_preview2&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_2_0_preview2&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_2_0_preview2&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;2e968a23387c3255379a9bf91f3ecdafb01d940d&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/2e968a23387c3255379a9bf91f3ecdafb01d940d&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_2_0_preview1&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_2_0_preview1&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_2_0_preview1&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;ac98aa3101ae3cf09c3bb318e22b72404150f106&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/ac98aa3101ae3cf09c3bb318e22b72404150f106&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_1_10&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_1_10&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_1_10&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;410b031acb0b85e86564cc5d6fdde57b1251505f&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/410b031acb0b85e86564cc5d6fdde57b1251505f&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_1_9&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_1_9&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_1_9&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;22b2eface036901d27bfd9a22057427e4cce5f06&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/22b2eface036901d27bfd9a22057427e4cce5f06&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_1_8&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_1_8&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_1_8&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;4876b9a68c6d04717c35c01b071e88eaf09a0bf7&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/4876b9a68c6d04717c35c01b071e88eaf09a0bf7&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_1_7&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_1_7&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_1_7&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;0f664738e9a1219767ab0d0d168902977305a61d&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/0f664738e9a1219767ab0d0d168902977305a61d&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_1_6&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_1_6&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_1_6&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;fe8cc13685a847f5b4b687d9edb88f5bee58fd70&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/fe8cc13685a847f5b4b687d9edb88f5bee58fd70&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_1_5&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_1_5&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_1_5&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;0d74082eced0254a30b8f09a4d65fff357fdc6cd&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/0d74082eced0254a30b8f09a4d65fff357fdc6cd&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_1_4&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_1_4&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_1_4&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;e966a41ca690a82114719d9cae85c7f12c954ac6&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/e966a41ca690a82114719d9cae85c7f12c954ac6&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_1_3&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_1_3&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_1_3&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;4cb2998f59939a8f275ea74079a4538f721a24ad&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/4cb2998f59939a8f275ea74079a4538f721a24ad&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_1_2&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_1_2&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_1_2&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;e9dce8d1b482200685996f64cc2c3bd6ba790110&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/e9dce8d1b482200685996f64cc2c3bd6ba790110&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_1_1&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_1_1&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_1_1&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;1980b4d4e4cc1dfd7f04d88c03e9f0a60dd4e94e&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/1980b4d4e4cc1dfd7f04d88c03e9f0a60dd4e94e&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_1_0&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_1_0&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_1_0&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;3603063e4385c45db103d979311f689e9146383e&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/3603063e4385c45db103d979311f689e9146383e&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_1_0_rc1&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_1_0_rc1&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_1_0_rc1&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;9881a183bde20d1c174d33d8a2f637e9c092a08b&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/9881a183bde20d1c174d33d8a2f637e9c092a08b&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_1_0_preview2&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_1_0_preview2&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_1_0_preview2&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;834679d12c16cb142a8b534be137fc3e3a3c82a4&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/834679d12c16cb142a8b534be137fc3e3a3c82a4&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_1_0_preview1&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_1_0_preview1&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_1_0_preview1&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;928c4a92de2df1955a8adf2f544c7cbec11b4711&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/928c4a92de2df1955a8adf2f544c7cbec11b4711&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_0_0_648&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_0_0_648&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_0_0_648&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;03ec9ed5c93d6681bff894e566f9affe9d80a248&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/03ec9ed5c93d6681bff894e566f9affe9d80a248&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;v2_0_0_647&quot;,\r\n        &quot;zipball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/zipball/v2_0_0_647&quot;,\r\n        &quot;tarball_url&quot;: &quot;https://api.github.com/repos/ruby/ruby/tarball/v2_0_0_647&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;sha&quot;: &quot;c60c15f371a6d2f2e024ebd75ee9b3fefa7d7118&quot;,\r\n          &quot;url&quot;: &quot;https://api.github.com/repos/ruby/ruby/commits/c60c15f371a6d2f2e024ebd75ee9b3fefa7d7118&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\nI can then run `cat ruby.json | jq &#39;.[0] | .tarball_url&#39;` and get the latest tarball for Ruby. However, I&#39;d like to *not* fetch any tarballs that are previews of Ruby or contain something like `&quot;yarv_migration_base&quot;`. Is there a way to exclude data using jq?\r\n",
        "link": "https://stackoverflow.com/questions/37501404/excluding-unwanted-names-from-json-with-jq",
        "title": "Excluding unwanted names from json with jq"
    },
    {
        "tags": [
            "json",
            "elasticsearch",
            "solr",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1464887246,
                "last_edit_date": 1464887246,
                "creation_date": 1464692702,
                "answer_id": 37543974,
                "question_id": 37540717,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As it turns out, `curl -XPOST &#39;http://localhost:8983/solr/flat/update/json/docs&#39; -d @json_file` does just this:\r\n\r\n    {\r\n        &quot;a.b&quot;:[1],\r\n        &quot;id&quot;:&quot;24e3e780-3a9e-4fa7-9159-fc5294e803cd&quot;,\r\n        &quot;_version_&quot;:1535841499921514496\r\n    }\r\n\r\nEDIT 1: solr 6.0.1 with `bin/solr -e cloud`. collection name is `flat`, all the rest are default (with `data-driven-schema` which is also default).\r\n\r\nEDIT 2: The final script I used: `find . -name &#39;*.json&#39; -exec curl -XPOST &#39;http://localhost:8983/solr/collection1/update/json/docs&#39; -d @{} \\;`.\r\n\r\nEDIT 3: Is is also possible to parallel with xargs and to add the id field with jq: `find . -name &#39;*.json&#39; -print0 | xargs -0 -n 1 -P 8 -I {} sh -c &quot;cat {} | jq &#39;. + {id: .a.b}&#39; | curl -XPOST &#39;http://localhost:8983/solr/collection/update/json/docs&#39; -d @-&quot;` where `-P` is the parallelism factor. I used jq to set an id so multiple uploads of the same document won&#39;t create duplicates in the collection (when I searched for the optimal value of `-P` it created duplicates in the collection)",
                "title": "Flatten nested JSON using jq"
            },
            {
                "up_vote_count": 32,
                "is_accepted": true,
                "score": 31,
                "last_activity_date": 1695490528,
                "last_edit_date": 1695490528,
                "creation_date": 1464729985,
                "answer_id": 37555908,
                "question_id": 37540717,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also use the following jq command to flatten nested JSON objects in this manner:\r\n\r\n    [paths(values) as $path | {&quot;key&quot;: $path | join(&quot;.&quot;), &quot;value&quot;: getpath($path)}] | from_entries\r\n\r\nThe way it works is: `leaf_paths` returns a stream of arrays which represent the paths on the given JSON document at which &quot;leaf elements&quot; appear, that is, elements which do not have child elements, such as numbers, strings and booleans. We pipe that stream into objects with `key` and `value` properties, where `key` contains the elements of the path array as a string joined by dots and `value` contains the element at that path. Finally, we put the entire thing in an array and run `from_entries` on it, which transforms an array of `{key, value}` objects into an object containing those key-value pairs.",
                "title": "Flatten nested JSON using jq"
            },
            {
                "up_vote_count": 19,
                "is_accepted": false,
                "score": 19,
                "last_activity_date": 1487392794,
                "last_edit_date": 1487392794,
                "creation_date": 1464735683,
                "answer_id": 37557003,
                "question_id": 37540717,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is just a variant of Santiago&#39;s jq:\r\n\r\n    . as $in \r\n    | reduce leaf_paths as $path ({};\r\n         . + { ($path | map(tostring) | join(&quot;.&quot;)): $in | getpath($path) })\r\n\r\nIt avoids the overhead of the key/value construction and destruction.\r\n\r\n(If you have access to a version of jq later than jq 1.5, you can omit the &quot;map(tostring)&quot;.)\r\n\r\nTwo important points about both these jq solutions:\r\n\r\n1. Arrays are also flattened.\r\nE.g. given `{&quot;a&quot;: {&quot;b&quot;: [0,1,2]}}` as input, the output would be:\r\n\r\n        {\r\n          &quot;a.b.0&quot;: 0,\r\n          &quot;a.b.1&quot;: 1,\r\n          &quot;a.b.2&quot;: 2\r\n        }\r\n\r\n2. If any of the keys in the original JSON contain periods, then key collisions are possible; such collisions will generally result in the loss of a value.  This would happen, for example, with the following input:\r\n\r\n        {&quot;a.b&quot;:0, &quot;a&quot;: {&quot;b&quot;: 1}}",
                "title": "Flatten nested JSON using jq"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1501979059,
                "creation_date": 1501979059,
                "answer_id": 45527527,
                "question_id": 37540717,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that uses **tostream**, **select**, **join**, **reduce** and **setpath**\r\n\r\n      reduce ( tostream | select(length==2) | .[0] |= [join(&quot;.&quot;)] ) as [$p,$v] (\r\n         {}\r\n         ; setpath($p; $v)\r\n      )",
                "title": "Flatten nested JSON using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1620922946,
                "creation_date": 1620922946,
                "answer_id": 67522704,
                "question_id": 37540717,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;ve recently written a script called [jqg](https://github.com/NorthboundTrain/jqg) that flattens arbitrarily complex JSON and searches the results using a regex; to simply flatten the JSON, your regex would be &#39;`.`&#39;, which matches everything. Unlike the answers above, the script will handle embedded arrays, `false` and `null` values, and can optionally treat empty arrays and objects (`[]` &amp; `{}`) as leaf nodes.\r\n\r\n    $ jq . test/odd-values.json\r\n    {\r\n      &quot;one&quot;: {\r\n        &quot;start-string&quot;: &quot;foo&quot;,\r\n        &quot;null-value&quot;: null,\r\n        &quot;integer-number&quot;: 101\r\n      },\r\n      &quot;two&quot;: [\r\n        {\r\n          &quot;two-a&quot;: {\r\n            &quot;non-integer-number&quot;: 101.75,\r\n            &quot;number-zero&quot;: 0\r\n          },\r\n          &quot;true-boolean&quot;: true,\r\n          &quot;two-b&quot;: {\r\n            &quot;false-boolean&quot;: false\r\n          }\r\n        }\r\n      ],\r\n      &quot;three&quot;: {\r\n        &quot;empty-string&quot;: &quot;&quot;,\r\n        &quot;empty-object&quot;: {},\r\n        &quot;empty-array&quot;: []\r\n      },\r\n      &quot;end-string&quot;: &quot;bar&quot;\r\n    }\r\n    \r\n    $ jqg . test/odd-values.json\r\n    {\r\n      &quot;one.start-string&quot;: &quot;foo&quot;,\r\n      &quot;one.null-value&quot;: null,\r\n      &quot;one.integer-number&quot;: 101,\r\n      &quot;two.0.two-a.non-integer-number&quot;: 101.75,\r\n      &quot;two.0.two-a.number-zero&quot;: 0,\r\n      &quot;two.0.true-boolean&quot;: true,\r\n      &quot;two.0.two-b.false-boolean&quot;: false,\r\n      &quot;three.empty-string&quot;: &quot;&quot;,\r\n      &quot;three.empty-object&quot;: {},\r\n      &quot;three.empty-array&quot;: [],\r\n      &quot;end-string&quot;: &quot;bar&quot;\r\n    }\r\n\r\n`jqg` was tested using jq 1.6\r\n\r\n**Note:** I am the author of the `jqg` script.",
                "title": "Flatten nested JSON using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1676628742,
                "creation_date": 1676628742,
                "answer_id": 75482876,
                "question_id": 37540717,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As @hraban mentioned, `leaf_paths` does not work as expected (furthermore, it is deprecated). `leaf_paths` is equivalent to `paths(scalars)`, it returns the paths of any values for which `scalars` returns a truthy value. `scalars` returns its input value if it is a scalar, or `null` otherwise. The problem with that is that `null` and `false` are not truthy values, so they will be removed from the output. The following code _does_ work, by checking the type of the values directly:\r\n\r\n    . as $in\r\n         | reduce paths(type != &quot;object&quot; and type != &quot;array&quot;) as $path ({};\r\n              . + { ($path | map(tostring) | join(&quot;.&quot;)): $in | getpath($path) })\r\n",
                "title": "Flatten nested JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 20,
        "last_activity_date": 1695490528,
        "creation_date": 1464683686,
        "last_edit_date": 1548098625,
        "question_id": 37540717,
        "body_markdown": "I&#39;d like to flatten a nested json object,  e.g. `{&quot;a&quot;:{&quot;b&quot;:1}}` to `{&quot;a.b&quot;:1}` in order to digest it in solr.\r\n\r\nI have 11 TB of json files which are both nested and contains dots in field names, meaning not elasticsearch (dots) nor solr (nested without the `_childDocument_` notation) can digest it as is.\r\n\r\nThe other solutions would be to replace dots in the field names with underscores and push it to elasticsearch, but I have far better experience with solr therefore I prefer the flatten solution (unless solr can digest those nested jsons as is??). \r\n\r\nI will prefer elasticsearch only if the digestion process will take far less time than solr, because my priority is digesting as fast as I can (thus I chose jq instead of scripting it in python). \r\n\r\nKindly help. \r\n\r\nEDIT:\r\n\r\nI think the pair of examples 3&amp;4 solves this for me:\r\nhttps://lucidworks.com/blog/2014/08/12/indexing-custom-json-data/\r\n\r\nI&#39;ll try soon.\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/37540717/flatten-nested-json-using-jq",
        "title": "Flatten nested JSON using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1098838,
                    "reputation": 8789,
                    "user_id": 1091784,
                    "user_type": "registered",
                    "accept_rate": 55,
                    "profile_image": "https://i.sstatic.net/cIHz9.png?s=256",
                    "display_name": "riteshtch",
                    "link": "https://stackoverflow.com/users/1091784/riteshtch"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1464756567,
                "post_id": 37559582,
                "comment_id": 62607598,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 298926,
                    "reputation": 2973,
                    "user_id": 605213,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/kjMKr.jpg?s=256",
                    "display_name": "Marty",
                    "link": "https://stackoverflow.com/users/605213/marty"
                },
                "reply_to_user": {
                    "account_id": 1098838,
                    "reputation": 8789,
                    "user_id": 1091784,
                    "user_type": "registered",
                    "accept_rate": 55,
                    "profile_image": "https://i.sstatic.net/cIHz9.png?s=256",
                    "display_name": "riteshtch",
                    "link": "https://stackoverflow.com/users/1091784/riteshtch"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1464757145,
                "post_id": 37559582,
                "comment_id": 62607830,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1692658390,
                "last_edit_date": 1692658390,
                "creation_date": 1464758934,
                "answer_id": 37560129,
                "question_id": 37559582,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The filter:\r\n\r\n    .. | objects | select(.Origins.Items[]? | .Id == &quot;abc&quot;) | .Id\r\n\r\nproduces:\r\n\r\n    &quot;parent123&quot;\r\n\r\nYou might want to parameterize the filter, e.g.:\r\n\r\n    def parent(child):\r\n     .. | objects | select( .Origins.Items[]? | .Id == child) | .Id ;\r\n      ",
                "title": "Return parent node with jq while querying one of its children"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1503771679,
                "creation_date": 1503771679,
                "answer_id": 45898420,
                "question_id": 37559582,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The filter in the original question is close to a solution.  All that&#39;s needed is to rearrange what goes in the `select`.  E.g.\r\n\r\n      .DistributionList.Items[]\r\n    | select(.Origins.Items[].Id == &quot;abc&quot;)\r\n    | .Id\r\n",
                "title": "Return parent node with jq while querying one of its children"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1692658390,
        "creation_date": 1464756095,
        "question_id": 37559582,
        "body_markdown": "Wondering if its possible to return the parent &quot;Id&quot; from the json below while querying the child &quot;Id&quot;\r\n\r\n    {\r\n        &quot;DistributionList&quot;: {\r\n            &quot;Items&quot;: [\r\n                {\r\n                    &quot;Origins&quot;: {\r\n                        &quot;Items&quot;: [\r\n                            {\r\n                                &quot;Id&quot;: &quot;abc&quot;\r\n                            }\r\n                        ],\r\n                        &quot;Quantity&quot;: 1\r\n                    },\r\n                    &quot;Id&quot;: &quot;parent123&quot;\r\n                },\r\n                {\r\n                    &quot;Origins&quot;: {\r\n                        &quot;Items&quot;: [\r\n                            {\r\n                                &quot;Id&quot;: &quot;def&quot;\r\n                            }\r\n                        ],\r\n                        &quot;Quantity&quot;: 1\r\n                    },\r\n                    &quot;Id&quot;: &quot;parent345&quot;\r\n                }\r\n             ]\r\n        }\r\n    }\r\n\r\nEg. If I query for child id &quot;abc&quot; it should return &quot;parent123&quot;.\r\n\r\nDoing something like: \r\n\r\n    more jsonfile | jq &#39;.DistributionList.Items[].Origins.Items[] | select(.Id == &quot;abc&quot;) | .Id&#39;\r\n\r\nwill only return &quot;abc&quot; -&gt; but i need the parent id.\r\nNot sure if there is way to do this with jq\r\n\r\n",
        "link": "https://stackoverflow.com/questions/37559582/return-parent-node-with-jq-while-querying-one-of-its-children",
        "title": "Return parent node with jq while querying one of its children"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 101,
                "is_accepted": true,
                "score": 100,
                "last_activity_date": 1692225332,
                "last_edit_date": 1692225332,
                "creation_date": 1464779490,
                "answer_id": 37567004,
                "question_id": 37563691,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Found the answer:\r\n\r\n&lt;!-- language: bash --&gt;\r\n    cat &lt;file&gt;.json | jq -r &#39;.files[] | select(.fileName==&quot;FOO&quot;) | .md5&#39;",
                "title": "jq select value from array"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1596536675,
                "last_edit_date": 1596536675,
                "creation_date": 1575394383,
                "answer_id": 59162494,
                "question_id": 37563691,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "or:\r\n\r\n```sh\r\ncat &lt;file&gt;.json | jq -r &#39;.files[] | select(.fileName==&quot;FOO&quot;).md5&#39;\r\n```",
                "title": "jq select value from array"
            },
            {
                "up_vote_count": 18,
                "is_accepted": false,
                "score": 14,
                "last_activity_date": 1633046164,
                "creation_date": 1633046164,
                "answer_id": 69399905,
                "question_id": 37563691,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "to answer the more generic how to select value from array selecting all filenames:\r\n\r\n\r\n```\r\ncat results.json | jq &#39;.files[] | .filename&#39;\r\n```",
                "title": "jq select value from array"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1705654090,
                "creation_date": 1705654090,
                "answer_id": 77844750,
                "question_id": 37563691,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to keep your item in the array, so do more of a filter you can do \r\n\r\n    cat &lt;file&gt;.json | jq -r &#39;.files | map(select(.fileName==&quot;FOO&quot;).md5)&#39;\r\n\r\nthis would result in \r\n\r\n    [&#39;blablabla&#39;]\r\n\r\n\r\n\r\n\r\n",
                "title": "jq select value from array"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 80,
        "last_activity_date": 1713974807,
        "creation_date": 1464770744,
        "last_edit_date": 1713974807,
        "question_id": 37563691,
        "body_markdown": "I have the following JSON file with example values:\r\n\r\n```json\r\n{\r\n  &quot;files&quot;: [{\r\n    &quot;fileName&quot;: &quot;FOO&quot;,\r\n    &quot;md5&quot;: &quot;blablabla&quot;\r\n  }, {\r\n    &quot;fileName&quot;: &quot;BAR&quot;,\r\n    &quot;md5&quot;: &quot;alaldlafj&quot;\r\n  }]\r\n}\r\n```\r\n\r\nNow what I want is to return the `md5` value where for example the `fileName` is &quot;FOO&quot;. For this I have the following statement in `jq`:\r\n\r\n&lt;!-- language: bash --&gt;\r\n    cat &lt;file&gt;.json | jq &#39;.[] | select(.fileName==&quot;FOO&quot;)&#39; \r\n\r\nHowever response back is: `jq: error (at &lt;stdin&gt;:11): Cannot index array with string &quot;fileName&quot;`\r\n\r\nWhat is the correct way to return the md5 value where the key fileName equals a certain argument?",
        "link": "https://stackoverflow.com/questions/37563691/jq-select-value-from-array",
        "title": "jq select value from array"
    },
    {
        "tags": [
            "nested",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1464808609,
                "creation_date": 1464808609,
                "answer_id": 37577031,
                "question_id": 37576570,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following jq filter produces the requested intermediate output:\r\n\r\n    .Snapshots[] | (. + (.Tags|from_entries)) | del(.Tags)\r\n\r\nExplanation: `from_entries` converts the array of key-value objects to an object with the given key-value pairs.  This is added to the target object, and finally the &quot;Tags&quot; key is removed. \r\n\r\nIf the &quot;target&quot; object has a key that also appears in the &quot;Tags&quot; array, then the above filter will favor the value in the &quot;Tags&quot; array.  You may accordingly wish to change the order of the operands of &quot;+&quot;, or resolve the conflict in some other way.",
                "title": "How to flatten JSON with nested structure before passing to @csv filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1464843675,
        "creation_date": 1464806954,
        "last_edit_date": 1464843675,
        "question_id": 37576570,
        "body_markdown": "I am trying to parse some JSON that is the output of an AWS CLI command to display Snapshots.  I want to load this data up into a spreadsheet to be able to filter, group, and audit it.\r\n\r\nI&#39;ve been stumped on how to get the nested Tags array flattened into the parent objects such that the intermediate can then be passed to the @csv filter.\r\n\r\nHere is the example:\r\n\r\n**Initial input JSON:**\r\n\r\n    {\r\n      &quot;Snapshots&quot;: [\r\n        {\r\n          &quot;SnapshotId&quot;: &quot;snap-fff&quot;,\r\n          &quot;StartTime&quot;: &quot;2014-04-01T06:00:13.000Z&quot;,\r\n          &quot;VolumeId&quot;: &quot;vol-fff&quot;,\r\n          &quot;VolumeSize&quot;: 50,\r\n          &quot;Description&quot;: &quot;desc1&quot;,\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Value&quot;: &quot;/dev/sdf&quot;,\r\n              &quot;Key&quot;: &quot;device&quot;\r\n            },\r\n            {\r\n              &quot;Value&quot;: &quot;a name&quot;,\r\n              &quot;Key&quot;: &quot;Name&quot;\r\n            },\r\n            {\r\n              &quot;Value&quot;: &quot;Internal&quot;,\r\n              &quot;Key&quot;: &quot;Customer&quot;\r\n            },\r\n            {\r\n              &quot;Value&quot;: &quot;Demo&quot;,\r\n              &quot;Key&quot;: &quot;Environment&quot;\r\n            },\r\n            {\r\n              &quot;Value&quot;: &quot;Brand 1&quot;,\r\n              &quot;Key&quot;: &quot;Branding&quot;\r\n            },\r\n            {\r\n              &quot;Value&quot;: &quot;i-fff&quot;,\r\n              &quot;Key&quot;: &quot;instance_id&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;SnapshotId&quot;: &quot;snap-ccc&quot;,\r\n          &quot;StartTime&quot;: &quot;2014-07-01T05:59:14.000Z&quot;,\r\n          &quot;VolumeId&quot;: &quot;vol-ccc&quot;,\r\n          &quot;VolumeSize&quot;: 8,\r\n          &quot;Description&quot;: &quot;B Desc&quot;,\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Value&quot;: &quot;/dev/sda1&quot;,\r\n              &quot;Key&quot;: &quot;device&quot;\r\n            },\r\n            {\r\n              &quot;Value&quot;: &quot;External&quot;,\r\n              &quot;Key&quot;: &quot;Customer&quot;\r\n            },\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;i-ccc&quot;,\r\n              &quot;Key&quot;: &quot;instance_id&quot;\r\n            },\r\n            {\r\n              &quot;Value&quot;: &quot;B Brand&quot;,\r\n              &quot;Key&quot;: &quot;Branding&quot;\r\n            },\r\n            {\r\n              &quot;Value&quot;: &quot;B Name&quot;,\r\n              &quot;Key&quot;: &quot;Name&quot;\r\n            },\r\n            {\r\n              &quot;Value&quot;: &quot;AnotherValue&quot;,\r\n              &quot;Key&quot;: &quot;AnotherKey&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n**Desired Intermediate:**\r\n\r\n    [\r\n      {\r\n        &quot;SnapshotId&quot;: &quot;snap-fff&quot;,\r\n        &quot;StartTime&quot;: &quot;2014-04-01T06:00:13.000Z&quot;,\r\n        &quot;VolumeId&quot;: &quot;vol-fff&quot;,\r\n        &quot;VolumeSize&quot;: 50,\r\n        &quot;Description&quot;: &quot;desc1&quot;,\r\n        &quot;device&quot;: &quot;/dev/sdf&quot;,\r\n        &quot;Name&quot;: &quot;a name&quot;,\r\n        &quot;Customer&quot;: &quot;Internal&quot;,\r\n        &quot;Environment&quot;: &quot;Demo&quot;,\r\n        &quot;Branding&quot;: &quot;Brand 1&quot;,\r\n        &quot;instance_id&quot;: &quot;i-fff&quot;,\r\n      }\r\n      {\r\n        &quot;SnapshotId&quot;: &quot;snap-ccc&quot;,\r\n        &quot;StartTime&quot;: &quot;2014-07-01T05:59:14.000Z&quot;,\r\n        &quot;VolumeId&quot;: &quot;vol-ccc&quot;,\r\n        &quot;VolumeSize&quot;: 8,\r\n        &quot;Description&quot;: &quot;B Desc&quot;,\r\n        &quot;device&quot;: &quot;/dev/sda1&quot;,\r\n        &quot;Customer&quot;: &quot;External&quot;,\r\n        &quot;Environment&quot;: &quot;Production&quot;,\r\n        &quot;instance_id&quot;: &quot;i-ccc&quot;,\r\n        &quot;Branding&quot;: &quot;B Brand&quot;,\r\n        &quot;Name&quot;: &quot;B Name&quot;,\r\n        &quot;AnotherKey&quot;: &quot;AnotherValue&quot;,\r\n      }\r\n    ]\r\n\r\n**Final Output:**\r\n\r\n    &quot;SnapshotId&quot;,&quot;StartTime&quot;,&quot;VolumeId&quot;,&quot;VolumeSize&quot;,&quot;Description&quot;,&quot;device&quot;,&quot;Name&quot;,&quot;Customer&quot;,&quot;Environment&quot;,&quot;Branding&quot;,&quot;instance_id&quot;,&quot;AnotherKey&quot;\r\n    &quot;snap-fff&quot;,&quot;2014-04-01T06:00:13.000Z&quot;,&quot;vol-fff&quot;,50,&quot;desc1&quot;,&quot;/dev/sdf&quot;,&quot;a name&quot;,&quot;Internal&quot;,&quot;Demo&quot;,&quot;Brand 1&quot;,&quot;i-fff&quot;,&quot;&quot;\r\n    &quot;snap-ccc&quot;,&quot;2014-07-01T05:59:14.000Z&quot;,&quot;vol-ccc&quot;,8,&quot;B Desc&quot;,&quot;/dev/sda1&quot;,&quot;External&quot;,&quot;Production&quot;,&quot;i-ccc&quot;,&quot;B Brand&quot;,&quot;B Name&quot;,&quot;AnotherValue&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/37576570/how-to-flatten-json-with-nested-structure-before-passing-to-csv-filter",
        "title": "How to flatten JSON with nested structure before passing to @csv filter"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "parsing",
            "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": 1464811562,
                "post_id": 37577683,
                "comment_id": 62642529,
                "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": 1464811651,
                "post_id": 37577683,
                "comment_id": 62642575,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1298963,
                    "reputation": 3538,
                    "user_id": 1249267,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://i.sstatic.net/vgXsR.jpg?s=256",
                    "display_name": "sudhishkr",
                    "link": "https://stackoverflow.com/users/1249267/sudhishkr"
                },
                "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": 1464811655,
                "post_id": 37577683,
                "comment_id": 62642578,
                "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": 1464811689,
                "post_id": 37577683,
                "comment_id": 62642596,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 65,
                "is_accepted": true,
                "score": 65,
                "last_activity_date": 1464811844,
                "last_edit_date": 1464811844,
                "creation_date": 1464811469,
                "answer_id": 37577805,
                "question_id": 37577683,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can simply use: `keys`:\r\n\r\n    % jq &#39;keys&#39; my.json\r\n    [\r\n      &quot;20160522201409-jobsv1-1&quot;\r\n    ]\r\n\r\nAnd to get the first:\r\n\r\n    % jq -r &#39;keys[0]&#39; my.json\r\n    20160522201409-jobsv1-1\r\n\r\n`-r` is for raw output:\r\n\r\n&gt; `--raw-output / -r:` With this option, if the filter’s result is a string then it will be written directly to standard output rather than being formatted as a JSON string with quotes. This can be useful for making jq filters talk to non-JSON-based systems.\r\n\r\n[Source][1]\r\n\r\nIf you want a known value below an unknown property, eg `xxx.hostName`:\r\n\r\n    % jq -r &#39;.[].hostName&#39; my.json\r\n    20160522201409-jobsv1-1\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "How to use `jq` to obtain the keys"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1721204881,
                "creation_date": 1721204881,
                "answer_id": 78758419,
                "question_id": 37577683,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "you can get the keys at the root of the json:\r\n\r\n```\r\ncat a.json | jq keys\r\n```\r\n\r\nyou can also pipe json into the `keys` function:\r\n\r\n```\r\ncat a.json | jq &quot;.data[] | keys&quot;\r\n```",
                "title": "How to use `jq` to obtain the keys"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 45,
        "last_activity_date": 1721204881,
        "creation_date": 1464810999,
        "last_edit_date": 1464812077,
        "question_id": 37577683,
        "body_markdown": "My json looks like this : \r\n\r\n    {\r\n      &quot;20160522201409-jobsv1-1&quot;: {\r\n        &quot;vmStateDisplayName&quot;: &quot;Ready&quot;,\r\n        &quot;servers&quot;: {\r\n          &quot;20160522201409 jobs_v1 1&quot;: {\r\n            &quot;serverStateDisplayName&quot;: &quot;Ready&quot;,\r\n            &quot;creationDate&quot;: &quot;2016-05-22T20:14:22.000+0000&quot;,\r\n            &quot;state&quot;: &quot;READY&quot;,\r\n            &quot;provisionStatus&quot;: &quot;PENDING&quot;,\r\n            &quot;serverRole&quot;: &quot;ROLE&quot;,\r\n            &quot;serverType&quot;: &quot;SERVER&quot;,\r\n            &quot;serverName&quot;: &quot;20160522201409 jobs_v1 1&quot;,\r\n            &quot;serverId&quot;: 2902\r\n          }\r\n        },\r\n        &quot;isAdminNode&quot;: true,\r\n        &quot;creationDate&quot;: &quot;2016-05-22T20:14:23.000+0000&quot;,\r\n        &quot;totalStorage&quot;: 15360,\r\n        &quot;shapeId&quot;: &quot;ot1&quot;,\r\n        &quot;state&quot;: &quot;READY&quot;,\r\n        &quot;vmId&quot;: 4353,\r\n        &quot;hostName&quot;: &quot;20160522201409-jobsv1-1&quot;,\r\n        &quot;label&quot;: &quot;20160522201409 jobs_v1 ADMIN_SERVER 1&quot;,\r\n        &quot;ipAddress&quot;: &quot;10.252.159.39&quot;,\r\n        &quot;publicIpAddress&quot;: &quot;10.252.159.39&quot;,\r\n        &quot;usageType&quot;: &quot;ADMIN_SERVER&quot;,\r\n        &quot;role&quot;: &quot;ADMIN_SERVER&quot;,\r\n        &quot;componentType&quot;: &quot;jobs_v1&quot;\r\n      }\r\n    }\r\n\r\nMy key keeps changing from time to time. So for example `20160522201409-jobsv1-1` may be something else tomorrow. Also I may more than one such entry in the json payload.\r\n\r\nI want to `echo $KEYS` and I am trying to do it using `jq`.\r\n\r\nThings I have tried : \r\n` | jq .KEYS` is the command i use frequently. \r\n\r\nIs there a jq command to display all the primary keys in the json?\r\n\r\nI only care about the `hostname` field. And I would like to extract that out. I know how to do it using `grep` but it is NOT a clean approach.",
        "link": "https://stackoverflow.com/questions/37577683/how-to-use-jq-to-obtain-the-keys",
        "title": "How to use `jq` to obtain the keys"
    },
    {
        "tags": [
            "json",
            "macos",
            "command-line",
            "installation",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1565215,
                    "reputation": 9313,
                    "user_id": 1454176,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/O9qna.png?s=256",
                    "display_name": "Zulu",
                    "link": "https://stackoverflow.com/users/1454176/zulu"
                },
                "edited": false,
                "score": 8,
                "creation_date": 1465255313,
                "post_id": 37668134,
                "comment_id": 62814675,
                "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": 1685628716,
                "post_id": 37668134,
                "comment_id": 134689487,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 199,
                "is_accepted": false,
                "score": 199,
                "last_activity_date": 1727325554,
                "last_edit_date": 1727325554,
                "creation_date": 1465254832,
                "answer_id": 37668210,
                "question_id": 37668134,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "On a Mac, the &quot;most efficient&quot; way to install jq would probably be using [homebrew][1], e.g.\r\n\r\n    brew install jq\r\n\r\nIf you want the development version, you could try:\r\n\r\n    brew install --HEAD jq\r\n\r\nbut this has various pre-requisites.  \r\n\r\nDetailed instructions are on the &quot;Installation&quot; page of the jq wiki: https://github.com/jqlang/jq/wiki/Installation\r\n\r\nThe same page also includes details regarding installation from source, and has notes on installing with MacPorts (&quot;ports&quot;), asdf ([tag:asdf-vm]), and 0install (&quot;zero-install&quot;). \r\n\r\n---\r\nFootnote: one can also use `brew` to install the Go and Rust implementations of jq:\r\n\r\n    brew install gojq\r\n    brew install jaq\r\n\r\n\r\n  [1]: https://brew.sh/",
                "title": "How to install JQ on Mac on the command line?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1475523870,
                "creation_date": 1475523870,
                "answer_id": 39839250,
                "question_id": 37668134,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For most it is a breeze, however like you I had a difficult time installing jq \r\n\r\nThe best resources I found are: https://stedolan.github.io/jq/download/  and  http://macappstore.org/jq/\r\n\r\nHowever neither worked for me. I run python 2 &amp; 3, and use brew in addition to pip, as well as Jupyter. I was only successful after brew uninstall jq then updating brew and rebooting my system\r\n\r\nWhat worked for me was removing all previous installs then `pip install jq`",
                "title": "How to install JQ on Mac on the command line?"
            },
            {
                "up_vote_count": 411,
                "is_accepted": false,
                "score": 409,
                "last_activity_date": 1710856949,
                "last_edit_date": 1710856949,
                "creation_date": 1520960493,
                "answer_id": 49261843,
                "question_id": 37668134,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can install any application/packages with brew on mac. If you want to know the exact command just search your package on [https://brewinstall.org][1] and you will get the set of commands needed to install that package. \r\n\r\nFirst open terminal and install brew\r\n\r\n    /bin/bash -c &quot;$(curl -fsSL raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)&quot;\r\n\r\nNow Install jq\r\n\r\n    brew install jq\r\n\r\n\r\n  [1]: https://brewinstall.org",
                "title": "How to install JQ on Mac on the command line?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1567489491,
                "creation_date": 1567489491,
                "answer_id": 57765667,
                "question_id": 37668134,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For CentOS, RHEL, Amazon Linux:\r\nsudo yum install jq",
                "title": "How to install JQ on Mac on the command line?"
            },
            {
                "up_vote_count": 74,
                "is_accepted": false,
                "score": 73,
                "last_activity_date": 1571220684,
                "last_edit_date": 1571220684,
                "creation_date": 1568739801,
                "answer_id": 57978952,
                "question_id": 37668134,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest way to install `jq` and test that it works is through brew and then using the simplest filter that merely formats the JSON\r\n\r\n# Install \r\n`brew` is the easiest way to manage packages on a mac:\r\n```\r\nbrew install jq\r\n```\r\nNeed `brew`? Run the following command:\r\n```\r\n/usr/bin/ruby -e &quot;$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)&quot;\r\n```\r\nFailing that: instructions to install and use are on https://brew.sh/\r\n\r\n# Test\r\nThe `.` filter takes its input and produces it unchanged as output. This is the identity operator. (quote the docs)\r\n```\r\necho &#39;{ &quot;name&quot;:&quot;John&quot;, &quot;age&quot;:31, &quot;city&quot;:&quot;New York&quot; }&#39; | jq .\r\n```\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",
                "title": "How to install JQ on Mac on the command line?"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1616715380,
                "creation_date": 1616715380,
                "answer_id": 66809017,
                "question_id": 37668134,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To make sure homebrew is installed and install `jq`\r\n\r\n```sh\r\ngit -C &quot;/usr/local/Homebrew/Library/Taps/homebrew/homebrew-cask&quot; fetch --unshallow \r\nbrew update\r\nbrew install jq\r\n```",
                "title": "How to install JQ on Mac on the command line?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1624291363,
                "creation_date": 1624291363,
                "answer_id": 68071170,
                "question_id": 37668134,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are looking for a good alternative to `homebrew` (whether in a Mac or Linux environment), one such is `0install` (&quot;Zero Install&quot;), which indeed has some advantages.  For example, it&#39;s trivially easy to have multiple versions of jq installed together.\r\n\r\nIf you already have 0install installed, to add jq it would be sufficient to type:\r\n\r\n\r\n    0install add jq https://apps.0install.net/utils/jq.xml\r\n\r\nThis installs a tiny script in ~/bin/jq, which you can use as though it were jq itself.\r\n\r\nTo install a particular version of jq, say jq 1.5, you just have to specify the version number:\r\n\r\n    0install add --version=1.5 jq1.5 https://apps.0install.net/utils/jq.xml\r\n\r\nFurther details about the versions of jq that are available using this &quot;feed&quot; for 0install can be obtained by viewing the above-mentioned URL in a browser.\r\n \r\n## Installing 0install\r\n\r\nOne option for installing 0install itself would of course be:\r\n\r\n     brew install 0install\r\n\r\nCurrently, a better option is to run:\r\n\r\n    curl -O https://get.0install.net/0install.sh &amp;&amp; chmod +x 0install.sh\r\n    ./0install.sh\r\n\r\nand then follow the directions.\r\n\r\nSee 0install.net for further details.\r\n",
                "title": "How to install JQ on Mac on the command line?"
            },
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 15,
                "last_activity_date": 1650065102,
                "creation_date": 1650065102,
                "answer_id": 71889817,
                "question_id": 37668134,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Check if homebrew is installed    \r\n\r\n    brew install jq\r\n\r\n",
                "title": "How to install JQ on Mac on the command line?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1653766512,
                "last_edit_date": 1653766512,
                "creation_date": 1653765332,
                "answer_id": 72418608,
                "question_id": 37668134,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Nothing agaist brew (I use both) but if you want to you can use [macports][1]\r\n\r\n````\r\nsudo port install jq\r\n````\r\n\r\nFWIW, [jc&#39;s][2] an interesting utility that plays very well with jq (its purpose is to json-ize command outputs).  And, yes, `brew install jc` or `sudo port install jc` both work.\r\n\r\n\r\n\r\n\r\n  [1]: https://www.macports.org/\r\n  [2]: https://github.com/kellyjonbrazil/jc",
                "title": "How to install JQ on Mac on the command line?"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1719741261,
                "last_edit_date": 1719741261,
                "creation_date": 1664959184,
                "answer_id": 73957844,
                "question_id": 37668134,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**Install `jq` without brew (Debian-based Linux):**\r\n1. `sudo apt install jq` \r\n2. Check the version for successful installation: `jq --version`\r\n\r\n**Install `jq` without brew (Mac):**\r\n1. Download the jq file:\r\n`curl -L -o jq https://github.com/stedolan/jq/releases/download/jq-1.6/jq-osx-amd64`\r\nor\r\n`wget -O jq https://github.com/stedolan/jq/releases/download/jq-1.6/jq-osx-amd64`\r\n\r\n2. Make the file executable:`chmod +x jq`\r\n3. Move the file to a directory in your PATH: `sudo mv jq /usr/local/bin`\r\n4. Check the version for successful installation: `jq --version`",
                "title": "How to install JQ on Mac on the command line?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1736345986,
                "creation_date": 1736345986,
                "answer_id": 79339513,
                "question_id": 37668134,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The question is very old but here&#39;s an update for the current macOS version. macOS Sequoia (15) has jq commnand-line utility pre-installed with the operating system. Xcode command line developer tools package isn&#39;t needed.\r\n\r\n```\r\n$ which jq\r\n/usr/bin/jq\r\n\r\n$ jq --version\r\njq-1.6-159-apple-gcff5336-dirty\r\n```",
                "title": "How to install JQ on Mac on the command line?"
            }
        ],
        "is_answered": true,
        "answer_count": 11,
        "score": 347,
        "last_activity_date": 1736345986,
        "creation_date": 1465254363,
        "last_edit_date": 1624256274,
        "question_id": 37668134,
        "body_markdown": "I need to know the most efficient way of installing JQ on Mac (El Capitan). The code is downloaded to my Mac but I would like to know how I can install and operate it via the command line.",
        "link": "https://stackoverflow.com/questions/37668134/how-to-install-jq-on-mac-on-the-command-line",
        "title": "How to install JQ on Mac on the command line?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1779,
                    "reputation": 4398,
                    "user_id": 2440,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/WHozO.jpg?s=256",
                    "display_name": "Sire",
                    "link": "https://stackoverflow.com/users/2440/sire"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633692418,
                "post_id": 37699158,
                "comment_id": 122833670,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 21,
                "is_accepted": true,
                "score": 20,
                "last_activity_date": 1548639481,
                "last_edit_date": 1548639481,
                "creation_date": 1465380208,
                "answer_id": 37699363,
                "question_id": 37699158,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `|=` operator to assign to a property:\r\n\r\n    jq -r &#39;.modules[].resources[] | select(.type == &quot;aws_launch_configuration&quot;) | select(.primary.attributes.name_prefix == &quot;pmsadmin-lc-&quot;)| .primary.attributes.image_id |= &quot;ami-a4df7gah&quot;",
                "title": "JSON JQ Find Replace Value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 9,
        "last_activity_date": 1548639481,
        "creation_date": 1465379653,
        "last_edit_date": 1522089149,
        "question_id": 37699158,
        "body_markdown": "I am trying to update &quot;image_id&quot; value in a json structure. Using the below command, how do I change `ami-d8cf5cab` to `ami-a4df7gah` So far, I have tried this\r\n\r\n    cat cog.test.tfstate | jq -r &#39;.modules[].resources[] | select(.type == &quot;aws_launch_configuration&quot;) | select(.primary.attributes.name_prefix == &quot;pmsadmin-lc-&quot;)&#39;\r\n    \r\nThe JSON data is\r\n\r\n    {\r\n      &quot;type&quot;: &quot;aws_launch_configuration&quot;,\r\n      &quot;primary&quot;: {\r\n        &quot;id&quot;: &quot;pmsadmin-lc-v47thk6rcrdgza6dujfzjatmju&quot;,\r\n        &quot;attributes&quot;: {\r\n          &quot;associate_public_ip_address&quot;: &quot;false&quot;,\r\n          &quot;ebs_block_device.#&quot;: &quot;0&quot;,\r\n          &quot;ebs_optimized&quot;: &quot;false&quot;,\r\n          &quot;enable_monitoring&quot;: &quot;true&quot;,\r\n          &quot;ephemeral_block_device.#&quot;: &quot;0&quot;,\r\n          &quot;iam_instance_profile&quot;: &quot;cog-test-pmsadmin&quot;,\r\n          &quot;id&quot;: &quot;pmsadmin-lc-v47thk6rcrdgza6dujfzjatmju&quot;,\r\n          &quot;image_id&quot;: &quot;ami-d8cf5cab&quot;,\r\n          &quot;instance_type&quot;: &quot;t2.small&quot;,\r\n          &quot;key_name&quot;: &quot;cog-test-internal&quot;,\r\n          &quot;name&quot;: &quot;pmsadmin-lc-v47thk6rcrdgza6dujfzjatmju&quot;,\r\n          &quot;name_prefix&quot;: &quot;pmsadmin-lc-&quot;,\r\n          &quot;root_block_device.#&quot;: &quot;0&quot;,\r\n          &quot;security_groups.#&quot;: &quot;4&quot;,\r\n          &quot;security_groups.1893851868&quot;: &quot;sg-7ee7bf1a&quot;,\r\n          &quot;security_groups.2774384192&quot;: &quot;sg-e2e7bf86&quot;,\r\n          &quot;security_groups.2825850029&quot;: &quot;sg-86e6bee2&quot;,\r\n          &quot;security_groups.3095009517&quot;: &quot;sg-f4e7bf90&quot;,\r\n          &quot;spot_price&quot;: &quot;&quot;,\r\n          &quot;user_data&quot;: &quot;ed03ac6642af8c97562b065c0b37f211b58ad0a2&quot;\r\n        }\r\n      }\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/37699158/json-jq-find-replace-value",
        "title": "JSON JQ Find Replace Value"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1465394747,
                "creation_date": 1465394747,
                "answer_id": 37704838,
                "question_id": 37704837,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This solution uses regular expressions and the `reduce` operator:\r\n\r\n`reduce .[] as $item ([]; if ($item | test(&quot;^bad-&quot;)) then .  else . + [$item] end)`\r\n\r\nThings I learned:\r\n\r\n1. the `reduce` operator\r\n2. you can pipe &#39;subitems&#39; through filters (above `$item | test(&quot;^bad&quot;)`) ",
                "title": "How to filter out values from array"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1465407141,
                "creation_date": 1465407141,
                "answer_id": 37709188,
                "question_id": 37704837,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. In this case you could also use startswith/1\r\n2. You can also use map/1, select/1 and not/0\r\n3. You can update the &quot;m&quot; slot in-place using |=\r\n\r\nThus:\r\n\r\n    .m |= map( select( startswith(&quot;bad-&quot;) | not ))\r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;m&quot;: [\r\n        &quot;ok&quot;,\r\n        &quot;also-ok&quot;\r\n      ]\r\n    }",
                "title": "How to filter out values from array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1465407141,
        "creation_date": 1465394747,
        "question_id": 37704837,
        "body_markdown": "I have an object that looks like this: `{&quot;m&quot;:[&quot;bad-1&quot;, &quot;ok&quot;, &quot;also-ok&quot;, &quot;bad-2&quot;, &quot;bad-3&quot;]}` I would like to keep just the values in `m` that don&#39;t start with `bad-`. ",
        "link": "https://stackoverflow.com/questions/37704837/how-to-filter-out-values-from-array",
        "title": "How to filter out values from array"
    },
    {
        "tags": [
            "json",
            "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": 1516428344,
                "post_id": 37710718,
                "comment_id": 83692916,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 233,
                "is_accepted": true,
                "score": 231,
                "last_activity_date": 1600969436,
                "last_edit_date": 1600969436,
                "creation_date": 1465412529,
                "answer_id": 37710802,
                "question_id": 37710718,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [parentheses](https://stedolan.github.io/jq/manual/#Parenthesis) around the string concatenation code:\r\n\r\n    echo &#39;{&quot;channel&quot;: &quot;youtube&quot;, &quot;profile_type&quot;: &quot;video&quot;, &quot;member_key&quot;: &quot;hello&quot;}&#39; \\\r\n     | jq &#39;{channel: (.profile_type + &quot;.&quot; + .channel)}&#39;",
                "title": "Concat 2 fields in JSON using jq"
            },
            {
                "up_vote_count": 108,
                "is_accepted": false,
                "score": 108,
                "last_activity_date": 1745832737,
                "last_edit_date": 1745832737,
                "creation_date": 1501980396,
                "answer_id": 45527623,
                "question_id": 37710718,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution that uses string interpolation as [Jeff](https://stackoverflow.com/users/390278/jeff-mercado) suggested:\r\n\r\n    {channel: &quot;\\(.profile_type).\\(.member_key)&quot;}\r\n\r\ne.g.\r\n\r\n    $ jq &#39;{channel: &quot;\\(.profile_type).\\(.member_key)&quot;}&#39; &lt;&lt;EOF\r\n    &gt; {&quot;channel&quot;: &quot;youtube&quot;, &quot;profile_type&quot;: &quot;video&quot;, &quot;member_key&quot;: &quot;hello&quot;}\r\n    &gt; EOF\r\n    {\r\n      &quot;channel&quot;: &quot;video.hello&quot;\r\n    }\r\n\r\nString interpolation works with the `\\(foo)` syntax (which is similar to a shell `$(foo)` call).  \r\nSee the official [JQ manual][1].\r\n\r\n\r\n  [1]: https://jqlang.org/manual/#string-interpolation",
                "title": "Concat 2 fields in JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 172,
        "last_activity_date": 1745832737,
        "creation_date": 1465412203,
        "last_edit_date": 1573113613,
        "question_id": 37710718,
        "body_markdown": "I am using `jq` to reformat my `JSON`.\r\n\r\nJSON String:\r\n\r\n`{&quot;channel&quot;: &quot;youtube&quot;, &quot;profile_type&quot;: &quot;video&quot;, &quot;member_key&quot;: &quot;hello&quot;}`\r\n\r\nWanted output:\r\n\r\n`{&quot;channel&quot; : &quot;profile_type.youtube&quot;}`\r\n\r\nMy command:\r\n\r\n`echo &#39;{&quot;channel&quot;: &quot;youtube&quot;, &quot;profile_type&quot;: &quot;video&quot;, &quot;member_key&quot;: &quot;hello&quot;}&#39; | jq -c &#39;. | {channel: .profile_type + &quot;.&quot; + .member_key}&#39;`\r\n\r\n\r\nI know that the command below concatenates the string. But it is not working in the same logic as above:\r\n\r\n`echo &#39;{&quot;channel&quot;: &quot;youtube&quot;, &quot;profile_type&quot;: &quot;video&quot;, &quot;member_key&quot;: &quot;hello&quot;}&#39; | jq -c &#39;.profile_type + &quot;.&quot; + .member_key&#39;`\r\n\r\nHow can I achieve my result using ONLY jq?",
        "link": "https://stackoverflow.com/questions/37710718/concat-2-fields-in-json-using-jq",
        "title": "Concat 2 fields in JSON using jq"
    },
    {
        "tags": [
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8325231,
                    "reputation": 10346,
                    "user_id": 6255513,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8dc0a9f96e28599a546fcb332e7ff365?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Smeeheey",
                    "link": "https://stackoverflow.com/users/6255513/smeeheey"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1465549478,
                "post_id": 37743955,
                "comment_id": 62958482,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8325231,
                    "reputation": 10346,
                    "user_id": 6255513,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8dc0a9f96e28599a546fcb332e7ff365?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Smeeheey",
                    "link": "https://stackoverflow.com/users/6255513/smeeheey"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1465549647,
                "post_id": 37743955,
                "comment_id": 62958581,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1465549860,
                "post_id": 37743955,
                "comment_id": 62958722,
                "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": 1465563997,
                "post_id": 37743955,
                "comment_id": 62967674,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1465550473,
                "last_edit_date": 1465550473,
                "creation_date": 1465550103,
                "answer_id": 37744405,
                "question_id": 37743955,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`jq &#39;.&quot;$2&quot;&#39;` will send literal `.&quot;$2&quot;` as a expression for jq, what you want is:\r\n\r\n    jq --arg key &quot;$2&quot; &#39;.[$key]&#39; &quot;$1&quot;\r\n\r\nAlso removed useless use of `cat`. \r\n\r\nI don&#39;t quite understand what you want with the eval part? But I guess you are trying to set `return_value` to the result from `jq`?\r\n\r\n    getJSONParameter() {\r\n      jq --arg key &quot;$2&quot; &#39;.[$key]&#39; &quot;$1&quot;\r\n    }\r\n\r\n    return_value=&quot;$(getJSONParameter &quot;etl-without-transformation.json&quot; &quot;success_email&quot;)&quot;",
                "title": "shell script returning null output"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1465568763,
                "last_edit_date": 1465568763,
                "creation_date": 1465552567,
                "answer_id": 37745276,
                "question_id": 37743955,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Another way to do it by using global variable:\r\n\r\n    return_value=&#39;default&#39;\r\n    getJSONParamater() {\r\n           return_value=$(cat &quot;$1&quot; | jq &quot;$2&quot;)\r\n    }\r\n    getJSONParamater etl-without-transformation.json  .success_email\r\n    echo $return_value",
                "title": "shell script returning null output"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1465568763,
        "creation_date": 1465548783,
        "question_id": 37743955,
        "body_markdown": "I am not able to debug why it is returning &lt;pre&gt;null&lt;/pre&gt; value. Can some-one please help into this.\r\n\r\nCode -\r\n\r\n&lt;pre&gt;\r\ngetJSONParamater() {\r\n       echo &quot;Before : $1 $2 $3&quot;\r\n       eval &quot;$3=$(cat $1 | jq &#39;.&quot;$2&quot;&#39;)&quot;\r\n       echo &quot;After : $1 $2 $3&quot;\r\n}\r\n\r\nreturn_value=&#39;default&#39;\r\ngetJSONParamater etl-without-transformation.json  success_email return_value\r\n\r\necho $return_value\r\n&lt;/pre&gt;",
        "link": "https://stackoverflow.com/questions/37743955/shell-script-returning-null-output",
        "title": "shell script returning null output"
    },
    {
        "tags": [
            "python",
            "json",
            "jq",
            "large-data"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3023868,
                    "reputation": 22536,
                    "user_id": 2564301,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/06c050c0677999b783246c5ff7471bcb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jongware",
                    "link": "https://stackoverflow.com/users/2564301/jongware"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1465809302,
                "post_id": 37785825,
                "comment_id": 63038103,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 904615,
                    "reputation": 3106,
                    "user_id": 2305993,
                    "user_type": "registered",
                    "accept_rate": 37,
                    "profile_image": "https://i.sstatic.net/EVrHW.jpg?s=256",
                    "display_name": "stackit",
                    "link": "https://stackoverflow.com/users/2305993/stackit"
                },
                "reply_to_user": {
                    "account_id": 3023868,
                    "reputation": 22536,
                    "user_id": 2564301,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/06c050c0677999b783246c5ff7471bcb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jongware",
                    "link": "https://stackoverflow.com/users/2564301/jongware"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1465809419,
                "post_id": 37785825,
                "comment_id": 63038202,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 904615,
                    "reputation": 3106,
                    "user_id": 2305993,
                    "user_type": "registered",
                    "accept_rate": 37,
                    "profile_image": "https://i.sstatic.net/EVrHW.jpg?s=256",
                    "display_name": "stackit",
                    "link": "https://stackoverflow.com/users/2305993/stackit"
                },
                "reply_to_user": {
                    "account_id": 3023868,
                    "reputation": 22536,
                    "user_id": 2564301,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/06c050c0677999b783246c5ff7471bcb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jongware",
                    "link": "https://stackoverflow.com/users/2564301/jongware"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1465809541,
                "post_id": 37785825,
                "comment_id": 63038291,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 904615,
                    "reputation": 3106,
                    "user_id": 2305993,
                    "user_type": "registered",
                    "accept_rate": 37,
                    "profile_image": "https://i.sstatic.net/EVrHW.jpg?s=256",
                    "display_name": "stackit",
                    "link": "https://stackoverflow.com/users/2305993/stackit"
                },
                "reply_to_user": {
                    "account_id": 3023868,
                    "reputation": 22536,
                    "user_id": 2564301,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/06c050c0677999b783246c5ff7471bcb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jongware",
                    "link": "https://stackoverflow.com/users/2564301/jongware"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1465809670,
                "post_id": 37785825,
                "comment_id": 63038387,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 48693,
                    "reputation": 30344,
                    "user_id": 144746,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://www.gravatar.com/avatar/170e317e1e3d42b520786bcec9dfb409?s=256&d=identicon&r=PG",
                    "display_name": "Voo",
                    "link": "https://stackoverflow.com/users/144746/voo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1465811303,
                "post_id": 37785825,
                "comment_id": 63039400,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 904615,
                    "reputation": 3106,
                    "user_id": 2305993,
                    "user_type": "registered",
                    "accept_rate": 37,
                    "profile_image": "https://i.sstatic.net/EVrHW.jpg?s=256",
                    "display_name": "stackit",
                    "link": "https://stackoverflow.com/users/2305993/stackit"
                },
                "reply_to_user": {
                    "account_id": 48693,
                    "reputation": 30344,
                    "user_id": 144746,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://www.gravatar.com/avatar/170e317e1e3d42b520786bcec9dfb409?s=256&d=identicon&r=PG",
                    "display_name": "Voo",
                    "link": "https://stackoverflow.com/users/144746/voo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1465811461,
                "post_id": 37785825,
                "comment_id": 63039512,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1465826714,
                "creation_date": 1465826714,
                "answer_id": 37791818,
                "question_id": 37785825,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I can&#39;t speak about its efficiency, but with jq, it&#39;s just a matter of slurping all files together:\r\n\r\n    jq -s &#39;.&#39; *.json",
                "title": "Append millions of JSON files into a single file efficiently"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1465885107,
                "creation_date": 1465885107,
                "answer_id": 37804300,
                "question_id": 37785825,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I found an excellent efficient way of doing it:\r\n\r\n     ls |xargs -n 10000 -P 8 jq -s &#39;.&#39; &gt;&gt;../jsonparsed\r\n\r\nThis spawn 8 concurrent processes each having 10k arguments and writes to a single jsonfile jsonparsed",
                "title": "Append millions of JSON files into a single file efficiently"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1466219112,
                "creation_date": 1466219112,
                "answer_id": 37892844,
                "question_id": 37785825,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following script (slurp.sh) exemplifies a direct approach using bash.\r\nIt can easily be modified depending on how the relevant JSON files are to be specified.\r\n\r\nI suspect that it would take much longer to develop and test a more complex solution than doing so will save in execution time, but if you want to experiment with parallelism, you might like to look into using the GNU `parallel` command.\r\n\r\nI&#39;ve tested and benchmarked the script using 100,000 trivial .json files\r\nin a single directory.  On my 6 year old computer, the following invocation takes about 8 minutes (wall clock time),\r\nof which the jq invocation takes about 0.2 sec.\r\n\r\n    $ ./slurp.sh | jq length\r\n    100000\r\n\r\nThe script:\r\n\r\n    #!/bin/bash\r\n    # This script slurps the contents of all the .json files in the pwd\r\n    ls | grep .json | nl | while read i f\r\n      do\r\n        if [ $i = 1 ] ; then\r\n    \t  echo &quot;[&quot;\r\n        else\r\n    \t  echo &quot;,&quot;\r\n        fi\r\n          cat $f\r\n      done\r\n    echo &quot;]&quot;\r\n",
                "title": "Append millions of JSON files into a single file efficiently"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1506003640,
        "creation_date": 1465809175,
        "last_edit_date": 1506102294,
        "question_id": 37785825,
        "body_markdown": "I have millions of json files which I need to append to a single json file as a list of json dicts:\r\n\r\n\r\nEach json file contains following dict:\r\n\r\n    {\r\n      &quot;finent&quot;: &quot;abc&quot;,\r\n      &quot;findeplabel&quot;: &quot;lbl&quot;,\r\n    }\r\n\r\n\r\n\r\nShould be combined into a single json file as a list of dicts:\r\n\r\n\r\n    [{\r\n      &quot;finent&quot;: &quot;abc&quot;,\r\n      &quot;findeplabel&quot;: &quot;lbl&quot;,\r\n    },\r\n    {\r\n      &quot;finent&quot;: &quot;abc&quot;,\r\n      &quot;findeplabel&quot;: &quot;lbl&quot;,\r\n    }...]\r\n\r\nThe problem with using &quot;cat&quot; command etc is that the input files are huge in number and the final file size can be &gt;8GB.\r\n\r\ninefficient version: `cat *.json|replace &quot;}\\n{&quot; &quot;},{&quot;`\r\nSo what is the most efficient way to merge the json files ideally concurrently for more efficiency?",
        "link": "https://stackoverflow.com/questions/37785825/append-millions-of-json-files-into-a-single-file-efficiently",
        "title": "Append millions of JSON files into a single file efficiently"
    },
    {
        "tags": [
            "bash",
            "shell",
            "while-loop",
            "sh",
            "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": 1465864155,
                "post_id": 37800919,
                "comment_id": 63067880,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1465864294,
                "post_id": 37800919,
                "comment_id": 63067916,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7402394,
                    "reputation": 15805,
                    "user_id": 5632400,
                    "user_type": "registered",
                    "accept_rate": 52,
                    "profile_image": "https://www.gravatar.com/avatar/7d4ca7b77eb57962901a043425d0b21b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "meallhour",
                    "link": "https://stackoverflow.com/users/5632400/meallhour"
                },
                "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": 1465871422,
                "post_id": 37800919,
                "comment_id": 63069464,
                "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": 1465875030,
                "post_id": 37800919,
                "comment_id": 63070208,
                "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": 1465881686,
                "post_id": 37800919,
                "comment_id": 63071962,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 476555,
                    "reputation": 47257,
                    "user_id": 887539,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/5baef9617bdee6db2f534c118bcbccee?s=256&d=identicon&r=PG",
                    "display_name": "Andreas Louv",
                    "link": "https://stackoverflow.com/users/887539/andreas-louv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1465895271,
                "post_id": 37800919,
                "comment_id": 63079486,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 476555,
                    "reputation": 47257,
                    "user_id": 887539,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/5baef9617bdee6db2f534c118bcbccee?s=256&d=identicon&r=PG",
                    "display_name": "Andreas Louv",
                    "link": "https://stackoverflow.com/users/887539/andreas-louv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1465905353,
                "post_id": 37800919,
                "comment_id": 63086729,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1465939763,
                "creation_date": 1465939763,
                "answer_id": 37822453,
                "question_id": 37800919,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; jq: error (at &lt;stdin&gt;:1): null (null) has no keys\r\n\r\nIs caused by `.` being null. In this case `.` refers to stdin which means that you get no response from `http://internal.private.registry.com/v2/cybs/${line}/tags/list`.\r\n\r\nYou cannot define dynamic named variables like this: `${line}$_image_taglist`. You should use an associative array if your bash version supports it:\r\n\r\n    declare -A arr\r\n    arr[&quot;$line&quot;]=$(curl ... | jq ...)\r\n\r\nBut in your case I can&#39;t really see why you need it, since you are just iteration over it. Why not use a pipe or process substitution?\r\n\r\n    while read -r tag; do\r\n        echo &quot;$tag&quot;\r\n     done &lt; &lt;(curl ... | jq ...)\r\n    ",
                "title": "How to list all tags for every docker image present in catalog?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1465939763,
        "creation_date": 1465862166,
        "last_edit_date": 1465871921,
        "question_id": 37800919,
        "body_markdown": "I am using the following command to list all the images within my private registry:  \r\n\r\n    curl -s http://internal.private.registry.com/v2/_catalog | jq -r &#39;.repositories[0:2] | to_entries | map( .value )[]&#39;\r\n\r\nOutput:  \r\n\r\n    centos\r\n    containersol/consul-server\r\n\r\nI am using the following command to list all the tags of a particular image within my private registry:  \r\n\r\n     curl -s GET http://internal.private.registry.com/v2/centos/tags/list | jq -r &#39;.tags | to_entries | map( .value )[]&#39;\r\n\r\nOutput:  \r\n\r\n    6.6\r\n    6\r\n    7.1.1503\r\n\r\nNow, I am trying to list all tags for every image present in catalog using the following bash script:  \r\n\r\n\r\n    #!/bin/sh\r\n    \r\n    image_name=$(curl -s http://internal.private.registry.com/v2/_catalog | jq -r &#39;.repositories[0:2] | to_entries | map( .value )[]&#39;)\r\n    \r\n    while read -r line; do \r\n        ${line}$_image_taglist=$(curl -s GET http://internal.private.registry.com/v2/cybs/${line}/tags/list | jq -r &#39;.tags | to_entries | map( .value )[]&#39;)\r\n    \twhile read -r tag; do\r\n    \t    echo &quot;$tag&quot;\r\n    \t done &lt;&lt;&lt; &quot;${line}$_image_taglist&quot;\t\r\n    done &lt;&lt;&lt; &quot;$image_name&quot;\r\n\r\nHowever, I am getting the following error while executing `${line}$_image_taglist=$(curl -s GET http://internal.private.registry.com/v2/cybs/${line}/tags/list | jq -r &#39;.tags | to_entries | map( .value )[]&#39;)` :  \r\n\r\n    jq: error (at &lt;stdin&gt;:1): null (null) has no keys\r\n\r\nAlso, please note that I am expecting that `dynamic variable` `${line}$_image_taglist` should resolve to `centos_image_taglist` and `containersol/consul-server_image_taglist`  \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/37800919/how-to-list-all-tags-for-every-docker-image-present-in-catalog",
        "title": "How to list all tags for every docker image present in catalog?"
    },
    {
        "tags": [
            "bash",
            "shell",
            "terminal",
            "edit",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 31262,
                    "reputation": 8663,
                    "user_id": 85737,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/ZV5WF.jpg?s=256",
                    "display_name": "cb0",
                    "link": "https://stackoverflow.com/users/85737/cb0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1465894142,
                "post_id": 37807074,
                "comment_id": 63078738,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 476555,
                    "reputation": 47257,
                    "user_id": 887539,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/5baef9617bdee6db2f534c118bcbccee?s=256&d=identicon&r=PG",
                    "display_name": "Andreas Louv",
                    "link": "https://stackoverflow.com/users/887539/andreas-louv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1465894296,
                "post_id": 37807074,
                "comment_id": 63078840,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1465894662,
                "creation_date": 1465894662,
                "answer_id": 37807375,
                "question_id": 37807074,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming you actually got valid JSON the following jq expression might work for you:\r\n\r\n    map_values(map({&quot;PutRequest&quot;: { &quot;Item&quot;: .}}))\r\n\r\nUsage:\r\n\r\n    jq &#39;map_values(map({&quot;PutRequest&quot;: { &quot;Item&quot;: .}}))&#39; file.json\r\n\r\nBreakdown:\r\n\r\n    map_values(           # Map values iterate over an object and assign the \r\n                          # returned value to the property\r\n      map(                # Map iterate over an array and assign the returned value\r\n                          # to the index, and creates a new array if an object is\r\n                          # mapped\r\n        {                 # Return an object\r\n          &quot;PutRequest&quot;: { # With PutRequest as a property\r\n            &quot;Item&quot;: .     # And Item, which contains the value (.)\r\n          }\r\n        }\r\n      )\r\n    )",
                "title": "Adding One more Parent Attrubute To JSON through Command line"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1465894662,
        "creation_date": 1465893885,
        "question_id": 37807074,
        "body_markdown": "I want edit the structure of json through Terminal using terminal commands or scripts.\r\n        If I have a json file Structure like this:\r\n\r\n\r\n\r\n \r\n\r\n  \r\n\r\n          {\r\n          &quot;Helloo&quot;: [\r\n            {\r\n        \r\n              &quot;AlbumTitle&quot;: {\r\n                &quot;S&quot;: &quot;Famous&quot;\r\n              },\r\n              &quot;SongTitle&quot;: {\r\n                &quot;S&quot;: &quot;Call Me Today&quot;\r\n              },\r\n              &quot;Artist&quot;: {\r\n                &quot;S&quot;: &quot;No One You Know&quot;\r\n              }\r\n              \r\n            },\r\n    {\r\n        \r\n              &quot;AlbumTitle&quot;: {\r\n                &quot;S&quot;: &quot;Famous1&quot;\r\n              },\r\n              &quot;SongTitle&quot;: {\r\n                &quot;S&quot;: &quot;Call Me Today1&quot;\r\n              },\r\n              &quot;Artist&quot;: {\r\n                &quot;S&quot;: &quot;No One You Know11&quot;\r\n              }\r\n              \r\n            }\r\n          ],\r\n          &quot;Music&quot;: [\r\n            {\r\n           \r\n              &quot;Album&quot;: {\r\n                &quot;S&quot;: &quot;Pop Songs&quot;\r\n              },\r\n              &quot;Production&quot;: {\r\n                &quot;S&quot;: &quot;X-series&quot;\r\n              },\r\n              &quot;Song&quot;: {\r\n                &quot;S&quot;: &quot;Once upon\r\n              },\r\n              &quot;Artist&quot;: {\r\n                &quot;S&quot;: &quot;XYZ&quot;\r\n              }\r\n            \r\n            }\r\n          ]\r\n        }\r\n\r\nSo here i want add &quot;Putrequest&quot; and &quot;Item&quot; attributes to each item of the array.. So i want the output like this:\r\n\r\n     {\r\n          &quot;Helloo&quot;: [\r\n            {\r\n            PutRequest&quot;:{  \r\n                &quot;Item&quot;:{ \r\n    \r\n              &quot;AlbumTitle&quot;: {\r\n                &quot;S&quot;: &quot;Famous&quot;\r\n              },\r\n              &quot;SongTitle&quot;: {\r\n                &quot;S&quot;: &quot;Call Me Today&quot;\r\n              },\r\n              &quot;Artist&quot;: {\r\n                &quot;S&quot;: &quot;No One You Know&quot;\r\n              }\r\n    \r\n            }\r\n            }\r\n            },\r\n    {\r\n    PutRequest&quot;:{  \r\n                &quot;Item&quot;:{ \r\n    \r\n              &quot;AlbumTitle&quot;: {\r\n                &quot;S&quot;: &quot;Famous1&quot;\r\n              },\r\n              &quot;SongTitle&quot;: {\r\n                &quot;S&quot;: &quot;Call Me Today1&quot;\r\n              },\r\n              &quot;Artist&quot;: {\r\n                &quot;S&quot;: &quot;No One You Know11&quot;\r\n              }\r\n    \r\n            }\r\n            }\r\n            }\r\n          ],\r\n          &quot;Music&quot;: [\r\n            {\r\n    PutRequest&quot;:{  \r\n                &quot;Item&quot;:{ \r\n              &quot;Album&quot;: {\r\n                &quot;S&quot;: &quot;Pop Songs&quot;\r\n              },\r\n              &quot;Production&quot;: {\r\n                &quot;S&quot;: &quot;X-series&quot;\r\n              },\r\n              &quot;Song&quot;: {\r\n                &quot;S&quot;: &quot;Once upon\r\n              },\r\n              &quot;Artist&quot;: {\r\n                &quot;S&quot;: &quot;XYZ&quot;\r\n              }\r\n    }\r\n    }\r\n            }\r\n          ]\r\n        }\r\n\r\n\r\nI tried to use Jq for this but still struggling.. Please help me To add these attributes to json using command prompt or bash/shell scripting.\r\nThanks\r\n\r\n",
        "link": "https://stackoverflow.com/questions/37807074/adding-one-more-parent-attrubute-to-json-through-command-line",
        "title": "Adding One more Parent Attrubute To JSON through Command line"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user3899165"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1465940385,
                "post_id": 37817820,
                "comment_id": 63108835,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1465941066,
                "last_edit_date": 1465941066,
                "creation_date": 1465932593,
                "answer_id": 37820561,
                "question_id": 37817820,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just use [`sub`][2]:\r\n\r\n    curl ... | jq -r &#39;.repositories[0:5][] | sub(&quot;^cybs/&quot;; &quot;&quot;)&#39;\r\n\r\nAlso note that `to_entries | map( .value )` is a [NOP][3] and should be removed.\r\n\r\nOutput:\r\n\r\n    centos\r\n    containersol/consul-server\r\n    containersol/mesos-agent\r\n    containersol/mesos-master\r\n    address-api\r\n\r\n\r\n  [2]: https://stedolan.github.io/jq/manual/#sub(regex;tostring)sub(regex;string;flags)\r\n  [3]: https://en.wikipedia.org/wiki/NOP",
                "title": "Strip a particular word from the beginning of string in jq output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1465941066,
        "creation_date": 1465922815,
        "last_edit_date": 1465932772,
        "question_id": 37817820,
        "body_markdown": "I am getting list of values as below using the curl command:  \r\n\r\n    curl -s http://internal.registry.com/v2/_catalog | jq -r &#39;.repositories[0:5] | to_entries | map( .value )[]&#39;\r\n\r\nOutput:  \r\n\r\n    centos\r\n    containersol/consul-server\r\n    containersol/mesos-agent\r\n    containersol/mesos-master\r\n    cybs/address-api\r\n\r\nI want to make sure that output should not have the prefix `cybs/` in it. for example, `cybs/address-api` should just be `address-api`\r\n\r\n",
        "link": "https://stackoverflow.com/questions/37817820/strip-a-particular-word-from-the-beginning-of-string-in-jq-output",
        "title": "Strip a particular word from the beginning of string in jq output"
    },
    {
        "tags": [
            "bash",
            "curl",
            "grep",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1465943322,
                "post_id": 37823145,
                "comment_id": 63109891,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 476555,
                    "reputation": 47257,
                    "user_id": 887539,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/5baef9617bdee6db2f534c118bcbccee?s=256&d=identicon&r=PG",
                    "display_name": "Andreas Louv",
                    "link": "https://stackoverflow.com/users/887539/andreas-louv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1465943394,
                "post_id": 37823145,
                "comment_id": 63109911,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1465944204,
                "last_edit_date": 1465944204,
                "creation_date": 1465943815,
                "answer_id": 37823248,
                "question_id": 37823145,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming you actually have an array around the three objects:\r\n\r\n    $ curl ... | jq -r &#39;.[].name&#39;\r\n    Dev_ReleaseRollout_Lane-3\r\n    Dev_ReleaseRollout_Lane-latest\r\n    Payments_Dev_Lane-267\r\n\r\nIt&#39;s fairly simple, `.` is the array, `[].name` take name from each element in the array. `-r` is raw output.\r\n\r\n&gt; `--raw-output / -r:`  \r\n&gt; With this option, if the filter’s result is a string then it will be written directly to standard output rather than being formatted as a JSON string with quotes. This can be useful for making jq filters talk to non-JSON-based systems.\r\n\r\nIf the cURL output is actually as mentioned above the following will work:\r\n\r\n    jq -rRs &#39;&quot;[\\(.)]&quot; | fromjson[].name&#39; file.json\r\n\r\nHowever I think there is a better way to wrap an array around input,\r\n\r\n`-R` is raw input and `-s` is slurp. `\\(...)` is [string interpolation][1].\r\n\r\n&gt; `--slurp/-s:`  \r\n&gt; Instead of running the filter for each JSON object in the input, read the entire input stream into a large array and run the filter just once.\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Stringinterpolation-%5C(foo)",
                "title": "How to retrieve &quot;name&quot; value from json using bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1465944204,
        "creation_date": 1465943192,
        "question_id": 37823145,
        "body_markdown": "I am using the following curl command:  \r\n\r\n    curl -s  -v --user admin:orca --insecure -X GET https://insecure.registry.com/api/v0/repositories/authi-api/tags  \r\n\r\nGetting following output:  \r\n\r\n       {\r\n        &quot;name&quot;: &quot;Dev_ReleaseRollout_Lane-3&quot;,\r\n        &quot;inRegistry&quot;: true,\r\n        &quot;hashMismatch&quot;: false,\r\n        &quot;inNotary&quot;: false\r\n       },\r\n       {\r\n        &quot;name&quot;: &quot;Dev_ReleaseRollout_Lane-latest&quot;,\r\n        &quot;inRegistry&quot;: true,\r\n        &quot;hashMismatch&quot;: false,\r\n        &quot;inNotary&quot;: false\r\n       },\r\n       {\r\n        &quot;name&quot;: &quot;Payments_Dev_Lane-267&quot;,\r\n        &quot;inRegistry&quot;: true,\r\n        &quot;hashMismatch&quot;: false,\r\n        &quot;inNotary&quot;: false\r\n       }\r\n\r\nI want to get only `name` values in a variable.  \r\nI need only `Dev_ReleaseRollout_Lane-3` `Dev_ReleaseRollout_Lane-latest` `Payments_Dev_Lane-267` in a variable",
        "link": "https://stackoverflow.com/questions/37823145/how-to-retrieve-name-value-from-json-using-bash",
        "title": "How to retrieve &quot;name&quot; value from json using bash?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 25,
                "is_accepted": true,
                "score": 25,
                "last_activity_date": 1466098583,
                "creation_date": 1466098583,
                "answer_id": 37865896,
                "question_id": 37864617,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This was actually relatively straight forward:\r\n\r\n    .things | .[] | {name: .name, category: .params | .[] | select(.key==&quot;category&quot;) | .value }",
                "title": "How to use jq to create an object with an arbitrary key from a sub array?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1466099082,
                "creation_date": 1466099082,
                "answer_id": 37866051,
                "question_id": 37864617,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your `params` almost looks like key/value entries, so you could create an object out of them by passing the array to `from_entries`.  So to combine everything, you merely need to do this:\r\n\r\n    .things | map({name} + (.params | from_entries))\r\n\r\nThis yields:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;foo&quot;,\r\n        &quot;key1&quot;: &quot;val1&quot;,\r\n        &quot;category&quot;: &quot;thefoocategory&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;bar&quot;,\r\n        &quot;key1&quot;: &quot;val1&quot;,\r\n        &quot;category&quot;: &quot;thebarcategory&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "How to use jq to create an object with an arbitrary key from a sub array?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 17,
        "last_activity_date": 1559335403,
        "creation_date": 1466094297,
        "last_edit_date": 1559335403,
        "question_id": 37864617,
        "body_markdown": "Please feel free to edit the title, I am not sure how to best express it :).\r\n\r\nI have JSON that, for example, looks like this: \r\n\r\n    {\r\n      &quot;things&quot;: [\r\n         {\r\n            &quot;name&quot;: &quot;foo&quot;,\r\n            &quot;params&quot;: [\r\n               {\r\n                 &quot;type&quot;: &quot;t1&quot;,\r\n                  &quot;key&quot;: &quot;key1&quot;,\r\n                  &quot;value&quot;: &quot;val1&quot;\r\n               },\r\n               {\r\n                  &quot;type&quot;: &quot;t1&quot;,\r\n                  &quot;key&quot;: &quot;category&quot;,\r\n                  &quot;value&quot;: &quot;thefoocategory&quot;\r\n               }\r\n            ]\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;bar&quot;,\r\n            &quot;params&quot;: [\r\n               {\r\n                 &quot;type&quot;: &quot;t1&quot;,\r\n                 &quot;key&quot;: &quot;key1&quot;,\r\n                 &quot;value&quot;: &quot;val1&quot;\r\n               },\r\n               {\r\n                 &quot;type&quot;: &quot;t1&quot;,\r\n                 &quot;key&quot;: &quot;category&quot;,\r\n                 &quot;value&quot;: &quot;thebarcategory&quot;\r\n               }\r\n            ]\r\n         }\r\n      ]\r\n    }\r\n\r\nWhat I am trying to achieve is output that looks like\r\n\r\n    [\r\n      {\r\n        name: &quot;foo&quot;,\r\n        category: &quot;thefoocategory&quot;\r\n      },\r\n      {\r\n        name: &quot;bar&quot;,\r\n        category: &quot;thebarcategory&quot;\r\n      }\r\n    ]\r\n\r\nI am able to extract the names quite easily with `jq &#39; .things | .[] | .name&#39;`\r\n\r\nI can also extract the categories with `jq &#39; .things | .[] | .params | .[] | select(.key == &quot;category&quot;) | .value&#39;`\r\n\r\nBut I have not been able to combine them.\r\n\r\nAny help appreciated\r\n\r\n",
        "link": "https://stackoverflow.com/questions/37864617/how-to-use-jq-to-create-an-object-with-an-arbitrary-key-from-a-sub-array",
        "title": "How to use jq to create an object with an arbitrary key from a sub array?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1466099318,
                "creation_date": 1466099318,
                "answer_id": 37866103,
                "question_id": 37865259,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As of jq 1.5, you could do regular expression matching.  So with that, just filter your array.\r\n\r\n    map(select(test(&quot;\\\\borange\\\\b&quot;)))",
                "title": "Json JQ Filter with Wildcard in Bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1466116620,
                "creation_date": 1466116620,
                "answer_id": 37870481,
                "question_id": 37865259,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`startswith` and `contains` can do this just fine. Use `select` to filter values by true/false:\r\n\r\n    map(select(startswith(&quot;orange&quot;)))",
                "title": "Json JQ Filter with Wildcard in Bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1694437596,
                "creation_date": 1694437596,
                "answer_id": 77081923,
                "question_id": 37865259,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "if you run this command :-\r\n\r\necho &#39;[ &quot;orange-1234&quot;, &quot;orange-12345&quot;, &quot;apple-1234&quot; ]&#39; | jq &#39;map(select(test(orange)))&#39;\r\n\r\nyou get the following output :\r\n\r\n[ &quot;orange-1234&quot;, &quot;orange-12345&quot; ]\r\n\r\nhere map expects a function which helps in filtering the elements, so here jq is essentially iterating over all elements, and selecting only those which return true for test(orange), which is a regex check ",
                "title": "Json JQ Filter with Wildcard in Bash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1694437596,
        "creation_date": 1466096400,
        "question_id": 37865259,
        "body_markdown": "Json input:\r\n\r\n    [ &quot;orange-1234&quot;, &quot;orange-12345&quot;, &quot;apple-1234&quot; ]\r\n\r\nDesired output:\r\n\r\n    [ &quot;orange-1234, &quot;orange-12345&quot; ]\r\n\r\nVia bash, I would like to use jq to find the values starting or containing orange*\r\n\r\nI would like the output to contain the complete value.  I have explored using jq startswith and contains, but only was able to return true or false\r\n",
        "link": "https://stackoverflow.com/questions/37865259/json-jq-filter-with-wildcard-in-bash",
        "title": "Json JQ Filter with Wildcard in Bash"
    }
]