[
    {
        "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": 1,
                "creation_date": 1511383583,
                "post_id": 47442344,
                "comment_id": 81842295,
                "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": 3,
                "creation_date": 1511383639,
                "post_id": 47442344,
                "comment_id": 81842319,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1511383867,
                "last_edit_date": 1511383867,
                "creation_date": 1511382738,
                "answer_id": 47443431,
                "question_id": 47442344,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could use process substitution and `--slurpfile` option to solve your issue:\r\n\r\n\r\n    MERGEDENTRY=$(echo &quot;$SOURCE&quot; | jq --slurpfile json &lt;(printf &#39;%s\\n&#39; &quot;$ADDITIONALJSONDATA&quot;) &#39;. += $json[0]&#39; | tr -d &#39;\\r\\n&#39;)\r\n\r\nAs per Charles&#39; suggestion, we can simplify further by using `&lt;&lt;&lt;` instead of `echo &quot;$SOURCE&quot; | ...`:\r\n\r\n    MERGEDENTRY=$(jq --slurpfile json &lt;(printf &#39;%s\\n&#39; &quot;$ADDITIONALJSONDATA&quot;) &#39;. += $json[0]&#39; &lt;&lt;&lt; &quot;$SOURCE&quot; | tr -d &#39;\\r\\n&#39;)\r\n",
                "title": "Merging a long JSON with another using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1511829712,
                "last_edit_date": 1511829712,
                "creation_date": 1511389814,
                "answer_id": 47444853,
                "question_id": 47442344,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. If, as seems to be the case here, you already have $DATA and $DATATYPE, there is no need for ADDITIONALJSONDATA\r\n\r\n2. In general, using `tr -d &#39;\\r\\n&#39;` here is very bad practice, e.g. because it could scrunch 1 and 2 together to make 12\r\n\r\nHopefully the following will meet your requirements:\r\n\r\n    MERGEDENTRY=$(jq -c --arg TYPE &quot;$DATATYPE&quot; --slurpfile A &lt;(printf &#39;%s\\n&#39; &quot;$DATA&quot;) &#39;\r\n      . += {($TYPE): $A[0]}&#39; &lt;&lt;&lt; &quot;$SOURCE&quot;)\r\n\r\n(We need to use `$A[0]` here because &quot;slurping&quot; puts $DATA into an array.) ",
                "title": "Merging a long JSON with another using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1511435653,
                "creation_date": 1511435653,
                "answer_id": 47454171,
                "question_id": 47442344,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I managed to do it far easier:\r\n``MERGEDENTRY=${source::-1}&quot;,&quot;\\&quot;$data_type\\&quot;&quot;:&quot;$data&quot;,&quot;``\r\nAnd then just keep in mind we need to end JSON payload properly by replacing `&#39;` by `}`.\r\n\r\nI can do this as I&#39;m always adding new JSON payload at the end of existing one.",
                "title": "Merging a long JSON with another using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1511829712,
        "creation_date": 1511378337,
        "last_edit_date": 1511383902,
        "question_id": 47442344,
        "body_markdown": "I need to do some CURLs from which I&#39;m building one output JSON. This is how I managed to perform a merge using a function:\r\n\r\n    ...\r\n    ADDITIONALJSONDATA=&quot;{\\&quot;$DATATYPE\\&quot; : &quot;$DATA&quot;}&quot; \r\n    MERGEDENTRY=$(echo $SOURCE | jq --argjson json &quot;$ADDITIONALJSONDATA&quot; &#39;. += $json&#39; | tr -d &#39;\\r\\n&#39;)\r\n     ...\r\n\r\nIt seems when JSON inside `$DATA` is big enough then I&#39;m getting `Argument list too long` error. Is it possible (in a nice way) to treat JSON to merge as a single argument here?",
        "link": "https://stackoverflow.com/questions/47442344/merging-a-long-json-with-another-using-jq",
        "title": "Merging a long JSON with another using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1511616511,
                "last_edit_date": 1511616511,
                "creation_date": 1511409416,
                "answer_id": 47447313,
                "question_id": 47445219,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First, rest assured that if you can formulate the requirements a bit more precisely, jq will be up to the task.\r\n\r\nIn fact, the following, which is just a small variation of what you already have, should meet the requirements as I currently understand them:\r\n\r\n    ..\r\n    | ((.opts.vulns | index(&quot;!CVE-2014-0160&quot;))? // empty) as $ix\r\n    | [.ip_str, .isp, .timestamp, .opts.vulns[$ix]]\r\n    | @csv\r\n\r\nWith the pastebin data, this produces:\r\n\r\n    &quot;196.196.216.13&quot;,&quot;Fiber Grid Inc&quot;,&quot;2017-08-29T06:57:22.546423&quot;,&quot;!CVE-2014-0160&quot;\r\n\r\n(I have included the computation of $ix in case you want a more complex matching criterion.)\r\n\r\n### Parameterization\r\nIf you want to parameterize the string to search for, replace it by (for example) `$string` in the jq program, and invoke jq like so \r\n\r\n    jq -r --arg string &quot;!CVE-2014-0160&quot; ......\r\n\r\nFor example:\r\n\r\n    jq -r --arg string &quot;!CVE-2014-0160&quot; -f program.jq shodan_data.json\r\n\r\n### Being agnostic about the location of the string of interest within the .isp object\r\n\r\n\r\n    jq -r —arg string &quot;!CVE-2014-0160&quot; &#39;..|select(.isp?)|. as $x\r\n      | select(..==$string)|$x|[.ip,.ip_str]|@csv’ data.json\r\n",
                "title": "jq - filtering JSON by searching key values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1511616511,
        "creation_date": 1511392092,
        "question_id": 47445219,
        "body_markdown": "Data sample - shodan_data.json (full sample: https://pastebin.com/KFkVmc2M)\r\n\r\n    {\r\n          &quot;ip&quot;: 3301234701,\r\n          &quot;_shodan&quot;: {\r\n            &quot;options&quot;: {\r\n              &quot;referrer&quot;: &quot;7ae15507-f5cc-4353-b72e-5cc0b1c34c5e&quot;\r\n            },\r\n          },\r\n          &quot;hash&quot;: -1056085507,\r\n          &quot;os&quot;: null,\r\n          &quot;title&quot;: &quot;WHM Login&quot;,\r\n          &quot;opts&quot;: {\r\n            &quot;vulns&quot;: [&quot;!CVE-2014-0160&quot;],\r\n            &quot;heartbleed&quot;: &quot;2017/08/29 09:57:30 196.196.216.13:2087 - SAFE\\\r\n            }\r\n          },\r\n          &quot;isp&quot;: &quot;Fiber Grid Inc&quot;,\r\n          &quot;http&quot;: {\r\n            &quot;redirects&quot;: [],\r\n            &quot;title&quot;: &quot;WHM Login&quot;,\r\n            &quot;robots&quot;: null,\r\n            &quot;favicon&quot;: null,\r\n            &quot;host&quot;: &quot;196.196.216.13&quot;,\r\n            &quot;html&quot;:\r\n    }\r\n\r\nMy `jq` code:\r\n\r\n    jq -r &#39;select((.opts.vulns[0] | contains(&quot;!CVE-2014-0160&quot;)))? | [&#39;.ip_str&#39;, &#39;.isp&#39;, &#39;.timestamp&#39;, .opts.vulns[0]] | @csv&#39; shodan_data.json\r\n\r\nExample output when using full dataset:\r\n\r\n    &quot;165.231.171.237&quot;,&quot;Fiber Grid Inc&quot;,&quot;2017-08-22T02:24:07.658547&quot;,&quot;!CVE-2014-0160&quot;\r\n\r\nRight now what it does is that it&#39;s searching for a specific JSON object `.opts.vulns[0]` with a value `!CVE-2014-0160` then filters the entire object where the value was found and prints the object values specified `.ip_str&#39;, &#39;.isp&#39;, &#39;.timestamp&#39;, .opts.vulns[0]` as csv. Also suppresses any errors where the searchable value isn&#39;t found which allows me to write the output to a .csv file.\r\n\r\nWhat I would like it to do is to take whatever value I would like to find, like in the example `!CVE-2014-0160` (like a search engine) and be able to recursively go through the entire JSON dataset and have the same end result as my code atm.\r\n\r\nI&#39;ve been trying to figure this one out and have been trying out `..` recursive descent and other methods but the way I&#39;m filtering the data seems to indicate that what I&#39;m trying to accomplish might need a different approach if even possible?",
        "link": "https://stackoverflow.com/questions/47445219/jq-filtering-json-by-searching-key-values",
        "title": "jq - filtering JSON by searching key values"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4677143,
                    "reputation": 15627,
                    "user_id": 3787051,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/k2G2V.png?s=256",
                    "display_name": "Alex Harvey",
                    "link": "https://stackoverflow.com/users/3787051/alex-harvey"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1511402248,
                "post_id": 47446387,
                "comment_id": 81848183,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 22779,
                    "reputation": 132266,
                    "user_id": 56541,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://i.sstatic.net/Wm7Xg.png?s=256",
                    "display_name": "David Z",
                    "link": "https://stackoverflow.com/users/56541/david-z"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1511403329,
                "post_id": 47446387,
                "comment_id": 81848401,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1511459791,
                "post_id": 47446387,
                "comment_id": 81876985,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1511403298,
                "creation_date": 1511403298,
                "answer_id": 47446562,
                "question_id": 47446387,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Bash executes loops in a subshell if they are part of a pipeline. See for example [BashFAQ/024](http://mywiki.wooledge.org/BashFAQ/024) and &quot;[Bash Script: While-Loop Subshell Dilemma](https://stackoverflow.com/questions/13726764/bash-script-while-loop-subshell-dilemma)&quot;.\r\n\r\nA possible workaround is to use process substitution:\r\n\r\n    while read tag; do\r\n      ...\r\n    done &lt; &lt;(jq -r &#39;. | keys[]&#39; &lt;&lt;&lt; &quot;$1&quot;)",
                "title": "Bash variable scope issue"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1511403298,
        "creation_date": 1511401593,
        "last_edit_date": 1511402817,
        "question_id": 47446387,
        "body_markdown": "I am struggling to understand what the cause of the following bug is and how I can fix it.\r\n\r\nI have this code:\r\n\r\n    set_filters() {\r\n      json=$1\r\n      filters=&#39;&quot;Name=instance-state-name,Values=running,stopped&quot;&#39;\r\n      echo $json | jq -r &#39;. | keys[]&#39; | \\\r\n        while read tag ; do\r\n          value=$(echo &quot;$json&quot; | jq -r &quot;.[\\&quot;$tag\\&quot;]&quot;)\r\n          filters=&quot;$filters \\&quot;Name=tag:${tag},Values=${value}\\&quot;&quot;\r\n        done\r\n      echo $filters\r\n    }\r\n    \r\n    set_filters &#39;{&quot;Name&quot;: &quot;*FOO*&quot;, &quot;Cost Center&quot;: &quot;XX111&quot;}&#39;\r\n\r\nThe output I am expecting:\r\n\r\n    &quot;Name=instance-state-name,Values=running,stopped&quot; &quot;Name=tag:Cost Center,Values=XX111&quot; &quot;Name=tag:Name,Values=*FOO*&quot;\r\n\r\nThe output I am getting:\r\n\r\n    &quot;Name=instance-state-name,Values=running,stopped&quot; \r\n\r\nIf I insert echo statements to assist with debugging:\r\n\r\n    set_filters() {\r\n      json=$1\r\n      filters=&#39;&quot;Name=instance-state-name,Values=running,stopped&quot;&#39;\r\n      echo $json | jq -r &#39;. | keys[]&#39; | \\\r\n        while read tag ; do\r\n          value=$(echo &quot;$json&quot; | jq -r &quot;.[\\&quot;$tag\\&quot;]&quot;)\r\n          filters=&quot;$filters \\&quot;Name=tag:${tag},Values=${value}\\&quot;&quot;\r\n          echo &quot;FILTERS INSIDE LOOP: $filters&quot;\r\n        done\r\n      echo &quot;FILTERS OUTSIDE LOOP: $filters&quot;\r\n    }\r\n\r\nThe output I then get is:\r\n\r\n    FILTERS INSIDE LOOP: &quot;Name=instance-state-name,Values=running,stopped&quot; &quot;Name=tag:Cost Center,Values=XX111&quot;\r\n    FILTERS INSIDE LOOP: &quot;Name=instance-state-name,Values=running,stopped&quot; &quot;Name=tag:Cost Center,Values=XX111&quot; &quot;Name=tag:Name,Values=*FOO*&quot;\r\n    FILTERS OUTSIDE LOOP: &quot;Name=instance-state-name,Values=running,stopped&quot;\r\n\r\n\r\nI can&#39;t explain the behaviour. In a language other than Bash I would assume a variable scope issue for the variable `$filters`, but I thought the scope would basically be global.\r\n\r\nI am using JQ version 1.3 and Bash version 4.1.2 on Red Hat Enterprise Linux 6.8.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/47446387/bash-variable-scope-issue",
        "title": "Bash variable scope issue"
    },
    {
        "tags": [
            "arrays",
            "json",
            "merge",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1511475580,
                "post_id": 47461167,
                "comment_id": 81882579,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1225336,
                    "reputation": 541,
                    "user_id": 1190994,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://www.gravatar.com/avatar/e6739f3b2bc14e81cb2a8eb7c9ee0f9e?s=256&d=identicon&r=PG",
                    "display_name": "kishore",
                    "link": "https://stackoverflow.com/users/1190994/kishore"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1511488694,
                "post_id": 47461167,
                "comment_id": 81885399,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1511504278,
                "creation_date": 1511504278,
                "answer_id": 47467396,
                "question_id": 47461167,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a possible solution assuming your sample data is in `file1.json`, `file2.json` and `file3.json`:\r\n\r\n    $ jq -Mn &#39;\r\n        reduce inputs as $i ({}; \r\n         reduce ($i|keys[]) as $k (.; .[$k] += $i[$k])) \r\n      | del(.links)\r\n    &#39; file1.json file2.json file3.json\r\n    {\r\n      &quot;projects&quot;: [\r\n        {\r\n          &quot;id&quot;: 15658857,\r\n          &quot;code&quot;: &quot;111&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 15623456,\r\n          &quot;code&quot;: &quot;122&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 15658857,\r\n          &quot;code&quot;: &quot;211&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 15658857,\r\n          &quot;code&quot;: &quot;311&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 15623456,\r\n          &quot;code&quot;: &quot;322&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 13438719,\r\n          &quot;code&quot;: &quot;333&quot;\r\n        }\r\n      ],\r\n      &quot;total_entries&quot;: 7173\r\n    }\r\n\r\nNote that this adds the values for `total_entries` from each file giving a different total then the one in the requested output.  ",
                "title": "Merging several json files with a common array element"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1511580558,
                "last_edit_date": 1511580558,
                "creation_date": 1511512942,
                "answer_id": 47469371,
                "question_id": 47461167,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following is essentially the same as @jq170727&#39;s solution, but packages the key abstraction into a function that may be worthy of your standard jq library:\r\n\r\n    # Gather by key all the values of the objects in a stream\r\n    def buckets(stream): reduce stream as $x ({};\r\n      reduce ($x|keys_unsorted[]) as $key (.;\r\n        .[$key] += [$x[$key]] ) );\r\n\r\nWith this in place, the solution becomes simply:\r\n\r\n    buckets(inputs) | map_values(add) | del(.links)\r\n\r\n### Standard Library\r\nFor example, if your standard jq library is in ~/.jq/jq/jq.jq then you could use the following one-liner:\r\n\r\n    jq -n &#39;include &quot;jq&quot;; buckets(inputs) | map_values(add) | del(.links)&#39; file{1,2,3}.json\r\n\r\n### Addendum re: `total_entries`\r\nOP asked:\r\n\r\n&gt; what do I need to do if I don&#39;t want to add the total_entries from each of the file, I would like to take the value from the first file only\r\n\r\nThe following modification of the above program will use the first-encountered value for `total_entries`:\r\n\r\n    buckets(inputs)\r\n    | . as $buckets\r\n    | map_values(add)\r\n    | del(.links) + {total_entries: $buckets[&quot;total_entries&quot;][0]}\r\n\r\n",
                "title": "Merging several json files with a common array element"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1511798093,
        "creation_date": 1511459704,
        "last_edit_date": 1511798093,
        "question_id": 47461167,
        "body_markdown": "I have several groups of json files where each group follows common pattern of data as below:\r\n\r\nfile 1:\r\n\r\n    {\r\n      &quot;projects&quot;: [\r\n        {\r\n          &quot;id&quot;: 15658857,\r\n          &quot;code&quot;: &quot;111&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 15623456,\r\n          &quot;code&quot;: &quot;122&quot;\r\n        }\r\n      ],\r\n      &quot;total_entries&quot;: 1391,\r\n      &quot;links&quot;: {\r\n        &quot;next&quot;: &quot;https://api.xxx.com/projects?page=12&amp;per_page=100&quot;,\r\n        &quot;last&quot;: &quot;https://api.xxx.com/projects?page=14&amp;per_page=100&quot;\r\n      }\r\n    }\r\n\r\nfile 2:\r\n\r\n    {\r\n      &quot;projects&quot;: [\r\n        {\r\n          &quot;id&quot;: 15658857,\r\n          &quot;code&quot;: &quot;211&quot;\r\n        }\r\n      ],\r\n      &quot;total_entries&quot;: 2391,\r\n      &quot;links&quot;: {\r\n        &quot;next&quot;: &quot;https://api.xxx.com/projects?page=22&amp;per_page=100&quot;,\r\n        &quot;last&quot;: &quot;https://api.xxx.com/projects?page=24&amp;per_page=100&quot;\r\n      }\r\n    } \r\n\r\nFile 3:\r\n\r\n    {\r\n      &quot;projects&quot;: [\r\n        {\r\n          &quot;id&quot;: 15658857,\r\n          &quot;code&quot;: &quot;311&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 15623456,\r\n          &quot;code&quot;: &quot;322&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 13438719,\r\n          &quot;code&quot;: &quot;333&quot;\r\n        }\r\n      ],\r\n      &quot;total_entries&quot;: 3391,\r\n      &quot;links&quot;: {\r\n        &quot;next&quot;: &quot;https://api.xxx.com/projects?page=32&amp;per_page=100&quot;,\r\n        &quot;last&quot;: &quot;https://api.xxx.com/projects?page=34&amp;per_page=100&quot;\r\n      }\r\n    }\r\n\r\nThe above 3 files are sample files of a group and each file in this group has an array element &quot;projects&quot;. Other groups have same structure but different array element name.\r\nI need to merge all the files of a group into a single file per group. The output of the above files is expected as:\r\n\r\n    {\r\n      &quot;projects&quot;: [\r\n        {\r\n          &quot;id&quot;: 15658857,\r\n          &quot;code&quot;: &quot;111&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 15623456,\r\n          &quot;code&quot;: &quot;122&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 15658857,\r\n          &quot;code&quot;: &quot;211&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 15658857,\r\n          &quot;code&quot;: &quot;311&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 15623456,\r\n          &quot;code&quot;: &quot;322&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 13438719,\r\n          &quot;code&quot;: &quot;333&quot;\r\n        }\r\n      ],\r\n      &quot;total_entries&quot;: 1391\r\n    }\r\n\r\nI used the following jq code to achieve this. \r\n\r\n    jq -s &quot;.[0].projects=([.[].projects]|flatten)|.[0] | del(.links)&quot; file[123].json\r\n\r\nBut I am not happy with this as I have to hard code array element name &quot;projects&quot; in this case. I am looking for a solution where array element name doesn&#39;t need to be specified, so I can use that expression for every of similar content file.\r\nThanks for the help. ",
        "link": "https://stackoverflow.com/questions/47461167/merging-several-json-files-with-a-common-array-element",
        "title": "Merging several json files with a common array element"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1511503182,
                "creation_date": 1511503182,
                "answer_id": 47467169,
                "question_id": 47464756,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is one solution, assuming the data is in `data.json`:\r\n\r\n    $ jq -M &#39;.sysstat.hosts[0].statistics[0].&quot;cpu-load&quot;[0].idle&#39; data.json\r\n    92.69\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/4Y2Ucl0I2C)",
                "title": "jq | to return specific item in nested json object"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1511512036,
                "creation_date": 1511512036,
                "answer_id": 47469159,
                "question_id": 47464756,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In this particular case, a short-and-sweet solution is:\r\n\r\n    .. | .idle? // empty\r\n\r\nIf the location of &quot;idle&quot; is important, then in case it appears more than once (or not at all), you may wish to consider:\r\n\r\n    .sysstat.hosts[].statistics[] | .[&quot;cpu-load&quot;][] | .idle\r\n",
                "title": "jq | to return specific item in nested json object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1511512036,
        "creation_date": 1511482097,
        "last_edit_date": 1511507022,
        "question_id": 47464756,
        "body_markdown": "I am new to jq and cannot work out how to get idle value from the above json.  By using jq command to retrieve json.  How do I get idle value using jq?\r\n\r\n    {\r\n      &quot;sysstat&quot;: {\r\n        &quot;hosts&quot;: [\r\n          {\r\n            &quot;nodename&quot;: &quot;localhost.localdomain&quot;,\r\n            &quot;sysname&quot;: &quot;Linux&quot;,\r\n            &quot;release&quot;: &quot;4.13.13-200.fc26.x86_64&quot;,\r\n            &quot;machine&quot;: &quot;x86_64&quot;,\r\n            &quot;number-of-cpus&quot;: 2,\r\n            &quot;date&quot;: &quot;24/11/17&quot;,\r\n            &quot;statistics&quot;: [\r\n              {\r\n                &quot;timestamp&quot;: &quot;00:00:45&quot;,\r\n                &quot;cpu-load&quot;: [\r\n                  {\r\n                    &quot;cpu&quot;: &quot;0&quot;,\r\n                    &quot;usr&quot;: 5.08,\r\n                    &quot;nice&quot;: 0.03,\r\n                    &quot;sys&quot;: 1.31,\r\n                    &quot;iowait&quot;: 0.07,\r\n                    &quot;irq&quot;: 0.73,\r\n                    &quot;soft&quot;: 0.09,\r\n                    &quot;steal&quot;: 0,\r\n                    &quot;guest&quot;: 0,\r\n                    &quot;gnice&quot;: 0,\r\n                    &quot;idle&quot;: 92.69\r\n                  }\r\n                ]\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    }",
        "link": "https://stackoverflow.com/questions/47464756/jq-to-return-specific-item-in-nested-json-object",
        "title": "jq | to return specific item in nested json object"
    },
    {
        "tags": [
            "bash",
            "curl",
            "jq",
            "quoting"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1511852241,
                "post_id": 47525421,
                "comment_id": 82007214,
                "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": 1,
                "creation_date": 1511852573,
                "post_id": 47525421,
                "comment_id": 82007359,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 246603,
                    "reputation": 930,
                    "user_id": 520843,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/711a181409e23c300b82404544166deb?s=256&d=identicon&r=PG",
                    "display_name": "grail",
                    "link": "https://stackoverflow.com/users/520843/grail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1511858224,
                "post_id": 47525421,
                "comment_id": 82010280,
                "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": 1511858654,
                "post_id": 47525421,
                "comment_id": 82010559,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1511867523,
                "last_edit_date": 1511867523,
                "creation_date": 1511864729,
                "answer_id": 47529182,
                "question_id": 47525421,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To debug cases like this, it&#39;s best to break things down into the basic components first.  In your case, I&#39;d guess you intended the jq filter to be:\r\n\r\n    [.field1,.field2] | &quot;\\(.[0]), \\(.[1])&quot;\r\n\r\nTo test:\r\n\r\n     jq -r -c &#39;[.field1,.field2] | &quot;\\(.[0]), \\(.[1])&quot;&#39;\r\n     {&quot;field1&quot;: 1, &quot;field2&quot;: 2}\r\n     1, 2\r\n\r\nOnce you have that part right, the rest is easy.  Assuming you are using a decent shell, you could probably make life simple for yourself by using `$()` rather than `&quot;$()&quot;`, or avoiding command substitution altogether. \r\n\r\nFrom the development and testing point of view, it might make sense to put the jq program that you know to be correct into a file, say program.jq, and then you can in sequence:\r\n\r\n(a) verify it in stand-alone mode, using `jq -r -c -f program.jq`\r\n\r\n(b) plug the jq invocation into your pipeline to verify that there isn&#39;t another problem elsewhere.\r\n\r\nIf using program.jq isn&#39;t ultimately satisfactory, you might want to consider setting a shell variable to the jq program, e.g.\r\n\r\n    JQ=&#39;[.field1,.field2] | &quot;\\(.[0]), \\(.[1])&quot;&#39;\r\n\r\n    echo $(jq -r -c &quot;$JQ&quot;)\r\n\r\nOf course the last line above is just there for testing.  Maybe you don&#39;t even need `$()` at all?\r\n\r\n\r\n",
                "title": "Brace usage error while using curl with in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1511867523,
        "creation_date": 1511851332,
        "last_edit_date": 1511852441,
        "question_id": 47525421,
        "body_markdown": "Following curl usage is not liking braces inside braces. I tried escaping but it didnt help ... any ideas?\r\n\r\n    echo &quot;$(curl -s -u ${USERNAME}:${PASSWORD} GET ${hostName}/${path}.json| jq -r -c &#39;[.field1,.field2] | \\&quot;(.[0]) ,(.[1])&quot;&#39;)&quot;\r\n\r\nResult:\r\n\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell\r\n    quoting issues?) at &lt;top-level&gt;, line 1:\r\n    \r\n    error near (.[0]`)`",
        "link": "https://stackoverflow.com/questions/47525421/brace-usage-error-while-using-curl-with-in-bash",
        "title": "Brace usage error while using curl with in bash"
    },
    {
        "tags": [
            "json",
            "powershell",
            "encoding",
            "utf-8",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5882981,
                    "reputation": 331,
                    "user_id": 4631824,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/JS6Cu.jpg?s=256",
                    "display_name": "Robin G&#252;ldenpfennig",
                    "link": "https://stackoverflow.com/users/4631824/robin-g%c3%bcldenpfennig"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1512044999,
                "post_id": 47527290,
                "comment_id": 82103724,
                "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": 1744866360,
                "post_id": 47527290,
                "comment_id": 140343182,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1512046889,
                "last_edit_date": 1512046889,
                "creation_date": 1511862750,
                "answer_id": 47528483,
                "question_id": 47527290,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You don’t mention which version of jq you are using, but I strongly suspect you have encountered a bug which has since been fixed. I believe the most recent UTF-8 bug was fixed by\r\nhttps://github.com/stedolan/jq/pull/1317\r\nin late January. Unfortunately, this means that for a fix, you’ll most likely need a version of jq more recent than 1.5.\r\n\r\nSince you are using Windows, I would suggest looking at https://github.com/stedolan/jq/wiki/Installation#windows-using-appveyor\r\n\r\n### Code Page\r\n\r\nMaybe changing the code page will help? At the command prompt, first run `chcp` to ascertain the current code page; if it is not already 65001, run `chcp 65001`.\r\n\r\nSee also https://superuser.com/questions/237081/whats-the-code-page-of-utf-8\r\n\r\n### Verification on a Mac\r\n\r\n    $ file john-doe.json\r\n    john-doe.json: UTF-8 Unicode text\r\n    \r\n    $ cat  john-doe.json\r\n    &quot;John Doe &#220;&#196;&#214;&quot;\r\n    \r\n    $ jq --version\r\n    jq-1.5\r\n    \r\n    $ jq . john-doe.json\r\n    &quot;John Doe &#220;&#196;&#214;&quot;\r\n    \r\n    $ jqMaster --version\r\n    jq-1.5rc2-250-g239278f\r\n    \r\n    $ jqMaster . john-doe.json\r\n    &quot;John Doe &#220;&#196;&#214;&quot;\r\n\r\n",
                "title": "How to keep UTF-8 encoding when sorting JSON with jq"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1659482662,
                "creation_date": 1659482662,
                "answer_id": 73214757,
                "question_id": 47527290,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I tried everything mentioned here and still got incorrect output. I had to set `[System.Console]::OutputEncoding=[System.Text.Encoding]::UTF8` in PowerShell and then it works as expected. That&#39;s actually the only thing I had to do.",
                "title": "How to keep UTF-8 encoding when sorting JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1659482662,
        "creation_date": 1511858675,
        "last_edit_date": 1511863368,
        "question_id": 47527290,
        "body_markdown": "I&#39;m using jq 1.5 on Windows PowerShell to sort the fields of a JSON file in an alphabetically order.\r\n\r\nThis works quite fine so far but special characters (like &#220;&#196;&#214;&#252;&#228;&#246;) are not kept in the jq output.\r\n\r\nThe original file is saved in UTF-8 encoding:\r\n\r\n    {\r\n      &quot;sha&quot;: &quot;18879fb99367924cd76d402e841155bf73c8afb3&quot;,\r\n      &quot;commit&quot;: {\r\n        &quot;author&quot;: {\r\n      \t&quot;name&quot;: &quot;John Doe &#220;&#196;&#214;&quot;,\r\n      \t&quot;email&quot;: &quot;john@example.com&quot;,\r\n      \t&quot;date&quot;: &quot;2017-11-23T07:51:22Z&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nAnd this is the jq output saved as UTF-8:\r\n\r\n    {\r\n      &quot;commit&quot;: {\r\n        &quot;author&quot;: {\r\n          &quot;date&quot;: &quot;2017-11-23T07:51:22Z&quot;,\r\n          &quot;email&quot;: &quot;john@example.com&quot;,\r\n          &quot;name&quot;: &quot;John Doe ???&quot;\r\n        }\r\n      },\r\n      &quot;sha&quot;: &quot;18879fb99367924cd76d402e841155bf73c8afb3&quot;\r\n    }\r\n\r\nAs you can see the characters &#220;&#196;&#214; are not recognized and are saved as ???.\r\n\r\nThis is how I use jq in PowerShell:\r\n\r\n    $json = Get-Content .\\json.txt -Encoding UTF8\r\n    $jsonSorted = $json | .\\jq-win64.exe --sort-keys &#39;.&#39;\r\n    Set-Content jsonSorted.txt -Value $jsonSorted -Encoding UTF8\r\n\r\n",
        "link": "https://stackoverflow.com/questions/47527290/how-to-keep-utf-8-encoding-when-sorting-json-with-jq",
        "title": "How to keep UTF-8 encoding when sorting JSON with jq"
    },
    {
        "tags": [
            "json",
            "conditional-statements",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1511863432,
                "last_edit_date": 1511863432,
                "creation_date": 1511863079,
                "answer_id": 47528601,
                "question_id": 47528282,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**jq** solution:\r\n\r\n    jq &#39;.params.context as $ctx \r\n        | {input: {text:.form.textinput1}} \r\n        + (if ($ctx | length) &gt; 0 then {context:$ctx} else {} end)&#39; file.json\r\n\r\n\r\n----------\r\n- `.params.context as $ctx` - assign `.params.context` value into variable `$ctx`\r\n- `if ($ctx | length) &gt; 0` - check if `$ctx` is not empty",
                "title": "How to set up conditional jq transform?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1512059552,
                "last_edit_date": 1512059552,
                "creation_date": 1511863461,
                "answer_id": 47528751,
                "question_id": 47528282,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "jq has two basic conditionals: `if ... then ... else ... end` and `A // B`.  In your case, the first suffices:\r\n\r\n    {&quot;input&quot;: {&quot;text&quot;: .form.textinput1}}\r\n    + (.params.context | if . == &quot;&quot; then null else {&quot;context&quot;:.} end)\r\n\r\nIf you need to apply some transformation, say f, to `.context` if it is not “”, then replace the final `.` by `f`.\r\n\r\n\r\n",
                "title": "How to set up conditional jq transform?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1512059552,
        "creation_date": 1511862169,
        "last_edit_date": 1512059249,
        "question_id": 47528282,
        "body_markdown": "I need to transform a JSON, which can either have 1 value or 2. So it can be:\r\n\r\n    {&quot;form&quot;:{&quot;textinput1&quot;:&quot;aaa&quot;},&quot;params&quot;:{&quot;context&quot;:&quot;&quot;}}\r\n\r\nor\r\n\r\n    {&quot;form&quot;:{&quot;textinput1&quot;:&quot;aaa&quot;},&quot;params&quot;:{&quot;context&quot;: &quot;something&quot;}}\r\n\r\n----------\r\nAnd the output I need is this:\r\n\r\n    {&quot;input&quot;: {&quot;text&quot;: &quot;aaa&quot;}}\r\n\r\nor\r\n\r\n    {&quot;input&quot;: {&quot;text&quot;: &quot;aaa&quot;},&quot;context&quot;: &quot;something&quot;}}\r\n\r\n----------\r\nJQ Transform would be:\r\n\r\n    {&quot;input&quot;: {&quot;text&quot;: .form.textinput1}}\r\nor\r\n\r\n    {&quot;input&quot;: {&quot;text&quot;: .form.textinput1},&quot;context&quot;:.params.context}\r\n\r\n-----------\r\nBut how to merge these two into a condition?",
        "link": "https://stackoverflow.com/questions/47528282/how-to-set-up-conditional-jq-transform",
        "title": "How to set up conditional jq transform?"
    },
    {
        "tags": [
            "json",
            "bash",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1511909363,
                "creation_date": 1511909363,
                "answer_id": 47542238,
                "question_id": 47542110,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you want them as a stream in the original order, use `keys_unsorted[]`;\r\nif you want them to be sorted first, use `keys[]`.\r\n ",
                "title": "Parsing JSON wih bash jq: Get top level strings"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1511909415,
        "creation_date": 1511908669,
        "last_edit_date": 1511909415,
        "question_id": 47542110,
        "body_markdown": "Right now I have a JSON file similar to this:\r\n\r\n    {\r\n    \t&quot;string1&quot;:[{\r\n    \t\t&quot;spec1&quot;: &quot;spec1value&quot;,\r\n    \t\t&quot;spec2&quot;: &quot;spec2value&quot;\r\n    \t}],\r\n    \t&quot;string2&quot;:[{\r\n    \t\t&quot;spec1&quot;: &quot;spec1value&quot;,\r\n    \t\t&quot;spec2&quot;: &quot;spec2value&quot;\r\n    \t}],\r\n    \t&quot;string3&quot;:[{\r\n    \t\t&quot;spec1&quot;: &quot;spec1value&quot;,\r\n    \t\t&quot;spec2&quot;: &quot;spec2value&quot;\r\n    \t}]\r\n    }\r\n\r\nI need to retrieve all top values from this JSON, i.e. &quot;string1&quot;, &quot;string2&quot; and &quot;string3&quot;. However I cannot find a good way of doing this.\r\n\r\nIf I had the file formatted like this, it would be much simpler, but I would like to avoid having that extra parameter for every entry:\r\n\r\n    {\r\n    \t&quot;string1&quot;:[{\r\n            &quot;stringName&quot;: &quot;string1&quot;,\r\n    \t\t&quot;spec1&quot;:      &quot;spec1value&quot;,\r\n    \t\t&quot;spec2&quot;:      &quot;spec2value&quot;\r\n    \t}],\r\n    \t&quot;string2&quot;:[{\r\n            &quot;stringName&quot;: &quot;string2&quot;,\r\n    \t\t&quot;spec1&quot;:      &quot;spec1value&quot;,\r\n    \t\t&quot;spec2&quot;:      &quot;spec2value&quot;\r\n    \t}],\r\n    \t&quot;string3&quot;:[{\r\n            &quot;stringName&quot;: &quot;string3&quot;,\r\n    \t\t&quot;spec1&quot;:      &quot;spec1value&quot;,\r\n    \t\t&quot;spec2&quot;:      &quot;spec2value&quot;\r\n    \t}]\r\n    }\r\n\r\nThen I would be able to just do:\r\n\r\n    jq -r &quot;.[][][\\&quot;stringName\\&quot;]&quot; file.json\r\n\r\nAny suggestions on how I could tackle this in a cleaner way?",
        "link": "https://stackoverflow.com/questions/47542110/parsing-json-wih-bash-jq-get-top-level-strings",
        "title": "Parsing JSON wih bash jq: Get top level strings"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1511954353,
                "post_id": 47551333,
                "comment_id": 82059684,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1179851,
                    "reputation": 442,
                    "user_id": 1155021,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3b1fc0aa598b6f00e873c0ff6be7c7ed?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "munikarmanish",
                    "link": "https://stackoverflow.com/users/1155021/munikarmanish"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1511954468,
                "post_id": 47551333,
                "comment_id": 82059741,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1179851,
                    "reputation": 442,
                    "user_id": 1155021,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3b1fc0aa598b6f00e873c0ff6be7c7ed?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "munikarmanish",
                    "link": "https://stackoverflow.com/users/1155021/munikarmanish"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1511955039,
                "post_id": 47551333,
                "comment_id": 82060097,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1511956649,
                "creation_date": 1511956649,
                "answer_id": 47552299,
                "question_id": 47551333,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With **`reduce`** function:\r\n\r\n    jq &#39;reduce .[] as $o ({}; .[$o[&quot;tone_id&quot;]] = $o[&quot;score&quot;])&#39; result.json\r\n\r\nThe output:\r\n\r\n    {\r\n      &quot;anger&quot;: 0.012,\r\n      &quot;disgust&quot;: 0.002,\r\n      &quot;fear&quot;: 0.14,\r\n      &quot;joy&quot;: 0.42\r\n    }\r\n\r\n",
                "title": "jq - convert a list of objects into a summarized object"
            },
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1511963404,
                "last_edit_date": 1511963404,
                "creation_date": 1511959052,
                "answer_id": 47553076,
                "question_id": 47551333,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A single-invocation one-liner:\r\n\r\n\r\n     jq &#39;map( {(.tone_id): .score} ) | add&#39;\r\n\r\n(You could also wrap square brackets around `.[] | { (.tone_id): .score }` before passing to `add` — the two approaches are equivalent.)",
                "title": "jq - convert a list of objects into a summarized object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1511969044,
                "creation_date": 1511969044,
                "answer_id": 47556219,
                "question_id": 47551333,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use `from_entries`:\r\n\r\n    jq &#39;[.[] | {key: .tone_id, value: .score}] | from_entries&#39; tmp.json\r\n    # or jq &#39;map({key: .tone_id, value: .score}) | from_entries&#39; tmp.json\r\n\r\nalthough in this case I don&#39;t see anything to recommend it over @peak&#39;s `add` solution.",
                "title": "jq - convert a list of objects into a summarized object"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 10,
        "last_activity_date": 1511984008,
        "creation_date": 1511953646,
        "last_edit_date": 1511984008,
        "question_id": 47551333,
        "body_markdown": "I have a JSON data like this:\r\n\r\n    [\r\n      {\r\n        &quot;tone_id&quot;: &quot;anger&quot;,\r\n        &quot;score&quot;: 0.012,\r\n        &quot;tone_name&quot;: &quot;Anger&quot;\r\n      },\r\n      {\r\n        &quot;tone_id&quot;: &quot;disgust&quot;,\r\n        &quot;score&quot;: 0.002,\r\n        &quot;tone_name&quot;: &quot;Disgust&quot;\r\n      },\r\n      {\r\n        &quot;tone_id&quot;: &quot;fear&quot;,\r\n        &quot;score&quot;: 0.14,\r\n        &quot;tone_name&quot;: &quot;Fear&quot;\r\n      },\r\n      {\r\n        &quot;tone_id&quot;: &quot;joy&quot;,\r\n        &quot;score&quot;: 0.42,\r\n        &quot;tone_name&quot;: &quot;Joy&quot;\r\n      }\r\n    ]\r\n\r\nI want to convert it into something like the following using **`jq`**:\r\n\r\n    {\r\n      &quot;anger&quot;: 0.012,\r\n      &quot;disgust&quot;: 0.002,\r\n      &quot;fear&quot;: 0.14,\r\n      &quot;joy&quot;: 0.42\r\n    }\r\n\r\nBest I could do is:\r\n\r\n    cat result.json | jq &#39;.[] | { (.tone_id): .score }&#39;\r\n\r\nwhich gave the following:\r\n\r\n    {\r\n      &quot;anger&quot;: 0.012\r\n    }\r\n    {\r\n      &quot;disgust&quot;: 0.002\r\n    }\r\n    {\r\n      &quot;fear&quot;: 0.14\r\n    }\r\n    {\r\n      &quot;joy&quot;: 0.42\r\n    }\r\n\r\n&gt; I know I can easily do this using other methods. Just wanted to know if it&#39;s possible using **`jq`** one-liner?",
        "link": "https://stackoverflow.com/questions/47551333/jq-convert-a-list-of-objects-into-a-summarized-object",
        "title": "jq - convert a list of objects into a summarized object"
    },
    {
        "tags": [
            "arrays",
            "json",
            "shell",
            "split",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1512014806,
                "last_edit_date": 1512014806,
                "creation_date": 1512013486,
                "answer_id": 47565529,
                "question_id": 47564278,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "jq IO is rather primitive, so I&#39;d suggest starting with:\r\n\r\n    def chunks(n):\r\n      def c: .[0:n], (if length &gt; n then .[n:]|c else empty end);\r\n      c;\r\n  \r\n    chunks(5)\r\n\r\n\r\nThe key now is to use the -c command-line option:\r\n\r\n    jq -c -f chunk.jq foo.json\r\n\r\nWith your data, this will produce a stream of three arrays, one per line.\r\n\r\nYou can pipe that into `split` or `awk` or whatever, to send each line to a separate file, e.g.\r\n\r\n    awk &#39;{n++; print &gt; &quot;out&quot; n &quot;.json&quot;}&#39;\r\n\r\nIf you want the arrays to be pretty-printed in each file, you could then use jq on each, perhaps with [sponge][1], along the lines of:\r\n\r\n    for f in out*.json ; do jq . $f | sponge $f ; done\r\n\r\n### def-free solution\r\n\r\nIf you don&#39;t want to define a function, or prefer a one-liner \r\nfor the jq component of the pipeline, consider this:\r\n\r\n    jq -c --argjson n 5 &#39;recurse(.[$n:]; length &gt; 0) | .[0:$n]&#39; foo.json\r\n\r\n### Notes\r\n1. `chunks` will also work on strings.\r\n2. `chunks` defines the 0-arity function, `c`, to take advantage of jq&#39;s support for tail-call optimization.\r\n\r\n  [1]: http://gnu.wiki/man1/sponge.1.php",
                "title": "How to break a JSON file into a smaller json wrapped in an array using jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1512031398,
                "last_edit_date": 1512031398,
                "creation_date": 1512018291,
                "answer_id": 47566254,
                "question_id": 47564278,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If data.json is VERY large (e.g., too big to fit comfortably into RAM), and if you have a version of jq that includes the so-called streaming parser, then you could use jq first to split up data.json into its top-level component elements, then regroup them, and finally use `awk` or `split` or whatever as described elsewhere on this page.\r\n\r\n### Invocation\r\nHere first is the pipeline you&#39;d use:\r\n\r\n    jq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39; data.json |\r\n      jq -cn -f groups.jq\r\n\r\n### groups.jq\r\n\r\n    # Use nan as EOS\r\n    def groups(stream; n):\r\n      foreach (stream,nan) as $x ([];\r\n        if length &lt; n then  . + [$x] else [$x] end;\r\n        if (.[-1]|isnan) and length &gt; 1 then .[:-1]\r\n        elif length == n then .\r\n        else empty end) ;\r\n      \r\n    groups(inputs; 5)",
                "title": "How to break a JSON file into a smaller json wrapped in an array using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1512031398,
        "creation_date": 1512003401,
        "last_edit_date": 1512014999,
        "question_id": 47564278,
        "body_markdown": "    [{&quot;foo&quot;: 1},\r\n     {&quot;foo&quot;: 2},\r\n     {&quot;foo&quot;: 3},\r\n     {&quot;foo&quot;: 4},\r\n     {&quot;foo&quot;: 5},\r\n     {&quot;foo&quot;: 6},\r\n     {&quot;foo&quot;: 7},\r\n     {&quot;foo&quot;: 8},\r\n     {&quot;foo&quot;: 9},\r\n     {&quot;foo&quot;: 10},\r\n     {&quot;foo&quot;: 11},\r\n     {&quot;foo&quot;: 12},\r\n     {&quot;foo&quot;: 13},\r\n     {&quot;foo&quot;: 14},\r\n     {&quot;foo&quot;: 15}\r\n    ]\r\n\r\nI want to break this array into smaller array files using jq. \r\n\r\nSo far I have tried this \r\n     \r\n     cat foo.json | jq -c -M -s &#39;.[]&#39; | split -l 5 - charded/\r\n\r\nThis results in 3 separate files but does not wrap the dictionaries into an array.",
        "link": "https://stackoverflow.com/questions/47564278/how-to-break-a-json-file-into-a-smaller-json-wrapped-in-an-array-using-jq",
        "title": "How to break a JSON file into a smaller json wrapped in an array using jq?"
    },
    {
        "tags": [
            "json",
            "object",
            "jq",
            "difference"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1512053760,
                "last_edit_date": 1512053760,
                "creation_date": 1512050394,
                "answer_id": 47575252,
                "question_id": 47573491,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First, please fix the JSON in your example.\r\n\r\nSecond, rest assured jq is well-suited for this task, but it will\r\nrequire some understanding of jq to devise a complete solution\r\nto the problem. \r\n\r\nSince the problem statement\r\nis currently somewhat underspecified, and since SO is not\r\na free programming service, I&#39;ll focus here on the\r\nkey functionality required, which I take to be finding\r\nthe &quot;difference&quot; between two objects with the same `id`\r\nand whose other keys are numerical strings.\r\n\r\n### Data suitable for testing\r\nLet&#39;s start with the two objects:\r\n\r\n    def s1: {\r\n      &quot;id&quot;: &quot;name1&quot;,\r\n      &quot;val1&quot;: &quot;0.77&quot;,\r\n      &quot;val2&quot;: &quot;1.34&quot;,\r\n      &quot;val3&quot;: &quot;7.89&quot;,\r\n      &quot;val4&quot;: &quot;6.00&quot;\r\n      };\r\n    \r\n    def s2: {\r\n      &quot;id&quot;: &quot;name1&quot;,\r\n      &quot;val1&quot;: &quot;0.35&quot;,\r\n      &quot;val2&quot;: &quot;2.34&quot;,\r\n      &quot;val3&quot;: &quot;6.50&quot;,\r\n      &quot;val4&quot;: &quot;6.01&quot;\r\n      };\r\n\r\n### minus/2\r\n\r\nThe hard part here is actually the numerical rounding, which is taken care of by the inner function `round(n)`:\r\n\r\n    # $a - $b\r\n    def minus($a; $b):\r\n      def round(n):\r\n        (if . &lt; 0 then -1 else 1 end) as $s\r\n        | $s*10*.*n\r\n        | if (floor % 10) &gt; 4 then (.+5) else . end\r\n        | ./10 | floor/n | .*$s;\r\n    \r\n      def m($k): ($a[$k]|tonumber) - ($b[$k]|tonumber) | round(100);\r\n      reduce ($a|keys_unsorted[]) as $k ({};\r\n        if $k == &quot;id&quot; then .id = $a[&quot;id&quot;]\r\n        else .[$k] = m($k)\r\n        end);\r\n    \r\n      minus(s2; s1)\r\n\r\n(If you really want the difference between two numbers\r\nto be a string, simply add a call to `tostring`.)\r\n\r\n### Output\r\n\r\n    {\r\n      &quot;id&quot;: &quot;name1&quot;,\r\n      &quot;val1&quot;: -0.42,\r\n      &quot;val2&quot;: 1,\r\n      &quot;val3&quot;: -1.39,\r\n      &quot;val4&quot;: 0.01\r\n    }\r\n\r\n### Hint\r\n\r\nThe following invocation of `minus/2` produces the result shown below when given the sample data provided (after it has been corrected):\r\n\r\n    map(.series) | transpose | map(minus(.[1]; .[0]))\r\n\r\nThe result:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;name1&quot;,\r\n        &quot;val1&quot;: -0.42,\r\n        &quot;val2&quot;: 1,\r\n        &quot;val3&quot;: -1.39,\r\n        &quot;val4&quot;: 0.01\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;name2&quot;,\r\n        &quot;val1&quot;: 2.2,\r\n        &quot;val2&quot;: -0.45,\r\n        &quot;val3&quot;: 1.05\r\n      }\r\n    ]\r\n\r\n### The rest\r\n... is up to you.  It will depend on how careful you want to be about\r\nmatching the &quot;id&quot; values, handling edge cases, and so on.",
                "title": "Diff 2 data series values using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1512058837,
        "creation_date": 1512044822,
        "last_edit_date": 1512058837,
        "question_id": 47573491,
        "body_markdown": "I&#39;m not an expert jq user and I have tried a lot of different solutions now on how to solve my problem.\r\nI have a number of series of data that belongs to a specific version that I want to calculate the difference between. The base data will always be an array with two elements containing the data serie&#39;s values. The number of values within each series can vary, i.e. the number of &quot;valX&quot; values is not constant.\r\nThe result should give all values &quot;ver1&quot;-&quot;ver2&quot;.\r\n\r\nThe resulting data given below is an example of how I would like the end result. If the values are missing trailing &quot;0&quot;, i.e. 1.20 =&gt; 1.2 and leading zero is missing, i.e. 0.01 =&gt; .01, that is no problem.\r\n\r\nExample JSON source data:\r\n\r\n    [\r\n      {\r\n        &quot;version&quot;: &quot;ver1&quot;,\r\n        &quot;series&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;name1&quot;,\r\n            &quot;val1&quot;: &quot;0.77&quot;,\r\n            &quot;val2&quot;: &quot;1.34&quot;,\r\n            &quot;val3&quot;: &quot;7.89&quot;,\r\n            &quot;val4&quot;: &quot;6.00&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;name2&quot;,\r\n            &quot;val1&quot;: &quot;0.34&quot;,\r\n            &quot;val2&quot;: &quot;1.00&quot;,\r\n            &quot;val3&quot;: &quot;12.15&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;version&quot;: &quot;ver2&quot;,\r\n        &quot;series&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;name1&quot;,\r\n            &quot;val1&quot;: &quot;0.35&quot;,\r\n            &quot;val2&quot;: &quot;2.34&quot;,\r\n            &quot;val3&quot;: &quot;6.50&quot;,\r\n            &quot;val4&quot;: &quot;6.01&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;name2&quot;,\r\n            &quot;val1&quot;: &quot;2.54&quot;,\r\n            &quot;val2&quot;: &quot;0.55&quot;,\r\n            &quot;val3&quot;: &quot;13.20&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nAnd I want a result like this or fairly similar:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;name1&quot;,\r\n        &quot;val1&quot;: &quot;-0.42&quot;,\r\n        &quot;val2&quot;: &quot;1.00&quot;,\r\n        &quot;val3&quot;: &quot;-1.39&quot;,\r\n        &quot;val4&quot;: &quot;0.01&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;name2&quot;,\r\n        &quot;val1&quot;: &quot;-2.20&quot;,\r\n        &quot;val2&quot;: &quot;-0.45&quot;,\r\n        &quot;val3&quot;: &quot;1.05&quot;\r\n      }\r\n    ]\r\n    \r\nAnyone with the knowledge that can help me or at least bump me in the correct direction?\r\n",
        "link": "https://stackoverflow.com/questions/47573491/diff-2-data-series-values-using-jq",
        "title": "Diff 2 data series values using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3540930,
                    "reputation": 6388,
                    "user_id": 2958070,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://i.sstatic.net/FtkjC.jpg?s=256",
                    "display_name": "Ben",
                    "link": "https://stackoverflow.com/users/2958070/ben"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1512058080,
                "post_id": 47577690,
                "comment_id": 82112468,
                "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": 3540930,
                    "reputation": 6388,
                    "user_id": 2958070,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://i.sstatic.net/FtkjC.jpg?s=256",
                    "display_name": "Ben",
                    "link": "https://stackoverflow.com/users/2958070/ben"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1512061070,
                "post_id": 47577690,
                "comment_id": 82114383,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 12,
                "is_accepted": true,
                "score": 12,
                "last_activity_date": 1619178765,
                "last_edit_date": 1619178765,
                "creation_date": 1512060129,
                "answer_id": 47578386,
                "question_id": 47577690,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use jq with the -s and -R options, e.g.\r\n\r\n    jq -sR .           \r\n    a\r\n    b\r\n\r\nResult:\r\n\r\n    &quot;a\\nb\\n&quot;",
                "title": "Multiline File in to single JSON string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1619178765,
        "creation_date": 1512057984,
        "last_edit_date": 1512060392,
        "question_id": 47577690,
        "body_markdown": "I&#39;m trying to JSON encode all of the contents of a single file into a single JSON string for a curl request in BASH. The file is text so it doesn&#39;t need to be base64 encoded. The big thing is that the file is multi-lined and the line breaks matter. I&#39;m trying to encode a PEM file.  If I strip the \\n out of the file, it breaks the PEM format. I tried to see if jq would help but I don&#39;t see any option to tell it to encode newline character. \r\n\r\nAnybody have any hints here? ",
        "link": "https://stackoverflow.com/questions/47577690/multiline-file-in-to-single-json-string",
        "title": "Multiline File in to single JSON string"
    },
    {
        "tags": [
            "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": 1512060320,
                "post_id": 47578328,
                "comment_id": 82113904,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7310558,
                    "reputation": 740,
                    "user_id": 5569925,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/0435bf08963d1ff53d3b01502f5f3767?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Goldfish",
                    "link": "https://stackoverflow.com/users/5569925/goldfish"
                },
                "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": 1512060472,
                "post_id": 47578328,
                "comment_id": 82113992,
                "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": 1512060593,
                "post_id": 47578328,
                "comment_id": 82114062,
                "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": 1512067516,
                "post_id": 47578328,
                "comment_id": 82118312,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1512060443,
                "last_edit_date": 1592644375,
                "creation_date": 1512060264,
                "answer_id": 47578422,
                "question_id": 47578328,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want `jq` to format the same JSON it got as input, pass `.` as the script for it to run:\n\n    curl -H &quot;Accept: application/json&quot; https://icanhazdadjoke.com/ | jq . &gt; file.txt\n\nFrom [the manual](https://stedolan.github.io/jq/manual/):\n\n&gt; **Identity: `.`**\n&gt;\n&gt; The absolute simplest filter is `.` . This is a filter that takes its input and produces it unchanged as output. That is, this is the identity operator.\n&gt;\n&gt; Since jq by default pretty-prints all output, this trivial program can be a useful way of formatting JSON output from, say, `curl`.\n\n",
                "title": "JQ giving usage error only if stdout is redirected"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1583686608,
        "creation_date": 1512059961,
        "last_edit_date": 1583686608,
        "question_id": 47578328,
        "body_markdown": "I have a curl command \r\n\r\n     curl -H &quot;Accept: application/json&quot; https://icanhazdadjoke.com/\r\n\r\nWhich returns the JSON (note: I chose this api because it has no auth so everyone can help test, it returns a formatted json but most API&#39;s return a flat json with no formatting... One line)\r\n\r\n&lt;!-- language: json --&gt;\r\n\r\n     {\r\n      &quot;id&quot;: &quot;5wAIRfaaUvc&quot;, \r\n      &quot;joke&quot;: &quot;What do you do when a blonde throws a grenade at you? Pull the pin and throw it back.&quot;, \r\n      &quot;status&quot;: 200\r\n    }\r\n\r\nWhen I pipe to JQ, jq responds as expected. I pipe to jq to ensure I have a formatted readable json\r\n\r\n    curl -H &quot;Accept: application/json&quot; https://icanhazdadjoke.com/ | jq\r\n\r\nReturns\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n      % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                     Dload  Upload   Total   Spent    Left  Speed\r\n    100   110  100   110    0     0    320      0 --:--:-- --:--:-- --:--:--   321\r\n    {\r\n      &quot;id&quot;: &quot;NCAIYLeNe&quot;,\r\n      &quot;joke&quot;: &quot;I fear for the calendar, it’s days are numbered.&quot;,\r\n      &quot;status&quot;: 200\r\n    }\r\n\r\n\r\nBUT when I pipe the output of JQ to a text file (I want a formatted version to be saved for readability, not the plain unformatted json)I get an error\r\n\r\n    curl -H &quot;Accept: application/json&quot; https://icanhazdadjoke.com/ | jq &gt; file.txt\r\n\r\nReturns\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    jq - commandline JSON processor [version 1.5]\r\n    Usage: jq [options] &lt;jq filter&gt; [file...]\r\n    \r\n    \tjq is a tool for processing JSON inputs, applying the\r\n    \tgiven filter to its JSON text inputs and producing the\r\n    \tfilter&#39;s results as JSON on standard output.\r\n    \tThe simplest filter is ., which is the identity filter,\r\n    \tcopying jq&#39;s input to its output unmodified (except for\r\n    \tformatting).\r\n    \tFor more advanced filters see the jq(1) manpage (&quot;man jq&quot;)\r\n    \tand/or https://stedolan.github.io/jq\r\n    \r\n    \tSome of the options include:\r\n    \t -c\t\tcompact instead of pretty-printed output;\r\n    \t -n\t\tuse `null` as the single input value;\r\n    \t -e\t\tset the exit status code based on the output;\r\n    \t -s\t\tread (slurp) all inputs into an array; apply filter to it;\r\n    \t -r\t\toutput raw strings, not JSON texts;\r\n    \t -R\t\tread raw strings, not JSON texts;\r\n    \t -C\t\tcolorize JSON;\r\n    \t -M\t\tmonochrome (don&#39;t colorize JSON);\r\n    \t -S\t\tsort keys of objects on output;\r\n    \t --tab\tuse tabs for indentation;\r\n    \t --arg a v\tset variable $a to value &lt;v&gt;;\r\n    \t --argjson a v\tset variable $a to JSON value &lt;v&gt;;\r\n    \t --slurpfile a f\tset variable $a to an array of JSON texts read from &lt;f&gt;;\r\n    \tSee the manpage for more options.\r\n      % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                     Dload  Upload   Total   Spent    Left  Speed\r\n    100   141  100   141    0     0    317      0 --:--:-- --:--:-- --:--:--   316\r\n    (23) Failed writing body",
        "link": "https://stackoverflow.com/questions/47578328/jq-giving-usage-error-only-if-stdout-is-redirected",
        "title": "JQ giving usage error only if stdout is redirected"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "ksh",
            "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": 1512092210,
                "post_id": 47585325,
                "comment_id": 82128443,
                "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": 1512093017,
                "post_id": 47585325,
                "comment_id": 82128666,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1512092327,
                "creation_date": 1512092327,
                "answer_id": 47585393,
                "question_id": 47585325,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use the `-r` argument to tell `jq` to use raw strings for its output.\r\n\r\n    jq -r . &lt;&lt;EOF\r\n    &quot;I\\nam\\na\\ngood\\nboy&quot;\r\n    EOF\r\n\r\n...emits the precise output:\r\n\r\n    I\r\n    am\r\n    a\r\n    good\r\n    boy\r\n\r\n",
                "title": "Control characters in jq parsed JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1512093320,
        "creation_date": 1512091770,
        "last_edit_date": 1512093320,
        "question_id": 47585325,
        "body_markdown": "I am writing a KSH shell script. It reads from a JSON file, which contains control characters like `\\n`, `\\r` and `\\t` in place of actual newline characters or tabs (so the control characters are being read as actual strings). I am using `jq` to parse the stuff I want from this JSON file, and appending it to a text file. This text file also ends up having the strings like `\\n`, `\\t` instead of newline, tabs, etc. I want the text file to have actual meaning of these control characters.\r\n\r\nFor example, for the string `&quot;I\\nam\\na\\ngood\\nboy&quot;`, I want my file to have:\r\n\r\n    I\r\n    am\r\n    a\r\n    good\r\n    boy\r\nAny ideas on how to accomplish this in a shell script?\r\n\r\nNote: I am writing in KSH, but answers in bash etc. would be acceptable.\r\n",
        "link": "https://stackoverflow.com/questions/47585325/control-characters-in-jq-parsed-json",
        "title": "Control characters in jq parsed JSON"
    },
    {
        "tags": [
            "json",
            "recursion",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 14,
                "is_accepted": false,
                "score": 14,
                "last_activity_date": 1512125533,
                "creation_date": 1512125533,
                "answer_id": 47591830,
                "question_id": 47591829,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just ignore keys when they are absent for some values in JSON:\r\n\r\n    jq &#39;.. | keys?&#39;\r\n",
                "title": "Get key names from JSON file recursively using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1601420395,
                "creation_date": 1601420395,
                "answer_id": 64128771,
                "question_id": 47591829,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ignore non-objects when inspecting for key names:\r\n```\r\njq -r &#39;.. | if type == &quot;object&quot; then to_entries[] | .key else empty end&#39; &quot;${LOCALAPPDATA}/Google/Chrome/User Data/default/Bookmarks&quot; | sort --uniq\r\nbookmark_bar\r\nchecksum\r\nchildren\r\ndate_added\r\ndate_modified\r\nguid\r\nid\r\nname\r\nother\r\nroots\r\nsynced\r\ntype\r\nurl\r\nversion\r\n```",
                "title": "Get key names from JSON file recursively using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1601420395,
        "creation_date": 1512125533,
        "last_edit_date": 1512127577,
        "question_id": 47591829,
        "body_markdown": "I can get top-level JSON keys with `jq` as\r\n\r\n    jq &#39;keys&#39;\r\n\r\nE.g., see this question: https://stackoverflow.com/questions/23118341/get-key-names-from-json-file-using-jq\r\n\r\nAnd I can enable recursion in `jq`:\r\n\r\n    jq &#39;..&#39;\r\n\r\nAs in: https://stackoverflow.com/questions/38459429/recursive-search-values-by-key\r\n\r\nBut `jq &#39;.. | keys&#39;` returns `jq: error at &lt;stdin&gt; string has no keys`.",
        "link": "https://stackoverflow.com/questions/47591829/get-key-names-from-json-file-recursively-using-jq",
        "title": "Get key names from JSON file recursively using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1312052,
                    "reputation": 4499,
                    "user_id": 1259865,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://i.sstatic.net/pK46m.png?s=256",
                    "display_name": "Asqan",
                    "link": "https://stackoverflow.com/users/1259865/asqan"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1512408354,
                "post_id": 47638471,
                "comment_id": 82235719,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1312052,
                    "reputation": 4499,
                    "user_id": 1259865,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://i.sstatic.net/pK46m.png?s=256",
                    "display_name": "Asqan",
                    "link": "https://stackoverflow.com/users/1259865/asqan"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1512468570,
                "post_id": 47638471,
                "comment_id": 82259972,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1512408751,
                "last_edit_date": 1512408751,
                "creation_date": 1512408339,
                "answer_id": 47638744,
                "question_id": 47638471,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The single quotes around the `jq` filter are in  the wrong place. In your attempt made it is also enclosing the actual JSON file input. The right syntax when applying filter over files is\r\n\r\n    jq &#39;&lt;filter&gt;&#39; json-file\r\n\r\nIn your case the right filter is just\r\n\r\n    .someparent[&quot;somechild&quot;] = $aVar\r\n\r\nand to use a shell variable in to the `jq`, you need to use the `--arg` field. Putting together both of the options. The first variable after `--arg` is used in the context of `jq` and the one following it is the actual shell variable.\r\n\r\n    aVar=&quot;anotherValue&quot;\r\n    jq --arg aVar &quot;$aVar&quot; &#39;.someparent[&quot;somechild&quot;] = $aVar&#39; &quot;$aDirection/package.json&quot;\r\n    #                                                    ^^^^ Remember the single quote \r\n    #                                                    terminating here and not extended\r\n\r\n    ",
                "title": "To be assigned value as variable in jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1512409147,
                "creation_date": 1512409147,
                "answer_id": 47638977,
                "question_id": 47638471,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just to be clear: using the OP&#39;s approach can be made to work, e.g.\r\n\r\n    jq &#39;.someparent[&quot;somechild&quot;] = &quot;&#39;&quot;$aVar&quot;&#39;&quot;&#39; &quot;$aDirection/package.json&quot;\r\n\r\nbut using `--arg` (for strings) and/or `--argjson` is far better.  An additional option for environment variables is to use the jq function `env`.",
                "title": "To be assigned value as variable in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1512468622,
        "creation_date": 1512407361,
        "last_edit_date": 1512468622,
        "question_id": 47638471,
        "body_markdown": "[json processor jq][1] for a package.json\r\n\r\n    {\r\n      &quot;someparent&quot; : {\r\n        &quot;somechild&quot; : &quot;oldvalue&quot;\r\n      }\r\n    }\r\n\r\nIf I run the following command (to change `oldvalue` to `somevalue`):\r\n\r\n\r\n    jq &#39;.someparent[&quot;somechild&quot;] = &quot;somevalue&quot; &quot;$aDirection/package.json&quot;&#39;\r\n\r\nIt is successfully changed. However, if I give a variable instead of `someValue`:\r\n\r\n     aVar=&quot;anotherValue&quot;\r\n     jq &#39;.someparent[&quot;somechild&quot;] = &quot;$aVar&quot; &quot;$aDirection/package.json&quot;&#39;\r\n\r\nIt is not working.\r\nWhat I already tried:\r\n\r\n    [&quot;aVar&quot;] #interpreted as string\r\n    [&quot;$aVar&quot;] #interpreted as string\r\n    &quot;$aVar&quot; # aVar is not defined\r\n    $avar #aVar is not defined\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/47638471/to-be-assigned-value-as-variable-in-jq",
        "title": "To be assigned value as variable in jq"
    },
    {
        "tags": [
            "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": 1,
                "creation_date": 1512421809,
                "post_id": 47641412,
                "comment_id": 82242431,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1512419911,
                "creation_date": 1512419911,
                "answer_id": 47641595,
                "question_id": 47641412,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One (not so hot) option would be to redirect STDERR to /dev/null:\r\n\r\n    jq  -r &#39;.results[].uri&#39; 2&gt; /dev/null\r\n\r\nSince there is clearly a possibility of error, a better option might be to break up the pipeline into steps so you can handle different errors as appropriate along the way.\r\n\r\nBy the way, that assertion indicates there&#39;s some kind of bug in jq itself. Would you be able to show us the corresponding output of `curl`?     ",
                "title": "Hide JQ Error Messages from Curl command"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1512421957,
                "creation_date": 1512421957,
                "answer_id": 47642045,
                "question_id": 47641412,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use `curl --fail` to only continue on to run the `jq` command if the `curl` succeeds:\r\n\r\n    url=&quot;URL/api/search/dates?dateFields=created&amp;from=${Two_Years_Ago}&amp;today&amp;repos=npm-local-lrn&quot;\r\n\r\n    if result=$(curl -s --fail  -u username:password &quot;$url&quot;); then\r\n      readarray -t installers &lt; &lt;(jq -r &#39;.results[].uri&#39; &lt;&lt;&lt;&quot;$result&quot; | sed &#39;s=/api/storage==&#39;)\r\n      if (( ${#installers[@]} )); then\r\n        for installer in &quot;${installers_to_delete[@]}&quot;; do\r\n          echo &quot;$installer&quot;\r\n        done\r\n      else\r\n        echo &quot;Empty list of installers retrieved&quot; &gt;&amp;2\r\n      fi\r\n    else\r\n      echo &quot;HTTP error retrieving installers&quot; &gt;&amp;2\r\n    fi",
                "title": "Hide JQ Error Messages from Curl command"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1512421957,
        "creation_date": 1512419125,
        "question_id": 47641412,
        "body_markdown": "I&#39;m running the following curl command:\r\n\r\n    installer_to_delete=$(curl -s -u username:password &quot;URL/api/search/dates?dateFields=created&amp;from=${Two_Years_Ago}&amp;today&amp;repos=npm-local-lrn&quot; | jq -r &#39;.results[].uri&#39;|sed &#39;s=/api/storage==&#39;)\r\n\r\n    if [[ $installer_to_delete == &quot;&quot; ]]\r\n    then\r\n    \techo &quot;No installers found&quot;\r\n    else\r\n    \tfor installer in $installer_to_delete\r\n    \tdo\r\n    \techo $installer\r\n    \tdone\r\n    fi\r\n\r\nThe error/output for this is:\r\n\r\n    assertion &quot;cb == jq_util_input_next_input_cb&quot; failed: file &quot;/usr/src/ports/jq/jq-1.5-3.x86_64/src/jq-1.5/util.c&quot;, line 371, function: jq_util_input_get_position\r\n\r\nIt shows this output whenever the Curl command can&#39;t find a file. How can I silence the JQ error from popping up whenever it can&#39;t find a file?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/47641412/hide-jq-error-messages-from-curl-command",
        "title": "Hide JQ Error Messages from Curl command"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1512498122,
                "last_edit_date": 1512498122,
                "creation_date": 1512497736,
                "answer_id": 47660175,
                "question_id": 47660015,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can apply the filter to extract each element of the JSON array and feed it to an array in `bash` and iterate over its content later. Assuming you have `bash` 4.0 or greater, you can use `mapfile` command as\r\n\r\n    mapfile -t configArr &lt; &lt;(jq -c &#39;.[]&#39;  &lt; app-cnfg.json)\r\n\r\nand now we loop over the array, to run the command for each config item,\r\n\r\n    for config in &quot;${configArr[@]}&quot;; do\r\n        aws dynamodb put-item --table-name &quot;xxx&quot; --item &quot;$config&quot;\r\n    done\r\n\r\n(or) use a more efficient way to read from an input data stream using a `while` loop and the `read` command (works on `bash` versions that don&#39;t support `mapfile` or `readarray`)\r\n\r\n    while IFS= read -r config; do\r\n        aws dynamodb put-item --table-name &quot;xxx&quot; --item &quot;$config&quot;\r\n    done&lt; &lt;(jq -c &#39;.[]&#39; &lt; app-cnfg.json)",
                "title": "Run a command for each item in jq array"
            },
            {
                "up_vote_count": 25,
                "is_accepted": true,
                "score": 25,
                "last_activity_date": 1708040669,
                "last_edit_date": 1708040669,
                "creation_date": 1512497870,
                "answer_id": 47660216,
                "question_id": 47660015,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can pipe to `xargs`:\r\n\r\n```sh\r\njq -c &#39;.[]&#39; app-cnfg.json \\\r\n    | xargs -L 1 aws dynamodb put-item --table-name &quot;xxx&quot; --item\r\n```\r\n\r\nThe `-c` option to jq makes sure each element is on a single line, and the `-L 1` option to `xargs` makes sure that the command is called once per item.\r\n\r\nIf you wanted to avoid potential problems with trailing whitespace (which would make `args` treat the following line as continuation of the current one), you can get your objects zero byte separated (requires jq 1.7 or newer):\r\n\r\n```sh\r\njq -c --raw-output0 &#39;.[]&#39; app-cnfg.json \\\r\n    | xargs -0 -n1 aws dynamodb put-item --table-name &quot;xxx&quot; --item\r\n```\r\n\r\nThe `--raw-output0` option behaves like `-r`, but with NUL instead of newlines.\r\n\r\n`xargs -0 -n1` expects zero byte delimited input and runs the command for each argument once.\r\n\r\n---\r\n\r\nFor jq versions older than 1.7:\r\n\r\n```sh\r\njq -j &#39;.[] | tostring + &quot;\\u0000&quot;&#39; app-cnfg.json \\\r\n    | xargs -0 -n1 aws dynamodb put-item --table-name &quot;xxx&quot; --item\r\n```\r\n\r\nThe `-j` option suppresses newlines from jq, `tostring` stringifies the objects and `+ &quot;\\u0000&quot;` appends a zero byte.\r\n",
                "title": "Run a command for each item in jq array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 18,
        "last_activity_date": 1708040669,
        "creation_date": 1512497205,
        "last_edit_date": 1512498041,
        "question_id": 47660015,
        "body_markdown": "This is how my input file looks like:\r\n\r\n    [\r\n      {\r\n        &quot;ConfigType&quot;: &quot;ABC&quot;,\r\n        &quot;Prop1&quot;: 3,\r\n        &quot;Prop2&quot;: 30\r\n      },\r\n      {\r\n        &quot;ConfigType&quot;: &quot;XYZ&quot;,\r\n        &quot;Prop3&quot;: &quot;Hello&quot;,\r\n        &quot;Prop4&quot;: &quot;World&quot;,\r\n        &quot;Prop5&quot;: &quot;Application&quot;\r\n      }\r\n    ]\r\n\r\nI need to prepare insert statement for each item.\r\n\r\nThis is how my jq command looks like which gives me each item.\r\n\r\n    cat app-cnfg.json |  jq -r &quot;.[]&quot;\r\n\r\nHow do I execute `aws dynamodb put-item --table-name &quot;xxx&quot; --item &lt;&lt;array&#39;s element&gt;&gt;`?\r\n",
        "link": "https://stackoverflow.com/questions/47660015/run-a-command-for-each-item-in-jq-array",
        "title": "Run a command for each item in jq array"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1512570267,
                "post_id": 47676527,
                "comment_id": 82311974,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1512570826,
                "post_id": 47676527,
                "comment_id": 82312344,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1512570755,
                "last_edit_date": 1512570755,
                "creation_date": 1512570527,
                "answer_id": 47676666,
                "question_id": 47676527,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -r &#39;.data | to_entries[] | &quot;\\(.key)=\\(.value)&quot;&#39; input.json\r\nThe output:\r\n\r\n    key1=value1\r\n    key2=value2\r\n\r\n",
                "title": "transform json to key/value file in bash"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1512570702,
                "creation_date": 1512570702,
                "answer_id": 47676735,
                "question_id": 47676527,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This will work in BASH.\r\n\r\n    #!/bin/bash\r\n    \r\n    all_keys=$( cat input.txt );\r\n    \r\n    while read key\r\n    do\r\n    \tgrep &quot;$key&quot; ./text.txt | awk -F&#39;:&#39; &#39;{ print $1&quot;=&quot;$2}&#39; | tr -d &#39;[&quot;, ]&#39;\r\n    done &lt;&lt;&lt; &quot;$all_keys&quot;\r\n\r\nAssuming you values are in *text.txt* and that you have your keys in *input.txt*.\r\n\r\nRegards!",
                "title": "transform json to key/value file in bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1512570945,
                "creation_date": 1512570945,
                "answer_id": 47676823,
                "question_id": 47676527,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In python\r\nThis reads stdin and outputs the desired &quot;key=value&quot; one per line\r\n\r\n    #!/usr/bin/python\r\n\r\n    import json\r\n    import sys\r\n    \r\n    data = sys.stdin.read()\r\n    \r\n    json_structure=json.loads(data)\r\n    \r\n    start_point=json_structure[&quot;data&quot;]\r\n    \r\n    for k in start_point.keys():\r\n        print(&quot;%s=%s&quot; % (k, start_point[k]))\r\n\r\nIf I was using python to unmangle the json input however, I would probably rewrite the bash script in python",
                "title": "transform json to key/value file in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1512570945,
        "creation_date": 1512570112,
        "question_id": 47676527,
        "body_markdown": "I have a JSON which looks like this:\r\n\r\n    {\r\n    \t&quot;lorem&quot;: &quot;ipsum&quot;,\r\n    \t&quot;dolor&quot;: &quot;sid&quot;,\r\n    \t&quot;data&quot;: {\r\n    \t\t&quot;key1&quot;: &quot;value1&quot;,\r\n    \t\t&quot;key2&quot;: &quot;value2&quot;\r\n    \t}\r\n    }\r\n\r\nand I want an output which is ini like where I only need the content of &#39;data&#39; (which is always flat, no branches). The output should look like this:\r\n\r\n    key1=value1\r\n    key2=value2\r\n\r\nI can use jq (just don&#39;t get it running) but have to use a bash script for it. Can anyone help?\r\n",
        "link": "https://stackoverflow.com/questions/47676527/transform-json-to-key-value-file-in-bash",
        "title": "transform json to key/value file in bash"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1512648014,
                "post_id": 47693714,
                "comment_id": 82348553,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2550933,
                    "reputation": 13299,
                    "user_id": 2214695,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/dee2ef257601e05c5659f04de9cb7c67?s=256&d=identicon&r=PG",
                    "display_name": "oliv",
                    "link": "https://stackoverflow.com/users/2214695/oliv"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1512652927,
                "post_id": 47693714,
                "comment_id": 82351640,
                "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": 1512656950,
                "post_id": 47693714,
                "comment_id": 82354186,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1512661281,
                "last_edit_date": 1512661281,
                "creation_date": 1512651300,
                "answer_id": 47695618,
                "question_id": 47693714,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If by &quot;merge&quot; you mean something like jq&#39;s `add`, then you could simply write:\r\n\r\n    jq -n &quot;$var1 + $var2&quot;\r\n\r\nMore generally, if your jq supports the --argson command-line option, then you could use it; otherwise, you could use —arg but some care would then be needed to do any required conversions. In either case, you will probably also want to use the -n command-line option.\r\n\r\nIf you are using a shell such as bash, another set of options is based on process substitution, e.g.\r\n\r\n    jq -s add &lt;(echo &quot;$var1&quot;) &lt;(echo &quot;$var2&quot;)\r\n\r\nIf your `echo` is unsuitable, you could use some other alternative (e.g. printf).\r\n\r\nIf process substitution is overkill, then another option, as @chepner pointed out, is simply to use &quot;$var1 $var2&quot;, e.g.\r\n\r\n    jq -s add &quot;$var1 $var2&quot;\r\n\r\nFinally, if the shell variables have been exported (i.e., if they are available as &quot;environment&quot; variables), then you can use jq&#39;s `env` function: `env.var1 + env.var2`",
                "title": "Passing multiple variables not files to jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1512661281,
        "creation_date": 1512644957,
        "last_edit_date": 1512651338,
        "question_id": 47693714,
        "body_markdown": "I have two variables in shell script, each one contains a JSON data.\r\n\r\nI wanted to merge these using command\r\n\r\n    jq &#39;.&#39; $var1 $var2\r\nwhere `echo $var1 =&gt; {&quot;key1&quot;: &quot;value1&quot;}`\r\n\r\n    echo $var2 =&gt; {&quot;key2&quot;: &quot;value2&quot;}\r\n\r\nbut it does not work, however when i write contents of these variables into file1 and file2 respectively, It works fine `jq &#39;.&#39; file1.json file2.json`\r\nit works perfectly.\r\nAny help regarding how to pass multiple variables to jq command will be appreciated.",
        "link": "https://stackoverflow.com/questions/47693714/passing-multiple-variables-not-files-to-jq-command",
        "title": "Passing multiple variables not files to jq command"
    },
    {
        "tags": [
            "json",
            "shell",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8436221,
                    "reputation": 245,
                    "user_id": 6330341,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/8bb990f3fe9fa1211a9e74a6d8f0e6d5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rajiv Rai",
                    "link": "https://stackoverflow.com/users/6330341/rajiv-rai"
                },
                "reply_to_user": {
                    "account_id": 2756623,
                    "reputation": 25897,
                    "user_id": 7553525,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/ua0kY.png?s=256",
                    "display_name": "zwer",
                    "link": "https://stackoverflow.com/users/7553525/zwer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1512739745,
                "post_id": 47715234,
                "comment_id": 82390743,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1512740614,
                "last_edit_date": 1512740614,
                "creation_date": 1512739857,
                "answer_id": 47715403,
                "question_id": 47715234,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to quote your column names, especially since they contain spaces and dashes. However you need to escape the quotes for bash:\r\n\r\n    jq --raw-output &#39;.users[] | [.username, .email, .&quot;total running apps&quot;, .&quot;api-mock-app&quot;, .&quot;flogo&quot;, .&quot;ipaas&quot;, .&quot;nodejs-app&quot;] | @csv&#39;",
                "title": "Convert a JSON into CSV using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1512741779,
                "creation_date": 1512741779,
                "answer_id": 47715931,
                "question_id": 47715234,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "i got this working code [click here][1]\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-html --&gt;\r\n\r\n    &lt;script src=&quot;https://ajax.googleapis.com/ajax/libs/jquery/2.0.2/jquery.min.js&quot;&gt;&lt;/script&gt;\r\n    &lt;html&gt;\r\n    &lt;head&gt;\r\n        &lt;title&gt;Demo - Covnert JSON to CSV&lt;/title&gt;\r\n        &lt;script type=&quot;text/javascript&quot; src=&quot;http://code.jquery.com/jquery-latest.js&quot;&gt;&lt;/script&gt;\r\n        &lt;script type=&quot;text/javascript&quot; src=&quot;https://github.com/douglascrockford/JSON-js/raw/master/json2.js&quot;&gt;&lt;/script&gt;\r\n\r\n        &lt;script type=&quot;text/javascript&quot;&gt;\r\n            // JSON to CSV Converter\r\n            function ConvertToCSV(objArray) {\r\n                var array = typeof objArray != &#39;object&#39; ? JSON.parse(objArray) : objArray;\r\n                var str = &#39;&#39;;\r\n\r\n                for (var i = 0; i &lt; array.length; i++) {\r\n                    var line = &#39;&#39;;\r\n                    for (var index in array[i]) {\r\n                        if (line != &#39;&#39;) line += &#39;,&#39;\r\n\r\n                        line += array[i][index];\r\n                    }\r\n\r\n                    str += line + &#39;\\r\\n&#39;;\r\n                }\r\n\r\n                return str;\r\n            }\r\n\r\n            // Example\r\n            $(document).ready(function () {\r\n\r\n                // Create Object\r\n                var items = [\r\n                      { name: &quot;Item 1&quot;, color: &quot;Green&quot;, size: &quot;X-Large&quot; },\r\n                      { name: &quot;Item 2&quot;, color: &quot;Green&quot;, size: &quot;X-Large&quot; },\r\n                      { name: &quot;Item 3&quot;, color: &quot;Green&quot;, size: &quot;X-Large&quot; }];\r\n\r\n                // Convert Object to JSON\r\n                var jsonObject = JSON.stringify(items);\r\n\r\n                // Display JSON\r\n                $(&#39;#json&#39;).text(jsonObject);\r\n\r\n                // Convert JSON to CSV &amp; Display CSV\r\n                $(&#39;#csv&#39;).text(ConvertToCSV(jsonObject));\r\n            });\r\n        &lt;/script&gt;\r\n    &lt;/head&gt;\r\n    &lt;body&gt;\r\n        &lt;h1&gt;\r\n            JSON&lt;/h1&gt;\r\n        &lt;pre id=&quot;json&quot;&gt;&lt;/pre&gt;\r\n        &lt;h1&gt;\r\n            CSV&lt;/h1&gt;\r\n        &lt;pre id=&quot;csv&quot;&gt;&lt;/pre&gt;\r\n    &lt;/body&gt;\r\n    &lt;/html&gt;\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n[check out this link ][1]\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/8847766/how-to-convert-json-to-csv-format-and-store-in-a-variable#",
                "title": "Convert a JSON into CSV using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1512741779,
        "creation_date": 1512739227,
        "last_edit_date": 1512739645,
        "question_id": 47715234,
        "body_markdown": "I have a json file, which is stored in an environment variable temp.\r\n\r\n`{\r\n  &quot;users&quot;: [\r\n    {\r\n      &quot;username&quot;: &quot;jack&quot;,\r\n      &quot;email&quot;: &quot;jack@somewhere.com&quot;,\r\n      &quot;total running apps&quot;: &quot;1&quot;,\r\n      &quot;api-mock-app&quot;: &quot;0&quot;,\r\n      &quot;flogo&quot;: &quot;1&quot;,\r\n      &quot;ipaas&quot;: &quot;0&quot;,\r\n      &quot;nodejs-app&quot;: &quot;0&quot;\r\n    },\r\n    {\r\n      &quot;username&quot;: &quot;jill&quot;,\r\n      &quot;email&quot;: &quot;jill@somewhere.com&quot;,\r\n      &quot;total running apps&quot;: &quot;1&quot;,\r\n      &quot;api-mock-app&quot;: &quot;0&quot;,\r\n      &quot;flogo&quot;: &quot;1&quot;,\r\n      &quot;ipaas&quot;: &quot;0&quot;,\r\n      &quot;nodejs-app&quot;: &quot;0&quot;\r\n    }\r\n  ]\r\n}\r\n`\r\nWhen i am converting this JSON into CSV using this command\r\n\r\n    jq -r &#39;.users[] | [.username, .email, .total running apps, .api-mock-app, .flogo, .ipaas, .nodejs-app] | @csv&#39; &lt;&lt;&lt; $temp\r\nI am getting following error.\r\n\r\njq: error: syntax error, unexpected IDENT (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.users[] | [.username, .email, .total running apps, .api-mock-app, .flogo, .ipaas, .nodejs-app] | @csv                                      \r\njq: 1 compile error\r\n\r\nAny help Please?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/47715234/convert-a-json-into-csv-using-jq",
        "title": "Convert a JSON into CSV using jq"
    },
    {
        "tags": [
            "json",
            "command-line",
            "left-join",
            "jq",
            "ndjson"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1512837185,
                "last_edit_date": 1512837185,
                "creation_date": 1512821757,
                "answer_id": 47728505,
                "question_id": 47725394,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that has several parts:\r\n\r\n1. Transforming your input into valid JSON.\r\n2. Library functions for performing joins.\r\n3. Running jq to produce the desired output, assuming your version of jq is sufficiently recent.\r\n4. What to do if you only have access to jq 1.5\r\n\r\nTo illustrate how straightforward everything is once you have the fluff issues resolved, here is the &quot;main&quot; jq program:\r\n\r\n    join(.state) | .count //= 0\r\n\r\nIn effect, this says: perform the join using .state as the join-key, and then ensure .count is set.\r\n\r\nThe output from the above one-liner will be the NDJSON:\r\n\r\n    {&quot;state&quot;:&quot;a&quot;,&quot;code&quot;:&quot;aa&quot;,&quot;count&quot;:1}\r\n    {&quot;state&quot;:&quot;b&quot;,&quot;code&quot;:&quot;bb&quot;,&quot;count&quot;:2}\r\n    {&quot;state&quot;:&quot;c&quot;,&quot;code&quot;:&quot;cc&quot;,&quot;count&quot;:0}\r\n\r\n### Part 1: dat1.json and dat2.json\r\n\r\nI am going to assume that you can produce valid JSON from your inputs.\r\nFor the sample data, I used `sed`:\r\n    \r\n    for i in 1 2 ; do\r\n      sed -e &#39;s/state/&quot;state&quot;/&#39; -e &#39;s/code/&quot;code&quot;/&#39; -e &#39;s/count/&quot;count&quot;/&#39; \\\r\n          -e &#39;s/ \\([a-z]*\\)\\([,}]\\)/ &quot;\\1&quot;\\2/g&#39; dat$i.ndjson &gt; dat$i.json\r\n    done\r\n\r\nThe following at any rate assumes you have two files, dat1.json and dat2.json, containing streams of valid JSON.\r\n\r\n### Part 2: `join`\r\n\r\nHere is a small library of filters for producing joins: the first works on streams, and the others on arrays.  These definitions assume your jq has `INDEX/2`.  See Part 4 if that is not the case.\r\n\r\n    def joins(s1; s2; filter1; filter2):\r\n      # combine two dictionaries using `add`\r\n        def merge: . as $in\r\n        | reduce (add|keys_unsorted[]) as $k ({}; .[$k] = ([$in[] | .[$k]] | add));\r\n      [INDEX(s1; filter1 | select(. != null)), INDEX(s2; filter2 | select(. != null))]\r\n      | merge[] ;\r\n    \r\n    def join(filter1; filter2):\r\n      joins(.[0][]; .[1][]; filter1; filter2);\r\n    \r\n    def join(f): join(f; f);\r\n\r\n### Part 3. Solution\r\n\r\nFirst, let&#39;s keep things simple.  If you place the above definitions for `join` and `joins` in a file, say d3.jq, followed by the one-line program given in the preamble, then the following invocation will do the trick, assuming your jq has `INDEX`:\r\n\r\n    jq -c -s -f d3.jq &lt;(jq -s . dat1.json) &lt;(jq -s . dat2.json)\r\n\r\nThis assumes you are using a shell that supports process substitution.  If not, then you can first run the &quot;.&quot; programs separately, e.g. if you have `sponge`:\r\n\r\n     for i in 1 2 ; do jq -s . dat$i.json | sponge dat$i.json ; done\r\n\r\n### Using `include`\r\nIf your jq supports `include`, and if you have the above definitions of `join` in a private standard library such as ~/.jq/jq/jq.jq \r\nthen your main jq program becomes the two-liner:\r\n\r\n    include &quot;jq&quot;;\r\n    join(.state) | .count //= 0&#39;\r\n\r\nThis means you could dispense with d3.jq and use the invocation:\r\n\r\n    jq -c -s &#39;include &quot;jq&quot;; join(.state)|.count //= 0&#39; \\\r\n       &lt;(jq -s . dat1.json) &lt;(jq -s . dat2.json)\r\n\r\n\r\n### Part 4: `INDEX`\r\n\r\nHere is a copy of `INDEX` as provided by recent versions of jq.  You could add these definitions to d3.jq (before the &quot;main&quot; part of the program), or to your library file, and so on:\r\n\r\n\r\n    def INDEX(stream; idx_expr):\r\n      reduce stream as $row ({};\r\n        .[$row|idx_expr|\r\n          if type != &quot;string&quot; then tojson\r\n          else .\r\n          end] |= $row);\r\n\r\n    def INDEX(idx_expr): INDEX(.[]; idx_expr);",
                "title": "Left join for D3 mapping returns null that prevents next step of data processing (ndjson-join or jq) command line"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1512837185,
        "creation_date": 1512794702,
        "question_id": 47725394,
        "body_markdown": "I am doing D3 mapping on a state level. Here  one problem that i met in data processing. For example, map data are like this, (dat1.ndjson)\r\n\r\n    {state: a, code: aa}\r\n    {state: b, code: bb}\r\n    {state: c, code: cc}\r\n\r\nBut usually the information we have are not complete, for example, there are no information in Antarctica usually but we still need to draw its contour when we do mapping. Information data is like, (dat2.ndjson)\r\n\r\n    {state: a, code: aa, count: 1}\r\n    {state: b, code: bb, count: 2}\r\n\r\nSo, when i try to do left join on these two data, it will returns (dat3.ndjson)\r\n\r\n    [{state: a, code: aa},{state: a, code: aa, count: 1}]\r\n    [{state: b, code: bb},{state: b, code: bb, count: 2}]\r\n    [{state: c, code: cc},null]\r\n\r\nThis is returned by\r\n\r\n    ndjson-join --left &#39;d.code&#39; dat1.ndjson dat2.ndjson &lt; merge.ndjson\r\n\r\nThe purpose is to connect this &#39;count&#39; information to map data, so usually I will first assign all items a count = 0 in dat1.ndjson, like this, (dat11.ndjson)\r\n\r\n    {state: a, code: aa, count: 0}\r\n    {state: b, code: bb, count: 0}\r\n    {state: c, code: cc, count: 0}\r\n\r\nand then use this left join method like the one I showed before to get something like this, (dat33.ndjson)\r\n\r\n    [{state: a, code: aa, count: 0},{state: a, code: aa, count: 1}]\r\n    [{state: b, code: bb, count: 0},{state: b, code: bb, count: 2}]\r\n    [{state: c, code: cc, count: 0},null]\r\n\r\nBut here comes the problem. If i use the following command to add all values together, it will return an error because of that null in the third line.\r\n\r\n    ndjson-map &#39;{state: d[0].state, code: d[0].code, count: d[0].count + \r\n    d[1].count}&#39; &lt; dat33.ndjson &gt; merge.ndjson\r\n\r\nNow I have to do this data processing in R which takes a lot of time as I need to do transformation between .ndjson and .csv. So I am looking for a better way to do this. I think there might be some ways by using &#39;ndjson-cli&#39;, &#39;jq&#39; or &#39;awk&#39; and &#39;sed&#39; and etc. \r\n\r\nAnyone have ideas? Thank you! :)\r\n\r\nE.\r\n ",
        "link": "https://stackoverflow.com/questions/47725394/left-join-for-d3-mapping-returns-null-that-prevents-next-step-of-data-processing",
        "title": "Left join for D3 mapping returns null that prevents next step of data processing (ndjson-join or jq) command line"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 69659,
                    "reputation": 9453,
                    "user_id": 202553,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/Clpiv.jpg?s=256",
                    "display_name": "knb",
                    "link": "https://stackoverflow.com/users/202553/knb"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1512896368,
                "post_id": 47730946,
                "comment_id": 82434860,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1512844929,
                "last_edit_date": 1512844929,
                "creation_date": 1512844420,
                "answer_id": 47731821,
                "question_id": 47730946,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I tried this, and it worked perfectly,\r\n\r\n\r\n    jq -r &#39;(.users[0] | keys), (.users[] | [.username, .email, .&quot;total running apps&quot;, .&quot;api-mock-app&quot;, .flogo, .ipaas, .&quot;nodejs-app&quot;]) | @csv&#39; temp.json\r\n\r\n\r\noutput format is.\r\n\r\n    &quot;api-mock-app&quot;,&quot;email&quot;,&quot;flogo&quot;,&quot;ipaas&quot;,&quot;nodejs-app&quot;,&quot;total running apps&quot;,&quot;username&quot;\r\n    &quot;jack&quot;,&quot;jack@somewhere.com&quot;,&quot;1&quot;,&quot;0&quot;,&quot;1&quot;,&quot;0&quot;,&quot;0&quot;\r\n    &quot;jill&quot;,&quot;jill@somewhere.com&quot;,&quot;1&quot;,&quot;0&quot;,&quot;1&quot;,&quot;0&quot;,&quot;0&quot;\r\n\r\n\r\n\r\n\r\n",
                "title": "Convert JSON array into CSV using jq"
            },
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1512852381,
                "creation_date": 1512852381,
                "answer_id": 47733020,
                "question_id": 47730946,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**jq** solution:\r\n\r\n    jq -r &#39;(.users[0] | keys_unsorted), (.users[] | to_entries | map(.value))|@csv&#39; temp.json\r\nThe output:\r\n\r\n    &quot;username&quot;,&quot;email&quot;,&quot;total running apps&quot;,&quot;api-mock-app&quot;,&quot;flogo&quot;,&quot;ipaas&quot;,&quot;nodejs-app&quot;\r\n    &quot;jack&quot;,&quot;jack@somewhere.com&quot;,&quot;1&quot;,&quot;0&quot;,&quot;1&quot;,&quot;0&quot;,&quot;0&quot;\r\n    &quot;jill&quot;,&quot;jill@somewhere.com&quot;,&quot;1&quot;,&quot;0&quot;,&quot;1&quot;,&quot;0&quot;,&quot;0&quot;\r\n\r\n",
                "title": "Convert JSON array into CSV using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1575964407,
                "creation_date": 1575964407,
                "answer_id": 59262542,
                "question_id": 47730946,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think the simplest ways to do it is\r\n\r\n    jq -r &quot;(.users[0] | keys_unsorted),  (.users[] | map(.) | @csv)&quot;",
                "title": "Convert JSON array into CSV using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 5,
        "last_activity_date": 1575964407,
        "creation_date": 1512838896,
        "last_edit_date": 1512839586,
        "question_id": 47730946,
        "body_markdown": "I have JSON file called temp.json.\r\n\r\n    {\r\n      &quot;users&quot;: [\r\n        {\r\n          &quot;username&quot;: &quot;jack&quot;,\r\n          &quot;email&quot;: &quot;jack@somewhere.com&quot;,\r\n          &quot;total running apps&quot;: &quot;1&quot;,\r\n          &quot;api-mock-app&quot;: &quot;0&quot;,\r\n          &quot;flogo&quot;: &quot;1&quot;,\r\n          &quot;ipaas&quot;: &quot;0&quot;,\r\n          &quot;nodejs-app&quot;: &quot;0&quot;\r\n        },\r\n        {\r\n          &quot;username&quot;: &quot;jill&quot;,\r\n          &quot;email&quot;: &quot;jill@somewhere.com&quot;,\r\n          &quot;total running apps&quot;: &quot;1&quot;,\r\n          &quot;api-mock-app&quot;: &quot;0&quot;,\r\n          &quot;flogo&quot;: &quot;1&quot;,\r\n          &quot;ipaas&quot;: &quot;0&quot;,\r\n          &quot;nodejs-app&quot;: &quot;0&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\ni want to convert this JSON into CSV lilke this,\r\n\r\n    username email              total running apps api-mock-app flogo ipaas nodejs-app\r\n    jack     jack@somewhere.com 1                  0            1     0     0\r\n    jill     jill@somewhere.com 1                  0            1     0     0\r\n\r\nI tried this \r\n\r\n    jq -r &#39;.users[] | keys[0] [.username, .email, .&quot;total running apps&quot;, .&quot;api-mock-app&quot;, .flogo, .ipaas, .&quot;nodejs-app&quot;] | join(&quot;, &quot;) | @csv&#39; temp.json`\r\n\r\nBut i am getting error\r\n\r\n    q: error (at temp.json:22): Cannot index string with string &quot;jack&quot;`\r\n\r\nCan anyone explain where am i making mistake and please let me know the correct answer.",
        "link": "https://stackoverflow.com/questions/47730946/convert-json-array-into-csv-using-jq",
        "title": "Convert JSON array into CSV using jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "any"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1512986575,
                "post_id": 47749719,
                "comment_id": 82460960,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4677143,
                    "reputation": 15627,
                    "user_id": 3787051,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/k2G2V.png?s=256",
                    "display_name": "Alex Harvey",
                    "link": "https://stackoverflow.com/users/3787051/alex-harvey"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1512986773,
                "post_id": 47749719,
                "comment_id": 82461080,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1512996701,
                "post_id": 47749719,
                "comment_id": 82467143,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4677143,
                    "reputation": 15627,
                    "user_id": 3787051,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/k2G2V.png?s=256",
                    "display_name": "Alex Harvey",
                    "link": "https://stackoverflow.com/users/3787051/alex-harvey"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1512998219,
                "post_id": 47749719,
                "comment_id": 82468085,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4677143,
                    "reputation": 15627,
                    "user_id": 3787051,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/k2G2V.png?s=256",
                    "display_name": "Alex Harvey",
                    "link": "https://stackoverflow.com/users/3787051/alex-harvey"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1512999285,
                "post_id": 47749719,
                "comment_id": 82468761,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1512985285,
                "creation_date": 1512985285,
                "answer_id": 47749982,
                "question_id": 47749719,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can lookup JSON in number or ways , \r\n\r\n1. by checking property exists or not \r\n2. by using [property] syntax,\r\n3. &#39;property&#39; in object syntax\r\n\r\nfor your case , here&#39;s a small sample , further you can lookup on array and see \r\n&gt;  containing a &quot;key&quot; key whose value contains EEE and a &quot;value&quot; key\r\n&gt; whose value is exactly FFF\r\n\r\n    for(var k=0; k &lt; p[&#39;AAA&#39;][&#39;BBB&#39;].length;k++){  \r\n       console.log(p[&#39;AAA&#39;][&#39;BBB&#39;][k]) \r\n    }\r\n\r\nwhere p is JSON object.\r\n\r\nHope that helps",
                "title": "Selecting from complex nested JSON data in JQ"
            },
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1513053229,
                "last_edit_date": 1513053229,
                "creation_date": 1513000919,
                "answer_id": 47754599,
                "question_id": 47749719,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In brief, yes.\r\n\r\nIn long:\r\n\r\n    .profiles.auto_scaler[]\r\n    | .dns_name as $name\r\n    | .auto_scaler_group_options\r\n    | select( any(.[&quot;:tags&quot;][];\r\n                 (.[&quot;:key&quot;] | index(&quot;fonzi&quot;)) and (.[&quot;:value&quot;] == &quot;true&quot;)) )\r\n    | $name\r\n\r\nThe output of the above is:\r\n\r\n    &quot;fonz1&quot;\r\n\r\n\r\nThe trick here is to extract the candidate .dns_name before diving more deeply into your &quot;complex nested JSON&quot;.\r\n\r\n### An alternative\r\n\r\nIf your jq does not have `any`, you could (in this particular case) get away without it by replacing the `select` expression above with:\r\n\r\n\r\n     select( .[&quot;:tags&quot;][]\r\n             | (.[&quot;:key&quot;] | index(&quot;fonzi&quot;)) and (.[&quot;:value&quot;] == &quot;true&quot;) )\r\n\r\nBe warned, though, that the semantics of the two expressions are slightly different.  (Homework exercise: what is the difference?)\r\n\r\nIf your jq doesn&#39;t have `any` and if you want the semantics of `any`, then you could easily roll your own, or simply upgrade :-)\r\n\r\n\r\n",
                "title": "Selecting from complex nested JSON data in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1513053229,
        "creation_date": 1512984361,
        "last_edit_date": 1513052840,
        "question_id": 47749719,
        "body_markdown": "I have JSON data like this:\r\n\r\n    {\r\n      &quot;profiles&quot;: {\r\n        &quot;auto_scaler&quot;: [\r\n          {\r\n            &quot;auto_scaler_group_name&quot;: &quot;myasg0&quot;,\r\n            &quot;auto_scaler_group_options&quot;: {\r\n              &quot;:availability_zones&quot;: [&quot;1a&quot;, &quot;1b&quot;, &quot;1c&quot;],\r\n              &quot;:max_size&quot;: 1,\r\n              &quot;:min_size&quot;: 1,\r\n              &quot;:subnets&quot;: [&quot;a&quot;, &quot;b&quot;, &quot;c&quot;],\r\n              &quot;:tags&quot;: [\r\n                {&quot;:key&quot;: &quot;Name&quot;, &quot;:value&quot;: &quot;app0&quot; },\r\n                {&quot;:key&quot;: &quot;env&quot;, &quot;:value&quot;: &quot;dev&quot; },\r\n                {&quot;:key&quot;: &quot;role&quot;, &quot;:value&quot;: &quot;app&quot; },\r\n                {&quot;:key&quot;: &quot;domain&quot;, &quot;:value&quot;: &quot;example.com&quot; },\r\n                {&quot;:key&quot;: &quot;fonzi_app&quot;, &quot;:value&quot;: &quot;true&quot;},\r\n                {&quot;:key&quot;: &quot;vpc&quot;, &quot;:value&quot;: &quot;nonprod&quot;}\r\n              ]\r\n            },\r\n            &quot;dns_name&quot;: &quot;fonz1&quot;\r\n          },\r\n          {\r\n            &quot;auto_scaler_group_name&quot;: &quot;myasg1&quot;,\r\n            &quot;auto_scaler_group_options&quot;: {\r\n              &quot;:availability_zones&quot;: [&quot;1a&quot;, &quot;1b&quot;, &quot;1c&quot;],\r\n              &quot;:max_size&quot;: 1,\r\n              &quot;:min_size&quot;: 1,\r\n              &quot;:subnets&quot;: [&quot;a&quot;, &quot;b&quot;, &quot;c&quot;],\r\n              &quot;:tags&quot;: [\r\n                {&quot;:key&quot;: &quot;Name&quot;, &quot;:value&quot;: &quot;app1&quot; },\r\n                {&quot;:key&quot;: &quot;env&quot;, &quot;:value&quot;: &quot;dev&quot; },\r\n                {&quot;:key&quot;: &quot;role&quot;, &quot;:value&quot;: &quot;app&quot; },\r\n                {&quot;:key&quot;: &quot;domain&quot;, &quot;:value&quot;: &quot;example.com&quot; },\r\n                {&quot;:key&quot;: &quot;bozo_app&quot;, &quot;:value&quot;: &quot;true&quot;},\r\n                {&quot;:key&quot;: &quot;vpc&quot;, &quot;:value&quot;: &quot;nonprod&quot;}\r\n              ]\r\n            },\r\n            &quot;dns_name&quot;: &quot;bozo1&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nI want to write a jq query to firstly select the Hash element in the Array at `.profiles.auto_scaler` whose Array of Hashes at `.auto_scaler_group_options.tags` contains Hashes containing a &quot;`:key`&quot; key whose value *contains* &quot;`fonzi`&quot; and a &quot;`:value`&quot; key whose value is *exactly* `true` and then return the value of the key `dns_name`.\r\n\r\nIn the example, the query would simply return `&quot;fonz1&quot;`.\r\n\r\nDoes anyone know how to do this, if it is possible, using jq?",
        "link": "https://stackoverflow.com/questions/47749719/selecting-from-complex-nested-json-data-in-jq",
        "title": "Selecting from complex nested JSON data in JQ"
    },
    {
        "tags": [
            "debugging",
            "runtime-error",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": false,
                "score": 11,
                "last_activity_date": 1561192830,
                "last_edit_date": 1561192830,
                "creation_date": 1513048108,
                "answer_id": 47764769,
                "question_id": 47764356,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. Rather than using `cat` (which is inefficient and hides the filename from jq), invoke jq with the filename as an argument.\r\n\r\n2. When I do this with your filter and sample data, I get the error message:\r\n\r\n     jq: error (at fulldata.json:31): Cannot index array with string &quot;submitter&quot;\r\n\r\nHere &quot;31&quot; is the line number, corresponding to the end of the file, that is, the end of the array.  So the error message is saying: &quot;you are trying to apply the index operation (.[&quot;submitter&quot;]) to an array.  Arrays can only be indexed by integers, so what&#39;s going on?  Your query applies to objects, not to arrays.  \r\n\r\n3. So a simple workaround is to wrap your query in a call to `map()`. This results in success.\r\n\r\n4. Another approach to debugging would be to use `debug`. You can sprinkle as many `debug`s in the query as you like.  You could, for example, start with:\r\n\r\n     select(debug | .submitter.user_fields.region == &quot;China&quot;)\r\n\r\n5. Suppose now there is a spurious object in the array:\r\n\r\n    { &quot;submitter&quot;: 0 }\r\n\r\nRunning our map(select(...)) program, we get:\r\n\r\n    jq: error (at fulldata.json:35): Cannot index number with string &quot;user_fields&quot;\r\n\r\nThis is the error message you got, and it&#39;s pointing to the line where the error occurs.  \r\n\r\n6. If you would rather just skip the anomalous records, consider using jq&#39;s (only) postfix `?` operator, e.g.\r\n\r\n    map( select(.submitter?.user_fields?.region? == &quot;China&quot;) )\r\n\r\n7. If you want the index in the array where the problematic object is,\r\nthen consider first adding an index, which can be done like so:\r\n\r\n\r\n    range(0;length) as $i | [$i, .[$i]]\r\n\r\nThis converts the array into a stream of pairs of the form [i, object], where i is the index (starting at 0).  You can then easily modify your query so that in case of an error, you can print the corresponding value of i.  For example:\r\n\r\n```\r\n   range(0;length) as $i | [$i, .[$i]]\r\n   | . as $pair\r\n   | try (.[1] | select(.submitter.user_fields.region == &quot;China&quot;))\r\n     catch ($pair[0] | error(tostring))\r\n```\r\n    \r\njq actually offers quite a lot of debugging support, including `debug`, `try ... catch ...`, and `error(...)` as already mentioned; these and some other goodies (e.g. `input_line_number`) are documented in the [reference manual][1].\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "How can I debug a stdin error that jq is throwing at me?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 8,
        "last_activity_date": 1561192830,
        "creation_date": 1513044805,
        "last_edit_date": 1513082883,
        "question_id": 47764356,
        "body_markdown": "given the following dummy data\r\n\r\n    [{\r\n      &quot;submitter&quot;: {\r\n        &quot;user_fields&quot;: {\r\n          &quot;region&quot;: &quot;Colombia&quot;\r\n        }\r\n      }\r\n    }, {\r\n      &quot;submitter&quot;: {\r\n        &quot;user_fields&quot;: {\r\n          &quot;region&quot;: &quot;China&quot;\r\n        }\r\n      }\r\n    }, {\r\n      &quot;submitter&quot;: {\r\n        &quot;user_fields&quot;: {\r\n          &quot;region&quot;: &quot;China&quot;\r\n        }\r\n      }\r\n    }, {\r\n      &quot;submitter&quot;: {\r\n        &quot;user_fields&quot;: {\r\n          &quot;region&quot;: &quot;Mexico&quot;\r\n        }\r\n      }\r\n    }, {\r\n      &quot;submitter&quot;: {\r\n        &quot;user_fields&quot;: {\r\n          &quot;region&quot;: &quot;Canada&quot;\r\n        }\r\n      }\r\n    }]\r\n\r\ncontained in \r\n\r\n    fulldata.json\r\n\r\ni am trying to filter the objects with \r\n\r\n    &quot;region&quot;: &quot;China&quot;\r\n\r\nand then I want all the objects that satisfy the filter to populate a new file \r\n\r\n    chinadata.json\r\n\r\nnow this is what i did:\r\n\r\n    cat fulldata.json | jq &#39;select(.submitter.user_fields.region == &quot;China&quot;)&#39; &gt; chinadata.json\r\n\r\nand effectively a new\r\n\r\n    chinadata.json \r\n\r\nhas been created in the process and it contains (it seems) all the correct info.\r\n\r\nThe problem, though, is that i have a bunch of lines throwing some errors of this kind while the previous command is ran:\r\n\r\n    jq: error (at &lt;stdin&gt;:45380): Cannot index number with string &quot;user_fields&quot;\r\n\r\nQuestion: how can i use the information provided by the error thrown and inspect exactly the objects that caused the error? I would like to correct any formatting mistakes but the dataset is so big that i cannot literally scroll down. \r\n\r\nAny idea would make me happy, thank you!",
        "link": "https://stackoverflow.com/questions/47764356/how-can-i-debug-a-stdin-error-that-jq-is-throwing-at-me",
        "title": "How can I debug a stdin error that jq is throwing at me?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1513088705,
                "creation_date": 1513088705,
                "answer_id": 47774937,
                "question_id": 47774666,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**jq** solution:\r\n\r\n    jq &#39;.properties.orchestratorProfile.kubernetesConfig.addons = \r\n         [.[] | if .name != &quot;rescheduler&quot; then .enabled = false else . end]&#39; file",
                "title": "JQ | Updating array element selected by `select`"
            },
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1513089150,
                "creation_date": 1513089150,
                "answer_id": 47775076,
                "question_id": 47774666,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your jq query is spot-on except essentially for a missing pair of parentheses:\r\n\r\n    (.properties.orchestratorProfile.kubernetesConfig.addons[]\r\n     | select (.name != &quot;rescheduler&quot; ).enabled) = false\r\n\r\nThat is, on the LHS of the assignment, you need to specify the paths of the values that need to be updated.\r\n\r\n",
                "title": "JQ | Updating array element selected by `select`"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1513089150,
        "creation_date": 1513087808,
        "question_id": 47774666,
        "body_markdown": "&lt;!-- What are you trying to accomplish? (Please include sample data.) --&gt;\r\nIn a JSON array, I want to select an array element on basis of a node&#39;s value,  then update a different node in the same array element. E.g. in the JSON below:\r\n\r\n    {\r\n    &quot;apiVersion&quot;: &quot;vlabs&quot;,\r\n    &quot;properties&quot;: {\r\n        &quot;orchestratorProfile&quot;: {\r\n        &quot;orchestratorType&quot;: &quot;Kubernetes&quot;,\r\n        &quot;orchestratorRelease&quot;: &quot;1.7&quot;,\r\n        &quot;orchestratorVersion&quot;: &quot;1.7.10&quot;,\r\n        &quot;kubernetesConfig&quot;: {\r\n            &quot;kubernetesImageBase&quot;: &quot;gcrio.azureedge.net/google_containers/&quot;,\r\n            &quot;clusterSubnet&quot;: &quot;10.105.208.0/20&quot;,\r\n            &quot;networkPolicy&quot;: &quot;calico&quot;,\r\n            &quot;nonMasqueradeCidr&quot;: &quot;10.0.0.0/8&quot;,\r\n            &quot;maxPods&quot;: 110,\r\n            &quot;dockerBridgeSubnet&quot;: &quot;172.17.0.1/16&quot;\r\n            &quot;addons&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;tiller&quot;,\r\n                &quot;enabled&quot;: true\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;aci-connector&quot;,\r\n                &quot;enabled&quot;: true\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;kubernetes-dashboard&quot;,\r\n                &quot;enabled&quot;: true\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;rescheduler&quot;,\r\n                &quot;enabled&quot;: true\r\n            }\r\n            ]\r\n        }\r\n        }\r\n    }\r\n    }\r\n\r\nI want to disable all addons which are not &quot;rescheduler&quot;, i.e. set `.enabled = false` for elements of array `.properties.orchestratorProfile.kubernetesConfig.addons[]` where `.name != &quot;rescheduler&quot;`. Closest I could work out was\r\n\r\n    jq -r &#39;.properties.orchestratorProfile.kubernetesConfig.addons[] |\r\n      select (.name != &quot;rescheduler&quot; ) | .enabled =  false&#39;\r\n\r\nbut this, or any other ways I tried, I always lose the data outside of the array.\r\n\r\nThe expected outcome is:\r\n\r\n    {\r\n    &quot;apiVersion&quot;: &quot;vlabs&quot;,\r\n    &quot;properties&quot;: {\r\n        &quot;orchestratorProfile&quot;: {\r\n        &quot;orchestratorType&quot;: &quot;Kubernetes&quot;,\r\n        &quot;orchestratorRelease&quot;: &quot;1.7&quot;,\r\n        &quot;orchestratorVersion&quot;: &quot;1.7.10&quot;,\r\n        &quot;kubernetesConfig&quot;: {\r\n            &quot;kubernetesImageBase&quot;: &quot;gcrio.azureedge.net/google_containers/&quot;,\r\n            &quot;clusterSubnet&quot;: &quot;10.105.208.0/20&quot;,\r\n            &quot;networkPolicy&quot;: &quot;calico&quot;,\r\n            &quot;nonMasqueradeCidr&quot;: &quot;10.0.0.0/8&quot;,\r\n            &quot;maxPods&quot;: 110,\r\n            &quot;dockerBridgeSubnet&quot;: &quot;172.17.0.1/16&quot;\r\n            &quot;addons&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;tiller&quot;,\r\n                &quot;enabled&quot;: false\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;aci-connector&quot;,\r\n                &quot;enabled&quot;: false\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;kubernetes-dashboard&quot;,\r\n                &quot;enabled&quot;: false\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;rescheduler&quot;,\r\n                &quot;enabled&quot;: true\r\n            }\r\n            ]\r\n        }\r\n        }\r\n    }\r\n    }\r\n\r\nHow do I go about doing this? Any idea or help or guidance is appreciated in advance.\r\n&lt;!-- Paste the part of the code that shows the problem. (Please indent 4 spaces.) --&gt;\r\n\r\n&lt;!-- What do you expect the result to be? --&gt;\r\n\r\n&lt;!-- What is the actual result you get? (Please include any errors.) --&gt;\r\n",
        "link": "https://stackoverflow.com/questions/47774666/jq-updating-array-element-selected-by-select",
        "title": "JQ | Updating array element selected by `select`"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1513092145,
                "post_id": 47775462,
                "comment_id": 82513020,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3067658,
                    "reputation": 13,
                    "user_id": 2599014,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3d7b4eefc6e864e60c53d1a6699da645?s=256&d=identicon&r=PG",
                    "display_name": "tarteflambee",
                    "link": "https://stackoverflow.com/users/2599014/tarteflambee"
                },
                "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": 1513094353,
                "post_id": 47775462,
                "comment_id": 82514504,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1513090715,
                "creation_date": 1513090715,
                "answer_id": 47775590,
                "question_id": 47775462,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It&#39;s not a `jq` problem but a quoting issue (as highlighted in the error).\r\n\r\nChange the `--arg` option to have the value within double quote:\r\n\r\n    arg=&#39;{&quot;test&quot;:&quot;hello world&quot;}&#39;\r\n    jq -n -r --arg m &quot;$arg&quot; &#39;$m | fromjson | {records:[{value:.}]}&#39;\r\n",
                "title": "jq not parsing json with spaces"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1513090822,
                "creation_date": 1513090822,
                "answer_id": 47775617,
                "question_id": 47775462,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You&#39;ve encountered a shell issue: you are missing quotation marks around `$(&lt;$1)`.  The hint is that the space makes a difference.\r\n\r\nBy the way, when there are several moving parts (as there are here), it would be wise to try to isolate the problem before resorting to stackoverflow.  That way, you will often solve the problem yourself; if not, it will at least make it easier for others to focus on the real (and hopefully interesting) issue.\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n ",
                "title": "jq not parsing json with spaces"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1513139554,
        "creation_date": 1513090313,
        "last_edit_date": 1513090502,
        "question_id": 47775462,
        "body_markdown": "I’m trying to run the following command that reads JSON from a file and formats it with jq :\r\n    \r\n    jq -n -r --arg m $(&lt;$1) &#39;$m | fromjson | {records:[{value:.}]}&#39;\r\n\r\nIt produces the desired output when the input JSON does not contain spaces, such as `{&quot;test&quot;:&quot;helloworld&quot;}` :\r\n    \r\n    {\r\n      &quot;records&quot;: [\r\n        {\r\n           &quot;value&quot;: {\r\n            &quot;test&quot;: &quot;helloworld&quot;\r\n          }\r\n         }\r\n      ]\r\n    }\r\n\r\nHowever, for an input like `{&quot;test&quot;:&quot;hello world&quot;}` it would give the following error:\r\n    \r\n    jq: error: syntax error, unexpected QQSTRING_START, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    world&quot;}     \r\n    jq: 1 compile error\r\n\r\nCan’t figure out what’s causing this problem.\r\n\r\nThanks for any help :) ",
        "link": "https://stackoverflow.com/questions/47775462/jq-not-parsing-json-with-spaces",
        "title": "jq not parsing json with spaces"
    },
    {
        "tags": [
            "select",
            "key-value",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1513103520,
                "creation_date": 1513103520,
                "answer_id": 47779294,
                "question_id": 47779110,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq &#39;map(select(.department == &quot;abc&quot;)) &#39; yourfile.json ",
                "title": "How to filter json data based on key value pair using jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1513226383,
                "last_edit_date": 1513226383,
                "creation_date": 1513144820,
                "answer_id": 47786502,
                "question_id": 47779110,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A flexible template might be like this:\r\n\r\n&lt;pre&gt;&lt;code&gt;jq --arg &lt;strong&gt;key&lt;/strong&gt; department --arg &lt;strong&gt;value&lt;/strong&gt; abc \\\r\n&#39;.[] | select(.[$key] == $value)&#39; &lt;strong&gt;input_file.json &gt; output_file.json&lt;/strong&gt;&lt;/code&gt;&lt;/pre&gt;\r\n\r\nThis way you can change the criteria at the arguments stage rather than the expression.\r\n\r\nImplementing that into a shell script might look like this:\r\n\r\n---\r\n\r\n**myscript.sh**\r\n\r\n    #!/usr/bin/env bash\r\n    key=&quot;$1&quot;\r\n    value=&quot;$2&quot;\r\n    file=&quot;$3&quot;\r\n    outfile=&quot;$4&quot;\r\n    jq --arg key &quot;$1&quot; --arg value &quot;$2&quot; \\\r\n    &#39;.[] | select(.[$key] == $value)&#39; &quot;$3&quot; &gt; &quot;$4&quot;\r\n\r\nWhich you would invoke like so:\r\n\r\n    ./myscript.sh department abc input.json output.json\r\n\r\n---\r\nEdit: Changed `.&quot;\\($key)&quot;` to `.[$key]` - thanks @peak",
                "title": "How to filter json data based on key value pair using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1513230178,
        "creation_date": 1513102789,
        "last_edit_date": 1513230178,
        "question_id": 47779110,
        "body_markdown": "Suppose I have some json data given below:\r\n\r\n    {&quot;name&quot;:&quot;alon&quot;,&quot;department&quot;:&quot;abc&quot;,&quot;id&quot;:&quot;ss12sd&quot;}\r\n    {&quot;name&quot;:&quot;kate&quot;,&quot;department&quot;:&quot;xyz&quot;,&quot;id&quot;:&quot;ajsj3&quot; }\r\n    {&quot;name&quot;:&quot;sam&quot;,&quot;department&quot;:&quot;abc&quot;,&quot;id&quot;:&quot;xx1d2&quot;}\r\n\r\nI want to filter data based on particular department and save it in a different json file. From above data suppose I want to filter all the data whose department is &#39;abc&#39; and save it in some new json file. How I can do this using jq. I am checking it&#39;s manual from [here](https://stedolan.github.io/jq/manual/#Basicfilters) but didn&#39;t understood that much.",
        "link": "https://stackoverflow.com/questions/47779110/how-to-filter-json-data-based-on-key-value-pair-using-jq",
        "title": "How to filter json data based on key value pair using jq?"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1513288760,
                "creation_date": 1513288760,
                "answer_id": 47822728,
                "question_id": 47822596,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**jq** solution:\r\n\r\n    jq --slurpfile annot annot.json &#39;.dashboard |= $annot[0]&#39; dashb.json\r\n\r\n&gt; `--slurpfile variable-name filename`:\r\n&gt; \r\n&gt; This option reads all the JSON texts in the named file and binds an\r\n&gt; array of the parsed JSON values to the given global variable.",
                "title": "Using jq to load one json file into the hash of another json file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1513290799,
                "creation_date": 1513290799,
                "answer_id": 47823135,
                "question_id": 47822596,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If your jq does not have --slurpfile, then you could, for example, run jq as follows:\r\n\r\n    jq -s &#39;.[0] as $fragment | .[1] | (.dashboard |= $fragment)&#39; fragment.json dashboard.json\r\n",
                "title": "Using jq to load one json file into the hash of another json file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1513341780,
        "creation_date": 1513288145,
        "last_edit_date": 1513341780,
        "question_id": 47822596,
        "body_markdown": "I&#39;m trying to figure out how to use [jq][1] to load the content of one json file into the hash of another file. E.g.:\r\n\r\nthis file:\r\n\r\n    {\r\n      &quot;annotations&quot;: {...},\r\n      &quot;rows&quot;: [ {...}, {...}]\r\n    }\r\n\r\nshould be inserted into this file at the hash dashboard:\r\n\r\n    {\r\n      &quot;dashboard&quot;: { },\r\n      &quot;overwrite&quot;: true,\r\n      &quot;message&quot;: &quot;new commit&quot;\r\n    }\r\n\r\nso the resulting file should be\r\n\r\n    {\r\n      &quot;dashboard&quot;: {\r\n         &quot;annotations&quot;: {...},\r\n         &quot;rows&quot;: [ {...}, {...}]\r\n      },\r\n      &quot;overwrite&quot;: true,\r\n      &quot;message&quot;: &quot;new commit&quot;\r\n    }\r\n\r\nI was thinking to do it with an pipe | or |= operator but I can&#39;t figure out how to use one content and assign it  to a select filter of the other file.\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/47822596/using-jq-to-load-one-json-file-into-the-hash-of-another-json-file",
        "title": "Using jq to load one json file into the hash of another json file"
    },
    {
        "tags": [
            "sed",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1513347896,
                "last_edit_date": 1513347896,
                "creation_date": 1513346427,
                "answer_id": 47833908,
                "question_id": 47833632,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Until you have everything working the way you want it, I&#39;d suggest taking one step at a time:\r\n\r\n    VALUE=$(jq .SAMPLE_RATE conf.json)\r\n    sed -i.bak -e &quot;/SAMPLE_RATE_SENSOR/s/[0-9][0-9]*/$VALUE/&quot; test.ino\r\n",
                "title": "Change value of Preprocessor Directives in a .ino file using sed and jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1513347896,
        "creation_date": 1513345485,
        "question_id": 47833632,
        "body_markdown": "I am trying to figure out a way to use a `conf.json` file where I may have a _key : value_ such as\r\n\r\n    SAMPLE_RATE : 1000\r\n\r\nand I would like to same use this value to change the preprocessor directives defines in an Arduino Sketch such as (`test.ino`)\r\n\r\n    #define SAMPLE_RATE_SENSOR (100)\r\n\r\nto be set from `(100)` to `(1000)`\r\n\r\nMy current try:\r\n\r\n    cat conf.json | jq .[] | sed -i -e &#39;/SAMPLE_RATE_SENSOR/s/[0-9]/...how to get the jq value here ..../ test.ino\r\n\r\nAs a basic test I tried\r\n\r\n    sed -i -e &#39;/SAMPLE_RATE_SENSOR/s/[0-9]/1000/&#39; test.ino\r\n\r\nbut there is not change to the file itself.\r\n\r\n## Aim\r\n\r\nMy Aim is actually to use a `conf` file to be sent to an Arduino Yun where a python will extract conf. info and change the Sketch with the Sample values accordingly and reprogram the microcontroller.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/47833632/change-value-of-preprocessor-directives-in-a-ino-file-using-sed-and-jq",
        "title": "Change value of Preprocessor Directives in a .ino file using sed and jq"
    },
    {
        "tags": [
            "regex",
            "syntax",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1513596772,
                "creation_date": 1513596772,
                "answer_id": 47867614,
                "question_id": 47862242,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There was a time when multi-arity functions were not supported in jq. I believe that the duality that you describe is a legacy of those days.  Any discrepancy would be a bug worthy of being reported.\r\n\r\n(Perhaps some people  got into the habit of typing `[x,y]` rather than `x;y` and preferred the former?)",
                "title": "Is there any functional difference in the regex patterns that jq offers when it comes to selecting an implementation?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1536412412,
        "creation_date": 1513572229,
        "last_edit_date": 1536412412,
        "question_id": 47862242,
        "body_markdown": "##Is there any difference between the two following expressions in `jq`?\r\n\r\n**Expression 1**&lt;pre&gt;&lt;code&gt;match(&quot;prefix.*if you do&quot;&lt;strong&gt;;&lt;/strong&gt;&quot;gmi&quot;)&lt;/code&gt;&lt;/pre&gt;\r\n\r\n**Expression 2**&lt;pre&gt;&lt;code&gt;match(&lt;strong&gt;[&lt;/strong&gt;&quot;prefix.*if you do&quot;&lt;strong&gt;,&lt;/strong&gt;&quot;gmi&quot;&lt;strong&gt;]&lt;/strong&gt;)&lt;/code&gt;&lt;/pre&gt;\r\n\r\n**Findings**\r\n\r\n 1. They both return the expected data:\r\n\r\n  &lt;pre&gt;&lt;code&gt;{\r\n       &quot;caveats&quot;: &quot;The command has been installed with the prefix \\&quot;g\\&quot;.\\nIf you do not want the prefix, install using the \\&quot;with-default-names\\&quot;\\noption.\\n&quot;\r\n}&lt;/code&gt;&lt;/pre&gt;\r\n\r\n 2. Removing the case insensitive (**`i`**) flag or the multi-line flag (**`m`**) on both expressions will cause the match to fail.\r\n\r\n 3. Using either syntax `[regex,flags]` **or** `regex;flags` works as according to the manual:\r\n\r\n &gt; &lt;pre&gt;&lt;code&gt;The jq regex filters are defined so that they can be used using one of\r\n &gt; these patterns:\r\n &gt; \r\n &gt; STRING | FILTER( REGEX ) &lt;br&gt;STRING | FILTER( REGEX; FLAGS )&lt;br&gt;STRING | FILTER( [REGEX] )&lt;br&gt;STRING | FILTER( [REGEX, FLAGS] )&lt;/code&gt;&lt;/pre&gt;\r\n\r\n 4. Mixing the `;` and `,` between the square bracketed versions causes unexpected results.\r\n\r\nTechnically everything is behaving as expected. \r\n\r\n**But are these results circumstantial because of the simplicity of my example** ? \r\n\r\nSpecifically:\r\n\r\n- Is this just convenience syntax ?\r\n- Is there some convention I am missing where the implementation choice is more important than flipping a coin ?\r\n- Is there any functional difference at all between the two versions ?",
        "link": "https://stackoverflow.com/questions/47862242/is-there-any-functional-difference-in-the-regex-patterns-that-jq-offers-when-it",
        "title": "Is there any functional difference in the regex patterns that jq offers when it comes to selecting an implementation?"
    },
    {
        "tags": [
            "json",
            "bash",
            "ssh",
            "terminal",
            "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": 1513669421,
                "post_id": 47881580,
                "comment_id": 82729965,
                "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": 1513671991,
                "post_id": 47881580,
                "comment_id": 82731121,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1513673824,
                "post_id": 47881580,
                "comment_id": 82732088,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1513758673,
                "last_edit_date": 1513758673,
                "creation_date": 1513680644,
                "answer_id": 47885282,
                "question_id": 47881580,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As @GordonDavisson pointed out, using `tee` to overwrite the input file is a (well-known - see e.g. the jq [FAQ][1]) recipe for disaster. If you absolutely positively want to overwrite the file unconditionally, then you might want to consider using `sponge`, as in\r\n\r\n    jq ... config.json | sponge config.json\r\n\r\n\r\nor more safely:\r\n\r\n    cp -p config.json config.json.bak &amp;&amp; jq ... config.json | sponge config.json\r\nFor further details about this and other options, search for ‘sponge’ in the FAQ.\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "I am using identical syntax in jq to change JSON values, yet one case works while other turns bash interactive, how can I fix this?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1513758673,
        "creation_date": 1513666974,
        "last_edit_date": 1513671049,
        "question_id": 47881580,
        "body_markdown": "I am trying to update a simple JSON file (consists of one object with several key/value pairs) and I am using the same command yet getting different results (sometimes even having the whole json wiped with the 2nd command). The command I am trying is:\r\n\r\n    cat ~/Desktop/config.json | jq &#39;.Option = &quot;klay 10&quot;&#39; | tee ~/Desktop/config.json\r\n\r\nThis command perfectly replaces the value of the `minerOptions` key with &quot;klay 10&quot;, my intended output. \r\n\r\nThen, I try to run the same process on the newly updated file (just value is changed for that one key) and only get interactive terminal with no result. `ps` unfortunately isn&#39;t helpful in showing what&#39;s going on. This is what I do after getting that first command to perfectly change the value of the key: \r\n\r\n    cat ~/Desktop/config.json | jq ‘.othOptions = &quot;-epool etc-eu1.nanopool.org:14324 -ewal 0xc63c1e59c54ca935bd491ac68fe9a7f1139bdbc0 -mode 1&quot;&#39; | tee ~/Desktop/config.json\r\n\r\nwhich I would have expected would replace the `othOptions` key value with the assigned result, just as the last did. I tried directly sending the stdout to the file, but no result there either. I even tried piping one more time and creating a temp file and then moving it to change to original, all of these, as opposed to the same identical command, just return `&gt;` and absolutely zero output; when I quit the process, it is the same value as before, not the new one.\r\n\r\nWhat am I missing here that is causing the same command with just different inputs (the key in second comes right after first and has identical structure, it&#39;s not creating an object or anything, just key-val pair like first. I thought it could be `tee` but any other implementation like a passing of stdout to file produces the same constant `&gt;` waiting for a command, no user. \r\n\r\nI genuinely looked everywhere I could online for why this could be happening before resorting to SE, it&#39;s giving me such a headache for what I thought should be simple. ",
        "link": "https://stackoverflow.com/questions/47881580/i-am-using-identical-syntax-in-jq-to-change-json-values-yet-one-case-works-whil",
        "title": "I am using identical syntax in jq to change JSON values, yet one case works while other turns bash interactive, how can I fix this?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 14,
                "is_accepted": false,
                "score": 14,
                "last_activity_date": 1597366780,
                "last_edit_date": 1597366780,
                "creation_date": 1513688525,
                "answer_id": 47887662,
                "question_id": 47887535,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "NM, solved it with the help of jqplay and some trial and error.\r\n\r\nThis is the solution:\r\n`.[] | select(.KVs[] | .Key == &quot;animal&quot; and .Value == &quot;lion&quot;)`\r\n\r\n([jqplay permalink][1])\r\n\r\n\r\n  [1]: https://jqplay.org/s/JqcLjeSkgJ",
                "title": "Filtering objects in jq by existence of nested array values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 11,
        "last_activity_date": 1629414652,
        "creation_date": 1513688071,
        "question_id": 47887535,
        "body_markdown": "Given a document like this:\r\n\r\n    [\r\n      {\r\n        &quot;KVs&quot; : [\r\n          {\r\n            &quot;Key&quot;: &quot;animal&quot;,\r\n            &quot;Value&quot;: &quot;lion&quot;\r\n          },\r\n          {\r\n            &quot;Key&quot;: &quot;mascot&quot;,\r\n            &quot;Value&quot;: &quot;lion&quot;\r\n          }\r\n        ],\r\n        &quot;name&quot;: &quot;roger&quot;\r\n      },\r\n      {\r\n        &quot;KVs&quot; : [\r\n          {\r\n            &quot;Key&quot;: &quot;animal&quot;,\r\n            &quot;Value&quot;: &quot;zebra&quot;\r\n          },\r\n          {\r\n            &quot;Key&quot;: &quot;mascot&quot;,\r\n            &quot;Value&quot;: &quot;lion&quot;\r\n          }\r\n        ],\r\n        &quot;name&quot;: &quot;linda&quot;\r\n      }\r\n    ]\r\n\r\nI want to use `jq` to select only those elements of the top array that contain the KV pair `animal == &quot;lion&quot;`.\r\n\r\nThe output for the above JSON document should be:\r\n\r\n    {\r\n      &quot;KVs&quot; : [\r\n        {\r\n          &quot;Key&quot;: &quot;animal&quot;,\r\n          &quot;Value&quot;: &quot;lion&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;mascot&quot;,\r\n          &quot;Value&quot;: &quot;lion&quot;\r\n        }\r\n      ],\r\n      &quot;name&quot;: &quot;roger&quot;\r\n    }\r\n\r\nCan&#39;t figure out how to accomplish this with `select()`. I know how to use it to select based on one specific field. e.g. by key name: `.[] | select(.KVs[].Key == &quot;animal&quot;)`, right? But how do I tell it to match the same KV object on two fields (Key &amp; Value)?\r\n",
        "link": "https://stackoverflow.com/questions/47887535/filtering-objects-in-jq-by-existence-of-nested-array-values",
        "title": "Filtering objects in jq by existence of nested array values"
    },
    {
        "tags": [
            "json",
            "object",
            "select",
            "nested",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1513703253,
                "creation_date": 1513703253,
                "answer_id": 47891927,
                "question_id": 47891145,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For small to modest-sized JSON input, you&#39;re on the right track with `..`\r\nbut it seems you want to select `objects`, like so:\r\n\r\n    .. | objects | select(.class==&quot;FINDME&quot;?) | .id\r\n\r\nFor JSON documents that are very large, this might require too much memory, so it may be worth knowing about jq&#39;s streaming parser. Unfortunately it&#39;s much more difficult to use, so I&#39;d suggest trying the above, and if you&#39;re interested, look  in the usual places for documentation about the `--stream` option.\r\n\r\n",
                "title": "Use JQ to select specific, arbitrarily nested objects from JSON"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1513750039,
                "last_edit_date": 1513750039,
                "creation_date": 1513705419,
                "answer_id": 47892492,
                "question_id": 47891145,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a streaming-parser solution. To make sense of it, you&#39;ll need to read up on the `--stream` option, but the key is that the output includes lines of the form: [PATH, VALUE]\r\n\r\n### program.jq\r\n\r\n    foreach inputs as $in (null;\r\n      if has(&quot;id&quot;) and has(&quot;class&quot;) then null\r\n      else . as $x\r\n      | $in\r\n      | if length != 2 then null\r\n        elif .[0][-1] == &quot;id&quot; then ($x + {id: .[-1]})\r\n        elif .[0][-1] == &quot;class&quot;\r\n             and .[-1] == &quot;FINDME&quot; then  ($x + {class: .[-1]})\r\n        else $x\r\n        end\r\n      end;\r\n      select(has(&quot;id&quot;) and has(&quot;class&quot;)) | .id )\r\n\r\n### Invocation\r\n\r\n    jq -n --stream -f program.jq input.json\r\n\r\n### Output with sample input\r\n\r\n    &quot;c1.1&quot;\r\n    &quot;c2&quot;\r\n    &quot;c3&quot;\r\n\r\n  \r\n\r\n",
                "title": "Use JQ to select specific, arbitrarily nested objects from JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 11,
        "last_activity_date": 1513750039,
        "creation_date": 1513700705,
        "last_edit_date": 1513709525,
        "question_id": 47891145,
        "body_markdown": "I&#39;m looking for efficient means to search through an large JSON object for &quot;sub-objects&quot; that match a filter (via `select()`, I imagine).  However, the top-level JSON is an object with arbitrary nesting contained within, including more simple values, objects and arrays of objects.  For example:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;foo&quot;,\r\n      &quot;class&quot;: &quot;system&quot;,\r\n      &quot;description&quot;: &quot;top-level-thing&quot;,\r\n      &quot;configuration&quot;: {\r\n        &quot;status&quot;: &quot;normal&quot;,\r\n        &quot;uuid&quot;: &quot;id&quot;\r\n      },\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;c1&quot;,\r\n          &quot;class&quot;: &quot;c1&quot;,\r\n          &quot;children&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;c1.1&quot;,\r\n              &quot;class&quot;: &quot;c1.1&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;c1.1&quot;,\r\n              &quot;class&quot;: &quot;FINDME&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;c2&quot;,\r\n          &quot;class&quot;: &quot;FINDME&quot;\r\n        }\r\n      ],\r\n      &quot;thing&quot;: {\r\n        &quot;id&quot;: &quot;c3&quot;,\r\n        &quot;class&quot;: &quot;FINDME&quot;\r\n      }\r\n    }    \r\n\r\nI have a solution which does **part of** what I want (and is understandable):\r\n\r\n    jq -r &#39;.. | arrays | .[] | select(.class==&quot;FINDME&quot;?) | .id&#39;\r\n\r\nwhich returns:\r\n\r\n    c2\r\n    c1.1\r\n\r\n... however, it misses `c3`, plus it changes the order of items output.  Additionally I&#39;m expecting this to operate on potentially very large JSON structures, I would like to make sure I find an efficient solution.  Bonus points for something that remains readable by `jq` neophytes (myself included).\r\n\r\nFWIW, references I was using to help me on the way, in case they help others:\r\n\r\n - https://stackoverflow.com/questions/18592173/select-objects-based-on-value-of-variable-in-object-using-jq\r\n - https://stackoverflow.com/questions/39800718/how-to-use-jq-to-find-all-paths-to-a-certain-key\r\n - https://stackoverflow.com/questions/38459429/recursive-search-values-by-key",
        "link": "https://stackoverflow.com/questions/47891145/use-jq-to-select-specific-arbitrarily-nested-objects-from-json",
        "title": "Use JQ to select specific, arbitrarily nested objects from JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1513714813,
                "creation_date": 1513714813,
                "answer_id": 47894600,
                "question_id": 47894527,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use this:\r\n\r\n    jq &#39;[{&quot;c&quot;:(.a[].b[].c)}]&#39; file.json",
                "title": "jq flattening JSON arrays"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1513715341,
                "creation_date": 1513715341,
                "answer_id": 47894706,
                "question_id": 47894527,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This does it:\r\n\r\n    jq &#39;[ .a[][][] ]&#39;",
                "title": "jq flattening JSON arrays"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1513716059,
                "last_edit_date": 1513716059,
                "creation_date": 1513715757,
                "answer_id": 47894802,
                "question_id": 47894527,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    $ jq [.[][][][]] &lt;&lt;&lt; &quot;$JSON&quot;\r\n    [\r\n      {\r\n        &quot;c&quot;: &quot;xxx&quot;\r\n      },\r\n      {\r\n        &quot;c&quot;: &quot;yyy&quot;\r\n      },\r\n      {\r\n        &quot;c&quot;: &quot;zzz&quot;\r\n      }\r\n    ]\r\n\r\nOR:\r\n\r\n    $ jq &#39;[.. | select(has(&quot;c&quot;)?)]&#39; &lt;&lt;&lt; &quot;$JSON&quot;\r\n    [\r\n      {\r\n        &quot;c&quot;: &quot;xxx&quot;\r\n      },\r\n      {\r\n        &quot;c&quot;: &quot;yyy&quot;\r\n      },\r\n      {\r\n        &quot;c&quot;: &quot;zzz&quot;\r\n      }\r\n    ]",
                "title": "jq flattening JSON arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1513716059,
        "creation_date": 1513714447,
        "last_edit_date": 1513715377,
        "question_id": 47894527,
        "body_markdown": "This\r\n\r\n    echo &#39;{&quot;a&quot;:[{&quot;b&quot;:[{&quot;c&quot;:&quot;xxx&quot;}]},{&quot;b&quot;:[{&quot;c&quot;:&quot;yyy&quot;},{&quot;c&quot;:&quot;zzz&quot;}]}]}&#39; |\r\n        jq &#39;.a[].b | map({&quot;c&quot;: .c})&#39;\r\n\r\nproduces this:\r\n\r\n    [\r\n      {\r\n        &quot;c&quot;: &quot;xxx&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;c&quot;: &quot;yyy&quot;\r\n      },\r\n      {\r\n        &quot;c&quot;: &quot;zzz&quot;\r\n      }\r\n    ]\r\n\r\nHow do I get a single output array like:\r\n\r\n    [\r\n      {\r\n        &quot;c&quot;: &quot;xxx&quot;\r\n      },\r\n      {\r\n        &quot;c&quot;: &quot;yyy&quot;\r\n      },\r\n      {\r\n        &quot;c&quot;: &quot;zzz&quot;\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/47894527/jq-flattening-json-arrays",
        "title": "jq flattening JSON arrays"
    },
    {
        "tags": [
            "json",
            "bash",
            "ssh",
            "jq"
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1513756294,
        "creation_date": 1513756294,
        "question_id": 47901164,
        "body_markdown": "I&#39;m trying to write a simple bash script that will pipeline a `jq` change of key-value, setting the `value` for key to a new one I pass into my bash script. \r\n\r\nI already got down the pipeline for changing the value, I run `jq &#39;.key = &quot;newVal&quot;&#39;&lt;config.json | sponge config.json`\r\n\r\nand this works for changing all the values I want, except I want to automate it so that I can just pass values I want changed into bash script and then have those replaced where `newVal` is in my code above. \r\n\r\nMy attempt was this:\r\n\r\n    confMizerFinal(){ status=$1; minPath=$2; minOps=$3; jq &#39;.status = &quot;&#39;$status&#39;&#39;&lt;config.json | sponge config.json; cat config.json; }\r\n\r\n(I included just one jq pipeline to make it easier to read, of course I would be having one for each newVal1... I want to set. The issue is actually passing it into the value, in this case, neither `&#39;$status&#39;` nor `&quot;$status&quot;`, unfortunately. Am I maybe oversimplifying this, and I cannot just pass the positional param value to the .key in JSON? \r\n\r\nAll help is much appreciated, this site has been instrumental to advancing my knowledge in bash. \r\n\r\n",
        "link": "https://stackoverflow.com/questions/47901164/how-can-i-pass-specific-string-values-to-a-jq-argument-as-positional-parameters",
        "title": "How can I pass specific string values to a jq argument as positional parameters"
    },
    {
        "tags": [
            "bash",
            "sh",
            "jq",
            "oh-my-zsh"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1513835380,
                "last_edit_date": 1513835380,
                "creation_date": 1513827787,
                "answer_id": 47917628,
                "question_id": 47917299,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I think I got it figured out here:\r\n\r\n    get_sfdx_defaultusername() {\r\n        config=&quot;$(cat .sfdx/sfdx-config.json 2&gt; /dev/null)&quot;;\r\n        globalConfig=&quot;$(cat ~/.sfdx/sfdx-config.json)&quot;;\r\n        aliasConfig=&quot;$(cat ~/.sfdx/alias.json)&quot;;\r\n\r\n        defaultusername=&quot;$(echo ${config} | jq -r .defaultusername)&quot;\r\n        defaultusernamealias=&quot;$(echo ${aliasConfig} | jq -r &#39;.orgs | to_entries[] | select(.value ==&quot;&#39;$defaultusername&#39;&quot;).key&#39; )&quot;\r\n        globaldefaultusername=&quot;$(echo ${globalConfig} | jq -r .defaultusername)&quot;\r\n\r\n        if [ ! $defaultusernamealias = &quot;null&quot; ]\r\n        then\r\n            echoString=$echoString$defaultusernamealias&quot;$txtylw (alias)&quot;\r\n        elif [ ! $defaultusername = &quot;null&quot; ]\r\n        then\r\n            echoString=$echoString$defaultusername&quot;$txtylw (local)&quot;\r\n        else\r\n            echoString=$echoString$globaldefaultusername&quot;$txtylw (global)&quot;\r\n        fi\r\n        echo $echoString&quot;\\n&quot;\r\n    }\r\n\r\nThis allows me to show my current defaultusername org like so:\r\n[![enter image description here][1]][1]\r\n\r\nIn case anyone is interested in using this or contributing to it, I published a [github repo here][2]\r\n\r\n\r\n  [1]: https://i.sstatic.net/cfn9D.png\r\n  [2]: https://github.com/Xtremefaith/sfdx-ohmyzsh",
                "title": "JQ get key based on variable value"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1513836484,
                "last_edit_date": 1513836484,
                "creation_date": 1513833288,
                "answer_id": 47918333,
                "question_id": 47917299,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Congratulations on figuring out how to use `to_entries`.\r\n\r\nOne small suggestion is to avoid using shell interpolation to &quot;construct&quot; the jq program.  A much better way to achieve the desired goal is to pass in the relevant values on the command-line. In your case, the following would be appropriate:\r\n\r\n    $ jq --arg username &quot;$defaultusername&quot; &#39;\r\n      .orgs | to_entries[] | select(.value == $username ).key&#39;\r\n\r\nAnother small point is to avoid using `echo` to send JSON to STDIN. There are several possibilities, including these patterns:\r\n\r\n* if you are using bash: `jq .... &lt;&lt;&lt; &quot;$JSON&quot;`\r\n* use `printf &quot;%s&quot; &quot;$JSON&quot; | jq ...`\r\n* `jq -n --argjson JSON &quot;$JSON&quot; &#39;$JSON | ...&#39;`\r\n\r\nIn your case, the last of these alternatives would look like this:\r\n\r\n    $ jq --arg username &quot;$defaultusername&quot; --argjson JSON &quot;$aliasConfig&quot; &#39;\r\n        $JSON\r\n        | .orgs | to_entries[] | select(.value == $username ).key&#39;\r\n\r\n\r\n",
                "title": "JQ get key based on variable value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1513836484,
        "creation_date": 1513825214,
        "last_edit_date": 1513832582,
        "question_id": 47917299,
        "body_markdown": "I&#39;m trying to create a ohmyzsh function for Salesforce&#39;s DX CLI based on Wade Wegner&#39;s guide [here][1]. In order to get the value I want I need to expand how he is using [JQ][2] which I&#39;ve never heard of before. I get the premise for this use case but I&#39;m struggling with one abstraction point (within the `aliasConfig` json). Here&#39;s my script so far\r\n\r\n    get_sfdx_defaultusername() {\r\n        config=&quot;$(cat .sfdx/sfdx-config.json 2&gt; /dev/null)&quot;;\r\n        globalConfig=&quot;$(cat ~/.sfdx/sfdx-config.json)&quot;;\r\n        aliasConfig=&quot;$(cat ~/.sfdx/alias.json)&quot;;\r\n\r\n        defaultusername=&quot;$(echo ${config} | jq -r .defaultusername)&quot;\r\n        defaultusernamealias=&quot;NEED HELP HERE&quot;\r\n        globaldefaultusername=&quot;$(echo ${globalConfig} | jq -r .defaultusername)&quot;\r\n\r\n        if [ ! $defaultusernamealias = &quot;null&quot; ]\r\n        then\r\n          echoString=$echoString$defaultusernamealias&quot;$txtylw (alias)&quot;\r\n        elif [ ! $defaultusername = &quot;null&quot; ]\r\n        then\r\n          echoString=$echoString$defaultusername&quot;$txtylw (local)&quot;\r\n        else\r\n          echoString=$echoString$globaldefaultusername&quot;$txtylw (global)&quot;\r\n        fi\r\n        echo $echoString&quot;\\n&quot;\r\n    }\r\n\r\nThe **alias.json** looks like this:\r\n\r\n    {\r\n        &quot;orgs&quot;: {\r\n            &quot;HubOrg&quot;: &quot;myemail@domain.com&quot;,        \r\n            &quot;my-scrath-org&quot;: &quot;test-jdj1iflkor4k@mydomain.net&quot;\r\n        }\r\n    }\r\n\r\nUsing the `${defaultusername}` I know the value in this case to be &quot;test-jdj1iflkor4k@mydomain.net&quot;, therefore I need it to set the value of `defaultusernamealias` to &quot;my-scrath-org&quot;\r\n\r\nNOTE: The closest answer I found was [this][3], but unfortunately I still couldn&#39;t get what I needed with it.\r\n\r\n\r\n  [1]: http://www.wadewegner.com/2017/04/show-the-salesforce-dx-org-config-in-your-bash-profile/#comment-3671894553\r\n  [2]: https://stedolan.github.io/jq/\r\n  [3]: https://stackoverflow.com/questions/43678724/jq-extracting-the-array-key-based-on-value",
        "link": "https://stackoverflow.com/questions/47917299/jq-get-key-based-on-variable-value",
        "title": "JQ get key based on variable value"
    },
    {
        "tags": [
            "aws-cli",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1513948890,
                "creation_date": 1513948890,
                "answer_id": 47942260,
                "question_id": 47939865,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Generally, the best way to pass the value of shell variables to a jq program is using the `-—arg` and/or `—-argjson` command-line options, as described in the manual. Environment variables can be passed in using `env`.\r\n\r\nSee also the https://github.com/stedolan/jq/wiki/FAQ",
                "title": "How to use jq with &#39;select(startswith(&quot;$variable&quot;))&#39;?"
            },
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1550362406,
                "last_edit_date": 1550362406,
                "creation_date": 1544497466,
                "answer_id": 53716749,
                "question_id": 47939865,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also do it without using `--arg` or `--argjson`. In your case, since your variable holds a string value, you may do it like this.\r\n\r\n    aws cloudformation describe-stacks --stack-name $StackName --region $region |\\\r\n    jq -r &#39;.Stacks[].Outputs[].OutputKey | select(startswith(&#39;\\&quot;$App\\&quot;&#39;) )&#39;\r\n\r\nNotice I added single quotation marks and escaped the double-quotation marks around your variable\r\n\r\nSee here [https://github.com/stedolan/jq/wiki/FAQ][1] on the &quot;*How can environment variables be passed to a jq program? How can a jq program be parameterized*?&quot; second answer.\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "How to use jq with &#39;select(startswith(&quot;$variable&quot;))&#39;?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1550362406,
        "creation_date": 1513938238,
        "question_id": 47939865,
        "body_markdown": "I&#39;m using `jq` to parse some output from AWS cli.\r\n\r\nI&#39;m trying to use `&#39;select(startswith(&quot;$variable&quot;) )&#39;` but for some reason it doesn&#39;t work even though when I use the variable&#39;s value it works properly.\r\n\r\nExample:\r\n\r\n    itai@MacBook-Pro ~/src/Scripts - $ echo $App\r\n    Analytics\r\n    itai@MacBook-Pro ~/src/Scripts - $ aws cloudformation describe-stacks --stack-name $StackName --region $region | jq -r &#39;.Stacks[].Outputs[].OutputKey | select(startswith(&quot;Analytics&quot;) )&#39;\r\n    AnalyticsAutoScalingGroup\r\n    itai@MacBook-Pro ~/src/Scripts - $ aws cloudformation describe-stacks --stack-name $StackName --region $region | jq -r &#39;.Stacks[].Outputs[].OutputKey | select(startswith(&quot;$App&quot;) )&#39;\r\n    itai@MacBook-Pro ~/src/Scripts - $\r\n\r\nI know I can use grep like so:\r\n\r\n    aws cloudformation describe-stacks --stack-name $StackName --region $region | jq -r &#39;.Stacks[].Outputs[].OutputKey&#39; | grep $App\r\n\r\nBut I prefer to use jq all along the command.\r\n\r\nAm I doing it wrong or is it just not possible?",
        "link": "https://stackoverflow.com/questions/47939865/how-to-use-jq-with-selectstartswithvariable",
        "title": "How to use jq with &#39;select(startswith(&quot;$variable&quot;))&#39;?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 20,
                "is_accepted": true,
                "score": 20,
                "last_activity_date": 1513944088,
                "creation_date": 1513944088,
                "answer_id": 47941201,
                "question_id": 47939901,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** approach:\r\n\r\n    jq -r &#39;.x[] | select(.name == &quot;Christmas&quot;).id&#39; file\r\n    171\r\n\r\n\r\n----------\r\nThe function `select(boolean_expression)` produces its input unchanged if `boolean_expression` returns `true` for that input, and produces no output otherwise.",
                "title": "jq: How to match one of array and get property value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1547063873,
                "creation_date": 1547063873,
                "answer_id": 54117419,
                "question_id": 47939901,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It can also been done like: \r\n\r\n    jq &#39;.x[] | select(.name == &quot;Christmas&quot;).id&#39;\r\n\r\nAlso you can try this at link [online jq play][1]\r\n\r\n\r\n  [1]: https://jqplay.org/",
                "title": "jq: How to match one of array and get property value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 10,
        "last_activity_date": 1704280793,
        "creation_date": 1513938445,
        "last_edit_date": 1704280793,
        "question_id": 47939901,
        "body_markdown": "I have some JSON like this:\r\n\r\n    {\r\n      &quot;x&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Hello&quot;,\r\n          &quot;id&quot;: &quot;211&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Goodbye&quot;,\r\n          &quot;id&quot;: &quot;221&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Christmas&quot;,\r\n          &quot;id&quot;: &quot;171&quot;\r\n        }\r\n      ],\r\n      &quot;y&quot;: &quot;value&quot;\r\n    }\r\n\r\nUsing jq, given a name value (e.g. Christmas) how can I get it&#39;s associated id (i.e. 171).\r\n\r\nI&#39;ve got as far as being able to check for presence of the name in one of the array&#39;s objects, but I can&#39;t work out how to filter it down\r\n\r\n    jq -r &#39;select(.x[].name == &quot;Christmas&quot;)&#39;",
        "link": "https://stackoverflow.com/questions/47939901/jq-how-to-match-one-of-array-and-get-property-value",
        "title": "jq: How to match one of array and get property value"
    },
    {
        "tags": [
            "json",
            "curl",
            "jenkins",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1513954120,
                "last_edit_date": 1513954120,
                "creation_date": 1513953717,
                "answer_id": 47943275,
                "question_id": 47942448,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Jenkins has it own api syntax which allows you to filter the api output. You can use the xml version and specify an xpath. In your case, the following url should get you the userId.\r\n\r\n    curl -g https://ip.us-west-2.compute.amazonaws.com/job/Company-Analytics-Prod-Deploy_New/24/api/xml?xpath=//*/action[1]/cause/userId\r\n\r\n\r\n",
                "title": "How to extract userId from curl on Jenkins build url using jq?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1513956959,
                "creation_date": 1513956959,
                "answer_id": 47943955,
                "question_id": 47942448,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using jq, you can protect against non-existence using the post-fix &quot;?&quot; operator, e.g. in your case:\r\n\r\n    .actions[].causes[]?.userId? | select(.)",
                "title": "How to extract userId from curl on Jenkins build url using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1513975608,
                "creation_date": 1513975608,
                "answer_id": 47947194,
                "question_id": 47942448,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "what about gerpping and trimming the output :\r\n\r\n    $ curl -s --insecure -u itaig:password  https://ip.us-west-2.compute.amazonaws.com/job/Company-Analytics-Prod-Deploy_New/24/api/json |\r\n       jq -r &#39;.actions[]&#39; | grep userId | cut -d &quot;:&quot; -f2 | tr -d &#39;&quot;,&quot; &#39;",
                "title": "How to extract userId from curl on Jenkins build url using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1513975756,
        "creation_date": 1513949708,
        "last_edit_date": 1513975756,
        "question_id": 47942448,
        "body_markdown": "I have the following output from `curl`ing Jenkins $BUILD_URL/api/json:\r\n\r\n    itai@Itais-MBP ~ -  $ curl -s --insecure -u itaig:password  https://ip.us-west-2.compute.amazonaws.com/job/Company-Analytics-Prod-Deploy_New/24/api/json |\r\n       jq -r &#39;.actions[]&#39;\r\n    {\r\n      &quot;_class&quot;: &quot;hudson.model.CauseAction&quot;,\r\n      &quot;causes&quot;: [\r\n        {\r\n          &quot;_class&quot;: &quot;hudson.model.Cause$UserIdCause&quot;,\r\n          &quot;shortDescription&quot;: &quot;Started by user Itai Ganot&quot;,\r\n          &quot;userId&quot;: &quot;itaig&quot;,\r\n          &quot;userName&quot;: &quot;Itai Ganot&quot;\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;_class&quot;: &quot;hudson.model.CauseAction&quot;,\r\n      &quot;causes&quot;: [\r\n        {\r\n          &quot;_class&quot;: &quot;com.sonyericsson.rebuild.RebuildCause&quot;,\r\n          &quot;shortDescription&quot;: &quot;Rebuilds build #23&quot;,\r\n          &quot;upstreamBuild&quot;: 23,\r\n          &quot;upstreamProject&quot;: &quot;Company-Analytics-Prod-Deploy_New&quot;,\r\n          &quot;upstreamUrl&quot;: &quot;view/Prod-US%20Deploy/job/Company-Analytics-Prod-Deploy_New/&quot;\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;_class&quot;: &quot;hudson.model.ParametersAction&quot;,\r\n      &quot;parameters&quot;: [\r\n        {\r\n          &quot;_class&quot;: &quot;eu.markov.jenkins.plugin.mvnmeta.MavenMetadataParameterValue&quot;,\r\n          &quot;name&quot;: &quot;Version&quot;\r\n        },\r\n        {\r\n          &quot;_class&quot;: &quot;hudson.model.StringParameterValue&quot;,\r\n          &quot;name&quot;: &quot;region&quot;,\r\n          &quot;value&quot;: &quot;us-east-1&quot;\r\n        },\r\n        {\r\n          &quot;_class&quot;: &quot;hudson.model.StringParameterValue&quot;,\r\n          &quot;name&quot;: &quot;StackName&quot;,\r\n          &quot;value&quot;: &quot;Company-Prd-21&quot;\r\n        },\r\n        {\r\n          &quot;_class&quot;: &quot;hudson.model.StringParameterValue&quot;,\r\n          &quot;name&quot;: &quot;autostart&quot;,\r\n          &quot;value&quot;: &quot;No&quot;\r\n        }\r\n      ]\r\n    }\r\n    {}\r\n    {}\r\n    {\r\n      &quot;_class&quot;: &quot;hudson.plugins.git.util.BuildData&quot;,\r\n      &quot;buildsByBranchName&quot;: {\r\n        &quot;refs/remotes/origin/master&quot;: {\r\n          &quot;_class&quot;: &quot;hudson.plugins.git.util.Build&quot;,\r\n          &quot;buildNumber&quot;: 24,\r\n          &quot;buildResult&quot;: null,\r\n          &quot;marked&quot;: {\r\n            &quot;SHA1&quot;: &quot;0e71efeac11c9909838453f4f103457ec3b04d27&quot;,\r\n            &quot;branch&quot;: [\r\n              {\r\n                &quot;SHA1&quot;: &quot;0e71efeac11c9909838453f4f103457ec3b04d27&quot;,\r\n                &quot;name&quot;: &quot;refs/remotes/origin/master&quot;\r\n              }\r\n            ]\r\n          },\r\n          &quot;revision&quot;: {\r\n            &quot;SHA1&quot;: &quot;0e71efeac11c9909838453f4f103457ec3b04d27&quot;,\r\n            &quot;branch&quot;: [\r\n              {\r\n                &quot;SHA1&quot;: &quot;0e71efeac11c9909838453f4f103457ec3b04d27&quot;,\r\n                &quot;name&quot;: &quot;refs/remotes/origin/master&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      },\r\n      &quot;lastBuiltRevision&quot;: {\r\n        &quot;SHA1&quot;: &quot;0e71efeac11c9909838453f4f103457ec3b04d27&quot;,\r\n        &quot;branch&quot;: [\r\n          {\r\n            &quot;SHA1&quot;: &quot;0e71efeac11c9909838453f4f103457ec3b04d27&quot;,\r\n            &quot;name&quot;: &quot;refs/remotes/origin/master&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;remoteUrls&quot;: [\r\n        &quot;git@git.assembla.com:company.ci.git&quot;\r\n      ],\r\n      &quot;scmName&quot;: &quot;&quot;\r\n    }\r\n    {\r\n      &quot;_class&quot;: &quot;hudson.plugins.git.GitTagAction&quot;\r\n    }\r\n    {}\r\n    {}\r\n    {}\r\n    {}\r\n    {}\r\n    itai@Itais-MBP ~ -  $\r\n\r\nI&#39;m trying to extract the &quot;userId&quot; who started the build job as the current available Jenkins plugins which are supposed to do it don&#39;t work for some reason.\r\n\r\nThis is what I tried but it gives me an error:\r\n\r\n    itai@Itais-MBP ~ -  $ curl -s --insecure -u itaig:password  https://ip.us-west-2.compute.amazonaws.com/job/Company-Analytics-Prod-Deploy_New/24/api/json |\r\n     jq -r &#39;.actions[].causes[] | .userId&#39;\r\n    itaig\r\n    null\r\n    jq: error (at &lt;stdin&gt;:0): Cannot iterate over null (null)\r\n    itai@Itais-MBP ~ -  $\r\n\r\nI think it&#39;s related to the fact that there&#39;s no &quot;.causes[]&quot; in some of the &quot;.actions[]&quot; blocks, and if that&#39;s the case, is it possible to extract the &quot;userId&quot;?",
        "link": "https://stackoverflow.com/questions/47942448/how-to-extract-userid-from-curl-on-jenkins-build-url-using-jq",
        "title": "How to extract userId from curl on Jenkins build url using jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1513958443,
                "creation_date": 1513958443,
                "answer_id": 47944251,
                "question_id": 47944079,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;m afraid you&#39;ll have to learn a bit about jq before you&#39;ll be able to use it effectively.  I&#39;d suggest mastering things bit-by-bit before trying to put everything together.  \r\n\r\nLet&#39;s start with `--arg inp4 &quot;$keypassword&quot;`.  That passes the shell variable to a jq dollar-variable, with the net effect of setting the jq variable $inp4 to the string-value of the shell variable $keypassword.  You can then use `$inp4` as a jq variable, like any other -- so no quotation marks around it.\r\n\r\nAnother useful thing to know how to use is the `-f` command-line option.  That should save you much time and aggravation.\r\n\r\nBy the way, when you do finally put everything together, you&#39;ll only need one invocation of jq.",
                "title": "jq parsing with arg filters does not give expected result"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1514930797,
        "creation_date": 1513957546,
        "last_edit_date": 1514930797,
        "question_id": 47944079,
        "body_markdown": "jq parser with --arg with String concatenation does not give proper json output. Input file is &#39;test.json&#39; and output file is &#39;final.json&#39;  \r\n\r\n\r\nThis is input json file\r\n    test.json\r\n    ---------\r\n            {\r\n              &quot;ParameterKey1&quot;:  &quot;&lt;value1&gt;&quot;,\r\n              &quot;Parameterkey2&quot;:  &quot;&lt;value2&gt;&quot; \r\n             }\r\n        \r\n        Tried test.json with 2nd filter \r\n        jq --arg inp4 &quot;$keypassword&quot; \\\r\n                        &#39;if .ParameterKey1 == &quot;&lt;value1&gt;&quot;\r\n                                then . + {&quot;ParameterKey1&quot; : ($input1) }\r\n                        else . end&#39;     | jq --arg inp5 &quot;$value2&quot;  \\\r\n                        &#39;if .Parameterkey2 == &quot;&lt;value2&gt;&quot;\r\n                                then . + {&quot;value2&quot; : ($input2) }\r\n                        else . end&#39;  test.json   &gt;  final.json\r\n        \r\n        \r\n        Tried test.json with 1st filter\r\n        jq --arg inp4 &quot;$key&quot; \\\r\n                        &#39;if .ParameterKey1 == &quot;&lt;value1&gt;&quot;\r\n                                then . + {&quot;ParameterKey1&quot; : ($input1) }\r\n                        else . end&#39;  test.json   | jq --arg inp5 &quot;$value2&quot;  \\\r\n                        &#39;if .Parameterkey2 == &quot;&lt;value2&gt;&quot;\r\n                                then . + {&quot;value2&quot; : ($input2) }\r\n                        else . end&#39;     &gt;  final.json\r\n        \r\n        \r\n        Tried test.json in both filters\r\n        jq --arg inp4 &quot;$key&quot; \\\r\n                        &#39;if .ParameterKey1 == &quot;&lt;value1&gt;&quot;\r\n                                then . + {&quot;ParameterKey1&quot; : ($inp4) }\r\n                        else . end&#39;  test.json   | jq --arg inp5 &quot;$value2&quot;  \\\r\n                        &#39;if .Parameterkey2 == &quot;&lt;value2&gt;&quot;\r\n                                then . + {&quot;value2&quot; : ($inp5) }\r\n                        else . end&#39;  test.json   &gt;  final.json\r\n        \r\n        Expected output: (final.json)\r\n          {\r\n              &quot;ParameterKey1&quot;:  &quot;value&quot;,\r\n              &quot;Parameterkey2&quot;:  &quot;value&quot; \r\n             }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/47944079/jq-parsing-with-arg-filters-does-not-give-expected-result",
        "title": "jq parsing with arg filters does not give expected result"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "filtering",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1513971833,
                "creation_date": 1513971833,
                "answer_id": 47946602,
                "question_id": 47946183,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. The output &quot;without commas&quot; is a stream of JSON; to emit an array, wrap your jq filter in square brackets.\r\n2. You can abbreviate `{id: id, type: .type}` to `{id, type}`\r\n3. Your filter which repeats .batter[] has the effect of creating a Cartesian product.  What you evidently want\r\ninstead is to expand .batter just once.\r\n\r\nPutting everything together:\r\n\r\n\r\n    [{id, type} + (.batter[] | {batterId: .id, batterType: .type})]\r\n\r\n",
                "title": "JQ filtering on fields in nested Objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1513983385,
        "creation_date": 1513969320,
        "last_edit_date": 1513983385,
        "question_id": 47946183,
        "body_markdown": "I have a large set of data, I am using JQ to construct the object that contains only the data I am interested in for a record. My problem is that I am starting to see duplicate objects, it seems my syntax is incorrect.\r\n\r\nI am working with an object that contains flat fields and an array of subObjects, there are particular fields I want to pull out and make new objects that have all the data I want. Including some flat fields and some fields from the array objects.\r\n\r\nHere is a smaller sample that helps demonstrate problem `tmpData.json`\r\n\r\n    {\r\n\t&quot;id&quot;: &quot;0001&quot;,\r\n\t&quot;type&quot;: &quot;donut&quot;,\r\n\t&quot;name&quot;: &quot;Cake&quot;,\r\n\t&quot;ppu&quot;: 0.55,\r\n\t&quot;batter&quot;: [{\r\n\t\t\t&quot;id&quot;: &quot;1001&quot;,\r\n\t\t\t&quot;type&quot;: &quot;Regular&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;id&quot;: &quot;1002&quot;,\r\n\t\t\t&quot;type&quot;: &quot;Chocolate&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;id&quot;: &quot;1003&quot;,\r\n\t\t\t&quot;type&quot;: &quot;Blueberry&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;id&quot;: &quot;1004&quot;,\r\n\t\t\t&quot;type&quot;: &quot;Devil&#39;s Food&quot;\r\n\t\t}\r\n\t]\r\n    }\r\n\r\nI run this : ` cat tmpData.txt | jq {&#39;id: .id, type: .type, batter: .batter[].id&#39;}`\r\n\r\nWhich outputs this non-json set of objects (it&#39;s missing commas)\r\n\r\n     \r\n    \r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batter&quot;: &quot;1001&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batter&quot;: &quot;1002&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batter&quot;: &quot;1003&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batter&quot;: &quot;1004&quot;\r\n    }\r\n\r\nThis is good. I now have objects each containing the parentID `0001` and the different items in the array are associated in each object.\r\n\r\nWhen I run: `cat tmpData.txt | jq {&#39;id: .id, type: .type, batterID: .batter[].id, batterType: .batter[].type&#39;}`\r\n\r\nWith the added `type` field I get a lot of duplicates that wrongly associate items\r\n\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batterID&quot;: &quot;1001&quot;,\r\n      &quot;batterType&quot;: &quot;Regular&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batterID&quot;: &quot;1001&quot;,\r\n      &quot;batterType&quot;: &quot;Chocolate&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batterID&quot;: &quot;1001&quot;,\r\n      &quot;batterType&quot;: &quot;Blueberry&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batterID&quot;: &quot;1001&quot;,\r\n      &quot;batterType&quot;: &quot;Devil&#39;s Food&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batterID&quot;: &quot;1002&quot;,\r\n      &quot;batterType&quot;: &quot;Regular&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batterID&quot;: &quot;1002&quot;,\r\n      &quot;batterType&quot;: &quot;Chocolate&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batterID&quot;: &quot;1002&quot;,\r\n      &quot;batterType&quot;: &quot;Blueberry&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batterID&quot;: &quot;1002&quot;,\r\n      &quot;batterType&quot;: &quot;Devil&#39;s Food&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batterID&quot;: &quot;1003&quot;,\r\n      &quot;batterType&quot;: &quot;Regular&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batterID&quot;: &quot;1003&quot;,\r\n      &quot;batterType&quot;: &quot;Chocolate&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batterID&quot;: &quot;1003&quot;,\r\n      &quot;batterType&quot;: &quot;Blueberry&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batterID&quot;: &quot;1003&quot;,\r\n      &quot;batterType&quot;: &quot;Devil&#39;s Food&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batterID&quot;: &quot;1004&quot;,\r\n      &quot;batterType&quot;: &quot;Regular&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batterID&quot;: &quot;1004&quot;,\r\n      &quot;batterType&quot;: &quot;Chocolate&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batterID&quot;: &quot;1004&quot;,\r\n      &quot;batterType&quot;: &quot;Blueberry&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;batterID&quot;: &quot;1004&quot;,\r\n      &quot;batterType&quot;: &quot;Devil&#39;s Food&quot;\r\n    }\r\n\r\n\r\nNow I see that each `batterID` is in an object with every type `regular, chocolate, blueberry`. But in fact `1002` is only ever `chocolate`.\r\n\r\nMy ideal output would be like this\r\n\r\n   \r\n\r\n     [{\r\n    &quot;id&quot;: &quot;0001&quot;,\r\n    &quot;type&quot;: &quot;donut&quot;,\r\n    &quot;batterID&quot;: &quot;1001&quot;,\r\n    &quot;batterType&quot;: &quot;Regular&quot;\r\n    },\r\n    {\r\n    &quot;id&quot;: &quot;0001&quot;,\r\n    &quot;type&quot;: &quot;donut&quot;,\r\n    &quot;batterID&quot;: &quot;1002&quot;,\r\n    &quot;batterType&quot;: &quot;Chocolate&quot;\r\n    }] \r\n\r\nYour expertise is appreciated!\r\n\r\nEDIT SOLVED: working command: `cat tmpData.txt | jq &#39;[{id, type} + (.batter[] | {batterId: .id, batterType: .type})]&#39;`\r\n",
        "link": "https://stackoverflow.com/questions/47946183/jq-filtering-on-fields-in-nested-objects",
        "title": "JQ filtering on fields in nested Objects"
    },
    {
        "tags": [
            "jq",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1513976699,
                "creation_date": 1513976699,
                "answer_id": 47947382,
                "question_id": 47946718,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The jq language has its own way of combining variables. In jq, the expression you wrote:\r\n\r\n    &quot;Company-$environment-$br-$app&quot;\r\n\r\nis just a vanilla JSON string.\r\n\r\nOne option would be to use jq&#39;s support for interpolation:\r\n\r\n    &quot;Company-\\($environment)-\\($br)-\\($app)&quot;\r\n\r\nAnother option would be to use jq&#39;s string-concatenation operator, `+`.\r\n\r\nYou could also use `join(&quot;-&quot;)`.  And so on.\r\n\r\n",
                "title": "How to parse aws-cli output using jq containing arguments using the --arg switch?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1513976699,
        "creation_date": 1513972438,
        "question_id": 47946718,
        "body_markdown": "I&#39;m trying to parse the output of `AWS cli` using `jq` where the jq query contains bash variables and by using [the --arg switch][1] like so:\r\n\r\n    $ aws ec2 describe-instances --region $region | jq --arg environment &quot;$Environment&quot; --arg br &quot;$BUILD_NUMBER&quot; --arg app &quot;$App&quot; -r &#39;.Reservations[].Instances[].Tags[]?.Value | select(startswith(&quot;Company-$environment-$br-$app&quot;)\r\n\r\nI get a new line when I run the command.\r\n\r\nThis is the output when I use hard coded auto scaling group name:\r\n\r\n    itai@Itais-MBP ~/Downloads -  $ aws ec2 describe-instances --region $region |   jq --arg environment &quot;$Environment&quot; --arg br &quot;$BUILD_NUMBER&quot; --arg app &quot;$App&quot;   -r &#39;.Reservations[].Instances[].Tags[]?.Value | select(startswith(&quot;Company-Dev-60-Api&quot;) )&#39;\r\n    Company-Dev-60-ApiServersASG-19L10K16RUXTE\r\n    Company-Dev-60-ApiServersASG-19L10K16RUXTE\r\n    itai@Itais-MBP ~/Downloads -  $\r\n\r\nYou can see the values of the variables are set:\r\n\r\n    itai@Itais-MBP ~/Downloads -  $ echo $Environment\r\n    Dev\r\n    itai@Itais-MBP ~/Downloads -  $ echo $App\r\n    Api\r\n    itai@Itais-MBP ~/Downloads -  $ echo $BUILD_NUMBER\r\n    60\r\n\r\nSo what am I doing wrong?\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
        "link": "https://stackoverflow.com/questions/47946718/how-to-parse-aws-cli-output-using-jq-containing-arguments-using-the-arg-switch",
        "title": "How to parse aws-cli output using jq containing arguments using the --arg switch?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1514318304,
                "post_id": 47982628,
                "comment_id": 82934948,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7310558,
                    "reputation": 740,
                    "user_id": 5569925,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/0435bf08963d1ff53d3b01502f5f3767?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Goldfish",
                    "link": "https://stackoverflow.com/users/5569925/goldfish"
                },
                "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": 1514318813,
                "post_id": 47982628,
                "comment_id": 82935135,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7310558,
                    "reputation": 740,
                    "user_id": 5569925,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/0435bf08963d1ff53d3b01502f5f3767?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Goldfish",
                    "link": "https://stackoverflow.com/users/5569925/goldfish"
                },
                "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": 1514319363,
                "post_id": 47982628,
                "comment_id": 82935305,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1514322870,
                "last_edit_date": 1514322870,
                "creation_date": 1514322456,
                "answer_id": 47983710,
                "question_id": 47982628,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "jq only supports adding the same data type using the `+` operator. You cannot add an array to object, or vice versa. \r\n\r\nIn order to add an array to an object, we must wrap the array in an object, and provide the key for the object containing the array. This makes sense if we think about json structure and how an array would be represented in a json object\r\n\r\nThe following command will work against the `tmpData.txt` file\r\n\r\n` cat tmpData.txt | jq &#39;{id, type} + {Batters: [(.batter[] | {batterId: .id, batterType: .type, status: .status.complete})]}&#39;`\r\n\r\nOutputs\r\n\r\n    {\r\n      &quot;id&quot;: &quot;0001&quot;,\r\n      &quot;type&quot;: &quot;donut&quot;,\r\n      &quot;Batters&quot;: [\r\n        {\r\n          &quot;batterId&quot;: &quot;1001&quot;,\r\n          &quot;batterType&quot;: &quot;Regular&quot;,\r\n          &quot;status&quot;: false\r\n        },\r\n        {\r\n          &quot;batterId&quot;: &quot;1002&quot;,\r\n          &quot;batterType&quot;: &quot;Chocolate&quot;,\r\n          &quot;status&quot;: false\r\n        },\r\n        {\r\n          &quot;batterId&quot;: &quot;1003&quot;,\r\n          &quot;batterType&quot;: &quot;Blueberry&quot;,\r\n          &quot;status&quot;: false\r\n        },\r\n        {\r\n          &quot;batterId&quot;: &quot;1004&quot;,\r\n          &quot;batterType&quot;: &quot;Devil&#39;s Food&quot;,\r\n          &quot;status&quot;: false\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "JQ insert Array into an object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1514322870,
        "creation_date": 1514314724,
        "last_edit_date": 1514319347,
        "question_id": 47982628,
        "body_markdown": "I am working with a large dataset, I am using JQ to construct an object containing only the data I am interested in. To help with the question I have provided sample data to help illustrate my problem. \r\n\r\nSo far, I have only found a way to add 2 objects or 2 arrays, but I want to take a set of flat fields, and add an array as a subObject to the main json. \r\n\r\ntmpData.txt\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;batter&quot;: [{\r\n            &quot;id&quot;: &quot;1001&quot;,\r\n            &quot;type&quot;: &quot;Regular&quot;,\r\n            &quot;status&quot;:{\r\n                &quot;complete&quot;: false\r\n            }\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;1002&quot;,\r\n            &quot;type&quot;: &quot;Chocolate&quot;,\r\n            &quot;status&quot;:{\r\n                &quot;complete&quot;: false\r\n            }\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;1003&quot;,\r\n            &quot;type&quot;: &quot;Blueberry&quot;,\r\n            &quot;status&quot;:{\r\n                &quot;complete&quot;: false\r\n            }\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;1004&quot;,\r\n            &quot;type&quot;: &quot;Devil&#39;s Food&quot;,\r\n            &quot;status&quot;:{\r\n                &quot;complete&quot;: false\r\n            }\r\n        }\r\n    ]\r\n    }\r\n\r\nSo far, the closest I have come is this\r\n\r\n `cat tmpData.txt | jq &#39;[{id, type}] + [(.batter[] | {batterId: .id, complete: .status.complete})]&#39;`\r\n\r\nwhich outputs the top level fields only 1 time, but each batter is it&#39;s own object, I need this whole output to be 1 object.\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;0001&quot;,\r\n        &quot;type&quot;: &quot;donut&quot;\r\n      },\r\n      {\r\n        &quot;batterId&quot;: &quot;1001&quot;,\r\n        &quot;complete&quot;: false\r\n      },\r\n      {\r\n        &quot;batterId&quot;: &quot;1002&quot;,\r\n        &quot;complete&quot;: false\r\n      },\r\n      {\r\n        &quot;batterId&quot;: &quot;1003&quot;,\r\n        &quot;complete&quot;: false\r\n      },\r\n      {\r\n        &quot;batterId&quot;: &quot;1004&quot;,\r\n        &quot;complete&quot;: false\r\n      }\r\n    ]\r\n\r\n**My ideal output would look like the following:**\r\n\r\n    {\r\n    &quot;id&quot;: &quot;0001&quot;,\r\n    &quot;type&quot;: &quot;donut&quot;,\r\n    &quot;batter&quot;: [{\r\n    \t&quot;id&quot;: &quot;1001&quot;,\r\n    \t&quot;complete&quot;: false\r\n    \t},\r\n    \t{\r\n    \t&quot;id&quot;: &quot;1002&quot;,\r\n    \t&quot;complete&quot;: false\r\n    \t},\r\n    \t{\r\n    \t&quot;id&quot;: &quot;1003&quot;,\r\n    \t&quot;complete&quot;: false\r\n    \t},\r\n    \t{\r\n    \t&quot;id&quot;: &quot;1004&quot;,\r\n    \t&quot;complete&quot;: false\r\n    \t}]\r\n    }\r\n\r\nAs you can see there is 1 single object that contains everything I need to know, and there is no duplicate or extraneous data. I want to output a single object that contains an array of batters with ID and their status.",
        "link": "https://stackoverflow.com/questions/47982628/jq-insert-array-into-an-object",
        "title": "JQ insert Array into an object"
    },
    {
        "tags": [
            "json",
            "object",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1514579850,
                "last_edit_date": 1514579850,
                "creation_date": 1514327610,
                "answer_id": 47984406,
                "question_id": 47983484,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your output included &quot;title3&quot; so I&#39;ll assume that you intended that the second occurrence of &quot;title2&quot; in the input was supposed to refer to &quot;title3&quot;.\r\n\r\nWith this assumption, the following jq program seems to do what you want:\r\n\r\n    map( .id )\r\n    | . as $in\r\n    | reduce range(0;length) as $i ({};\r\n        . + {($in[$i]): &quot;dummy\\(1+$i)&quot;})\r\n\r\nIn words, extract the values of .id, and then turn each into an object of the form: `{(.id) : &quot;dummy\\(1+$i)&quot;}`\r\n\r\nThis uses string interpolation, and produces:\r\n\r\n    {\r\n      &quot;title&quot;: &quot;dummy1&quot;,\r\n      &quot;title1&quot;: &quot;dummy2&quot;,\r\n      &quot;title2&quot;: &quot;dummy3&quot;,\r\n      &quot;title3&quot;: &quot;dummy4&quot;\r\n    }\r\n\r\n### reduce-free solution\r\n\r\n    map(.id )\r\n    | [., [range(0;length)]]\r\n    | transpose\r\n    | map( {(.[0]): &quot;dummy\\(.[1]+1)&quot;})\r\n    | add\r\n\r\n### Output\r\n\r\n&gt; Can we also create a new json file and write the newly created object onto it using jq?\r\n\r\nYes, just use output redirection:\r\n\r\n    jq -f program.jq messages.json &gt; output.json\r\n\r\n### Addendum\r\n\r\n&gt; I want a parent object &quot;de&quot; to the already created json file objects\r\n\r\nYou could just pipe either of the above solutions to: `{de: .}`",
                "title": "create an object from an existing json file using &#39;jq&#39;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1514579850,
        "creation_date": 1514320782,
        "last_edit_date": 1514341090,
        "question_id": 47983484,
        "body_markdown": "I have a messages.json file\r\n\r\n    [\r\n        {\r\n            &quot;id&quot;: &quot;title&quot;,\r\n            &quot;description&quot;: &quot;This is the Title&quot;,\r\n            &quot;defaultMessage&quot;: &quot;title&quot;,\r\n            &quot;filepath&quot;: &quot;src/title.js&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;title1&quot;,\r\n            &quot;description&quot;: &quot;This is the Title1&quot;,\r\n            &quot;defaultMessage&quot;: &quot;title1&quot;,\r\n            &quot;filepath&quot;: &quot;src/title1.js&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;title2&quot;,\r\n            &quot;description&quot;: &quot;This is the Title2&quot;,\r\n            &quot;defaultMessage&quot;: &quot;title2&quot;,\r\n            &quot;filepath&quot;: &quot;src/title2.js&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;title2&quot;,\r\n            &quot;description&quot;: &quot;This is the Title2&quot;,\r\n            &quot;defaultMessage&quot;: &quot;title2&quot;,\r\n            &quot;filepath&quot;: &quot;src/title2.js&quot;\r\n          },\r\n        ]\r\n\r\nI want to create an object \r\n\r\n    {\r\n        &quot;title&quot;: &quot;Dummy1&quot;,\r\n        &quot;title1&quot;: &quot;Dummy2&quot;,\r\n        &quot;title2&quot;: &quot;Dummy3&quot;,\r\n        &quot;title3&quot;: &quot;Dummy4&quot;\r\n      }\r\n\r\nfrom the top one.\r\nSo far I have \r\n\r\n    jq &#39;.[] | .id&#39; src/messages.json;\r\n\r\nAnd it does give me the IDs\r\nHow do I add some random text and make the new object as above?\r\n\r\nCan we also create a new JSON file and write the newly created object onto it using jq?\r\n",
        "link": "https://stackoverflow.com/questions/47983484/create-an-object-from-an-existing-json-file-using-jq",
        "title": "create an object from an existing json file using &#39;jq&#39;"
    },
    {
        "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": 1,
                "creation_date": 1514407338,
                "post_id": 47998378,
                "comment_id": 82965137,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6230814,
                    "reputation": 234,
                    "user_id": 4847664,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/35f96b09b80f14cf5319a371a1553471?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Annette",
                    "link": "https://stackoverflow.com/users/4847664/annette"
                },
                "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": 1514407635,
                "post_id": 47998378,
                "comment_id": 82965240,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1514408275,
                "last_edit_date": 1514408275,
                "creation_date": 1514407641,
                "answer_id": 47998459,
                "question_id": 47998378,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you want to keep other surrounding key/value pairs and only update the `values` item, you need to calculate a new value for it. Doing that may look like the following:\r\n\r\n    jq \\\r\n      --arg updateKey &quot;URL&quot; \\\r\n      --arg updateVal &quot;http://10.20.200.1&quot; \\\r\n      &#39;.values = [.values[] | if (.key == $updateKey) then (.value = $updateVal) else . end]&#39;",
                "title": "Update one value (matching a known key) in a list of JSON objects using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1514408785,
                "creation_date": 1514408785,
                "answer_id": 47998647,
                "question_id": 47998378,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following is just a variation of @CharlesDuffy&#39;s excellent answer:\r\n\r\n    def when(c; f): if c? // null then f else . end;\r\n    \r\n    .values = map( when(.key == $updateKey; .value = $updateVal) )\r\n\r\nThis definition of `when/2` is quite generic.  It adds a small measure of safety, and avoids the tedium of `if _ then _ else . end`.  It is perhaps worthy of your standard jq library (e.g. ~/.jq or ~/.jq/jq/jq.jq).",
                "title": "Update one value (matching a known key) in a list of JSON objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1514408785,
        "creation_date": 1514407192,
        "last_edit_date": 1514408147,
        "question_id": 47998378,
        "body_markdown": "i have multiple json files in the below format as environment files and need to test it against an endpoint,\r\n\r\n    {\r\n      &quot;id&quot;: &quot;test1123&quot;,\r\n      &quot;name&quot;: &quot;my testing&quot;,\r\n      &quot;values&quot;: [\r\n        {\r\n          &quot;enabled&quot;: true,\r\n          &quot;key&quot;: &quot;URL&quot;,\r\n          &quot;value&quot;: &quot;http://localhost:3000/&quot;,\r\n          &quot;type&quot;: &quot;text&quot;\r\n        },\r\n        {\r\n          &quot;enabled&quot;: true,\r\n          &quot;key&quot;: &quot;User1Token&quot;,\r\n          &quot;value&quot;: &quot;&quot;,\r\n          &quot;type&quot;: &quot;text&quot;\r\n        },\r\n        {\r\n          &quot;enabled&quot;: true,\r\n          &quot;key&quot;: &quot;User2Token&quot;,\r\n          &quot;value&quot;: &quot;&quot;,\r\n          &quot;type&quot;: &quot;text&quot;\r\n        },\r\n        {\r\n          &quot;enabled&quot;: true,\r\n          &quot;key&quot;: &quot;IdentityURL&quot;,\r\n          &quot;value&quot;: &quot;&quot;,\r\n          &quot;type&quot;: &quot;text&quot;\r\n        },\r\n        {\r\n          &quot;enabled&quot;: true,\r\n          &quot;key&quot;: &quot;AdminToken&quot;,\r\n          &quot;value&quot;: &quot;&quot;,\r\n          &quot;type&quot;: &quot;text&quot;\r\n        }\r\n      ],\r\n      &quot;timestamp&quot;: 1511892974802,\r\n      &quot;_postman_variable_scope&quot;: &quot;environment&quot;,\r\n      &quot;_postman_exported_at&quot;: &quot;2017-11-28T19:38:23.389Z&quot;,\r\n      &quot;_postman_exported_using&quot;: &quot;Postman/5.3.0&quot;\r\n    }\r\n\r\nI wanted to update the end point in this json before running my test. The endpoint value needs to be added to value attribute of values object where the key is &quot;URL&quot;\r\n\r\nso in the above case, i should update the endpoint in the first index of values array,\r\n\r\n    {\r\n      &quot;enabled&quot;: true,\r\n      &quot;key&quot;: &quot;URL&quot;,\r\n      &quot;value&quot;: &quot;http://10.20.200.1/&quot;,\r\n      &quot;type&quot;: &quot;text&quot;\r\n    }\r\n\r\nwhere http://10.20.200.1/ is my endpoint.\r\n\r\nThe current code I&#39;m trying to use is:\r\n\r\n    jq &#39;.values | map(if .key == &quot;URL&quot; then . + {&quot;value&quot;:&quot;10.20.13.28/&quot;;} else . end )&#39;\r\n\r\n...but this results in a syntax error. Can anyone suggest me on how to use jq to update the value correctly?\r\n\r\nNote: the key URL won&#39;t be always the first index of values.\r\n",
        "link": "https://stackoverflow.com/questions/47998378/update-one-value-matching-a-known-key-in-a-list-of-json-objects-using-jq",
        "title": "Update one value (matching a known key) in a list of JSON objects using jq"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1514428414,
                "creation_date": 1514428414,
                "answer_id": 48000944,
                "question_id": 48000460,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Except for the ordering, the following jq program produces the desired output, as shown below:\r\n\r\n    ..\r\n    | select(.name? and .system_name?)\r\n    | {name, parent_name, system_name}\r\n\r\n### Transcript\r\n\r\n    $ jq -f program.jq input.json\r\n    {\r\n      &quot;name&quot;: &quot;parent 1&quot;,\r\n      &quot;parent_name&quot;: null,\r\n      &quot;system_name&quot;: &quot;sys 1 name&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;child 1&quot;,\r\n      &quot;parent_name&quot;: &quot;parent 1&quot;,\r\n      &quot;system_name&quot;: &quot;cisco 1&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;child 2&quot;,\r\n      &quot;parent_name&quot;: &quot;parent 1&quot;,\r\n      &quot;system_name&quot;: &quot;cisco 1&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;parent 2&quot;,\r\n      &quot;parent_name&quot;: null,\r\n      &quot;system_name&quot;: &quot;sys 2 name&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;child 3&quot;,\r\n      &quot;parent_name&quot;: &quot;parent 2&quot;,\r\n      &quot;system_name&quot;: &quot;hp 1&quot;\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;parent 3&quot;,\r\n      &quot;parent_name&quot;: null,\r\n      &quot;system_name&quot;: &quot;sys 3 name&quot;\r\n    }\r\n\r\n\r\n",
                "title": "How to use jq to provide ungrouped result (i.e. parent and children attributes separately)?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1514428607,
        "creation_date": 1514423551,
        "last_edit_date": 1514428607,
        "question_id": 48000460,
        "body_markdown": "There is a JSON which I am getting with a script:\r\n\r\n    {\r\n    &quot;data&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;physical&quot;,\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;children&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;CISCO&quot;,\r\n              &quot;description&quot;: &quot;test&quot;,\r\n              &quot;id&quot;: 53,\r\n              &quot;min_max_policy&quot;: {\r\n                &quot;legal_hold&quot;: 0,\r\n                &quot;name&quot;: &quot;child 1&quot;,\r\n                &quot;max&quot;: 60,\r\n                &quot;min&quot;: 0\r\n              },\r\n              &quot;name&quot;: &quot;child 1&quot;,\r\n              &quot;parent_id&quot;: 1,\r\n              &quot;parent_name&quot;: &quot;parent 1&quot;,\r\n              &quot;system_id&quot;: 1,\r\n              &quot;system_name&quot;: &quot;cisco 1&quot;,\r\n              &quot;version&quot;: &quot;None&quot;\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;CISCO&quot;,\r\n              &quot;description&quot;: &quot;test&quot;,\r\n              &quot;id&quot;: 54,\r\n              &quot;min_max_policy&quot;: {\r\n                &quot;legal_hold&quot;: 0,\r\n                &quot;name&quot;: &quot;child 2&quot;,\r\n                &quot;max&quot;: 60,\r\n                &quot;min&quot;: 0\r\n              },\r\n              &quot;name&quot;: &quot;child 2&quot;,\r\n              &quot;parent_id&quot;: 1,\r\n              &quot;parent_name&quot;: &quot;parent 1&quot;,\r\n              &quot;system_id&quot;: 2,\r\n              &quot;system_name&quot;: &quot;cisco 1&quot;,\r\n              &quot;version&quot;: &quot;None&quot;\r\n            }\r\n          ],\r\n          &quot;type&quot;: &quot;network devices&quot;\r\n        }\r\n      ],\r\n      &quot;machine_type&quot;: &quot;X32&quot;,\r\n      &quot;min_max_policy&quot;: {\r\n        &quot;id&quot;: 1,\r\n        &quot;name&quot;: &quot;parent 1&quot;,\r\n        &quot;max&quot;: 60,\r\n        &quot;min&quot;: 0\r\n      },\r\n      &quot;name&quot;: &quot;parent 1&quot;,\r\n      &quot;system_id&quot;: 1,\r\n      &quot;system_name&quot;: &quot;sys 1 name&quot;,\r\n      &quot;version&quot;: &quot;1.0&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;physical&quot;,\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;children&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;HP&quot;,\r\n              &quot;description&quot;: &quot;test&quot;,\r\n              &quot;id&quot;: 55,\r\n              &quot;min_max_policy&quot;: {\r\n                &quot;legal_hold&quot;: 0,\r\n                &quot;name&quot;: &quot;child 3&quot;,\r\n                &quot;max&quot;: 60,\r\n                &quot;min&quot;: 0\r\n              },\r\n              &quot;name&quot;: &quot;child 3&quot;,\r\n              &quot;parent_id&quot;: 2,\r\n              &quot;parent_name&quot;: &quot;parent 2&quot;,\r\n              &quot;system_id&quot;: 3,\r\n              &quot;system_name&quot;: &quot;hp 1&quot;,\r\n              &quot;version&quot;: &quot;None&quot;\r\n            }\r\n          ],\r\n          &quot;type&quot;: &quot;network devices&quot;\r\n        }\r\n      ],\r\n      &quot;machine_type&quot;: &quot;X32&quot;,\r\n      &quot;min_max_policy&quot;: {\r\n        &quot;id&quot;: 2,\r\n        &quot;legal_hold&quot;: 0,\r\n        &quot;name&quot;: &quot;parent 2&quot;,\r\n        &quot;max&quot;: 60,\r\n        &quot;min&quot;: 0\r\n      },\r\n      &quot;name&quot;: &quot;parent 2&quot;,\r\n      &quot;system_id&quot;: 2,\r\n      &quot;system_name&quot;: &quot;sys 2 name&quot;,\r\n      &quot;version&quot;: &quot;1.0&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;physical&quot;,\r\n      &quot;machine_type&quot;: &quot;X32&quot;,\r\n      &quot;min_max_policy&quot;: {\r\n        &quot;id&quot;: 3,\r\n        &quot;name&quot;: &quot;parent 3&quot;,\r\n        &quot;max&quot;: 60,\r\n        &quot;min&quot;: 0\r\n      },\r\n      &quot;name&quot;: &quot;parent 3&quot;,\r\n      &quot;system_id&quot;: 3,\r\n      &quot;system_name&quot;: &quot;sys 3 name&quot;,\r\n      &quot;version&quot;: &quot;1.0&quot;\r\n    }\r\n    ]\r\n    }\r\n\r\nIt has 3 parent objects and children. For example, &quot;parent 1&quot; has 2 children, &quot;parent 2&quot; has 1 and &quot;parent 3&quot; has 0. \r\n\r\nHow to format this JSON with jq to display it in such way:\r\n    \r\n    {\r\n    &quot;name&quot;: &quot;child 1&quot;,\r\n    &quot;parent_name&quot;: &quot;parent 1&quot;,\r\n    &quot;system_name&quot;: &quot;cisco 1&quot;\r\n    }\r\n    {\r\n    &quot;name&quot;: &quot;child 2&quot;,\r\n    &quot;parent_name&quot;: &quot;parent 1&quot;,\r\n    &quot;system_name&quot;: &quot;cisco 1&quot;\r\n    }\r\n    {\r\n    &quot;name&quot;: &quot;parent 1&quot;,\r\n    &quot;parent_name&quot;: null,\r\n    &quot;system_name&quot;: &quot;sys 1 name&quot;\r\n    }\r\n    {\r\n    &quot;name&quot;: &quot;child 3&quot;,\r\n    &quot;parent_name&quot;: &quot;parent 2&quot;,\r\n    &quot;system_name&quot;: &quot;hp 1&quot;\r\n    }\r\n    {\r\n    &quot;name&quot;: &quot;parent 2&quot;,\r\n    &quot;parent_name&quot;: null,\r\n    &quot;system_name&quot;: &quot;sys 2 name&quot;\r\n    }\r\n    {\r\n    &quot;name&quot;: &quot;parent 3&quot;,\r\n    &quot;parent_name&quot;: null,\r\n    &quot;system_name&quot;: &quot;sys 3 name&quot;\r\n    }\r\n\r\n?\r\n\r\nI have tried some options but jq is grouping parent and children. I can&#39;t find a way how to display it in the mentioned way.",
        "link": "https://stackoverflow.com/questions/48000460/how-to-use-jq-to-provide-ungrouped-result-i-e-parent-and-children-attributes-s",
        "title": "How to use jq to provide ungrouped result (i.e. parent and children attributes separately)?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 25,
                "is_accepted": true,
                "score": 25,
                "last_activity_date": 1514461267,
                "last_edit_date": 1514461267,
                "creation_date": 1514458446,
                "answer_id": 48006169,
                "question_id": 48005870,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming your root node name is `newList` as you have in the question given, to get the `id` and created date, you can do string interpolation with `jq`\r\n\r\n    api-producing-json | jq --raw-output &#39;.newList[] | &quot;\\(.id) \\(.create.date)&quot;&#39;\r\n\r\nThis way the filter is independent of the dynamic numbers in the nodes (`243`, `244`). Drop the `--raw-output` flag if you need the output with quotes.\r\n\r\nTo process further in a loop, you can iterate it over a bash loop,\r\n\r\n    while read -r id name date; do\r\n        echo &quot;Do whatever with ${id} ${name} ${date}&quot;\r\n    done&lt; &lt;(api-producing-json | jq --raw-output &#39;.newList[] | &quot;\\(.id) \\(.name) \\(.create.date)&quot;&#39;)\r\n\r\nor to even more carefully delimit the words if you are worried about the spaces in any of the fields, use a delimiter as `|` in the filter as `&quot;\\(.id)|\\(.name)|\\(.create.date)&quot;` and use the `read` command in the while loop by setting `IFS=|` so the variables are stored appropriately.\r\n\r\n---\r\n\r\nAlways use the official [jq - documentation](https://stedolan.github.io/jq/tutorial/) for help and use this nice playground to test out the filters, [jq - online](https://jqplay.org/s/N-M-QiVCq4)\r\n",
                "title": "Iterate over json with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1691010298,
                "creation_date": 1691010298,
                "answer_id": 76823522,
                "question_id": 48005870,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, the easy part: you would need `.newList.&quot;243&quot;` (with double-quotes) to access the `&quot;243&quot;` details. jq was interpreting `.243` as a number instead of a string, and the object keys are all strings.\r\n\r\nBut as you say, you don&#39;t know the keys ahead of time, so we can&#39;t use specific keys. That&#39;s okay, there are ways to get them if we need them. And in any case, your original question just asks for the name and create_date, so we can ignore the numeric keys\r\n\r\n## The simple version\r\n\r\nTo discard the keys, we can use the `values` filter, and then we can use `map` to apply some other filter to the values. So our solution is going to look something like ` cat input.json | jq &#39; .newList | values | map(some_filter) &#39;`.\r\n\r\nWhat is `some_filter`? well it&#39;s whatever we want it to be, so long as it takes in the right kind of object, and spits out the kind of output that we&#39;re looking for. I used to try and write these things as one-liners, but I&#39;ve found that jq is a lot easier to think about if you use the def keyword to define your own filters (much like you&#39;d define helper-functions in other languages)\r\n\r\nMy proposed solution:\r\n\r\n```\r\ncat input.json | jq `\r\n      def details_to_string:\r\n          . | &quot;Details: \\(id), \\(.name), \\(.create.date)&quot;;\r\n\r\n      .newList | values | map(details_to_string)\r\n`\r\n```\r\n\r\nHow does this work?\r\n\r\n* Before we start processing the input, we define a new filter called &#39;details_to_string&#39;. It takes in an object that has an &#39;id&#39; field, and a `.create.date&#39; field, and uses string interpolation to return a string. (I&#39;m not sure what output format you wanted, but a formatted string is an easy example). Note the colon at the end of the &#39;def&#39; line, and the semi-colon at the end of the actual filter definition\r\n* The actual processing begins on the final line. This is where the JSON object from the input file is fed in to the program\r\n* First, the object goes through a `.newList` filter, the result is the newList object ( `{ &quot;243&quot;: X, &quot;244&quot;: Y }` where `X` and `Y` are smaller JSON objects\r\n* Next, this object goes through the `values` filter, the result is an array of the values ( `[ X, Y]` where `X` and `Y` are the same smaller JSON objects from above)\r\n* Finally this array passes through `map(details_to_string)`. Map takes in an array and changes every item in the array by passing it through the `details_to_string` filter. So it takes in an array like `[X_details_object, Y_details_object]` and outputs and array like `[X_string, Y_string]`\r\n\r\nWhat&#39;s the output?\r\n\r\n```\r\n[\r\n  &quot;Details: 243, test, 2017-08-31 13:57:29&quot;,\r\n  &quot;Details: 244, test, 2017-08-31 13:57:29&quot;\r\n]\r\n``` \r\n\r\nIf you just want the individual strings (no square brackets, no commas) then you can split the array open at the end. ( `.newList | values | map(details_to_string) | .[]` ). If you also change &#39;jq&#39; to &#39;jq -r&#39; then you&#39;ll get rid of the quote marks as well\r\n\r\nIf you only wanted the first item in the list, then you can extract that with `.[0]`: `.newList | values | .[0] | details_to_string` (Note that we&#39;ve now done away with the array, so we don&#39;t need `map` anymore).\r\n\r\n## The more interesting version\r\n\r\nIn a comment above, you asked about how to capture and include the keys &quot;243&quot; and &quot;244&quot;, and you mentioned that those strings wouldn&#39;t be available in a field called &quot;id&quot;, like they are in the original example. For this, I think it&#39;s best to use a filter called `to_entries`\r\n\r\n`to_entries` makes the keys and the values of an object available, by turning them both into values. Each key-value pair inside an object becomes something that I think of as an &#39;entry&#39; object, which looks like `{ &quot;key&quot;: some_key, &quot;value&quot;: some_value}`. Note that &quot;key&quot; and &quot;value&quot; are literally the strings &quot;key&quot; and &quot;value&quot;, so an object like `{ &quot;243&quot;: &quot;alpha&quot;, &quot;244&quot;: &quot;Beta&quot;}` Becomes an array like `[ {&quot;key&quot;: &quot;243&quot;, &quot;value&quot;: &quot;alpha&quot;}, {&quot;key&quot;: &quot;244&quot;, &quot;value&quot;: &quot;beta&quot;} ]`.\r\n\r\nThis makes the keys available, but it can also get hard to keep track of how the data is structured as it moves through the system. This is where I find that pulling things out into functions really helps\r\n\r\n```\r\ncat input.json | jq &#39;\r\n        def entry_to_list:\r\n            [ .key, .value.name, .value.create.date ];\r\n\r\n        def list_to_string:\r\n          &quot;Details:&quot; + .[0] + &quot;, &quot; +  .[1] + &quot;, &quot; + .[2] ;\r\n\r\n       .newList | to_entries | map( entry_to_list | list_to_string )\r\n    &#39;\r\n```\r\n\r\noutput:\r\n\r\n```\r\n[\r\n  &quot;Details: 243, test, 2017-08-31 13:57:29&quot;,\r\n  &quot;Details: 244, test, 2017-08-31 13:57:29&quot;\r\n]\r\n```\r\n\r\nWith this version, you get an intermediate step with values like `[&quot;244&quot;, &quot;test&quot;, &quot;2017-08-31 13:57:29&quot;], which opens up a few options for sorting the results. (Arrays are sorted by the first field first, then by the second field, etc)\r\n\r\n* `newList | to_entries | map(entry_to_list) | sort | map(list_to_string)` (sort the entries before converting to strings)\r\n* `newList | to_entries | map(entry_to_list) | min | list_to_string` (select the lowest entry before converting to string)\r\n",
                "title": "Iterate over json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 13,
        "last_activity_date": 1691010298,
        "creation_date": 1514457386,
        "last_edit_date": 1514458697,
        "question_id": 48005870,
        "body_markdown": "I am parsing an API which sends me a JSON response like this:\r\n\r\n    {\r\n      &quot;newList&quot;: {\r\n        &quot;243&quot;: {\r\n          &quot;id&quot;: &quot;243&quot;,\r\n          &quot;name&quot;: &quot;test&quot;,\r\n          &quot;create&quot;: {\r\n            &quot;date&quot;: &quot;2017-08-31 13:57:29&quot;\r\n          }\r\n        },\r\n        &quot;244&quot;: {\r\n          &quot;id&quot;: &quot;244&quot;,\r\n          &quot;name&quot;: &quot;test&quot;,\r\n          &quot;create&quot;: {\r\n            &quot;date&quot;: &quot;2017-08-31 13:57:29&quot;\r\n          }\r\n        }\r\n     }\r\n    }\r\n\r\nI am trying to get the name and the create date out of this using bash with jq, so for with little to no success.\r\n\r\njq &#39;.newList&#39; does work and brings me down one level, but that&#39;s not sufficient.\r\n\r\njq &#39;.newList .243&#39; gives me a compile error. Furthermore, the 243 is dynamic and can change at any time. What am I doing wrong here?",
        "link": "https://stackoverflow.com/questions/48005870/iterate-over-json-with-jq",
        "title": "Iterate over json with jq"
    },
    {
        "tags": [
            "json",
            "locale",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 87713,
                    "reputation": 14521,
                    "user_id": 243103,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/6c8ef2ca3f81839e3ef4f2c061313502?s=256&d=identicon&r=PG",
                    "display_name": "Stefan Dragnev",
                    "link": "https://stackoverflow.com/users/243103/stefan-dragnev"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1541670343,
                "post_id": 48021870,
                "comment_id": 93298343,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1541716754,
                "creation_date": 1541716754,
                "answer_id": 53217221,
                "question_id": 48021870,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks like there is a bug open for this issue. https://github.com/stedolan/jq/issues/1740\r\n\r\nCurrently (in v1.6), localization is not supported for date functionality.",
                "title": "jq, locale and strptime: how to use properly"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1541716754,
        "creation_date": 1514546686,
        "question_id": 48021870,
        "body_markdown": "I have this input\r\n\r\n    {&quot;text&quot;: &quot;05 april 2017&quot;}\r\n\r\nIf I run `echo &#39;{&quot;text&quot;: &quot;05 april 2017&quot;}&#39; | jq &#39;.text|strptime(&quot;%d %B %Y&quot;)&#39;` I have the right result.\r\n\r\nIf I set temporary my locale in italian with `export LC_ALL=it_IT.utf8` and apply `.text|strptime(&quot;%d %B %Y&quot;)` to \r\n\r\n\r\n    {&quot;text&quot;: &quot;05 aprile 2017&quot;}\r\n\r\n\r\nI have `date &quot;05 aprile 2017&quot; does not match format &quot;%d %B %Y&quot;`.\r\n\r\nHo to manage date localization settings with jq to recognize months local name?\r\n\r\nThank you",
        "link": "https://stackoverflow.com/questions/48021870/jq-locale-and-strptime-how-to-use-properly",
        "title": "jq, locale and strptime: how to use properly"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1514658944,
                "creation_date": 1514658944,
                "answer_id": 48036801,
                "question_id": 48036567,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I figured out this query:\r\n\r\n    [.[].id] | to_entries | .[0:map(select(.value==1))[].key][].value\r\n\r\nIf you know a less verbose way to achieve the same, let me know!",
                "title": "Select elements before nth element with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1514668458,
                "last_edit_date": 1514668458,
                "creation_date": 1514665372,
                "answer_id": 48037584,
                "question_id": 48036567,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Short and simple:\r\n\r\n    .[0: map(.id) | index(1)]\r\n\r\nFancy but fast:\r\n\r\n    label $top | .[] | if .id == 1 then break $top else . end",
                "title": "Select elements before nth element with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1514680644,
        "creation_date": 1514657153,
        "last_edit_date": 1514680644,
        "question_id": 48036567,
        "body_markdown": "I&#39;m stuck on the following json with jq. The elements below are sorted descending by some timestamp (not included in the json). I need to select the ids before id X. E.g. select ids before id 1 should return 2, 3 and 5.\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;somekey&quot;: &quot;somevalue&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 3,\r\n        &quot;somekey&quot;: &quot;somevalue&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 5,\r\n        &quot;somekey&quot;: &quot;somevalue&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 1,\r\n        &quot;somekey&quot;: &quot;somevalue&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 4,\r\n        &quot;somekey&quot;: &quot;somevalue&quot;\r\n      }\r\n    ]\r\n\r\nAny idea how to do this in a one-liner with jq? Specifically the &quot;select elements before&quot; part.",
        "link": "https://stackoverflow.com/questions/48036567/select-elements-before-nth-element-with-jq",
        "title": "Select elements before nth element with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1514842561,
                "creation_date": 1514842561,
                "answer_id": 48053414,
                "question_id": 48050565,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The question is a bit confusing; for example, it seems to presuppose that .Value can simultaneously be equal to both &quot;qa&quot; and &quot;databaseteam&quot;.  In fact, in your sample data, there is no &quot;instance&quot; for which(.Value == &quot;qa&quot; and .Key == &quot;databaseteam&quot;) either, so for the sake of this illustration, I&#39;ll assume you meant\r\n\r\n    select(.Value == &quot;qa&quot; and .Key == &quot;environment&quot;)\r\n\r\nHowever, if you meant something else, perhaps `select(.Value == &quot;qa&quot; or .Value == &quot;databaseteam&quot;)`, you can easily adapt the following, which produces the results shown below.\r\n\r\n\r\n    .Instances[]\r\n    | .PrivateIpAddress as $PIPA\r\n    | .InstanceType as $IT\r\n    | .Tags[]\r\n    | select(.Value == &quot;qa&quot; and .Key == &quot;environment&quot;)\r\n    | [$PIPA, $IT]\r\n\r\n### Transcript\r\n\r\n    $ jq -f program.jq data.json\r\n    [\r\n      &quot;bb&quot;,\r\n      &quot;t2.micro&quot;\r\n    ]\r\n\r\n",
                "title": "How to filter JSON data with jq based on values from multiple keys and show one particular attribute if the filter succeeds?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1514842561,
        "creation_date": 1514817784,
        "question_id": 48050565,
        "body_markdown": "For example, I have this JSON data:\r\n\r\n    {\r\n        &quot;Instances&quot;: [\r\n            {\r\n                &quot;Monitoring&quot;: {\r\n                    &quot;State&quot;: &quot;disabled&quot;\r\n                }, \r\n                &quot;PublicDnsName&quot;: &quot;ec2-aa.compute-1.amazonaws.com&quot;, \r\n                &quot;State&quot;: {\r\n                    &quot;Code&quot;: 16, \r\n                    &quot;Name&quot;: &quot;running&quot;\r\n                }, \r\n                &quot;EbsOptimized&quot;: false, \r\n                &quot;LaunchTime&quot;: &quot;2017-08-14T17:29:54.000Z&quot;, \r\n                &quot;PublicIpAddress&quot;: &quot;aa&quot;, \r\n                &quot;PrivateIpAddress&quot;: &quot;bb&quot;, \r\n                &quot;ProductCodes&quot;: [], \r\n                &quot;VpcId&quot;: &quot;vpc-xx&quot;, \r\n                &quot;StateTransitionReason&quot;: &quot;&quot;, \r\n                &quot;InstanceId&quot;: &quot;i-f21c76a0&quot;, \r\n                &quot;ImageId&quot;: &quot;ami-xx&quot;, \r\n                &quot;PrivateDnsName&quot;: &quot;ip-bb.ec2.internal&quot;, \r\n                &quot;KeyName&quot;: &quot;blah&quot;, \r\n                &quot;SecurityGroups&quot;: [\r\n                    {\r\n                        &quot;GroupName&quot;: &quot;mygroup&quot;, \r\n                        &quot;GroupId&quot;: &quot;sg-xx&quot;\r\n                    }\r\n                ], \r\n                &quot;ClientToken&quot;: &quot;&quot;, \r\n                &quot;SubnetId&quot;: &quot;subnet-xx&quot;, \r\n                &quot;InstanceType&quot;: &quot;t2.micro&quot;, \r\n                &quot;NetworkInterfaces&quot;: [\r\n                    {\r\n                        &quot;Status&quot;: &quot;in-use&quot;, \r\n                        &quot;MacAddress&quot;: &quot;&quot;, \r\n                        &quot;SourceDestCheck&quot;: true, \r\n                        &quot;VpcId&quot;: &quot;vpc-xx&quot;, \r\n                        &quot;Description&quot;: &quot;&quot;, \r\n                        &quot;NetworkInterfaceId&quot;: &quot;eni-xx&quot;, \r\n                        &quot;PrivateIpAddresses&quot;: [\r\n                            {\r\n                                &quot;PrivateDnsName&quot;: &quot;ip-bb.ec2.internal&quot;, \r\n                                &quot;PrivateIpAddress&quot;: &quot;aa&quot;, \r\n                                &quot;Primary&quot;: true, \r\n                                &quot;Association&quot;: {\r\n                                    &quot;PublicIp&quot;: &quot;aa&quot;, \r\n                                    &quot;PublicDnsName&quot;: &quot;ec2-bb-1.amazonaws.com&quot;, \r\n                                    &quot;IpOwnerId&quot;: &quot;amazon&quot;\r\n                                }\r\n                            }\r\n                        ], \r\n                        &quot;PrivateDnsName&quot;: &quot;ip-aa.ec2.internal&quot;, \r\n                        &quot;Attachment&quot;: {\r\n                            &quot;Status&quot;: &quot;attached&quot;, \r\n                            &quot;DeviceIndex&quot;: 0, \r\n                            &quot;DeleteOnTermination&quot;: true, \r\n                            &quot;AttachmentId&quot;: &quot;eni-attach-b11454cb&quot;, \r\n                            &quot;AttachTime&quot;: &quot;2014-07-02T19:24:19.000Z&quot;\r\n                        }, \r\n                        &quot;Groups&quot;: [\r\n                            {\r\n                                &quot;GroupName&quot;: &quot;mygroup&quot;, \r\n                                &quot;GroupId&quot;: &quot;sg-xx&quot;\r\n                            }\r\n                        ], \r\n                        &quot;Ipv6Addresses&quot;: [], \r\n                        &quot;OwnerId&quot;: &quot;aa&quot;, \r\n                        &quot;PrivateIpAddress&quot;: &quot;aa&quot;, \r\n                        &quot;SubnetId&quot;: &quot;subnet-bb&quot;, \r\n                        &quot;Association&quot;: {\r\n                            &quot;PublicIp&quot;: &quot;aa&quot;, \r\n                            &quot;PublicDnsName&quot;: &quot;ec2-aa-1.amazonaws.com&quot;, \r\n                            &quot;IpOwnerId&quot;: &quot;amazon&quot;\r\n                        }\r\n                    }\r\n                ], \r\n                &quot;SourceDestCheck&quot;: true, \r\n                &quot;Placement&quot;: {\r\n                    &quot;Tenancy&quot;: &quot;default&quot;, \r\n                    &quot;GroupName&quot;: &quot;&quot;, \r\n                    &quot;AvailabilityZone&quot;: &quot;us-east-1e&quot;\r\n                }, \r\n                &quot;Hypervisor&quot;: &quot;xen&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;: true, \r\n                            &quot;VolumeId&quot;: &quot;vol-4fb6ed03&quot;, \r\n                            &quot;AttachTime&quot;: &quot;2014-07-02T19:24:23.000Z&quot;\r\n                        }\r\n                    }\r\n                ], \r\n                &quot;Architecture&quot;: &quot;x86_64&quot;, \r\n                &quot;RootDeviceType&quot;: &quot;ebs&quot;, \r\n                &quot;RootDeviceName&quot;: &quot;/dev/sda1&quot;, \r\n                &quot;VirtualizationType&quot;: &quot;hvm&quot;, \r\n                &quot;Tags&quot;: [\r\n                    {\r\n                        &quot;Value&quot;: &quot;qa&quot;, \r\n                        &quot;Key&quot;: &quot;environment&quot;\r\n                    }, \r\n                    {\r\n                        &quot;Value&quot;: &quot;database&quot;, \r\n                        &quot;Key&quot;: &quot;system&quot;\r\n                    }, \r\n                    {\r\n                        &quot;Value&quot;: &quot;databaseteam&quot;, \r\n                        &quot;Key&quot;: &quot;team&quot;\r\n                    }\r\n                ], \r\n                &quot;AmiLaunchIndex&quot;: 0\r\n            }\r\n        ], \r\n        &quot;ReservationId&quot;: &quot;r-xx&quot;, \r\n        &quot;Groups&quot;: [], \r\n        &quot;OwnerId&quot;: &quot;xx&quot;\r\n    }\r\n\r\nSimilar data is scattered throughout the JSON data as obtained from `aws ec2 describe-instances` command.\r\n\r\nNow I want to filter PrivateIPAddress and InstanceType *only* if some key: value pair from the Tags[] array match. I am primarily looking for something like, if `select(.Value == &quot;qa&quot; and .Value == databaseteam)` match. In other words, based out of match criterion from the Tags array defined in the jq filter, I want to show PrivateIPAddress and InstanceType.\r\n\r\nHow I can achieve this? I have tried map, select and possibly all kinds of previous SO answers, github issue replies but I can&#39;t get this to work.\r\n\r\nThanks,",
        "link": "https://stackoverflow.com/questions/48050565/how-to-filter-json-data-with-jq-based-on-values-from-multiple-keys-and-show-one",
        "title": "How to filter JSON data with jq based on values from multiple keys and show one particular attribute if the filter succeeds?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 29,
                "is_accepted": false,
                "score": 29,
                "last_activity_date": 1514889168,
                "creation_date": 1514889168,
                "answer_id": 48059361,
                "question_id": 48058204,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One of many possible solutions in jq:\r\n\r\n    group_by(.) | map(select(length&gt;1) | .[0])",
                "title": "Find duplicates in JSON array"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1605160693,
                "last_edit_date": 1605160693,
                "creation_date": 1514890178,
                "answer_id": 48059577,
                "question_id": 48058204,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Solutions involving the built-in `group_by` involve a sort and  are therefore inefficient if the goal is simply to identify the duplicates.  Here is a sort-free solution that uses a generic and powerful `bagof` function defined here on a stream:\r\n\r\n```\r\n# Create a two-level dictionary giving [item, n] where n\r\n# is the multiplicity of the item in the stream\r\ndef bagof(stream):\r\n  reduce stream as $x ({};\r\n    ($x | [type, tostring]) as $key\r\n    | getpath($key) as $entry\r\n    | if $entry then setpath($key; [$x, ($entry[1] + 1 )])\r\n      else setpath($key; [$x, 1])\r\n      end ) ;\r\n```\r\n```\r\n# Emit a stream of duplicated items in the stream, s:\r\ndef duplicates(s): bagof(s) | .[][] | select(.[1]&gt;1) | .[0];\r\n\r\n# Input: an array\r\n# Output: an array of items that are duplicated in the array\r\ndef duplicates: [duplicates(.[])];\r\n\r\n```",
                "title": "Find duplicates in JSON array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 11,
        "last_activity_date": 1605160693,
        "creation_date": 1514884099,
        "last_edit_date": 1514890081,
        "question_id": 48058204,
        "body_markdown": "Does anyone know how to use jq to find the duplicate(s) in a JSON array?\r\n\r\nFor example:\r\n\r\nInput: \r\n\r\n    [{&quot;foo&quot;: 1, &quot;bar&quot;: 2}, {&quot;foo&quot;: 1, &quot;bar&quot;: 2}, {&quot;foo&quot;: 4, &quot;bar&quot;: 5}]\r\n\r\nOutput:\r\n\r\n  \t[{&quot;foo&quot;: 1, &quot;bar&quot;: 2}]",
        "link": "https://stackoverflow.com/questions/48058204/find-duplicates-in-json-array",
        "title": "Find duplicates in JSON array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1514958648,
                "last_edit_date": 1514958648,
                "creation_date": 1514891343,
                "answer_id": 48059873,
                "question_id": 48058260,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One possibility would be to use `..`:\r\n\r\n    .. | objects | select( has(&quot;name&quot;) ) | .name\r\n\r\nor perhaps just:\r\n\r\n    .. | .name? // empty",
                "title": "How to get same property at different levels with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1514891930,
                "creation_date": 1514891930,
                "answer_id": 48060008,
                "question_id": 48058260,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One way to combine the two queries would be to use `,`:\r\n\r\n      .[] | (.name, .children[]?.name)\r\n\r\n",
                "title": "How to get same property at different levels with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1514926740,
                "creation_date": 1514926740,
                "answer_id": 48067770,
                "question_id": 48058260,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Simplest form I think is:\r\n\r\n    .. | .name?\r\n\r\nWhat does it mean?\r\n\r\n.. is a recursive decent, producing every value.\r\n\r\n.. | .name?\r\n\r\nfinds all the values in keys starting with **name**.\r\n\r\nYou can find more in **[here in the manual](https://stedolan.github.io/jq/manual/#example12)**\r\n",
                "title": "How to get same property at different levels with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1514958648,
        "creation_date": 1514884388,
        "question_id": 48058260,
        "body_markdown": "    [{\r\n    \r\n        &quot;name&quot;: &quot;asd&quot;\r\n        &quot;children&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;sfgdfg&quot;\r\n        }]\r\n    }]&#39;\r\n\r\nI can get names of all parents or children so\r\n\r\n    jq &#39;.[] | (.name)&#39;\r\n    jq &#39;.[] | (.children[].name)&#39;\r\n\r\nHow can I get both with a one liner containing a OR?\r\n",
        "link": "https://stackoverflow.com/questions/48058260/how-to-get-same-property-at-different-levels-with-jq",
        "title": "How to get same property at different levels with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1514963174,
                "last_edit_date": 1514963174,
                "creation_date": 1514962716,
                "answer_id": 48072636,
                "question_id": 48072308,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The filter you are evidently trying to write is:\r\n\r\n          if .key1 == &quot;&quot; then . + {&quot;key1&quot; : $input } else . end\r\n          | if .key2 == &quot;&quot; then . + {&quot;key2&quot; : $input } else . end\r\n\r\nThis can be simplified to:\r\n\r\n          if .key1 == &quot;&quot; then .key1 = $input else . end\r\n          | if .key2 == &quot;&quot; then .key2 = $input else . end\r\n\r\nYou might also like to consider the following approach:\r\n\r\n          def update(f): f |= (if . == &quot;&quot; then $input else . end);\r\n          update(.key1) | update(.key2)\r\n",
                "title": "combine two jq filters into one"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1514963174,
        "creation_date": 1514961070,
        "last_edit_date": 1514962320,
        "question_id": 48072308,
        "body_markdown": "How jq filter combines the filter outputs? Following jq not generates output.json with respective input arg value (&#39;jack&#39;).\r\n\r\ninput.json\r\n----------\r\n\r\n    {\r\n    &quot;key1&quot;: &quot;&quot;,\r\n    &quot;key2&quot;: &quot;&quot;\r\n    }\r\n\r\n\t jq --arg input &quot;$username&quot; \\\r\n              &#39;if .key1 == &quot;&lt;value1&gt;&quot;\r\n                     then . + {&quot;key1&quot; : ($input) }\r\n              else . end&#39; input.json |\r\n              &#39;if .key2 == &quot;&lt;value2&gt;&quot;\r\n                     then . + {&quot;key2&quot; : ($input) }\r\n              else . end&#39;  &gt;  output.json\r\n\r\noutput.json\r\n-----------\r\n\r\n    {\r\n    &quot;key1&quot;: &quot;jack&quot;,\r\n    &quot;key2&quot;: &quot;jack&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/48072308/combine-two-jq-filters-into-one",
        "title": "combine two jq filters into one"
    },
    {
        "tags": [
            "json",
            "floating-point",
            "type-conversion",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1514986215,
                "creation_date": 1514986215,
                "answer_id": 48078423,
                "question_id": 48077471,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Simply with *jq*&#39;s `tonumber` function:\r\n\r\n    jq &#39;.[] | select((.a|tonumber) &gt; 50 and (.b|tonumber) &gt; 50)&#39; mydata.json\r\nThe output:\r\n\r\n    {\r\n      &quot;a&quot;: &quot;70.0&quot;,\r\n      &quot;b&quot;: &quot;92.67&quot;,\r\n      &quot;c&quot;: &quot;0&quot;,\r\n      &quot;d&quot;: &quot;0&quot;\r\n    }\r\n\r\n",
                "title": "Parsing float value from string by jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1515644269,
        "creation_date": 1514982683,
        "last_edit_date": 1515644269,
        "question_id": 48077471,
        "body_markdown": "I have a particular JSON data which contain float value that I need to conditionally process over an array of JSON. This is an example of one JSON instance:\r\n\r\n    [\r\n       {\r\n          &quot;a&quot;: &quot;0&quot;,\r\n          &quot;b&quot;: &quot;66.67&quot;,\r\n          &quot;c&quot;: &quot;0&quot;,\r\n          &quot;d&quot;: &quot;0&quot;\r\n       },\r\n       {\r\n          &quot;a&quot;: &quot;12.33&quot;,\r\n          &quot;b&quot;: &quot;0&quot;,\r\n          &quot;c&quot;: &quot;60.2&quot;,\r\n          &quot;d&quot;: &quot;19.3&quot;\r\n       },\r\n       {\r\n          &quot;a&quot;: &quot;70.0&quot;,\r\n          &quot;b&quot;: &quot;92.67&quot;,\r\n          &quot;c&quot;: &quot;0&quot;,\r\n          &quot;d&quot;: &quot;0&quot;\r\n       }\r\n    ]\r\n\r\nand I wish to conditionally select like\r\n\r\n    cat mydata.json | jq &#39;.[] | select((.a &gt; 50) and (.b &gt; 50))&#39;\r\n\r\nand it should sound like\r\n\r\n    {\r\n          &quot;a&quot;: &quot;70.0&quot;,\r\n          &quot;b&quot;: &quot;92.67&quot;,\r\n          &quot;c&quot;: &quot;0&quot;,\r\n          &quot;d&quot;: &quot;0&quot;\r\n    }\r\n\r\nThe problem is my original data is a string value and I have no idea how to parse it for a conditional selection.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48077471/parsing-float-value-from-string-by-jq",
        "title": "Parsing float value from string by jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "array-difference"
        ],
        "answers": [
            {
                "up_vote_count": 12,
                "is_accepted": true,
                "score": 12,
                "last_activity_date": 1515421727,
                "last_edit_date": 1515421727,
                "creation_date": 1514991166,
                "answer_id": 48079780,
                "question_id": 48078614,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`del` is intended for deleting-by-path, not by-value:\r\n\r\n     [10,11,12] | del(.[0]) #=&gt; [11,12]\r\n\r\nOne way to achieve what you want is to use `select`:\r\n\r\n     [10,11,12] | map(select(. != 10))\r\n\r\nAnother would be to use array subtraction:\r\n\r\n     [10,11,12] - [10]\r\n\r\nBut that&#39;s maybe too easy.",
                "title": "jq remove element from array by value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1515421727,
        "creation_date": 1514986936,
        "last_edit_date": 1515045330,
        "question_id": 48078614,
        "body_markdown": "I&#39;m using `jq` and trying to remove an element from an array based on it&#39;s value by can&#39;t figure out the syntax, it works with map but not del:\r\n\r\ninput = `[10,11,12]`\r\n\r\n`echo $input | jq -r &#39;map(select(. == 10))&#39;` returns `[10]`\r\n\r\n`echo $input | jq -r &#39;del(select(. == 10))&#39;` returns `[10,11,12]` not `[11,12]` as expected\r\n\r\nCan someone point me in the right direction?",
        "link": "https://stackoverflow.com/questions/48078614/jq-remove-element-from-array-by-value",
        "title": "jq remove element from array by value"
    },
    {
        "tags": [
            "arrays",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1514999575,
                "post_id": 48081944,
                "comment_id": 83138375,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1515008024,
                "creation_date": 1515008024,
                "answer_id": 48084001,
                "question_id": 48081944,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It&#39;s not entirely clear from the question what the expected output is supposed to be, but it looks like you want to concatenate the arrays.  \r\n\r\nIf that&#39;s the case and if your file list is file1 file2 ... then the following invocation would be appropriate:\r\n\r\n    jq add file1 file2 ...\r\n\r\np.s. In future, please follow the guidelines at  http://stackoverflow.com/help/mcve minimal complete verifiable example\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "jq: join array elements from different files into one array"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1558530711,
                "creation_date": 1558530711,
                "answer_id": 56257661,
                "question_id": 48081944,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I had the same issue and found my solution on github: https://github.com/stedolan/jq/issues/805#issuecomment-109783967\r\n\r\n\r\n&gt; Using the -s option will return an array containing the contents of the input JSON files, which, in your case, are also arrays. This means that you need to spread (…[]) two array levels, and collect ([…]) the result.\r\n\r\n`jq -s &#39;[.[][]]&#39; a-*.json &gt; manifest.json`",
                "title": "jq: join array elements from different files into one array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1604573623,
                "creation_date": 1604573623,
                "answer_id": 64695718,
                "question_id": 48081944,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I was able to solve this with:\r\n\r\n`jq -s &#39;flatten&#39; file1 file2 ...`\r\n\r\nSo -s (slurp) assembles an array of files&#39; contents (arrays), and `flatten` removes the extra [] levels and the output is an array of all records from all files.",
                "title": "jq: join array elements from different files into one array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1604573623,
        "creation_date": 1514999179,
        "question_id": 48081944,
        "body_markdown": "I have a series of JSON files like these:\r\n\r\n    [\r\n      {\r\n        &quot;bent_general&quot;: &quot;0&quot;,\r\n        &quot;bext_general&quot;: &quot;0&quot;,\r\n        &quot;date_yyyymmdd&quot;: &quot;20171104&quot;,\r\n        &quot;end_time&quot;: &quot;2017-11-07T02:58:56&quot;,\r\n        &quot;householdid&quot;: &quot;EAM2231&quot;\r\n      },\r\n      {\r\n        &quot;bent_general&quot;: &quot;2&quot;,\r\n        &quot;bext_general&quot;: &quot;8&quot;,\r\n        &quot;date_yyyymmdd&quot;: &quot;20171126&quot;,\r\n        &quot;end_time&quot;: &quot;2017-12-07T05:58:56&quot;,\r\n        &quot;householdid&quot;: &quot;EAM1234&quot;,\r\n      }\r\n    ]\r\n\r\nI need to combine them in one big file with the same structure:\r\n\r\n    [\r\n      {\r\n        &quot;data_from&quot;: &quot;first_file&quot;\r\n      },\r\n      {\r\n        &quot;data_from&quot;: &quot;second_file&quot;\r\n      }\r\n    ]\r\n\r\nI tried:\r\njq -s . file1 file2\r\n\r\nBut the result is:\r\n\r\n    [\r\n      [\r\n        {\r\n          &quot;data_from&quot;: &quot;first_file&quot;\r\n        }\r\n      ]\r\n      ,\r\n      [\r\n        {\r\n          &quot;data_from&quot;: &quot;second_file&quot;\r\n        }\r\n      ]\r\n    ]\r\n\r\nAny idea is appreciated.",
        "link": "https://stackoverflow.com/questions/48081944/jq-join-array-elements-from-different-files-into-one-array",
        "title": "jq: join array elements from different files into one array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1515002145,
                "post_id": 48082550,
                "comment_id": 83139733,
                "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": 1515002373,
                "post_id": 48082550,
                "comment_id": 83139850,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1220345,
                    "reputation": 2483,
                    "user_id": 1187098,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/2c31da844ec3d4c6889e2dd5e9323037?s=256&d=identicon&r=PG",
                    "display_name": "art vanderlay",
                    "link": "https://stackoverflow.com/users/1187098/art-vanderlay"
                },
                "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": 1515002636,
                "post_id": 48082550,
                "comment_id": 83139983,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1515002197,
                "creation_date": 1515002197,
                "answer_id": 48082695,
                "question_id": 48082550,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To use a sigil that can&#39;t possibly exist as a value in a shell array, NUL is an appropriate choice.\r\n\r\n    nameArr=( &quot;Leia&quot; &quot;Darth Vader&quot; &quot;Anakin&quot; &quot;Han Solo&quot; &quot;Yoda&quot; )\r\n    printf &#39;%s\\0&#39; &quot;${nameArr[@]}&quot; | jq -csR &#39;split(&quot;\\u0000&quot;)&#39;\r\n\r\n...properly emits:\r\n\r\n    [&quot;Leia&quot;,&quot;Darth Vader&quot;,&quot;Anakin&quot;,&quot;Han Solo&quot;,&quot;Yoda&quot;]",
                "title": "Create JSON array from shell array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1515644177,
        "creation_date": 1515001701,
        "last_edit_date": 1515644177,
        "question_id": 48082550,
        "body_markdown": "We are trying to get `jq`v1.5 64bit to parse an array then echo out the result.\r\n\r\nDo we have the correct `jq` syntax?\r\n\r\n    #!/bin/bash\r\n    declare -a nameArr \r\n    nameArr=(&quot;Leia&quot; &quot;Darth Vader&quot; &quot;Anakin&quot; &quot;Han Solo&quot; &quot;Yoda&quot;)\r\n    jq -c -n  &quot;$nameArr&quot; \r\n\r\ngives error\r\n\r\n    jq: error: syntax error, unexpected $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    Leia,    \r\n    jq: 1 compile error\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48082550/create-json-array-from-shell-array-with-jq",
        "title": "Create JSON array from shell array with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1515050265,
                "post_id": 48090023,
                "comment_id": 83155120,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1515063034,
                "creation_date": 1515063034,
                "answer_id": 48093639,
                "question_id": 48090023,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your version of jq evidently requires the `.` filter here, as in:\r\n\r\n     jq -s -R .",
                "title": "Can&#39;t store output of jq in variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1515063034,
        "creation_date": 1515048376,
        "question_id": 48090023,
        "body_markdown": "I have some text that I want to escape to something I can use in JSON.\r\nI can escape the text using jq and display it\r\n\r\n    normaltext=&quot;My normal text that I want to put in \\&quot;JSON\\&quot;&quot;\r\n    echo $normaltext | jq --slurp --raw-input\r\n&gt; &quot;My normal text that I want to put in \\&quot;JSON\\&quot;\\n&quot;\r\n\r\nHowever, store that command output into a variable, jq doesn&#39;t seem to receive the input and just displays the help text.\r\n\r\n    escapedtext=$(echo $normaltext | jq --slurp --raw-input)\r\n\r\n&gt; jq - commandline JSON processor [version 1.5-1-a5b5cbe]\r\nUsage: jq [options] &lt;jq filter&gt; [file...]\r\n",
        "link": "https://stackoverflow.com/questions/48090023/cant-store-output-of-jq-in-variable",
        "title": "Can&#39;t store output of jq in variable"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1515090946,
                "creation_date": 1515090946,
                "answer_id": 48101538,
                "question_id": 48100901,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** + **`awk`** solution (assuming *Linux* environment):\r\n\r\n    curl -s &quot;https://api.coinmarketcap.com/v1/ticker/?convert=EUR&amp;limit=20&quot; \\\r\n    | jq -r &#39;.[] | [.rank, .symbol, .percent_change_1h, .percent_change_24h,\r\n    .percent_change_7d, .price_eur, .market_cap_eur] | @tsv&#39; \\\r\n    | awk &#39;{ $6=sprintf(&quot;%.3f&quot;,$6); $7=$7/(1*10^6) }1&#39; | column -t\r\nThe output:\r\n\r\n    1   BTC    1.62   0.76    5.63    12618.627  211768\r\n    2   XRP    -4.04  13.64   142.7   2.885      111773\r\n    3   ETH    -1.12  11.55   40.07   845.206    81790.2\r\n    4   BCH    1.01   -7.0    -4.13   2043.695   34524.9\r\n    5   ADA    -2.79  10.38   194.99  0.966      25046.2\r\n    6   XEM    -1.64  17.26   96.98   1.445      13006.7\r\n    7   XLM    -3.54  -9.96   267.75  0.660      11804\r\n    8   TRX    -0.48  152.86  454.55  0.169      11132.6\r\n    9   LTC    -1.64  -3.04   -2.97   197.775    10801.2\r\n    10  MIOTA  5.79   4.76    19.54   3.481      9675.58\r\n    11  DASH   0.73   8.52    13.65   1045.762   8155.11\r\n    12  NEO    0.13   9.17    69.28   87.454     5684.52\r\n    13  EOS    -0.25  27.87   22.32   9.652      5628.04\r\n    14  XMR    0.32   0.28    6.36    333.080    5183.6\r\n    15  BTG    1.12   2.98    -2.53   231.167    3870.93\r\n    16  QTUM   0.28   3.58    11.99   50.186     3702.88\r\n    17  XRB    4.29   15.4    160.91  25.188     3356.32\r\n    18  ETC    -3.23  10.74   24.11   30.394     3005.25\r\n    19  ICX    -3.59  9.69    37.95   6.352      2398.27\r\n    20  LSK    5.42   9.61    -1.45   18.794     2192.41\r\n",
                "title": "Convert a string to a number using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1515155079,
        "creation_date": 1515088318,
        "last_edit_date": 1515155079,
        "question_id": 48100901,
        "body_markdown": "After parsing some json I have numbers like the following\r\n\r\n    1\tBTC\t1.1\t-1.27\t4.5\t12483.315628\t209496088918\r\n    2\tXRP\t-1.14\t20.92\t153.78\t3.0061025564\t116453842357\r\n    3\tETH\t-1.08\t13.41\t40.64\t847.89295234\t82049924696.0\r\n    4\tBCH\t0.51\t-9.21\t-5.22\t2025.07027989\t34210094446.0\r\n    5\tADA\t1.12\t14.9\t205.14\t0.9950722725\t25799309000.0\r\n    6\tXEM\t-0.02\t20.4\t100.84\t1.4710629893\t13239566903.0\r\n\r\nand I would like to convert them to numbers before printing them because they&#39;re not that readable this way. \r\n\r\nIn the last but one column I&#39;d like to truncate precision to 3 digits after the dot and in the last column I&#39;d like to divide by 1M. In the json these fields are strings. I&#39;m forced to use [jq][1].\r\n\r\nThe context is this:\r\n\r\n    curl -s &quot;https://api.coinmarketcap.com/v1/ticker/?convert=EUR&amp;limit=20&quot; | jq -r &#39;.[] | [.rank, .symbol, .percent_change_1h, .percent_change_24h, .percent_change_7d, .price_eur, .market_cap_eur] | @tsv&#39;\r\n\r\nI added a [issue][2] on the project github, so check there for updates also.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/\r\n  [2]: https://github.com/stedolan/jq/issues/1573",
        "link": "https://stackoverflow.com/questions/48100901/convert-a-string-to-a-number-using-jq",
        "title": "Convert a string to a number using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 57200,
                    "reputation": 158728,
                    "user_id": 171318,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/ePRKy.jpg?s=256",
                    "display_name": "hek2mgl",
                    "link": "https://stackoverflow.com/users/171318/hek2mgl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1515116096,
                "post_id": 48105506,
                "comment_id": 83187789,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1234597,
                    "reputation": 563,
                    "user_id": 1198458,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/335c23496708a08dd03c7b2f1eb82628?s=256&d=identicon&r=PG",
                    "display_name": "M.Ridha",
                    "link": "https://stackoverflow.com/users/1198458/m-ridha"
                },
                "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": 1515117072,
                "post_id": 48105506,
                "comment_id": 83188016,
                "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": 1515117120,
                "post_id": 48105506,
                "comment_id": 83188032,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1515117635,
                "last_edit_date": 1515117635,
                "creation_date": 1515116891,
                "answer_id": 48106125,
                "question_id": 48105506,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I would do this in a more convenient programming language, like Python:\r\n\r\n    #!/usr/bin/env python\r\n    import json\r\n    import sys \r\n    \r\nThanks https://stackoverflow.com/a/38373810/171318\r\n\r\n    def load_json_multiple(segments):\r\n        chunk = &quot;&quot;\r\n        for segment in segments:\r\n            chunk += segment\r\n            try:\r\n                yield json.loads(chunk)\r\n                chunk = &quot;&quot;\r\n            except ValueError:\r\n                pass\r\n    \r\n... and the `main()` method:\r\n    \r\n    def main():\r\n    \r\n        lookup = {}\r\n        # You might wanna use argparse for this in real life\r\n        filename = sys.argv[1]\r\n        with open(filename) as f:\r\n            for parsed_json in load_json_multiple(f):\r\n                key = &#39;{}/{}/{}&#39;.format(parsed_json[&#39;id&#39;],\r\n                                        parsed_json[&#39;code&#39;],\r\n                                        parsed_json[&#39;severityCode&#39;])\r\n    \r\n                status = True if parsed_json[&#39;alert&#39;][&#39;status&#39;] == &#39;On&#39; else False\r\n                if key in lookup and lookup[key] != (not status):\r\n                    print(&#39;invalid&#39;)\r\n                    return 1\r\n    \r\n                lookup[key] = status\r\n    \r\n        print(&#39;valid&#39;)\r\n        return 0\r\n    \r\n    \r\n    if __name__ == &#39;__main__&#39;:\r\n        sys.exit(main())\r\n\r\nStore it in a file, let&#39;s say *validate.py*, `chmod +x` it and call it like this:\r\n\r\n    ./validate.py valid.json\r\n    ./validate.py invalid.json\r\n    ...",
                "title": "Parsing JSON lines with JQ for flapping key values in sequence"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1532112422,
                "last_edit_date": 1532112422,
                "creation_date": 1515122834,
                "answer_id": 48106817,
                "question_id": 48105506,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I don&#39;t think I can use group_by to look for duplicates (the group_by&#39;s result is sorted).\r\n\r\nThat&#39;s right, but it&#39;s very easy to define a non-sorting &quot;group_by&quot;, which, as we&#39;ll see, can also easily be used to sort by all keys except for specifically designated ones.  \r\n\r\n### GROUPS_BY\r\n\r\nFirst, here is a simple filter which retains the original order of items within each group:\r\n\r\n    # The filter, f, must produce a string for each item in `stream`\r\n    def GROUPS_BY(stream; f):\r\n      reduce stream as $x ({}; .[$x|f] += [$x] ) | .[] ;\r\n\r\nThe &quot;S&quot; in the name emphasizes that the function is stream-oriented, first in that the first argument is a stream, and second in that the function produces a stream of the groups; the name is upper-cased to emphasize the differences with the existing built-in function.\r\n\r\n### Example\r\n\r\nTo illustrate how this can be used to group by all but a specific key, consider this example (taken from another SO question):\r\n\r\n    def data:\r\n      [{&quot;foo&quot;:1,&quot;bar&quot;:&quot;a&quot;,&quot;baz&quot;:&quot;whatever&quot;},\r\n       {&quot;foo&quot;:1,&quot;bar&quot;:&quot;a&quot;,&quot;baz&quot;:&quot;hello&quot;},\r\n       {&quot;foo&quot;:1,&quot;bar&quot;:&quot;b&quot;,&quot;baz&quot;:&quot;world&quot;}] ;\r\n\r\n    GROUPS_BY(data[]; del(.baz) | tostring)\r\n\r\n### Output\r\n\r\n    [{&quot;foo&quot;:1,&quot;bar&quot;:&quot;a&quot;,&quot;baz&quot;:&quot;whatever&quot;},{&quot;foo&quot;:1,&quot;bar&quot;:&quot;a&quot;,&quot;baz&quot;:&quot;hello&quot;}]\r\n    [{&quot;foo&quot;:1,&quot;bar&quot;:&quot;b&quot;,&quot;baz&quot;:&quot;world&quot;}]\r\n\r\n### Refinement\r\nIt may be objected that requiring that f always be string-valued introduces several potential difficulties, so here is an efficient but more versatile definition:\r\n\r\n    # Emit a stream of the groups defined by f, without using sort.\r\n    # f need not be string-valued.\r\n    def GROUPS_BY(stream; f): \r\n       reduce stream as $x ({};\r\n         ($x|f) as $s\r\n         | ($s|type) as $t\r\n         | (if $t == &quot;string&quot; then $s else ($s|tojson) end) as $y\r\n         | .[$t][$y] += [$x] )\r\n       | .[][]\r\n       ;\r\n\r\nNow we can simply write:\r\n\r\n    GROUPS_BY(data[]; del(.baz))\r\n\r\n### Usage with the JSON-Lines file\r\n\r\nThe simplest way to use `GROUPS_BY` with a JSON-Lines file is with `inputs`, e.g. assuming the more versatile def is used, you&#39;d write:\r\n\r\n\r\n    GROUPS_BY(inputs; del(.alert))\r\n\r\nDon&#39;t forget to invoke jq with the -n option when using `inputs`.\r\n\r\n### A filter to determine validity\r\n\r\nAccording to my understanding of the problem, the following filter can be used to determine validity of a group:\r\n\r\n    def changing(f):\r\n      def c:\r\n        if length &lt;= 1 then true\r\n        elif (.[0] | f) == (.[1] | f) then false\r\n        else .[1:] | c\r\n        end;\r\n      c ;\r\n      \r\n(The inner function, c, is used here for efficient recursion. Of course, if computing `f` redundantly is a concern, then a variant definition should be used.)\r\n \r\n### Solution\r\n\r\nPutting it altogether using the more versatile definition of GROUPS_BY,\r\nand assuming we wish to identify the invalid groups, the solution seems to be a two-liner:\r\n\r\n    GROUPS_BY(inputs; del(.alert))\r\n    | select( changing(.alert.status) | not )\r\n    \r\n",
                "title": "Parsing JSON lines with JQ for flapping key values in sequence"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1532112422,
        "creation_date": 1515111666,
        "last_edit_date": 1515115411,
        "question_id": 48105506,
        "body_markdown": "I have a file containing json lines that need to be verified for its validity based on the sequence of each json&#39;s flapping &quot;alert.status&quot; value. \r\n\r\nA sample of valid json lines:\r\n\r\n    {&quot;id&quot;:123,&quot;code&quot;:&quot;foo&quot;,&quot;severity&quot;:&quot;Critical&quot;,&quot;severityCode&quot;:1, &quot;property&quot;:{ &quot;priority&quot;:&quot;top&quot;, &quot;owner&quot;:&quot;dev&quot;}, &quot;alert&quot;:{&quot;mgmt&quot;:&quot;yes&quot;, &quot;status&quot;:&quot;On&quot;}}\r\n    {&quot;id&quot;:456,&quot;code&quot;:&quot;bar&quot;,&quot;severity&quot;:&quot;High&quot;,&quot;severityCode&quot;:2,&quot;property&quot;:{ &quot;priority&quot;:&quot;top&quot;, &quot;owner&quot;:&quot;dev&quot;}, &quot;alert&quot;:{&quot;mgmt&quot;:&quot;yes&quot;, &quot;status&quot;:&quot;On&quot;}}\r\n    {&quot;id&quot;:123,&quot;code&quot;:&quot;foo&quot;,&quot;severity&quot;:&quot;Critical&quot;,&quot;severityCode&quot;:1,&quot;property&quot;:{ &quot;priority&quot;:&quot;top&quot;, &quot;owner&quot;:&quot;dev&quot;}, &quot;alert&quot;:{&quot;mgmt&quot;:&quot;yes&quot;, &quot;status&quot;:&quot;Off&quot;}}\r\n    {&quot;id&quot;:456,&quot;code&quot;:&quot;bar&quot;,&quot;severity&quot;:&quot;High&quot;,&quot;severityCode&quot;:2,&quot;property&quot;:{ &quot;priority&quot;:&quot;top&quot;, &quot;owner&quot;:&quot;dev&quot;}, &quot;alert&quot;:{&quot;mgmt&quot;:&quot;yes&quot;, &quot;status&quot;:&quot;Off&quot;}}\r\n    {&quot;id&quot;:123,&quot;code&quot;:&quot;foo&quot;,&quot;severity&quot;:&quot;Critical&quot;,&quot;severityCode&quot;:1,&quot;property&quot;:{ &quot;priority&quot;:&quot;top&quot;, &quot;owner&quot;:&quot;dev&quot;}, &quot;alert&quot;:{&quot;mgmt&quot;:&quot;yes&quot;, &quot;status&quot;:&quot;On&quot;}}\r\n    {&quot;id&quot;:456,&quot;code&quot;:&quot;bar&quot;,&quot;severity&quot;:&quot;High&quot;,&quot;severityCode&quot;:2,&quot;property&quot;:{ &quot;priority&quot;:&quot;top&quot;, &quot;owner&quot;:&quot;dev&quot;}, &quot;alert&quot;:{&quot;mgmt&quot;:&quot;yes&quot;, &quot;status&quot;:&quot;On&quot;}}\r\n\r\n\r\nThe above file is valid since the duplicate jsons (line 1,5 and line 2,6) have status flapping from &quot;on&quot;, &quot;off&quot;, &quot;on&quot; and so on.\r\n\r\nA sample of invalid json lines:\r\n\r\n    {&quot;id&quot;:123,&quot;code&quot;:&quot;foo&quot;,&quot;severity&quot;:&quot;Critical&quot;,&quot;severityCode&quot;:1, &quot;property&quot;:{ &quot;priority&quot;:&quot;top&quot;, &quot;owner&quot;:&quot;dev&quot;}, &quot;alert&quot;:{&quot;mgmt&quot;:&quot;yes&quot;, &quot;status&quot;:&quot;On&quot;}}\r\n    {&quot;id&quot;:456,&quot;code&quot;:&quot;bar&quot;,&quot;severity&quot;:&quot;High&quot;,&quot;severityCode&quot;:2,&quot;property&quot;:{ &quot;priority&quot;:&quot;top&quot;, &quot;owner&quot;:&quot;dev&quot;}, &quot;alert&quot;:{&quot;mgmt&quot;:&quot;yes&quot;, &quot;status&quot;:&quot;On&quot;}}\r\n    {&quot;id&quot;:123,&quot;code&quot;:&quot;foo&quot;,&quot;severity&quot;:&quot;Critical&quot;,&quot;severityCode&quot;:1,&quot;property&quot;:{ &quot;priority&quot;:&quot;top&quot;, &quot;owner&quot;:&quot;dev&quot;}, &quot;alert&quot;:{&quot;mgmt&quot;:&quot;yes&quot;, &quot;status&quot;:&quot;On&quot;}}\r\n    {&quot;id&quot;:456,&quot;code&quot;:&quot;bar&quot;,&quot;severity&quot;:&quot;High&quot;,&quot;severityCode&quot;:2,&quot;property&quot;:{ &quot;priority&quot;:&quot;top&quot;, &quot;owner&quot;:&quot;dev&quot;}, &quot;alert&quot;:{&quot;mgmt&quot;:&quot;yes&quot;, &quot;status&quot;:&quot;Off&quot;}}\r\n    {&quot;id&quot;:123,&quot;code&quot;:&quot;foo&quot;,&quot;severity&quot;:&quot;Critical&quot;,&quot;severityCode&quot;:1,&quot;property&quot;:{ &quot;priority&quot;:&quot;top&quot;, &quot;owner&quot;:&quot;dev&quot;}, &quot;alert&quot;:{&quot;mgmt&quot;:&quot;yes&quot;, &quot;status&quot;:&quot;Off&quot;}}\r\n    {&quot;id&quot;:456,&quot;code&quot;:&quot;bar&quot;,&quot;severity&quot;:&quot;High&quot;,&quot;severityCode&quot;:2,&quot;property&quot;:{ &quot;priority&quot;:&quot;top&quot;, &quot;owner&quot;:&quot;dev&quot;}, &quot;alert&quot;:{&quot;mgmt&quot;:&quot;yes&quot;, &quot;status&quot;:&quot;Off&quot;}}\r\n\r\nThe above is invalid since jsons in line 1 and 3 are duplicate having its &quot;status&quot; value stays the same without flapping from on or off.\r\n\r\nI tried to use jq to read the json lines into a json array \r\n\r\n    jq --slurp &#39;map(select(. &gt;= 2))&#39; jsonfile &gt; jsonarray\r\n\r\nBut since the sequence in each line is important, I don&#39;t think I can use group_by to look for duplicates (the group_by&#39;s result is sorted).\r\n\r\nI&#39;m thinking about inserting a new key with incremental number in each json so after using group_by, we can sort the result based on this new key to get back the sequence. \r\n\r\nIs there a way in jq to use group by all except two keys? (in this case &quot;status&quot; and the new key with incremental number). \r\n\r\nIs there any better approach how to solve this problem?\r\n\r\nThanks so much for your help!\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48105506/parsing-json-lines-with-jq-for-flapping-key-values-in-sequence",
        "title": "Parsing JSON lines with JQ for flapping key values in sequence"
    },
    {
        "tags": [
            "json",
            "object",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1515469570,
                "last_edit_date": 1515469570,
                "creation_date": 1515437178,
                "answer_id": 48156329,
                "question_id": 48155814,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following uses the versatile and efficient version of `GROUPS_BY` defined at https://stackoverflow.com/questions/48105506\r\n\r\n(`GROUPS_BY` is an efficient version of the built-in `group_by`, which you could also use, as shown below.)\r\n\r\n`GROUPS_BY` is stream-oriented.  Thus the &quot;natural&quot; use of `GROUPS_BY` to solve the problem at hand is:\r\n\r\n      GROUPS_BY(.[]; [.street, .housenumber])\r\n      | (.[0]|del(.member)) + { members: (map(.member)) }\r\n\r\nThis produces a stream of the &quot;groups&quot;, while preserving the ordering of the &quot;members&quot;:\r\n\r\n    {&quot;street&quot;:&quot;Foobar ave&quot;,&quot;housenumber&quot;:4,&quot;members&quot;:[&quot;Carl&quot;,&quot;Bernd&quot;]}\r\n    {&quot;street&quot;:&quot;Foobar ave&quot;,&quot;housenumber&quot;:2,&quot;members&quot;:[&quot;Ann&quot;]}\r\n\r\nIf you require that the result be an array, then simply wrap the two-line program above in square brackets: [ .... ]\r\n\r\n### Solution using built-in `group_by`\r\nCurrently, `group_by` uses a sorting algorithm, which means that the ordering of the &quot;members&quot; might not be preserved:\r\n\r\n    group_by( [.street, .housenumber])\r\n    | map((.[0]|del(.member)) + { members: (map(.member)) })\r\n\r\n### Generic Solution using melds_by/2\r\n\r\nGiven a stream of objects and a grouping criterion, f, `melds_by` emits \r\na stream of pairs of the form:\r\n\r\n     [groupid, melded_object]\r\n\r\nwhere `melded_object` is an object constructed from the objects in the &quot;groupid&quot; group, with all the keys present in this group, and where the value at each key is the array of corresponding values:\r\n\r\n    def melds_by(stream; f):\r\n      GROUPS_BY(stream; f)\r\n      | . as $in\r\n      | [ (.[0]|f),\r\n          reduce (add|keys[]) as $k ({}; .[$k] = [$in[] | .[$k]]) ]\r\n      ;\r\n\r\nTo obtain the solution to the original problem as a single array, we can simply write:\r\n\r\n    [ melds_by(.[]; {street, housenumber})\r\n      | .[1] + .[0]\r\n      | with_entries(.key |= if . == &quot;member&quot; then &quot;members&quot; else . end) ]\r\n\r\nThe last line above simply renames the &quot;member&quot; key.",
                "title": "JQ: Merge Entries if some key values are identical"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1515470952,
        "creation_date": 1515435046,
        "last_edit_date": 1515470952,
        "question_id": 48155814,
        "body_markdown": "I would like to merge entries of a json file with jq.\r\n\r\nIf values of some defined keys are matching, I&#39;d like to merge the entries. The data which does not match should be stored in an array.  \r\nI provided some example JSON for this case.\r\n\r\nIf the street and the house number are identical, I&#39;d like to merge this entry and put the values of &quot;member&quot; into an array.     \r\n\r\n**Matching keys**: housenumber + street have to be identical.\r\n\r\nExample Input\r\n \r\n\r\n    [{\r\n     &quot;street&quot;  : &quot;Foobar ave&quot;,\r\n     &quot;housenumber&quot;: 4,\r\n     &quot;member&quot;:&quot;Carl&quot;\r\n     },\r\n     {\r\n     &quot;street&quot;  : &quot;Foobar ave&quot;,\r\n     &quot;housenumber&quot;: 4,\r\n     &quot;member&quot;:&quot;Bernd&quot;\r\n     },\r\n     {\r\n     &quot;street&quot;  : &quot;Foobar ave&quot;,\r\n     &quot;housenumber&quot;: 2,\r\n     &quot;member&quot;:&quot;Ann&quot;\r\n     }]\r\n\r\n Target result:\r\n\r\n    [{\r\n     &quot;street&quot;  : &quot;Foobar ave&quot;,\r\n     &quot;housenumber&quot;: 4,\r\n     &quot;members&quot;:[&quot;Carl&quot;,&quot;Bernd&quot;]\r\n     },\r\n     {\r\n     &quot;street&quot;  : &quot;Foobar ave&quot;,\r\n     &quot;housenumber&quot;: 2,\r\n     &quot;members&quot;:[&quot;Ann&quot;]\r\n     }]",
        "link": "https://stackoverflow.com/questions/48155814/jq-merge-entries-if-some-key-values-are-identical",
        "title": "JQ: Merge Entries if some key values are identical"
    },
    {
        "tags": [
            "json",
            "string",
            "edit",
            "jq",
            "in-place"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1515532512,
                "last_edit_date": 1515532512,
                "creation_date": 1515528343,
                "answer_id": 48175898,
                "question_id": 48175679,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; jq &#39;.files[] | map( .date |= .date[0:19] )&#39; files.json \r\n\r\nThere are at least two problems with the above.\r\n\r\nYou can either write `.date = .date[0:19]`, or (better): `.date |= .[0:19]`\r\n\r\nIt&#39;s not entirely clear what you want, but if the goal is simply to edit the JSON, then one option would be:\r\n\r\n    .files |= map( .date |= .[0:19] )",
                "title": "How do I replace a value with a substring of that value?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1515585154,
        "creation_date": 1515527385,
        "last_edit_date": 1515585154,
        "question_id": 48175679,
        "body_markdown": "I have some json that looks like this (very simplified):\r\n\r\n    {&quot;files&quot;:[\r\n      {&quot;date&quot;:&quot;2018-01-08T11:38:36+00:00&quot;},\r\n      {&quot;date&quot;:&quot;2018-01-08T11:38:27+00:00&quot;},\r\n      {&quot;date&quot;:&quot;2018-01-07T20:02:12+00:00&quot;},\r\n      {&quot;date&quot;:&quot;2018-01-07T18:23:26+00:00&quot;}\r\n    ]}\r\n\r\nI want to convert the dates to epoch seconds so I can sort them. But this format doesn&#39;t quite match what strptime will accept:\r\n\r\n    $ jq &#39;.files[] | .date |= strptime(&quot;%Y-%m-%dT%H:%M:%S%z&quot;)&#39; files.json \r\n    jq: error (at files.json:6): date &quot;2018-01-08T11:38:36+00:00&quot; does not match format &quot;%Y-%m-%dT%H:%M:%S%z&quot;\r\n\r\nSo, if I just strip off the last 5 characters I can use the same format, minus the %z. This works:\r\n\r\n    $ jq &#39;.files[] | .date[0:19]&#39; files.json \r\n    &quot;2018-01-08T11:38:36&quot;\r\n    &quot;2018-01-08T11:38:27&quot;\r\n    &quot;2018-01-07T20:02:12&quot;\r\n    &quot;2018-01-07T18:23:26&quot;\r\n\r\nSo, what am I doing wrong here:\r\n\r\n    $ jq &#39;.files[] | map( .date |= .date[0:19] )&#39; files.json \r\n    jq: error (at files.json:6): Cannot index string with string &quot;date&quot;\r\n\r\nThanks to @peak I got it worked out:\r\n\r\n    $ jq -c &#39;.files[] | .date |= .[0:19]&#39; files.json\r\n    {&quot;date&quot;:&quot;2018-01-08T11:38:36&quot;}\r\n    {&quot;date&quot;:&quot;2018-01-08T11:38:27&quot;}\r\n    {&quot;date&quot;:&quot;2018-01-07T20:02:12&quot;}\r\n    {&quot;date&quot;:&quot;2018-01-07T18:23:26&quot;}",
        "link": "https://stackoverflow.com/questions/48175679/how-do-i-replace-a-value-with-a-substring-of-that-value",
        "title": "How do I replace a value with a substring of that value?"
    },
    {
        "tags": [
            "json",
            "bash",
            "addition",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1515670406,
                "post_id": 48205247,
                "comment_id": 83393122,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1515671455,
                "last_edit_date": 1515671455,
                "creation_date": 1515670424,
                "answer_id": 48206082,
                "question_id": 48205247,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can add zero to a null to get ... zero.\r\n\r\n    jq &#39;.[] | .[].y | .&quot;number of un-used&quot; | .count + 0&#39; &lt; input.json\r\n\r\nThis produces the list of `count` values you&#39;re looking for, with the `null` values showing `0`. Adding them to your sum should not change it.\r\n\r\n`jq` can do basic arithmetic in its expressions, but having it calculate your sum internally gets a little more complex. While you can define a function that uses a `reduce`, it would probably be easier to sum these values by appending something to the command line like this:\r\n\r\n    | awk &#39;{n+=$1}END{print n}&#39;\r\n\r\nOf course, there&#39;s a zillion ways you could add up numbers, some more hackish than others.\r\n\r\n    $ { printf &#39;%s+&#39; $(jq &#39;.[] | .[].y | .&quot;number of un-used&quot; | .count + 0&#39; input.json); echo 0; } | bc\r\n    18",
                "title": "JQ - parsing field by hierarchy"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1515706939,
                "last_edit_date": 1515706939,
                "creation_date": 1515680392,
                "answer_id": 48209208,
                "question_id": 48205247,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since the JSON is very large, you might want a solution that is overall quite efficient, so it would be worthwhile considering the following:\r\n\r\n    def sigma(s): reduce s as $x (0; .+$x);\r\n    sigam(.[].[].y | .[&quot;number of un-used&quot;] | .count)\r\n\r\nNotice that this also addresses the problem with nulls. To make the solution even more robust, you could sprinkle in some occurrences of post-fix `?` as well.\r\n\r\nFor humomgously large JSON, you might need a streaming solution, but that would be considerably more complicated, though the above def would still be applicable.\r\n",
                "title": "JQ - parsing field by hierarchy"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1515707215,
                "creation_date": 1515707215,
                "answer_id": 48216336,
                "question_id": 48205247,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If the JSON is too large to fit comfortably in memory, then jq&#39;s streaming parser could be used, as illustrated here.\r\n\r\n### Invocation\r\n\r\n    $ jq -n --stream -f program.jq input.json\r\n\r\nNote especially the &quot;-n&quot; option.\r\n\r\n### program.jq\r\n\r\n    def sigma(s): reduce s as $x (0; .+$x);\r\n\r\n    sigma(inputs \r\n          | select(length==2) \r\n          | select(.[0][-3:] == [&quot;y&quot;,&quot;number of un-used&quot;,&quot;count&quot;])\r\n\t      | .[1] )\r\n\t     \r\n",
                "title": "JQ - parsing field by hierarchy"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1515727777,
        "creation_date": 1515667706,
        "last_edit_date": 1515727777,
        "question_id": 48205247,
        "body_markdown": "I have very large json I want to extract sum of data from it using jq.  \r\n\r\nI am trying every possible way but I think I am missing something here..\r\n\r\nMy Json subset:\r\n\r\n    {&quot;main&quot;:\r\n      {&quot;0&quot;: {&quot;x&quot;: {&quot;a&quot;:1}, &quot;y&quot;: {&quot;number of un-used&quot;:{&quot;count&quot;:2} , &quot;z&quot;:2}},\r\n      &quot;1&quot;: {&quot;x&quot;: {&quot;a&quot;:1}, &quot;y&quot;: {&quot;number of un-used&quot;:{&quot;count&quot;:3} , &quot;z&quot;:2}},\r\n      &quot;2&quot;: {&quot;x&quot;: {&quot;a&quot;:1}, &quot;y&quot;: {&quot;number of un-used&quot;:{&quot;count&quot;:4} , &quot;z&quot;:2}},\r\n      &quot;3&quot;: {&quot;x&quot;: {&quot;a&quot;:1}, &quot;y&quot;: {&quot;no un-used&quot;:{&quot;z&quot;:3} , &quot;z&quot;:2}},\r\n      &quot;4&quot;: {&quot;x&quot;: {&quot;a&quot;:1}, &quot;y&quot;: {&quot;no un-used&quot;:{&quot;z&quot;:3} , &quot;z&quot;:2}}},\r\n     &quot;no-main&quot;:\r\n      {&quot;0&quot;: {&quot;x&quot;: {&quot;a&quot;:1}, &quot;y&quot;: {&quot;number of un-used&quot;:{&quot;count&quot;:2} , &quot;z&quot;:2}},\r\n      &quot;1&quot;: {&quot;x&quot;: {&quot;a&quot;:1}, &quot;y&quot;: {&quot;number of un-used&quot;:{&quot;count&quot;:3} , &quot;z&quot;:2}},\r\n      &quot;2&quot;: {&quot;x&quot;: {&quot;a&quot;:1}, &quot;y&quot;: {&quot;number of un-used&quot;:{&quot;count&quot;:4} , &quot;z&quot;:2}},\r\n      &quot;3&quot;: {&quot;x&quot;: {&quot;a&quot;:1}, &quot;y&quot;: {&quot;no un-used&quot;:{&quot;z&quot;:3} , &quot;z&quot;:2}},\r\n      &quot;4&quot;: {&quot;x&quot;: {&quot;a&quot;:1}, &quot;y&quot;: {&quot;no un-used&quot;:{&quot;z&quot;:3} , &quot;z&quot;:2}}}}\r\n\r\nI want the sum of &quot;count&quot; - &quot;number of un-used&quot; that is under &quot;y&quot;.\r\n\r\nMy most successful one is:\r\n    \r\n    cat json | jq &#39;.[] | .[].y | .[&quot;number of un-used&quot;] | .count&#39;\r\n\r\nBut the results contains a lot of &quot;null&quot; because &quot;number of un-used&quot; is not in all of &quot;y&quot; dicts..\r\n\r\nIs it solvable?\r\n",
        "link": "https://stackoverflow.com/questions/48205247/jq-parsing-field-by-hierarchy",
        "title": "JQ - parsing field by hierarchy"
    },
    {
        "tags": [
            "shell",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1515748922,
                "creation_date": 1515748922,
                "answer_id": 48223057,
                "question_id": 48222990,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to separate your first argument from the rest of arguments in your function `mycurl()`. Do a capture of `$1` and use the `shift` once to pass the rest of the arguments as below\r\n\r\n    mycurl() {\r\n        reqMethod=$1; shift\r\n\r\n        curl -X &quot;$reqMethod&quot; \\\r\n             -H &#39;Accept: application/vnd.layer+json; version=3.0&#39; \\\r\n             -H &#39;Authorization: Bearer qFyBLjM9mhOlIwjZCeblbV9CrLZh2rqNzVIlIuf8a07UBj5F&#39; \\\r\n             -H &#39;Content-Type: application/json&#39; \\\r\n             &quot;$@&quot;\r\n    }\r\n\r\nThe reason being `$@` represents all the positional arguments passed to the function script, if you pass it to the `-X` it would be incorrect. So we store the first argument in a variable and the `shift` call will now hold rest of the arguments except `$1` which then can be passed to the acutal `curl`. \r\n\r\nAlso if you are exactly sure of only two arguments to the script, just `$1` for request method and `$2` for the URL to be passed.",
                "title": "Request method as parameter in function not working properly"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1515770550,
        "creation_date": 1515748709,
        "last_edit_date": 1515770550,
        "question_id": 48222990,
        "body_markdown": "Here is a function that executes a GET request for a given URL\r\n\r\n\r\n    mycurl() {\r\n    curl -X GET \\\r\n         -H &#39;Accept: application/vnd.layer+json; version=3.0&#39; \\\r\n    \t -H &#39;Authorization: Bearer qFyBLjM9mhOlIwjZCeblbV9CrLZh2rqNzVIlIuf8a07UBj5F&#39; \\\r\n         -H &#39;Content-Type: application/json&#39; \\\r\n        &quot;$@&quot;}\r\n\r\n    exportsData=$(mycurl https://api.layer.com/apps/9d649224-cde5-11e7-b916-f3d1a15f96fe/exports)\r\n    count=$(jq -r &#39;.|length&#39; &lt;&lt;&lt;&quot;$exportsData&quot;)\r\n    echo $count;\r\n\r\n\r\nThis prints the count once as :\r\n\r\n30\r\n\r\nI am trying to convert the mycurl function to accept request method as a parameter like so\r\n\r\n    mycurl() {\r\n    curl -X &quot;$@&quot; \\\r\n         -H &#39;Accept: application/vnd.layer+json; version=3.0&#39; \\\r\n    \t -H &#39;Authorization: Bearer qFyBLjM9mhOlIwjZCeblbV9CrLZh2rqNzVIlIuf8a07UBj5F&#39; \\\r\n         -H &#39;Content-Type: application/json&#39; \\\r\n        &quot;$@&quot;}\r\n    exportsData=$(mycurl GET https://api.layer.com/apps/9d649224-cde5-11e7-b916-f3d1a15f96fe/exports)\r\n    count=$(jq -r &#39;.|length&#39; &lt;&lt;&lt;&quot;$exportsData&quot;)\r\n    echo $count;\r\n\r\nThe output of the above is \r\n\r\n    curl: (6) Could not resolve host: GET\r\n    100 52280  100 52280    0     0  39425      0  0:00:01  0:00:01 --:--:-- 10742\r\n    30 30\r\n\r\nWhat’s the issue? Why is count being printed twice?\r\n",
        "link": "https://stackoverflow.com/questions/48222990/request-method-as-parameter-in-function-not-working-properly",
        "title": "Request method as parameter in function not working properly"
    },
    {
        "tags": [
            "arrays",
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 544853,
                    "reputation": 3278,
                    "user_id": 6999988,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6b8a483bb8671f8c11a275cf33d9991f?s=256&d=identicon&r=PG",
                    "display_name": "Martin Schneider",
                    "link": "https://stackoverflow.com/users/6999988/martin-schneider"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1515752445,
                "post_id": 48224065,
                "comment_id": 83429701,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1515774491,
                "last_edit_date": 1515774491,
                "creation_date": 1515773847,
                "answer_id": 48230124,
                "question_id": 48224065,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Indeed, using `transpose` allows a simple, one-line solution along the lines you envisioned:\r\n\r\n    ( keys_unsorted, ([.[]] | transpose)[]) | @csv\r\n\r\nWith the sample data, invocation of jq with the -r option yields:\r\n\r\n    \r\n    &quot;latitude&quot;,&quot;longitude&quot;,&quot;drivingDifficultyIndex&quot;,&quot;iconCode&quot;,&quot;observationTimeUtcIso&quot;,&quot;precip1Hour&quot;\r\n    39.582,26.675,0,31,&quot;2016-06-26T00:20:00+0000&quot;,0\r\n    39.582,26.675,34,11,&quot;2016-06-26T01:20:00+0000&quot;,0.1\r\n    39.582,26.675,34,11,&quot;2016-06-26T02:20:00+0000&quot;,0.5",
                "title": "jq: convert JSON file with arrays to CSV - transposed?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1515774491,
        "creation_date": 1515752255,
        "last_edit_date": 1515766079,
        "question_id": 48224065,
        "body_markdown": "I&#39;m trying to use jq to convert a JSON output to CSV. \r\n\r\nHere&#39;s input.json (stripped down a lot - I may have up to 600 array elements, but the same number for each):\r\n\r\n        {\r\n      &quot;latitude&quot;: [39.582, 39.582, 39.582],\r\n      &quot;longitude&quot;: [26.675, 26.675, 26.675],\r\n      &quot;drivingDifficultyIndex&quot;: [0, 34, 34],\r\n      &quot;iconCode&quot;: [31, 11, 11],\r\n      &quot;observationTimeUtcIso&quot;: [&quot;2016-06-26T00:20:00+0000&quot;, &quot;2016-06-26T01:20:00+0000&quot;, &quot;2016-06-26T02:20:00+0000&quot;],\r\n      &quot;precip1Hour&quot;: [0.0, 0.1, 0.5]\r\n    }\r\n\r\nMy best attempt thus far is:\r\n\r\n    jq --raw-output &#39;keys , .[] | @csv&#39;\r\n\r\nwhich makes\r\n\r\n    &quot;drivingDifficultyIndex&quot;,&quot;iconCode&quot;,&quot;latitude&quot;,&quot;longitude&quot;,&quot;observationTimeUtcIso&quot;,&quot;precip1Hour&quot;\r\n    39.582,39.582,39.582\r\n    26.675,26.675,26.675\r\n    0,34,34\r\n    31,11,11\r\n    &quot;2016-06-26T00:20:00+0000&quot;,&quot;2016-06-26T01:20:00+0000&quot;,&quot;2016-06-26T02:20:00+0000&quot;\r\n    0,0.1,0.5\r\n\r\n[https://stackoverflow.com/questions/32960857/how-to-convert-arbirtrary-simple-json-to-csv-using-jq][1] gives some good hints, but I still end up with the data in rows (like above) rather than columns. \r\n\r\nWhat I&#39;m after is this:\r\n\r\n    &quot;latitude&quot;,&quot;longitude&quot;,&quot;drivingDifficultyIndex&quot;,&quot;iconCode&quot;,&quot;observationTimeUtcIso&quot;,&quot;precip1Hour&quot;\r\n    39.582,\t26.675,\t0,\t31,\t\\2016-06-26T00:20:00+0000\\&quot;,\t0\r\n    39.582,\t26.675,\t34,\t11,\t\\&quot;2016-06-26T01:20:00+0000\\&quot;,\t0.1\r\n    39.582,\t26.675,\t34,\t11,\t\\&quot;2016-06-26T02:20:00+0000\\&quot;,\t0.5\r\n\r\nWith up to 600 elements in each array, I need the CSV file to have a separate column for each array; rows 2 downwards need transposing.\r\n\r\nCan someone help jq produce the output I want?\r\n\r\nThanks...\r\n\r\n**Update:** \r\n\r\n    jq --raw-output &#39;keys_unsorted, map(.[0]) , map(.[1]), map(.[2]) |@csv&#39;\r\ngives me what I want, for the example 3 array members above. But how can I get this to work to account for much larger (unknown) number of array elements?\r\n\r\n  [1]: https://stackoverflow.com/questions/32960857/how-to-convert-arbirtrary-simple-json-to-csv-using-jq",
        "link": "https://stackoverflow.com/questions/48224065/jq-convert-json-file-with-arrays-to-csv-transposed",
        "title": "jq: convert JSON file with arrays to CSV - transposed?"
    },
    {
        "tags": [
            "json",
            "utf-8",
            "binary",
            "hex",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1515999427,
                "last_edit_date": 1515999427,
                "creation_date": 1515865602,
                "answer_id": 48242564,
                "question_id": 48240055,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    def hx:\r\n      def hex: [if . &lt; 10 then 48 + . else  55 + . end] | implode ;\r\n      tonumber | &quot;\\(./16 | floor | hex)\\(. % 16 | hex)&quot;;\r\n    \r\n    {&quot;key&quot;:&quot;_\\u00b7_&quot;} | .key | explode | map(hx)\r\n\r\nproduces:\r\n\r\n    [&quot;5F&quot;,&quot;B7&quot;,&quot;5F&quot;]\r\n\r\n### &quot;Raw Bytes&quot; (*caveat emptor*)\r\nSince jq only supports UTF-8 strings, you would have to use some external tool to obtain the &quot;raw bytes&quot;. Maybe this is closer to what you want:\r\n\r\n    jq -nrj &#39;{&quot;key&quot;:&quot;_\\u00b7_&quot;} | .key&#39; | iconv -f utf-8 -t ISO8859-1\r\n\r\nThis produces the three bytes.\r\n\r\nAnd here&#39;s an iconv-free solution:\r\n\r\n    jq -nrj &#39;{&quot;key&quot;:&quot;_\\u00b7_&quot;} | .key&#39; | php -r &#39;print utf8_decode(readline());&#39;",
                "title": "Extract UTF-uncoded binary data from JSON using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1515939002,
                "creation_date": 1515939002,
                "answer_id": 48250402,
                "question_id": 48240055,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**Alternate**\r\n\r\nAddressing the character encoding scenario outside of `jq`:\r\n\r\nThough you didn&#39;t want extra tools, `iconv` and `hexdump` are indeed readily available - I for one frequently lean on `iconv` when I require certain parts of a pipeline to be completely known to me, and `hexdump` when I want control of the formatting of the representation of those parts.\r\n\r\nSo an alternative is:\r\n\r\n    jq -njr &#39;{&quot;key&quot;:&quot;_\\u00b7_&quot;} | .key&#39; | iconv -f utf8 -t UTF-32LE | hexdump -ve &#39;1/1 &quot;%.X&quot;&#39;\r\n\r\nResult:\r\n\r\n`5FB75F`\r\n\r\n\r\n",
                "title": "Extract UTF-uncoded binary data from JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1515999427,
        "creation_date": 1515848074,
        "last_edit_date": 1515900305,
        "question_id": 48240055,
        "body_markdown": "Say I have a JSON with a 0xb7 byte encoded as a UTF codepoint:\r\n\r\n    {&quot;key&quot;:&quot;_\\u00b7_&quot;}\r\n\r\nIf I extract the value of the &quot;key&quot; with jq it keeps the utf8 encoding of this byte which is &quot;c2 b7&quot;:\r\n\r\n    $ echo &#39;{&quot;key&quot;:&quot;_\\u00b7_&quot;}&#39; | ./jq &#39;.key&#39; -r | xxd\r\n    0000000: 5fc2 b75f 0a                             _.._.\r\n\r\n**Is there any jq command that extracts the decoded &quot;5f b7 5f&quot; byte sequence out of this JSON?**\r\n\r\nI can solve this with extra tools like iconv but it&#39;s a bit ugly:\r\n\r\n    $ echo &#39;{&quot;key&quot;:&quot;_\\u00b7_&quot;}&#39; | ./jq &#39;.key&#39; -r \\\r\n          | iconv -f utf8 -t utf32le \\\r\n          | xxd -ps | sed -e &#39;s/000000//g&#39; | xxd -ps -r \\\r\n          | xxd\r\n    0000000: 5fb7 5f0a                                _._.",
        "link": "https://stackoverflow.com/questions/48240055/extract-utf-uncoded-binary-data-from-json-using-jq",
        "title": "Extract UTF-uncoded binary data from JSON using jq"
    },
    {
        "tags": [
            "json",
            "regex",
            "replace",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1515981574,
                "last_edit_date": 1515981574,
                "creation_date": 1515971500,
                "answer_id": 48255102,
                "question_id": 48254985,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This appears to be a case for `walk/1` but I&#39;m not sure whether you want the semantics of `sub` or `gsub`.  For the sake of illustration, let&#39;s use `gsub`:\r\n\r\n    walk(if type == &quot;string&quot; then gsub(&quot;DEV&quot;; &quot;INT&quot;) else . end)\r\n\r\nOf course if you want the key names checked as well, the above would have to be adjusted accordingly.\r\n\r\nIf your jq does not have `walk/1`, then consider upgrading to `master` or include its definition, which is available from https://github.com/stedolan/jq/blob/master/src/builtin.jq",
                "title": "JQ - Replace string in full json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1515981574,
        "creation_date": 1515970473,
        "question_id": 48254985,
        "body_markdown": "guys.\r\n\r\nI need to replace all occurrences of a string with a different string in the whole body of a JSON in JQ. \r\n\r\nSay in the following input JSON I want to replace the string &quot;DEV&quot; with &quot;INT&quot;. How could I do this in JQ?\r\n\r\nInput JSON:\r\n\r\n    {  \r\n       &quot;startIndex&quot;:0,\r\n       &quot;vXPolicies&quot;:[  \r\n          {  \r\n             &quot;policyName&quot;:&quot;DEVXPolicyDEF&quot;,\r\n             &quot;tables&quot;:&quot;DEVX_DE_DEF&quot;             \r\n          },\r\n          {  \r\n             &quot;policyName&quot;:&quot;DEVXPolicyABC&quot;,\r\n             &quot;tables&quot;:&quot;DEVX_DE_ABC&quot;\r\n          }\r\n       ]\r\n    }\r\n\r\nDesired output JSON:\r\n\r\n    {  \r\n       &quot;startIndex&quot;:0,\r\n       &quot;vXPolicies&quot;:[  \r\n          {  \r\n             &quot;policyName&quot;:&quot;INTXPolicyDEF&quot;,\r\n             &quot;tables&quot;:&quot;INTX_DE_DEF&quot;\r\n          },\r\n          {  \r\n             &quot;policyName&quot;:&quot;INTXPolicyABC&quot;,\r\n             &quot;tables&quot;:&quot;INTX_DE_ABC&quot;\r\n          }\r\n       ]\r\n    }\r\n\r\nThank you!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48254985/jq-replace-string-in-full-json",
        "title": "JQ - Replace string in full json"
    },
    {
        "tags": [
            "json",
            "transformation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1516029017,
                "last_edit_date": 1516029017,
                "creation_date": 1516000280,
                "answer_id": 48258369,
                "question_id": 48258020,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One option would be to use the filter:\r\n\r\n    .roles |= if type == &quot;array&quot; then join(&quot;,&quot;) else . end\r\n\r\nIn the first example, this would produce the value: &quot;ADMIN,USER&quot;\r\n\r\nA more robust filter would be:\r\n\r\n    .roles |= if type == &quot;array&quot; then map(tostring)|join(&quot;,&quot;) else . end\r\n\r\nStill more robust would be to use `@csv` in the `then` clause, but this will produce more quotation marks than you might want:\r\n\r\n    &quot;\\&quot;ADMIN\\&quot;,\\&quot;USER\\&quot;&quot;\r\n\r\nSo you might want to consider using @tsv instead; it would produce:\r\n\r\n    &quot;ADMIN\\tUSER&quot;\r\n\r\n",
                "title": "Transform a particular field with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1516029017,
        "creation_date": 1515998239,
        "last_edit_date": 1515998876,
        "question_id": 48258020,
        "body_markdown": "I have a json object with a field which can have a string or an array value.\r\n\r\n    {\r\n      &quot;roles&quot;: [&quot;ADMIN&quot;, &quot;USER&quot;]\r\n      &quot;user_id&quot;: 100,\r\n      &quot;message&quot;: &quot;abc added a user xyz&quot;,\r\n      &quot;level&quot;: &quot;info&quot;,\r\n      &quot;created_at&quot;: &quot;2014-10-12 14:06:37&quot;\r\n    }\r\n    {\r\n      &quot;roles&quot;: &quot;ADMIN&quot;\r\n      &quot;user_id&quot;: 102,\r\n      &quot;message&quot;: &quot;a added a user b&quot;,\r\n      &quot;level&quot;: &quot;info&quot;,\r\n      &quot;created_at&quot;: &quot;2014-10-12 14:06:37&quot;\r\n    }\r\n\r\nI want to transform roles field to a csv, and keep the rest of the fields as is.\r\n\r\n    {\r\n      &quot;roles&quot;: &quot;ADMIN,USER&quot;\r\n      &quot;user_id&quot;: 100,\r\n      &quot;message&quot;: &quot;abc added a user xyz&quot;,\r\n      &quot;level&quot;: &quot;info&quot;,\r\n      &quot;created_at&quot;: &quot;2014-10-12 14:06:37&quot;\r\n    }\r\n    {\r\n      &quot;roles&quot;: &quot;ADMIN&quot;\r\n      &quot;user_id&quot;: 102,\r\n      &quot;message&quot;: &quot;a added a user b&quot;,\r\n      &quot;level&quot;: &quot;info&quot;,\r\n      &quot;created_at&quot;: &quot;2014-10-12 14:06:37&quot;\r\n    }\r\n\r\nI tried reading the documentation, but couldn&#39;t find a construct to just transform a single field. Can this be achieved using Jq?",
        "link": "https://stackoverflow.com/questions/48258020/transform-a-particular-field-with-jq",
        "title": "Transform a particular field with jq"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1516128459,
                "last_edit_date": 1516128459,
                "creation_date": 1516123037,
                "answer_id": 48286580,
                "question_id": 48285020,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq --slurpfile users 1st.json &#39;$users[0].users[0] as $users \r\n         | .info.users |= map(if in($users) then $users[.] else . end)&#39; 2nd.json\r\n\r\nThe output:\r\n\r\n    {\r\n      &quot;info&quot;: {\r\n        &quot;users&quot;: [\r\n          &quot;user1&quot;,\r\n          &quot;user2&quot;,\r\n          &quot;key3&quot;,\r\n          &quot;key4&quot;\r\n        ]\r\n      }\r\n    }\r\n\r\n",
                "title": "jq - parsing&amp; replacement based on key-value pairs within json"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1516232488,
                "last_edit_date": 1516232488,
                "creation_date": 1516127003,
                "answer_id": 48287582,
                "question_id": 48285020,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since .users[0] is a JSON dictionary, it would make sense to use it as such (e.g. for efficiency):\r\n\r\nInvocation:\r\n    jq -c --slurpfile users users.json -f program.jq input.json\r\n\r\nprogram.jq:\r\n\r\n    $users[0].users[0] as $dict\r\n    | .info.users |= map($dict[.] // .)\r\n\r\nOutput:\r\n\r\n    {&quot;info&quot;:{&quot;users&quot;:[&quot;user1&quot;,&quot;user2&quot;,&quot;key3&quot;,&quot;key4&quot;]}}\r\n\r\nNote: the above assumes that the dictionary contains no null or false values, or rather that any such values in the dictionary should be ignored. This avoids the double lookup that would otherwise be required. If this assumption is invalid, then a solution using `has` or `in` (e.g. as provided by RomanPerekhrest) would be appropriate.\r\n\r\n### Solution to supplemental problem\r\n(See &quot;comments&quot;.)\r\n\r\n    $users[0].users[0] as $dict\r\n    | second\r\n    | .info.users |= (map($dict[.] | select(. != null)))\r\n\r\n### sponge\r\nIt is highly inadvisable to use redirection to overwrite an input file.\r\nIf you have or can install `sponge`, then it would be far better to use it.  For further details, see e.g. &quot;What is jq&#39;s equivalent of sed -i?&quot;  in the jq [FAQ][1].\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "jq - parsing&amp; replacement based on key-value pairs within json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1516232488,
        "creation_date": 1516117583,
        "last_edit_date": 1516160134,
        "question_id": 48285020,
        "body_markdown": "I have a json file in the form of a key-value map. For example:\r\n\r\n    {\r\n        &quot;users&quot;:[\r\n        {\r\n            &quot;key1&quot;:&quot;user1&quot;,\r\n            &quot;key2&quot;:&quot;user2&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI have another json file. The values in the second file has to be replaced based on the keys in first file.\r\n\r\nFor example 2nd file is:\r\n\r\n    {\r\n        &quot;info&quot;:\r\n        {\r\n        &quot;users&quot;:[&quot;key1&quot;,&quot;key2&quot;,&quot;key3&quot;,&quot;key4&quot;]\r\n        }\r\n    }\r\n\r\nThis second file should be replaced with \r\n\r\n    {\r\n        &quot;info&quot;:\r\n        {\r\n        &quot;users&quot;:[&quot;user1&quot;,&quot;user2&quot;,&quot;key3&quot;,&quot;key4&quot;]\r\n        }\r\n    }\r\n\r\nBecause the value of key1 in first file is user1. this could be done with any python program, but I am learning jq and would like to try if it is possible with jq itself. I tried different combinations with reading file using slurpfile, then select &amp; walk etc. But couldn&#39;t arrive at the required solution.\r\n\r\nAny suggestions for the same will be appreciated.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48285020/jq-parsing-replacement-based-on-key-value-pairs-within-json",
        "title": "jq - parsing&amp; replacement based on key-value pairs within json"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "influxdb"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1777232,
                    "reputation": 22015,
                    "user_id": 1620779,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://i.sstatic.net/dlgGb.png?s=256",
                    "display_name": "sjsam",
                    "link": "https://stackoverflow.com/users/1620779/sjsam"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516164427,
                "post_id": 48293564,
                "comment_id": 83572532,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1516175925,
                "last_edit_date": 1516175925,
                "creation_date": 1516165973,
                "answer_id": 48293995,
                "question_id": 48293564,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Given the JSON shown, the jq query:\r\n\r\n    .results[].series[].values[]\r\n\r\nproduces:\r\n\r\n    [\r\n      &quot;2018-01-17T04:15:30Z&quot;,\r\n      690.1\r\n    ]\r\n\r\nThis seems to be the output you want, but from the point of view of someone who is not familiar with influxdb, the requirements seem very opaque, so you might want to consider a variant, such as:\r\n\r\n    .results[-1].series[-1].values[-1]\r\n\r\nwhich in this case produces the same result, as it happens.\r\n\r\nIf you just want the atomic values, you could simply append `[]` to either of the queries above.\r\n",
                "title": "Retrieve one (last) value from influxdb"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1516168574,
                "last_edit_date": 1516168574,
                "creation_date": 1516167883,
                "answer_id": 48294317,
                "question_id": 48293564,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Pipe that curl to the `jq` below \r\n\r\n    $ your_curl_stuff_here | jq &#39;.results[].series[]|.name,.values[0][]&#39;\r\n    &quot;grid&quot;\r\n    &quot;2018-01-17T04:15:30Z&quot;\r\n    690.1\r\n\r\nThe results could be stored into a bash array and used later.\r\n\r\n    $ results=( $(your_curl_stuff_here | jq &#39;.results[].series[]|.name,.values[0][]&#39;) )\r\n    $ echo &quot;${results[@]}&quot;\r\n    &quot;grid&quot; &quot;2018-01-17T04:15:30Z&quot; 690.1\r\n    # Individual values could be accessed using &quot;${results[0]}&quot; and so, mind quotes\r\n\r\nAll good &lt;kbd&gt;:-)&lt;/kbd&gt;\r\n\r\n",
                "title": "Retrieve one (last) value from influxdb"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1516175925,
        "creation_date": 1516163002,
        "last_edit_date": 1516175720,
        "question_id": 48293564,
        "body_markdown": "I&#39;m trying to retrieve the last value inserted into a table in influxdb. What I need to do is then post it to another system via HTTP.\r\n\r\nI&#39;d like to do all this in a bash script, but I&#39;m open to Python also.\r\n\r\n     $ curl -sG &#39;https://influx.server:8086/query&#39; --data-urlencode &quot;db=iotaWatt&quot; --data-urlencode &quot;q=SELECT LAST(\\&quot;value\\&quot;) FROM \\&quot;grid\\&quot; ORDER BY time DESC&quot; | jq -r\r\n\r\n    {\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;statement_id&quot;: 0,\r\n          &quot;series&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;grid&quot;,\r\n              &quot;columns&quot;: [\r\n                &quot;time&quot;,\r\n                &quot;last&quot;\r\n              ],\r\n              &quot;values&quot;: [\r\n                [\r\n                  &quot;2018-01-17T04:15:30Z&quot;,\r\n                  690.1\r\n                ]\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nWhat I&#39;m struggling with is getting this value into a clean format I can use. I don&#39;t really want to use sed, and I&#39;ve tried jq but it complains the data is a string and not an index:\r\n\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index array with string &quot;series&quot;\r\n\r\nAnyone have a good suggestion?\r\n",
        "link": "https://stackoverflow.com/questions/48293564/retrieve-one-last-value-from-influxdb",
        "title": "Retrieve one (last) value from influxdb"
    },
    {
        "tags": [
            "arrays",
            "json",
            "sorting",
            "edit",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1516208631,
                "creation_date": 1516208631,
                "answer_id": 48306397,
                "question_id": 48306264,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Aha, this seems to work:\r\n\r\n    $ jq &lt; users.json &#39;map(.items |= (. // [])) | map(.items |= sort)&#39;",
                "title": "How do I sort a possibly-absent array with jq?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1516215921,
                "creation_date": 1516215921,
                "answer_id": 48308247,
                "question_id": 48306264,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can preserve the original structure if you map the values of the object using `map_values`. Then from there, if you want to preserve the absence of the items array, just check for it beforehand.\r\n\r\n    map_values(if has(&quot;items&quot;) then .items |= sort else . end)\r\n\r\nOtherwise if you don&#39;t care about adding the empty items:\r\n\r\n    map_values(.items |= (. // [] | sort))",
                "title": "How do I sort a possibly-absent array with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1516557238,
        "creation_date": 1516208194,
        "last_edit_date": 1516557238,
        "question_id": 48306264,
        "body_markdown": "Given the following JSON:\r\n\r\n    {\r\n      &quot;alice&quot;: { &quot;items&quot;: [&quot;foo&quot;, &quot;bar&quot;] },\r\n      &quot;bob&quot;: { &quot;items&quot;: [&quot;bar&quot;, &quot;foo&quot;] },\r\n      &quot;charlie&quot;: { &quot;items&quot;: [&quot;foo&quot;, &quot;bar&quot;] }\r\n    }\r\n\r\nI can sort the `items` array as follows:\r\n\r\n    $ jq &lt; users.json &#39;map(.items |= sort)&#39;\r\n    [\r\n      {\r\n        &quot;items&quot;: [\r\n          &quot;bar&quot;,\r\n          &quot;foo&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;items&quot;: [\r\n          &quot;bar&quot;,\r\n          &quot;foo&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;items&quot;: [\r\n          &quot;bar&quot;,\r\n          &quot;foo&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nHowever, this crashes if any user doesn&#39;t have `items`:\r\n\r\n    {\r\n      &quot;alice&quot;: { &quot;items&quot;: [&quot;foo&quot;, &quot;bar&quot;] },\r\n      &quot;bob&quot;: { &quot;items&quot;: [&quot;bar&quot;, &quot;foo&quot;] },\r\n      &quot;charlie&quot;: {}\r\n    }\r\n\r\nTrying to sort it gives an error.\r\n\r\n    $ jq &lt; users.json &#39;map(.items |= sort)&#39;\r\n    jq: error (at &lt;stdin&gt;:5): null (null) cannot be sorted, as it is not an array\r\n\r\nHow can I obtain the following?\r\n\r\n    $ jq &lt; users.json SOMETHING\r\n    [\r\n      {\r\n        &quot;items&quot;: [\r\n          &quot;bar&quot;,\r\n          &quot;foo&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;items&quot;: [\r\n          &quot;bar&quot;,\r\n          &quot;foo&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;items&quot;: [\r\n        ]\r\n      }\r\n    ]\r\n\r\nI&#39;ve tried using `// []` but I&#39;m not sure how to do this in relation to sorting.",
        "link": "https://stackoverflow.com/questions/48306264/how-do-i-sort-a-possibly-absent-array-with-jq",
        "title": "How do I sort a possibly-absent array with jq?"
    },
    {
        "tags": [
            "json",
            "jq",
            "pretty-print",
            "jsonlint"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1516641381,
                "last_edit_date": 1516641381,
                "creation_date": 1516247096,
                "answer_id": 48313511,
                "question_id": 48313302,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. The sample is not valid JSON.  \r\n\r\n2. jq can be used to pretty-print valid JSON, though there are some important caveats, mainly about numbers.  For example:\r\n\r\n        $ jq . &lt;&lt;&lt; &#39;{ &quot;abc&quot;: { &quot;name&quot;: &quot;John&quot;, &quot;address&quot;: &quot;USA&quot; }, &quot;xyz&quot;: { &quot;name&quot;: &quot;Robert&quot;, &quot;address&quot;: &quot;Canada&quot; } }&#39;  \r\n        {\r\n          &quot;abc&quot;: {\r\n            &quot;name&quot;: &quot;John&quot;,\r\n            &quot;address&quot;: &quot;USA&quot;\r\n          },\r\n          &quot;xyz&quot;: {\r\n            &quot;name&quot;: &quot;Robert&quot;,\r\n            &quot;address&quot;: &quot;Canada&quot;\r\n          }\r\n        }\r\n\r\n3. See the jq [FAQ][1] for information about converting not-quite-valid JSON to JSON -- search for `not-quite-valid`. \r\n\r\n4. At least one of the tools mentioned in the above-referenced section in the jq FAQ (jsonlint) will not only convert single-quoted quasi-JSON to JSON, but also pretty-print it.\r\n\r\n5. In the example you gave, you could use `sed` or even `tr` in conjunction with jq:\r\n\r\n        echo &quot;{ &#39;abc&#39;: { &#39;name&#39;: &#39;John&#39;, &#39;address&#39;: &#39;USA&#39; }, &#39;xyz&#39;: { &#39;name&#39;: &#39;Robert&#39;, &#39;address&#39;: &#39;Canada&#39; } }&quot; |\r\n          tr &quot;&#39;&quot; &#39;&quot;&#39; | jq .\r\n        {\r\n          &quot;abc&quot;: {\r\n            &quot;name&quot;: &quot;John&quot;,\r\n            &quot;address&quot;: &quot;USA&quot;\r\n          },\r\n          &quot;xyz&quot;: {\r\n            &quot;name&quot;: &quot;Robert&quot;,\r\n            &quot;address&quot;: &quot;Canada&quot;\r\n          }\r\n        }\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ\r\n\r\n",
                "title": "how to prettyprint a single-quoted JSON file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1516641381,
        "creation_date": 1516245598,
        "last_edit_date": 1516641161,
        "question_id": 48313302,
        "body_markdown": "{ &#39;abc&#39;: { &#39;name&#39;: &#39;John&#39;, &#39;address&#39;: &#39;USA&#39; }, &#39;xyz&#39;: { &#39;name&#39;: &#39;Robert&#39;, &#39;address&#39;: &#39;Canada&#39; } }",
        "link": "https://stackoverflow.com/questions/48313302/how-to-prettyprint-a-single-quoted-json-file-using-jq",
        "title": "how to prettyprint a single-quoted JSON file using jq"
    },
    {
        "tags": [
            "sql",
            "json",
            "group-by",
            "aggregate-functions",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1516283390,
                "last_edit_date": 1516283390,
                "creation_date": 1516281745,
                "answer_id": 48322406,
                "question_id": 48321235,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Extended **`jq`** solution:\r\n\r\nCustom **`count()`** function:\r\n\r\n    jq -sc &#39;def count($k): group_by(.[$k])[] | length as $l | .[0] \r\n                           | .pets_count = $l \r\n                           | del(.pet_id, .pet, .litter); \r\n            count(&quot;owner_id&quot;)&#39; source.data\r\nThe output:\r\n\r\n    {&quot;owner_id&quot;:1,&quot;owner&quot;:&quot;Adams&quot;,&quot;age&quot;:25,&quot;pets_count&quot;:2}\r\n    {&quot;owner_id&quot;:2,&quot;owner&quot;:&quot;Baker&quot;,&quot;age&quot;:55,&quot;pets_count&quot;:1}\r\n    {&quot;owner_id&quot;:3,&quot;owner&quot;:&quot;Clark&quot;,&quot;age&quot;:40,&quot;pets_count&quot;:1}\r\n    {&quot;owner_id&quot;:4,&quot;owner&quot;:&quot;Davis&quot;,&quot;age&quot;:31,&quot;pets_count&quot;:3}\r\n\r\n\r\n----------\r\nCustom **`sum()`** function:\r\n\r\n    jq -sc &#39;def sum($k): group_by(.[$k])[] | map(.litter) as $litters | .[0] \r\n                         | . + {litter_total: $litters | add, litter_max: $litters | max} \r\n                         | del(.pet_id, .pet, .litter); \r\n            sum(&quot;owner_id&quot;)&#39; source.data\r\nThe output:\r\n\r\n    {&quot;owner_id&quot;:1,&quot;owner&quot;:&quot;Adams&quot;,&quot;age&quot;:25,&quot;litter_total&quot;:6,&quot;litter_max&quot;:4}\r\n    {&quot;owner_id&quot;:2,&quot;owner&quot;:&quot;Baker&quot;,&quot;age&quot;:55,&quot;litter_total&quot;:3,&quot;litter_max&quot;:3}\r\n    {&quot;owner_id&quot;:3,&quot;owner&quot;:&quot;Clark&quot;,&quot;age&quot;:40,&quot;litter_total&quot;:4,&quot;litter_max&quot;:4}\r\n    {&quot;owner_id&quot;:4,&quot;owner&quot;:&quot;Davis&quot;,&quot;age&quot;:31,&quot;litter_total&quot;:9,&quot;litter_max&quot;:4}\r\n\r\n\r\n----------\r\nCustom **`array_agg()`** function:\r\n\r\n    jq -sc &#39;def array_agg($k): group_by(.[$k])[] | map(.pet) as $pets | .[0] \r\n                               | .pets = $pets | del(.pet_id, .pet, .litter); \r\n            array_agg(&quot;owner_id&quot;)&#39; source.data\r\nThe output:\r\n\r\n    {&quot;owner_id&quot;:1,&quot;owner&quot;:&quot;Adams&quot;,&quot;age&quot;:25,&quot;pets&quot;:[&quot;Bella&quot;,&quot;Lucy&quot;]}\r\n    {&quot;owner_id&quot;:2,&quot;owner&quot;:&quot;Baker&quot;,&quot;age&quot;:55,&quot;pets&quot;:[&quot;Daisy&quot;]}\r\n    {&quot;owner_id&quot;:3,&quot;owner&quot;:&quot;Clark&quot;,&quot;age&quot;:40,&quot;pets&quot;:[&quot;Molly&quot;]}\r\n    {&quot;owner_id&quot;:4,&quot;owner&quot;:&quot;Davis&quot;,&quot;age&quot;:31,&quot;pets&quot;:[&quot;Lola&quot;,&quot;Sadie&quot;,&quot;Luna&quot;]}\r\n\r\n",
                "title": "SQL-style GROUP BY aggregate functions in jq (COUNT, SUM and etc)"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1532112546,
                "last_edit_date": 1532112546,
                "creation_date": 1516304323,
                "answer_id": 48329078,
                "question_id": 48321235,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a nice exercise, but SO is not a programming service, so I will focus here on some key concepts for generic solutions in jq that are efficient, even for very large collections.\r\n\r\n### GROUPS_BY\r\n\r\nThe key to efficiency here is avoiding the built-in `group_by`, as it requires sorting.  Since jq is fundamentally stream-oriented, the following definition of `GROUPS_BY` is likewise stream-oriented. It takes advantage of the efficiency of key-based lookups, while avoiding calling `tojson` on strings:\r\n\r\n    # emit a stream of the groups defined by f\r\n    def GROUPS_BY(stream; f): \r\n      reduce stream as $x ({};\r\n         ($x|f) as $s\r\n         | ($s|type) as $t\r\n         | (if $t == &quot;string&quot; then $s else ($s|tojson) end) as $y\r\n         | .[$t][$y] += [$x] )\r\n       | .[][] ;\r\n\r\n### `distinct` and `count_distinct`\r\n\r\n    # Emit an array of the distinct entities in `stream`, without sorting\r\n    def distinct(stream): \r\n      reduce stream as $x ({};\r\n          ($x|type) as $t\r\n          | (if $t == &quot;string&quot; then $x else ($x|tojson) end) as $y\r\n          | if (.[$t] | has($y)) then . else .[$t][$y] += [$x] end )\r\n       | [.[][]] | add ;\r\n\r\n\r\n    # Emit the number of distinct items in the given stream\r\n    def count_distinct(stream):\r\n       def sum(s): reduce s as $x (0;.+$x);\r\n       reduce stream as $x ({};\r\n           ($x|type) as $t\r\n           | (if $t == &quot;string&quot; then $x else ($x|tojson) end) as $y\r\n           | .[$t][$y] = 1 )\r\n       | sum( .[][] ) ;\r\n\r\n### Convenience function\r\n\r\n    def owner: {owner_id,owner,age};\r\n\r\n### Example: &quot;COUNT the number of pets per owner&quot;\r\n\r\n    GROUPS_BY(inputs; .owner_id)\r\n    | (.[0] | owner) + {pets_count: count_distinct(.[]|.pet_id)}\r\n\r\nInvocation: jq -nc -f program1.jq input.json\r\n\r\nOutput:\r\n\r\n    {&quot;owner_id&quot;:1,&quot;owner&quot;:&quot;Adams&quot;,&quot;age&quot;:25,&quot;pets_count&quot;:2}\r\n    {&quot;owner_id&quot;:2,&quot;owner&quot;:&quot;Baker&quot;,&quot;age&quot;:55,&quot;pets_count&quot;:1}\r\n    {&quot;owner_id&quot;:3,&quot;owner&quot;:&quot;Clark&quot;,&quot;age&quot;:40,&quot;pets_count&quot;:1}\r\n    {&quot;owner_id&quot;:4,&quot;owner&quot;:&quot;Davis&quot;,&quot;age&quot;:31,&quot;pets_count&quot;:3}\r\n\r\n### Example: &quot;SUM up the number of whelps per owner and get their MAX&quot;\r\n\r\n    GROUPS_BY(inputs; .owner_id)\r\n    | (.[0] | owner)\r\n      + {litter_total: (map(.litter) | add)}\r\n      + {litter_max:  (map(.litter) | max)}\r\n   \r\nInvocation: jq -nc -f program2.jq input.json\r\n   \r\nOutput: as given.\r\n\r\n### Example: &quot;ARRAY_AGG pets per owner&quot;\r\n\r\n    GROUPS_BY(inputs; .owner_id)\r\n    | (.[0] | owner) + {pets: distinct(.[]|.pet)}\r\n\r\nInvocation: jq -nc -f program3.jq input.json\r\n\r\nOutput:\r\n\r\n    {&quot;owner_id&quot;:1,&quot;owner&quot;:&quot;Adams&quot;,&quot;age&quot;:25,&quot;pets&quot;:[&quot;Bella&quot;,&quot;Lucy&quot;]}\r\n    {&quot;owner_id&quot;:2,&quot;owner&quot;:&quot;Baker&quot;,&quot;age&quot;:55,&quot;pets&quot;:[&quot;Daisy&quot;]}\r\n    {&quot;owner_id&quot;:3,&quot;owner&quot;:&quot;Clark&quot;,&quot;age&quot;:40,&quot;pets&quot;:[&quot;Molly&quot;]}\r\n    {&quot;owner_id&quot;:4,&quot;owner&quot;:&quot;Davis&quot;,&quot;age&quot;:31,&quot;pets&quot;:[&quot;Lola&quot;,&quot;Sadie&quot;,&quot;Luna&quot;]}",
                "title": "SQL-style GROUP BY aggregate functions in jq (COUNT, SUM and etc)"
            },
            {
                "up_vote_count": 11,
                "is_accepted": false,
                "score": 11,
                "last_activity_date": 1587665246,
                "creation_date": 1587665246,
                "answer_id": 61394090,
                "question_id": 48321235,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an alternative, not using any custom functions with basic JQ. (I took the liberty to get rid of redundant parts of the question)\r\n\r\n**Count**\r\n```\r\nIn&gt; jq -s &#39;group_by(.owner_id) |  map({ owner_id: .[0].owner_id, count: map(.pet) | length})&#39;\r\nOut&gt;[{&quot;owner_id&quot;: &quot;1&quot;,&quot;pets_count&quot;: 2}, ...]\r\n```\r\n\r\n**Sum**\r\n```\r\nIn&gt; jq -s &#39;group_by(.owner_id) | map({owner_id: .[0].owner_id, sum: map(.litter) | add})&#39;\r\nOut&gt; [{&quot;owner_id&quot;: &quot;1&quot;,&quot;sum&quot;: 6}, ...]\r\n```\r\n\r\n**Max**\r\n```\r\nIn&gt; jq -s &#39;group_by(.owner_id) | map({owner_id: .[0].owner_id, max: map(.litter) | max})&#39;\r\nOut&gt; [{&quot;owner_id&quot;: &quot;1&quot;,&quot;max&quot;: 4}, ...]\r\n```\r\n\r\n**Aggregate**\r\n```\r\nIn&gt; jq -s &#39;group_by(.owner_id) | map({owner_id: .[0].owner_id, agg: map(.pet) })&#39;\r\nOut&gt; [{&quot;owner_id&quot;: &quot;1&quot;,&quot;agg&quot;: [&quot;Bella&quot;,&quot;Lucy&quot;]}, ...]\r\n```\r\nSure, these might not be the most efficient implementations, but they show nicely how to implement custom functions oneself. All that changes between the different functions is inside the last `map` and the function after the pipe `|` (`length`, `add`, `max`)\r\n\r\nThe first map iterates over the different groups, taking the name from the first item, and using map again to iterate over the same-group items. Not as pretty as SQL, but not terribly more complicated.\r\n\r\nI learned JQ today, and managed to do this already, so this should be encouraging for anyone getting started. JQ is neither like sed nor like SQL, but not terribly hard either.",
                "title": "SQL-style GROUP BY aggregate functions in jq (COUNT, SUM and etc)"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 14,
        "last_activity_date": 1587665246,
        "creation_date": 1516278069,
        "last_edit_date": 1517126847,
        "question_id": 48321235,
        "body_markdown": "Similar questions asked here before:\r\n\r\nCount items for a single key:  https://stackoverflow.com/questions/45170897/jq-count-the-number-of-items-in-json-by-a-specific-key\r\n\r\nCalculate the sum of object values:\r\nhttps://stackoverflow.com/questions/28484534/how-do-i-sum-the-values-in-an-array-of-maps-in-jq\r\n\r\n# Question\r\n\r\nHow to emulate the COUNT aggregate function which should behave similarly to its SQL original? Let&#39;s extend this question even more to include other regular SQL functions:\r\n\r\n - COUNT\r\n - SUM / MAX/ MIN / AVG\r\n - ARRAY_AGG\r\n\r\nThe last one is not a standard SQL function - it&#39;s from PostgreSQL but is quite useful.\r\n\r\nAt input comes a stream of valid JSON objects. For demonstration let&#39;s pick a simple story of owners and their pets.\r\n\r\n# Model and data\r\n\r\nBase relation: **Owner**\r\n\r\n    id name  age\r\n     1 Adams  25\r\n     2 Baker  55\r\n     3 Clark  40\r\n     4 Davis  31\r\n\r\nBase relation: **Pet**\r\n\r\n    id name  litter owner_id\r\n    10 Bella      4        1\r\n    20 Lucy       2        1\r\n    30 Daisy      3        2\r\n    40 Molly      4        3\r\n    50 Lola       2        4\r\n    60 Sadie      4        4\r\n    70 Luna       3        4\r\n\r\n# Source\r\n\r\nFrom above we get a derivative relation **Owner_Pet** (a result of SQL JOIN of the above relations) presented in JSON format for our jq queries (**the source data**):\r\n\r\n&lt;!-- language: json --&gt;\r\n\r\n    { &quot;owner_id&quot;: 1, &quot;owner&quot;: &quot;Adams&quot;, &quot;age&quot;: 25, &quot;pet_id&quot;: 10, &quot;pet&quot;: &quot;Bella&quot;, &quot;litter&quot;: 4 }\r\n    { &quot;owner_id&quot;: 1, &quot;owner&quot;: &quot;Adams&quot;, &quot;age&quot;: 25, &quot;pet_id&quot;: 20, &quot;pet&quot;: &quot;Lucy&quot;,  &quot;litter&quot;: 2 }\r\n    { &quot;owner_id&quot;: 2, &quot;owner&quot;: &quot;Baker&quot;, &quot;age&quot;: 55, &quot;pet_id&quot;: 30, &quot;pet&quot;: &quot;Daisy&quot;, &quot;litter&quot;: 3 }\r\n    { &quot;owner_id&quot;: 3, &quot;owner&quot;: &quot;Clark&quot;, &quot;age&quot;: 40, &quot;pet_id&quot;: 40, &quot;pet&quot;: &quot;Molly&quot;, &quot;litter&quot;: 4 }\r\n    { &quot;owner_id&quot;: 4, &quot;owner&quot;: &quot;Davis&quot;, &quot;age&quot;: 31, &quot;pet_id&quot;: 50, &quot;pet&quot;: &quot;Lola&quot;,  &quot;litter&quot;: 2 }\r\n    { &quot;owner_id&quot;: 4, &quot;owner&quot;: &quot;Davis&quot;, &quot;age&quot;: 31, &quot;pet_id&quot;: 60, &quot;pet&quot;: &quot;Sadie&quot;, &quot;litter&quot;: 4 }\r\n    { &quot;owner_id&quot;: 4, &quot;owner&quot;: &quot;Davis&quot;, &quot;age&quot;: 31, &quot;pet_id&quot;: 70, &quot;pet&quot;: &quot;Luna&quot;,  &quot;litter&quot;: 3 }\r\n\r\n# Requests\r\n\r\nHere are sample requests and their expected output:\r\n\r\n - COUNT the number of pets per owner:\r\n\r\n&lt;!-- language: json --&gt;\r\n\r\n    { &quot;owner_id&quot;: 1, &quot;owner&quot;: &quot;Adams&quot;, &quot;age&quot;: 25, &quot;pets_count&quot;: 2 }\r\n    { &quot;owner_id&quot;: 2, &quot;owner&quot;: &quot;Baker&quot;, &quot;age&quot;: 55, &quot;pets_count&quot;: 1 }\r\n    { &quot;owner_id&quot;: 3, &quot;owner&quot;: &quot;Clark&quot;, &quot;age&quot;: 40, &quot;pets_count&quot;: 1 }\r\n    { &quot;owner_id&quot;: 4, &quot;owner&quot;: &quot;Davis&quot;, &quot;age&quot;: 31, &quot;pets_count&quot;: 3 }\r\n\r\n - SUM up the number of whelps per owner **and** get their MAX (MIN/AVG):\r\n\r\n&lt;!-- language: json --&gt;\r\n\r\n    { &quot;owner_id&quot;: 1, &quot;owner&quot;: &quot;Adams&quot;, &quot;age&quot;: 25, &quot;litter_total&quot;: 6, &quot;litter_max&quot;: 4 }\r\n    { &quot;owner_id&quot;: 2, &quot;owner&quot;: &quot;Baker&quot;, &quot;age&quot;: 55, &quot;litter_total&quot;: 3, &quot;litter_max&quot;: 3 }\r\n    { &quot;owner_id&quot;: 3, &quot;owner&quot;: &quot;Clark&quot;, &quot;age&quot;: 40, &quot;litter_total&quot;: 4, &quot;litter_max&quot;: 4 }\r\n    { &quot;owner_id&quot;: 4, &quot;owner&quot;: &quot;Davis&quot;, &quot;age&quot;: 31, &quot;litter_total&quot;: 9, &quot;litter_max&quot;: 4 }\r\n\r\n - ARRAY_AGG pets per owner:\r\n\r\n&lt;!-- language: json --&gt;\r\n\r\n    { &quot;owner_id&quot;: 1, &quot;owner&quot;: &quot;Adams&quot;, &quot;age&quot;: 25, &quot;pets&quot;: [ &quot;Bella&quot;, &quot;Lucy&quot; ] }\r\n    { &quot;owner_id&quot;: 2, &quot;owner&quot;: &quot;Baker&quot;, &quot;age&quot;: 55, &quot;pets&quot;: [ &quot;Daisy&quot; ] }\r\n    { &quot;owner_id&quot;: 3, &quot;owner&quot;: &quot;Clark&quot;, &quot;age&quot;: 40, &quot;pets&quot;: [ &quot;Molly&quot; ] }\r\n    { &quot;owner_id&quot;: 4, &quot;owner&quot;: &quot;Davis&quot;, &quot;age&quot;: 31, &quot;pets&quot;: [ &quot;Lola&quot;, &quot;Sadie&quot;, &quot;Luna&quot; ] }\r\n",
        "link": "https://stackoverflow.com/questions/48321235/sql-style-group-by-aggregate-functions-in-jq-count-sum-and-etc",
        "title": "SQL-style GROUP BY aggregate functions in jq (COUNT, SUM and etc)"
    },
    {
        "tags": [
            "json",
            "amazon-ec2",
            "command-line",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516287105,
                "post_id": 48322962,
                "comment_id": 83633386,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 58377,
                    "reputation": 271975,
                    "user_id": 174777,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/6PnNW.jpg?s=256",
                    "display_name": "John Rotenstein",
                    "link": "https://stackoverflow.com/users/174777/john-rotenstein"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1516306487,
                "post_id": 48322962,
                "comment_id": 83644893,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1527525319,
                "last_edit_date": 1527525319,
                "creation_date": 1516311422,
                "answer_id": 48330719,
                "question_id": 48322962,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can easily eliminate the calls to `jq -s` by wrapping expressions as appropriately in square brackets, or maybe better, using `map`.\r\n\r\nFor example, your last pair of jq calls can be simplified to:\r\n\r\n    jq &#39;group_by(.iname) | map({(.[0].iname): [.[] | .ip]})&#39;\r\n\r\nThe following should allow you to reduce the four calls to one:\r\n\r\n    [.Reservations[]\r\n     | .Instances[]\r\n     | (.Tags | { &quot;iname&quot;: ( map ( select(.Value | contains(&quot;my-vm&quot;)))[] | .Value ) } )\r\n        + ( { &quot;ip&quot;: ( .NetworkInterfaces[].PrivateIpAddress) } ) ]\r\n    | group_by(.iname) | map({(.[0].iname): [.[] | .ip]})\r\n\r\nHowever, I would advise against using `contains` here, unless you fully understand the complications.\r\n",
                "title": "Parsing aws ec2 describe-instances to get all private ip addresses"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1527542074,
                "last_edit_date": 1527542074,
                "creation_date": 1527541643,
                "answer_id": 50573411,
                "question_id": 48322962,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Before you go into trying to simplify your jq calls, I think it would be more beneficial to first look at the source data and how it relates to the result you want.\r\n\r\nIgnoring a lot of the other details in the data, I think we can agree that your data looks sorta like this:\r\n\r\n    {\r\n        &quot;Reservations&quot;: [\r\n            {\r\n                &quot;Instances&quot;: [\r\n                    {\r\n                        &quot;NetworkInterfaces&quot;: [\r\n                            { &quot;PrivateIpAddress&quot;: &quot;10.11.2.145&quot; },\r\n                            { &quot;PrivateIpAddress&quot;: &quot;10.11.1.146&quot; },\r\n                            { &quot;PrivateIpAddress&quot;: &quot;10.11.10.144&quot; }\r\n                        ],\r\n                        &quot;Tags&quot;: [\r\n                            { &quot;Key&quot;: &quot;Name&quot;, &quot;Value&quot;: &quot;my-vm-b&quot; }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;NetworkInterfaces&quot;: [\r\n                            { &quot;PrivateIpAddress&quot;: &quot;10.11.1.9&quot; },\r\n                            { &quot;PrivateIpAddress&quot;: &quot;10.11.10.125&quot; },\r\n                            { &quot;PrivateIpAddress&quot;: &quot;10.11.2.85&quot; }\r\n                        ],\r\n                        &quot;Tags&quot;: [\r\n                            { &quot;Key&quot;: &quot;Name&quot;, &quot;Value&quot;: &quot;my-vm-a&quot; }\r\n                        ]\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\r\nWith something that looks like this, your jq query can simply be:\r\n\r\n    [.Reservations[].Instances[] |\r\n        {\r\n            (.Tags|from_entries.Name): [.NetworkInterfaces[].PrivateIpAddress]\r\n        }\r\n    ]\r\n\r\nNo intermediate results needed. Just a few things of note here.\r\n\r\n* The tags are already an array of key/value pairs, you can easily read values from here converting them to an object first using `from_entries`\r\n* You are selecting instances based on an existence of a tag value containing `&quot;my-vm&quot;`. I&#39;m not sure you even need to do this, I don&#39;t know what your data looks like but they are likely in a fixed name so you should just use that name.",
                "title": "Parsing aws ec2 describe-instances to get all private ip addresses"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1527542074,
        "creation_date": 1516283559,
        "question_id": 48322962,
        "body_markdown": "Two of my EC2 instances have 3 IPs each. I managed to successfully grab a list of JSON objects:\r\n\r\n    aws ec2 describe-instances | jq &#39;.Reservations[] | .Instances[] | (.Tags | { &quot;iname&quot;: ( map ( select(.Value | contains(&quot;my-vm&quot;)))[] | .Value ) } ) + ( { &quot;ip&quot;: ( .NetworkInterfaces[].PrivateIpAddress) } )&#39; | jq -s .\r\n\r\nGiving me the following result:\r\n\r\n    [\r\n      {\r\n        &quot;iname&quot;: &quot;my-vm-b&quot;,\r\n        &quot;ip&quot;: &quot;10.11.2.145&quot;\r\n      },\r\n      {\r\n        &quot;iname&quot;: &quot;my-vm-b&quot;,\r\n        &quot;ip&quot;: &quot;10.11.1.146&quot;\r\n      },\r\n      {\r\n        &quot;iname&quot;: &quot;my-vm-b&quot;,\r\n        &quot;ip&quot;: &quot;10.11.10.144&quot;\r\n      },\r\n      {\r\n        &quot;iname&quot;: &quot;my-vm-a&quot;,\r\n        &quot;ip&quot;: &quot;10.11.1.9&quot;\r\n      },\r\n      {\r\n        &quot;iname&quot;: &quot;my-vm-a&quot;,\r\n        &quot;ip&quot;: &quot;10.11.10.125&quot;\r\n      },\r\n      {\r\n        &quot;iname&quot;: &quot;my-vm-a&quot;,\r\n        &quot;ip&quot;: &quot;10.11.2.85&quot;\r\n      }\r\n    ]\r\n\r\nand then I added to the command the following:\r\n\r\n    ... | jq &#39; group_by(.iname)[] | {(.[0].iname): [.[] | .ip]}&#39; | jq -s .\r\n\r\nTo finally get the list of objects the way I wanted:\r\n\r\n    [\r\n      {\r\n        &quot;my-vm-a&quot;: [\r\n          &quot;10.11.1.9&quot;,\r\n          &quot;10.11.10.125&quot;,\r\n          &quot;10.11.2.85&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;my-vm-b&quot;: [\r\n          &quot;10.11.2.145&quot;,\r\n          &quot;10.11.1.146&quot;,\r\n          &quot;10.11.10.144&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nNotice I had to call jq like 4 times. I know I must be doing something wrong so I was wondering if I could do it with a single jq call.\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/48322962/parsing-aws-ec2-describe-instances-to-get-all-private-ip-addresses",
        "title": "Parsing aws ec2 describe-instances to get all private ip addresses"
    },
    {
        "tags": [
            "json",
            "bash",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516290336,
                "post_id": 48324463,
                "comment_id": 83635602,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7730283,
                    "reputation": 534,
                    "user_id": 8683461,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/0e0261096af7948670d22e5cee928c0b?s=256&d=identicon&r=PG",
                    "display_name": "MarvinLeRouge",
                    "link": "https://stackoverflow.com/users/8683461/marvinlerouge"
                },
                "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": 1516349007,
                "post_id": 48324463,
                "comment_id": 83658058,
                "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": 1516376900,
                "post_id": 48324463,
                "comment_id": 83675151,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1516293158,
                "creation_date": 1516293158,
                "answer_id": 48326071,
                "question_id": 48324463,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    #!/bin/bash\r\n        json_file=&quot;/home/pruebas/file.json&quot;\r\n        while read line\r\n         do\r\n        \tif [ $(echo $line|grep annonce|wc -l) -gt 0 ]\r\n        \t\tthen\r\n        \t\t\tvar_annonce_id=$(echo $line |grep annonce |awk &#39;BEGIN {FS=&quot;\\&quot;&quot;}{print $4}&#39;)\r\n        \t\t\tvar_titre_slug=$(echo $line |grep annonce |awk &#39;BEGIN {FS=&quot;\\]&quot;}{print $2}&#39; | awk &#39;BEGIN {FS=&quot;\\&quot;&quot;}{print $4}&#39;)\r\n        \t\t\tvar_photo_array=$(echo $line |grep annonce |awk &#39;BEGIN {FS=&quot;\\[&quot;}{print $2}&#39; |awk &#39;BEGIN {FS=&quot;\\]&quot;}{print $1}&#39; |tr -d &quot;\\&quot;&quot; | sed s/&quot;\\,&quot;/&quot; &quot;/g )\r\n        \t\t\techo &quot;Annonce_id=$var_annonce_id&quot;\r\n        \t\t\techo &quot;Titre_slug=$var_titre_slug&quot;\r\n        \t\t\techo &quot;Photo Array=$var_photo_array&quot;\r\n        \tfi\r\n        done &lt; $json_file",
                "title": "Bash and jq nested loops on json"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1516301921,
                "last_edit_date": 1516301921,
                "creation_date": 1516301457,
                "answer_id": 48328373,
                "question_id": 48324463,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There are many possible solutions in bash. Here&#39;s one that does NOT require `mapfile` (aka `readarray`):\r\n\r\n    while read -r annonce\r\n    do      \r\n        read -r titre\r\n        IFS=$&#39;\\t&#39; read -r -a photos\r\n        echo annonce=&quot;$annonce&quot;\r\n        echo titre=&quot;$titre&quot;\r\n        echo number of photos is ${#photos[@]}\r\n    done &lt; &lt;(jq -r &#39;.[] | .annonce_id, .titre_slug, (.photos | @tsv)&#39; input.json)\r\n\r\n\r\n",
                "title": "Bash and jq nested loops on json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1516301921,
        "creation_date": 1516288301,
        "question_id": 48324463,
        "body_markdown": "I try to use jq to parse a json file and use it in a bash script, but i&#39;m having some difficulties.\r\nThe json\r\n\r\n    [\r\n    {&quot;annonce_id&quot;:&quot;123&quot;,&quot;photos&quot;:[&quot;url_01&quot;],&quot;titre_slug&quot;:&quot;slug1&quot;},\r\n    {&quot;annonce_id&quot;:&quot;456&quot;,&quot;photos&quot;:[&quot;url_11&quot;,&quot;url_12&quot;],&quot;titre_slug&quot;:&quot;slug2&quot;},\r\n    {&quot;annonce_id&quot;:&quot;7890&quot;,&quot;photos&quot;:[&quot;url_31&quot;],&quot;titre_slug&quot;:&quot;slug3&quot;},\r\n    {&quot;annonce_id&quot;:&quot;1234&quot;,&quot;photos&quot;:[&quot;url_41&quot;],&quot;titre_slug&quot;:&quot;slug4&quot;},\r\n    {&quot;annonce_id&quot;:&quot;5678&quot;,&quot;photos&quot;:[&quot;url_51&quot;],&quot;titre_slug&quot;:&quot;slug5&quot;},\r\n    {&quot;annonce_id&quot;:&quot;90123&quot;,&quot;photos&quot;:[&quot;url_61&quot;],&quot;titre_slug&quot;:&quot;slug6&quot;}\r\n    ]\r\n\r\nThe goal :\r\nFor each line, retrieve annonce_id, titre_slug and photos in bash variables. Photos should be in an array, since it can contain 1 or more elements.\r\n\r\nIf i do a\r\n\r\n    jq -r &#39;.[] | .annonce_id, .titre_slug, .photos&#39;\r\n\r\non this data, i display the info, but i&#39;d like to have it in bash variables (preferably named after the json fields), to use annonce_id and titre_slug, and iterate over photos.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/48324463/bash-and-jq-nested-loops-on-json",
        "title": "Bash and jq nested loops on json"
    },
    {
        "tags": [
            "json",
            "amazon-dynamodb",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1517126599,
                "last_edit_date": 1517126599,
                "creation_date": 1516299584,
                "answer_id": 48327881,
                "question_id": 48327037,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As I understand the problem, the piece of the puzzle you&#39;re missing is the ability to transform a JSON object {key1: value1, key2: value2, ...} into an object of the form: {key1: {&quot;N&quot;: (value1|tostring)}, ...\r\n\r\nThis can be done using the filter:\r\n\r\n    to_entries | map( {(.key): {N: (.value|tostring)}} ) | add;\r\n\r\nIt might be worthwhile wrapping this functionality into a named function:\r\n\r\n    def package: to_entries | map( {(.key): {N: (.value|tostring)}} ) | add;\r\n\r\nThe solution to the problem (as I understand it) can then be written:\r\n\r\n    {Codes: {M: package}}\r\n    \r\nInput:\r\n        \r\n    { &quot;200&quot;: 1728, &quot;201&quot;: 288, &quot;301&quot;: 214, &quot;401&quot;: 104, &quot;404&quot;: 12 }\r\n    \r\nOutput:\r\n    \r\n    {\r\n      &quot;Codes&quot;: {\r\n        &quot;M&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;N&quot;: &quot;1728&quot;\r\n          },\r\n          &quot;201&quot;: {\r\n            &quot;N&quot;: &quot;288&quot;\r\n          },\r\n          &quot;301&quot;: {\r\n            &quot;N&quot;: &quot;214&quot;\r\n          },\r\n          &quot;401&quot;: {\r\n            &quot;N&quot;: &quot;104&quot;\r\n          },\r\n          &quot;404&quot;: {\r\n            &quot;N&quot;: &quot;12&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n",
                "title": "Formatting JSON data for DynamoDB using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1517126599,
        "creation_date": 1516296238,
        "question_id": 48327037,
        "body_markdown": "Trying to format a json object into a proper format for DynamoDB in shell\r\n\r\n    { &quot;200&quot;: 1728, &quot;201&quot;: 288, &quot;301&quot;: 214, &quot;401&quot;: 104, &quot;404&quot;: 12 }\r\n                \r\nI originally had a script that I figured was the proper format, but the data retrieved is dynamic as it can have any number of keys   \r\n\r\n    jq -r &#39;.codes&#39; item.json | jq --slurp &#39;{Codes:{M: .[]}}&#39;\r\n\r\noutputs\r\n\r\n    {&quot;Codes&quot;: {&quot;M&quot;: { &quot;200&quot;: 1728, &quot;201&quot;: 288, &quot;301&quot;: 214, &quot;401&quot;: 104, &quot;404&quot;: 12 }}}\r\n\r\nDynamoDB format, the one field that will be static is &quot;N&quot;, but the numbers have to be formatted to string, which I may be able to do in the initial filter\r\n\r\n    {&quot;Codes&quot;: {&quot;M&quot;: { &quot;200&quot;: {&quot;N&quot;: &quot;1728&quot;}, &quot;201&quot;: {&quot;N&quot;: &quot;288&quot;}, &quot;301&quot;: {&quot;N&quot;: &quot;214&quot;}, &quot;401&quot;: {&quot;N&quot;: 104}, &quot;404&quot;: {&quot;N&quot;: &quot;12&quot;} }}}\r\n\r\nIt took me 4 days to try getting what Ive gotten so far, and am stuck as to formatting it correctly\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48327037/formatting-json-data-for-dynamodb-using-jq",
        "title": "Formatting JSON data for DynamoDB using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3581140,
                    "reputation": 1966,
                    "user_id": 2989337,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://i.sstatic.net/JoDFi.png?s=256",
                    "display_name": "JawguyChooser",
                    "link": "https://stackoverflow.com/users/2989337/jawguychooser"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516322381,
                "post_id": 48332459,
                "comment_id": 83650677,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3581140,
                    "reputation": 1966,
                    "user_id": 2989337,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://i.sstatic.net/JoDFi.png?s=256",
                    "display_name": "JawguyChooser",
                    "link": "https://stackoverflow.com/users/2989337/jawguychooser"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516322545,
                "post_id": 48332459,
                "comment_id": 83650711,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4734553,
                    "reputation": 1499,
                    "user_id": 3829310,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://i.sstatic.net/blWdU.jpg?s=256",
                    "display_name": "Steve Amerige",
                    "link": "https://stackoverflow.com/users/3829310/steve-amerige"
                },
                "reply_to_user": {
                    "account_id": 3581140,
                    "reputation": 1966,
                    "user_id": 2989337,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://i.sstatic.net/JoDFi.png?s=256",
                    "display_name": "JawguyChooser",
                    "link": "https://stackoverflow.com/users/2989337/jawguychooser"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516322679,
                "post_id": 48332459,
                "comment_id": 83650733,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3581140,
                    "reputation": 1966,
                    "user_id": 2989337,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://i.sstatic.net/JoDFi.png?s=256",
                    "display_name": "JawguyChooser",
                    "link": "https://stackoverflow.com/users/2989337/jawguychooser"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516322929,
                "post_id": 48332459,
                "comment_id": 83650801,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4734553,
                    "reputation": 1499,
                    "user_id": 3829310,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://i.sstatic.net/blWdU.jpg?s=256",
                    "display_name": "Steve Amerige",
                    "link": "https://stackoverflow.com/users/3829310/steve-amerige"
                },
                "reply_to_user": {
                    "account_id": 3581140,
                    "reputation": 1966,
                    "user_id": 2989337,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://i.sstatic.net/JoDFi.png?s=256",
                    "display_name": "JawguyChooser",
                    "link": "https://stackoverflow.com/users/2989337/jawguychooser"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516323232,
                "post_id": 48332459,
                "comment_id": 83650868,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1516339793,
                "creation_date": 1516339793,
                "answer_id": 48334653,
                "question_id": 48332459,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If I understand what you&#39;re trying to do correctly, it doesn&#39;t seem possible to me to do it &quot;pure jq&quot; having read the docs (and being a regular `jq` user myself). The closest I could come to helping here was to simplify the `jq` part itself:\r\n    \r\n    jq -r &quot;$Prefix| { $Suffix }&quot; &quot;$File&quot;\r\n\r\nThis has the same behavior as your example (on this limited set of cases):\r\n\r\n    GetSubobject &#39;.b.x.y&#39; example.json\r\n    {\r\n      &quot;y&quot;: {\r\n        &quot;j&quot;: true,\r\n        &quot;k&quot;: [\r\n          1,\r\n          2,\r\n          3\r\n        ]\r\n      }\r\n    }\r\n\r\nThis is really a case of metaprogramming, you want to programmatically operate on a `jq` program.  Well, it makes sense (to me) that `jq` takes its program as input but doesn&#39;t allow you to alter the program itself.  bash seems like an appropriate choice for doing the metaprogramming here: to convert a `jq` program into another one and then run `jq` using that.",
                "title": "How to get a subobject out of JSON using jq, keeping final key in the result without Bash processing?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1516340593,
                "creation_date": 1516340593,
                "answer_id": 48334803,
                "question_id": 48332459,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Somewhat further simplifying the `jq` part but with the same general constraints as JawguyChooser&#39;s answer, how about the much simpler Bash function\r\n\r\n    GetSubject () {\r\n        local newroot=${1##*.}\r\n        jq -r &quot;{$newroot: $1}&quot; &quot;$2&quot;\r\n    }\r\n\r\nI may be overlooking some nuances of your more-complex Bash processing, but this seems to work for the example you provided.",
                "title": "How to get a subobject out of JSON using jq, keeping final key in the result without Bash processing?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1516354106,
                "creation_date": 1516354106,
                "answer_id": 48337849,
                "question_id": 48332459,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If the goal is to do as little as possible in `bash`, then maybe the following bash function will fill the bill:\r\n\r\n    function GetSubobject {\r\n       local Filter=&quot;$1&quot;    # Filter is of the form .&lt;key&gt;.&lt;key&gt; ... .&lt;key&gt;\r\n       local File=&quot;$2&quot;      # File is the JSON to get the subobject\r\n       jq  &#39;(null|path(&#39;&quot;$Filter&quot;&#39;)) as $path\r\n            | {($path[-1]): &#39;&quot;$Filter&quot;&#39;}&#39; &quot;$File&quot;\r\n    }\r\n\r\nAn alternative would be to pass `$Filter` in as a string (e.g. --arg filter &quot;$Filter&quot;), have jq do the parsing, and then use `getpath`.\r\n\r\nIt would of course be simplest if GetSubobject could be called with the path separated from the field of interest, like this:\r\n\r\n    GetSubobject .b.x y filename\r\n\r\n",
                "title": "How to get a subobject out of JSON using jq, keeping final key in the result without Bash processing?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1516354106,
        "creation_date": 1516321792,
        "last_edit_date": 1516323288,
        "question_id": 48332459,
        "body_markdown": "I&#39;m writing a Bash function to get a portion of a JSON object. The API for the function is:\r\n\r\n    GetSubobject()\r\n    {\r\n       local Filter=&quot;$1&quot;    # Filter is of the form .&lt;key&gt;.&lt;key&gt; ... .&lt;key&gt;\r\n       local File=&quot;$2&quot;      # File is the JSON to get the subobject\r\n\r\n       # Code to get subobject using jq\r\n       # ...\r\n    }\r\n\r\nTo illustrate what I mean by a subobject, consider the Bash function call:\r\n\r\n    GetSubobject .b.x.y example.json\r\n\r\nwhere the file example.json contains:\r\n\r\n    {\r\n       &quot;a&quot;: { &quot;p&quot;: 1, &quot;q&quot;: 2 },\r\n       &quot;b&quot;:\r\n       {\r\n          &quot;x&quot;:\r\n          {\r\n              &quot;y&quot;: { &quot;j&quot;: true, &quot;k&quot;: [1,2,3] },\r\n              &quot;z&quot;: [4,5,6]\r\n          }\r\n       }\r\n    }\r\n\r\nThe result from the function call would be emitted to stdout:\r\n\r\n    {\r\n      &quot;y&quot;: {\r\n        &quot;j&quot;: true,\r\n        &quot;k&quot;: [\r\n          1,\r\n          2,\r\n          3\r\n        ]\r\n      }\r\n    }\r\n\r\n\r\nNote that the code `jq -r &quot;$Filter&quot; &quot;$File&quot;` would not give the desired answer. It would give:\r\n\r\n    { &quot;j&quot;: true, &quot;k&quot;: [1,2,3] }\r\n\r\nPlease note that the answer I&#39;m looking for needs to be something I can use in the Bash function API above. So, the answer should use the Filter and File variables as show above and not be specific to the example above.\r\n\r\nI have come up with a solution; however, it relies on Bash to do part of the job. I am hoping that the solution can be pure jq without reliance on Bash processing.\r\n\r\n    #!/bin/bash\r\n    \r\n    GetSubobject()\r\n    {\r\n       local Filter=&quot;$1&quot;\r\n       local File=&quot;$2&quot;\r\n    \r\n       # General case: separate:\r\n       #    .&lt;key1&gt;.&lt;key2&gt; ... .&lt;keyN-1&gt;.&lt;keyN&gt;\r\n       # into:\r\n       #   Prefix=.&lt;key1&gt;.&lt;key2&gt; ... .&lt;keyN-1&gt;\r\n       #   Suffix=&lt;keyN&gt;\r\n       local Suffix=&quot;${Filter##*.}&quot;\r\n       local Prefix=&quot;${Filter%.$Suffix}&quot;\r\n    \r\n       # Edge case: where Filter = .&lt;key&gt;\r\n       # Set:\r\n       #    Prefix=.\r\n       #    Suffix=&lt;key&gt;\r\n       if [[ -z $Prefix ]]; then\r\n          Prefix=&#39;.&#39;\r\n          Suffix=&quot;${Filter#.}&quot;\r\n       fi\r\n    \r\n       jq -r &quot;$Prefix|to_entries|map(select(.key==\\&quot;$Suffix\\&quot;))|from_entries&quot; &quot;$File&quot;\r\n    }\r\n    \r\n    GetSubobject &quot;$@&quot;\r\n\r\nHow would I complete the above Bash function using jq to obtain the desired result, hopefully in a less brute-force way that takes advantage of jq&#39;s capabilities without having to do pre-processing in Bash?",
        "link": "https://stackoverflow.com/questions/48332459/how-to-get-a-subobject-out-of-json-using-jq-keeping-final-key-in-the-result-wit",
        "title": "How to get a subobject out of JSON using jq, keeping final key in the result without Bash processing?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "shell",
            "average",
            "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": 1516324815,
                "post_id": 48332761,
                "comment_id": 83651219,
                "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": 1516324949,
                "post_id": 48332761,
                "comment_id": 83651248,
                "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": 1516325099,
                "post_id": 48332761,
                "comment_id": 83651286,
                "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": 1516325730,
                "post_id": 48332761,
                "comment_id": 83651420,
                "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": 1516328138,
                "post_id": 48332761,
                "comment_id": 83651943,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1516328108,
                "last_edit_date": 1516328108,
                "creation_date": 1516326535,
                "answer_id": 48333008,
                "question_id": 48332761,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq -r &#39;\r\n        .[].stats.data[]\r\n        | (.identifier.values[]) as $identifier\r\n        | (.metric[]\r\n           | select(.name == &quot;avg(total_response_time)&quot;)\r\n           | .values\r\n          ) as $values\r\n        | [$identifier, ($values | add) / ($values | length)]\r\n        | @tsv\r\n        &#39; &lt;test.json\r\n\r\n...yields:\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    test    354.43398004304896\r\n    test2   104.14989963503649\r\n    appdyn  80.1233179403148\r\n    AppDyn  6.555555555555556",
                "title": "Calculate Average values in a JSON array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1516506659,
                "last_edit_date": 1516506659,
                "creation_date": 1516330721,
                "answer_id": 48333486,
                "question_id": 48332761,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First, for clarity, here is a stream-oriented helper function:\r\n    \r\n    def average(s): \r\n      reduce s as $x (null; .sum += $x | .n += 1)\r\n      | if . == null then null else .sum / .n end;\r\n\r\n\r\nNext, we have a choice.  We can either treat each item in the .stats.data array individually, or we can group the items by the value of .identifier.  In the example, the results would be the same (except possibly for the ordering), but let us consider here the two cases separately:\r\n\r\n### Average per item in .stats.data\r\n\r\n    .Response.stats.data[]\r\n    | {id: (.identifier.values),\r\n       average: average(.metric[]\r\n         | select(.name == &quot;avg(total_response_time)&quot;)\r\n         | .values[]) }\r\n\r\n### Group by .identifier\r\n\r\n    .Response.stats.data\r\n    | group_by(.identifier)[]\r\n    | {id: (.[0].identifier.values),\r\n       average: (.[].metric[] \r\n         | select(.name == &quot;avg(total_response_time)&quot;) \r\n         | .values[] ) }\r\n \r\n\r\n### Output\r\n\r\n    {&quot;id&quot;:[&quot;test&quot;],&quot;average&quot;:354.43398004304896}\r\n    {&quot;id&quot;:[&quot;test2&quot;],&quot;average&quot;:104.14989963503649}\r\n    {&quot;id&quot;:[&quot;appdyn&quot;],&quot;average&quot;:80.1233179403148}\r\n    {&quot;id&quot;:[&quot;AppDyn&quot;],&quot;average&quot;:6.555555555555556}\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "Calculate Average values in a JSON array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1517158252,
        "creation_date": 1516324559,
        "last_edit_date": 1517158252,
        "question_id": 48332761,
        "body_markdown": "I am working with a JSON file of this format:\r\n\r\n      {\r\n      &quot;Response&quot; : {\r\n        &quot;TimeUnit&quot; : [ 1516298400000, 1516302000000, 1516305600000, 1516309200000, 1516312800000, 1516316400000 ],\r\n        &quot;metaData&quot; : {\r\n          &quot;errors&quot; : [ ],\r\n          &quot;notices&quot; : [ &quot;Source:Postgres&quot;, &quot;Limit applied: 14400&quot;, &quot;PG Host:ruappg0ro.apigeeks.net&quot;, &quot;Metric with Avg of total_response_time was requested. For this a global avg was also computed with name global-avg-total_response_time&quot;, &quot;query served by:88bec25a-ef48-464e-b41d-e447e3beeb88&quot;, &quot;Table used: edge.api.faxgroupusenondn012.agg_api&quot; ]\r\n        },\r\n        &quot;stats&quot; : {\r\n          &quot;data&quot; : [ {\r\n            &quot;identifier&quot; : {\r\n              &quot;names&quot; : [ &quot;apiproxy&quot; ],\r\n              &quot;values&quot; : [ &quot;test&quot; ]\r\n            },\r\n            &quot;metric&quot; : [ {\r\n              &quot;env&quot; : &quot;test&quot;,\r\n              &quot;name&quot; : &quot;sum(message_count)&quot;,\r\n              &quot;values&quot; : [ 28.0, 129.0, 24.0, 20.0, 71.0, 30.0 ]\r\n            }, {\r\n              &quot;env&quot; : &quot;test&quot;,\r\n              &quot;name&quot; : &quot;avg(total_response_time)&quot;,\r\n              &quot;values&quot; : [ 312.57142857142856, 344.2480620155039, 374.2083333333333, 381.1, 350.67605633802816, 363.8 ]\r\n            }, {\r\n              &quot;env&quot; : &quot;test&quot;,\r\n              &quot;name&quot; : &quot;sum(is_error)&quot;,\r\n              &quot;values&quot; : [ 0.0, 0.0, 0.0, 0.0, 0.0, 0.0 ]\r\n            }, {\r\n              &quot;env&quot; : &quot;test&quot;,\r\n              &quot;name&quot; : &quot;global-avg-total_response_time&quot;,\r\n              &quot;values&quot; : [ 349.5860927152318 ]\r\n            } ]\r\n          }, {\r\n            &quot;identifier&quot; : {\r\n              &quot;names&quot; : [ &quot;apiproxy&quot; ],\r\n              &quot;values&quot; : [ &quot;test2&quot; ]\r\n            },\r\n            &quot;metric&quot; : [ {\r\n              &quot;env&quot; : &quot;test&quot;,\r\n              &quot;name&quot; : &quot;sum(message_count)&quot;,\r\n              &quot;values&quot; : [ 0.0, 0.0, 0.0, 16.0, 137.0, 100.0 ]\r\n            }, {\r\n              &quot;env&quot; : &quot;test&quot;,\r\n              &quot;name&quot; : &quot;avg(total_response_time)&quot;,\r\n              &quot;values&quot; : [ 0.0, 0.0, 0.0, 237.4375, 198.02189781021897, 189.44 ]\r\n            }, {\r\n              &quot;env&quot; : &quot;test&quot;,\r\n              &quot;name&quot; : &quot;sum(is_error)&quot;,\r\n              &quot;values&quot; : [ 0.0, 0.0, 0.0, 16.0, 137.0, 100.0 ]\r\n            }, {\r\n              &quot;env&quot; : &quot;test&quot;,\r\n              &quot;name&quot; : &quot;global-avg-total_response_time&quot;,\r\n              &quot;values&quot; : [ 197.12252964426878 ]\r\n            } ]\r\n          }, {\r\n            &quot;identifier&quot; : {\r\n              &quot;names&quot; : [ &quot;apiproxy&quot; ],\r\n              &quot;values&quot; : [ &quot;appdyn&quot; ]\r\n            },\r\n            &quot;metric&quot; : [ {\r\n              &quot;env&quot; : &quot;test&quot;,\r\n              &quot;name&quot; : &quot;sum(message_count)&quot;,\r\n              &quot;values&quot; : [ 0.0, 0.0, 0.0, 11.0, 137.0, 98.0 ]\r\n            }, {\r\n              &quot;env&quot; : &quot;test&quot;,\r\n              &quot;name&quot; : &quot;avg(total_response_time)&quot;,\r\n              &quot;values&quot; : [ 0.0, 0.0, 0.0, 170.0, 161.57664233576642, 149.16326530612244 ]\r\n            }, {\r\n              &quot;env&quot; : &quot;test&quot;,\r\n              &quot;name&quot; : &quot;sum(is_error)&quot;,\r\n              &quot;values&quot; : [ 0.0, 0.0, 0.0, 11.0, 137.0, 98.0 ]\r\n            }, {\r\n              &quot;env&quot; : &quot;test&quot;,\r\n              &quot;name&quot; : &quot;global-avg-total_response_time&quot;,\r\n              &quot;values&quot; : [ 157.0081300813008 ]\r\n            } ]\r\n          }, {\r\n            &quot;identifier&quot; : {\r\n              &quot;names&quot; : [ &quot;apiproxy&quot; ],\r\n              &quot;values&quot; : [ &quot;AppDyn&quot; ]\r\n            },\r\n            &quot;metric&quot; : [ {\r\n              &quot;env&quot; : &quot;test&quot;,\r\n              &quot;name&quot; : &quot;sum(message_count)&quot;,\r\n              &quot;values&quot; : [ 0.0, 0.0, 0.0, 3.0, 0.0, 0.0 ]\r\n            }, {\r\n              &quot;env&quot; : &quot;test&quot;,\r\n              &quot;name&quot; : &quot;avg(total_response_time)&quot;,\r\n              &quot;values&quot; : [ 0.0, 0.0, 0.0, 39.333333333333336, 0.0, 0.0 ]\r\n            }, {\r\n              &quot;env&quot; : &quot;test&quot;,\r\n              &quot;name&quot; : &quot;sum(is_error)&quot;,\r\n              &quot;values&quot; : [ 0.0, 0.0, 0.0, 0.0, 0.0, 0.0 ]\r\n            }, {\r\n              &quot;env&quot; : &quot;test&quot;,\r\n              &quot;name&quot; : &quot;global-avg-total_response_time&quot;,\r\n              &quot;values&quot; : [ 39.333333333333336 ]\r\n            } ]\r\n          } ]\r\n        }\r\n      }\r\n    }\r\n\r\nand would like to calculate the average of all values under:  `&quot;name&quot; : &quot;avg(total_response_time)&quot;` for each `identifier`iteratively. \r\n\r\nI have tried a few attempts and I really don&#39;t know how to proceed as the count of the `identifiers` and the `avg(total_response_time)` varies. \r\n\r\n&gt;     for identifier in $(cat response4.json | jq -r  &#39;.[].stats.data[].identifier.values&#39; | sed &#39;s/[][]//g&#39; | sed\r\n&gt; &#39;s/&quot;//g&#39;); do\r\n&gt;       echo ${identifier}\r\n&gt;     \r\n&gt;     avg_response_time=$(cat response4.json | jq -r  &#39;.[].stats.data[].metric[]&#39;) #don&#39;t know how to iterate through the \r\n&gt;     done\r\n\r\nAny help/idea will be greatly appreciated.  ",
        "link": "https://stackoverflow.com/questions/48332761/calculate-average-values-in-a-json-array",
        "title": "Calculate Average values in a JSON array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1516395461,
                "last_edit_date": 1516395461,
                "creation_date": 1516395008,
                "answer_id": 48349348,
                "question_id": 48348722,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following filter will, I believe, produce the desired result in the particular case that has been presented, but the general requirements are unclear, so it may be necessary to make adjustments accordingly:\r\n\r\n    def add_merge($one; $two):\r\n      def pairwise_add:\r\n        transpose\r\n        | map(if .[0].id == .[1].id then add else . end);\r\n      reduce ($one|keys_unsorted[]) as $k ($one+$two;\r\n         if ($one[$k]|type) == &quot;array&quot;\r\n         then .[$k] = ([$one[$k], $two[$k]] | pairwise_add)\r\n         else .\r\n         end);\r\n\r\nFor the given pair of objects, the result is:\r\n\r\n    {\r\n      &quot;parameter1&quot;: &quot;object1&quot;,\r\n      &quot;childs&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;child1&quot;,\r\n          &quot;parameter-A&quot;: &quot;value-A&quot;,\r\n          &quot;parameter-B&quot;: &quot;value-B&quot;\r\n        }\r\n      ],\r\n      &quot;parameter2&quot;: &quot;object2&quot;\r\n    }\r\n\r\n",
                "title": "How to merge JSON objects with sub arrays with adding objects with matching values inside the array instead of replacing them with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1516435762,
        "creation_date": 1516392337,
        "last_edit_date": 1516435762,
        "question_id": 48348722,
        "body_markdown": "I have two JSON objects:\r\n\r\n    {\r\n      &quot;parameter1&quot;: &quot;object1&quot;,\r\n      &quot;childs&quot;: [\r\n        { \r\n          &quot;id&quot;: &quot;child1&quot;,\r\n          &quot;parameter-A&quot;: &quot;value-A&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nand\r\n\r\n\r\n    {\r\n      &quot;parameter2&quot;: &quot;object2&quot;,\r\n      &quot;childs&quot;: [\r\n        { \r\n          &quot;id&quot;: &quot;child1&quot;,\r\n          &quot;parameter-B&quot;: &quot;value-B&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nand I need to merge the objects, but I don&#39;t want to get the containing arrays to be replaced, but also merged, i.e. added in case the id equals. This is what I need:\r\n\r\n\r\n    {\r\n      &quot;parameter1&quot;: &quot;object1&quot;,\r\n      &quot;parameter2&quot;: &quot;object2&quot;,\r\n      &quot;childs&quot;: [\r\n        { \r\n          &quot;id&quot;: &quot;child1&quot;,\r\n          &quot;parameter-A&quot;: &quot;value-A&quot;,\r\n          &quot;parameter-B&quot;: &quot;value-B&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI currently merge the two files with `jq -s &#39;.[0] * .[1]&#39; file1 file2`, but parameter-A is overwritten by parameter-B with the unwanted result where parameter-A is missing:\r\n\r\n    {\r\n      &quot;parameter1&quot;: &quot;object1&quot;,\r\n      &quot;parameter2&quot;: &quot;object2&quot;,\r\n      &quot;childs&quot;: [\r\n        { \r\n          &quot;id&quot;: &quot;child1&quot;,\r\n          &quot;parameter-B&quot;: &quot;value-B&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI could also change the JSON structure if that would simplify a solution.",
        "link": "https://stackoverflow.com/questions/48348722/how-to-merge-json-objects-with-sub-arrays-with-adding-objects-with-matching-valu",
        "title": "How to merge JSON objects with sub arrays with adding objects with matching values inside the array instead of replacing them with jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1516520471,
                "creation_date": 1516520471,
                "answer_id": 48364675,
                "question_id": 48364608,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq -r &#39;.array[] as $a | [.field1, $a.child_field1, $a.child_field2] | @csv&#39;\r\n\r\nDoes the right thing for the sample data you provided, but I freely admit there are lots of ways to do that kind of thing in `jq`, and that was only the first one which sprang to mind.\r\n\r\nI fed it through `@csv` because it seemed like that was what you wanted, but if you prefer the actual output, exactly as you have written, then:\r\n\r\n    jq -r &#39;.array[] as $a | &quot;\\(.field1),\\($a.child_field1),\\($a.child_field2)&quot;&#39;\r\n\r\nwill produce it",
                "title": "Parse JSON field with jq and output repeatedly for every child"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1516542024,
                "last_edit_date": 1516542024,
                "creation_date": 1516521109,
                "answer_id": 48364757,
                "question_id": 48364608,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -r &#39;.field1 as $f1 | .array[] \r\n           | [$f1, .[]] \r\n           | join(&quot;,&quot;)&#39; input.json\r\nThe output:\r\n\r\n    foo,c1_1,c1_2\r\n    foo,c2_1,c2_2\r\n\r\n",
                "title": "Parse JSON field with jq and output repeatedly for every child"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1516525799,
                "creation_date": 1516525799,
                "answer_id": 48365273,
                "question_id": 48364608,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In cases like this, there&#39;s no need for `reduce` or `to_entries&#39;, or to list the fields explicitly -- one can simply exploit jq&#39;s backtracking behavior:\r\n\r\n    .field1 as $f\r\n    | .array[]\r\n    | [$f, .[]]\r\n    | @csv\r\n\r\nAs pointed out by @MatthewLDaniel, there are many alternatives to using @csv here.  ",
                "title": "Parse JSON field with jq and output repeatedly for every child"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1516542024,
        "creation_date": 1516519776,
        "question_id": 48364608,
        "body_markdown": "I have the following JSON:\r\n\r\n        {\r\n            &quot;field1&quot;:&quot;foo&quot;,\r\n            &quot;array&quot;:[\r\n                {\r\n                    child_field1:&quot;c1_1&quot;,\r\n                    child_field2:&quot;c1_2&quot;\r\n                },\r\n                {\r\n                    child_field1:&quot;c2_1&quot;,\r\n                    child_field2:&quot;c2_2&quot;\r\n                }\r\n             ]...\r\n        }\r\n\r\nand using ```jq```, I would like to return the following output, where the value of ```field1``` is repeated for every child element.:\r\n\r\n        foo,c1_1,c1_2\r\n        foo,c2_1,c2_2\r\n        ...\r\n\r\nI can access each field separately, am having trouble returning the desired result above.\r\n\r\nCan this be done with jq?",
        "link": "https://stackoverflow.com/questions/48364608/parse-json-field-with-jq-and-output-repeatedly-for-every-child",
        "title": "Parse JSON field with jq and output repeatedly for every child"
    },
    {
        "tags": [
            "json",
            "nested",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1516608221,
                "last_edit_date": 1516608221,
                "creation_date": 1516572278,
                "answer_id": 48372185,
                "question_id": 48372018,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq &#39;[group_by(.service_name)[] \r\n        | .[0].service_name as $name \r\n        | { name: $name, \r\n            data: map({ date: .time, \r\n                        details: {event, version}}) \r\n          }]&#39; jsonfile\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;cart&quot;,\r\n        &quot;data&quot;: [\r\n          {\r\n            &quot;date&quot;: &quot;2017-12-21 07:21:00&quot;,\r\n            &quot;details&quot;: {\r\n              &quot;event&quot;: &quot;Success&quot;,\r\n              &quot;version&quot;: &quot;9ff24c4&quot;\r\n            }\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;prices&quot;,\r\n        &quot;data&quot;: [\r\n          {\r\n            &quot;date&quot;: &quot;2017-12-21 07:24:00&quot;,\r\n            &quot;details&quot;: {\r\n              &quot;event&quot;: &quot;Success&quot;,\r\n              &quot;version&quot;: &quot;61f4u8e&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;date&quot;: &quot;2017-12-21 07:23:00&quot;,\r\n            &quot;details&quot;: {\r\n              &quot;event&quot;: &quot;Fail&quot;,\r\n              &quot;version&quot;: &quot;21c2f7d&quot;\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\n",
                "title": "jq: How to convert flat json into nested one"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1517126455,
        "creation_date": 1516571027,
        "last_edit_date": 1517126455,
        "question_id": 48372018,
        "body_markdown": "I&#39;ve been trying to re-arrange a pretty flat json into structure with more depth, so far without any success. Here&#39;s my source data:\r\n\r\n`[  {\r\n    &quot;id&quot;: &quot;27&quot;,\r\n    &quot;time&quot;: &quot;2017-12-21 07:24:00&quot;,\r\n    &quot;service_name&quot;: &quot;prices&quot;,\r\n    &quot;version&quot;: &quot;61f4u8e&quot;,\r\n    &quot;event&quot;: &quot;Success&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;28&quot;,\r\n    &quot;time&quot;: &quot;2017-12-21 07:23:00&quot;,\r\n    &quot;service_name&quot;: &quot;prices&quot;,\r\n    &quot;version&quot;: &quot;21c2f7d&quot;,\r\n    &quot;event&quot;: &quot;Fail&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;29&quot;,\r\n    &quot;time&quot;: &quot;2017-12-21 07:21:00&quot;,\r\n    &quot;service_name&quot;: &quot;cart&quot;,\r\n    &quot;version&quot;: &quot;9ff24c4&quot;,\r\n    &quot;event&quot;: &quot;Success&quot;\r\n  }\r\n]\r\n`\r\n\r\nThe result should look like this:\r\n\r\n`[\r\n  {\r\n    &quot;name&quot;: &quot;cart&quot;,\r\n    &quot;data&quot;: [\r\n      {\r\n        &quot;date&quot;: &quot;2017-12-21 07:21:00&quot;,\r\n        &quot;details&quot;: {\r\n          &quot;event&quot;: &quot;Success&quot;,\r\n          &quot;version&quot;: &quot;9ff24c4&quot;\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;prices&quot;,\r\n    &quot;data&quot;: [\r\n      {\r\n        &quot;date&quot;: &quot;2017-12-21 07:24:00&quot;,\r\n        &quot;details&quot;: {\r\n          &quot;event&quot;: &quot;Success&quot;,\r\n          &quot;version&quot;: &quot;61f4u8e&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;date&quot;: &quot;2017-12-21 07:23:00&quot;,\r\n        &quot;details&quot;: {\r\n          &quot;event&quot;: &quot;Fail&quot;,\r\n          &quot;version&quot;: &quot;21c2f7d&quot;\r\n        }\r\n      }\r\n    ]\r\n  }\r\n]`\r\n\r\nSo, basically grouping by service_name and moving the other fields around a little.\r\n\r\nSo far I&#39;ve managed to group, but only one level:\r\n\r\n`group_by(.service_name) | map({name: .[0].service_name, data: .})`\r\nHow can I shuffle around the other values, assuming the input will always have all fields as in the example above?\r\n",
        "link": "https://stackoverflow.com/questions/48372018/jq-how-to-convert-flat-json-into-nested-one",
        "title": "jq: How to convert flat json into nested one"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516618352,
                "post_id": 48379728,
                "comment_id": 83746235,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1141474,
                    "reputation": 6443,
                    "user_id": 1125251,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://i.sstatic.net/DO9cG.jpg?s=256",
                    "display_name": "Tom Oakley",
                    "link": "https://stackoverflow.com/users/1125251/tom-oakley"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516618483,
                "post_id": 48379728,
                "comment_id": 83746311,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516621231,
                "post_id": 48379728,
                "comment_id": 83747958,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1141474,
                    "reputation": 6443,
                    "user_id": 1125251,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://i.sstatic.net/DO9cG.jpg?s=256",
                    "display_name": "Tom Oakley",
                    "link": "https://stackoverflow.com/users/1125251/tom-oakley"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516621374,
                "post_id": 48379728,
                "comment_id": 83748041,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1516626182,
                "creation_date": 1516626182,
                "answer_id": 48382228,
                "question_id": 48379728,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Let&#39;s say besides the main API json file `apiResponse.json`: \r\n\r\n    {\r\n      &quot;objectList&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;item1&quot;,\r\n          &quot;value&quot;: false\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;item2&quot;,\r\n          &quot;value&quot;: true\r\n        },\r\n    \t{\r\n          &quot;name&quot;: &quot;item4&quot;,\r\n          &quot;value&quot;: true\r\n        }\r\n      ]\r\n    }\r\n\r\nwe have new objects list contained in file `new_objects.dat`:\r\n\r\n    {&quot;name&quot;:&quot;item1&quot;,&quot;value&quot;:true}\r\n    {&quot;name&quot;:&quot;item2&quot;,&quot;value&quot;:false}\r\n    {&quot;name&quot;:&quot;item3&quot;,&quot;value&quot;:true}\r\n\r\n\r\n----------\r\n\r\n    jq --slurpfile new_items new_objects.dat \\\r\n         &#39;.objectList |= [ . + $new_items | group_by(.name)[] | add ]&#39; apiResponse.json\r\nThe output:\r\n\r\n    {\r\n      &quot;objectList&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;item1&quot;,\r\n          &quot;value&quot;: true\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;item2&quot;,\r\n          &quot;value&quot;: false\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;item3&quot;,\r\n          &quot;value&quot;: true\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;item4&quot;,\r\n          &quot;value&quot;: true\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n\r\n\r\n",
                "title": "Add to list of objects and overwrite if already present in array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1516634911,
                "creation_date": 1516634911,
                "answer_id": 48385009,
                "question_id": 48379728,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use `select` to filter the input. This selects the &quot;item2&quot; elements:\r\n\r\n    .objectList[] | select(.name == &quot;item2&quot;)\r\n\r\nThe above will return `null` if you select &quot;item3&quot;.  In that case you can use the alternative operator `//` to define a default value:\r\n\r\n    (.objectList[] | select(.name == &quot;itemX&quot;)) // {&quot;name&quot;: &quot;item3&quot;, &quot;value&quot;: null}\r\n\r\nThe above will always return an object, which can be modified by setting &quot;value&quot; to `false`:\r\n\r\n    ((.objectList[] | select(.name == &quot;itemX&quot;)) // {&quot;name&quot;: &quot;item3&quot;, &quot;value&quot;: null}) | .value = false\r\n\r\nIn order to get a complete list, you have to add those elements which do not match with another select.\r\n\r\n    .objectList[] | select(.name != &quot;itemX&quot;)\r\n\r\nThe two lists can be joined using a comma and square brackets and the result can be put into a new object.\r\n\r\n    [\r\n      (((.objectList[] | select(.name == &quot;itemX&quot;)) // {&quot;name&quot;: &quot;item3&quot;, &quot;value&quot;: null}) | .value = false)\r\n      ,\r\n      (.objectList[] | select(.name != &quot;itemX&quot;))\r\n    ] |\r\n    {&quot;objectList&quot;: .}\r\n",
                "title": "Add to list of objects and overwrite if already present in array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1516634911,
        "creation_date": 1516617886,
        "last_edit_date": 1516626415,
        "question_id": 48379728,
        "body_markdown": "I have a JSON object that comes from an API that looks like this:\r\n\r\n    {\r\n      &quot;objectList&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;item1&quot;,\r\n          &quot;value&quot;: false\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;item2&quot;,\r\n          &quot;value&quot;: true\r\n        }\r\n      ]\r\n    }\r\n\r\nI need to append items to this. I can do this using `jq`:\r\n\r\n    jq &#39;.objectList += [{&quot;name&quot;: &quot;item3&quot;, &quot;value&quot;: true}]&#39; apiResponse.json\r\n\r\nHowever, sometimes I need to add an item with a name attribute that already exists in the response, I need to overwrite it&#39;s value with the new one I want to set. For example, I may want to change the value of &#39;item2&#39; to `false`. \r\n\r\nI&#39;ve written a filter in jq so that I can loop through the `objectList`, but I&#39;m not sure how to compare the two names (the one I want to add, and the name of the item in the current iteration of the loop). Here is my loop filter:\r\n\r\n    jq -r &#39;.objectList[] | [.name]\r\n\r\nThis prints out an array like this:\r\n\r\n    [\r\n      &quot;extendedStatus&quot;\r\n    ]\r\n    [\r\n      &quot;anotherFeature&quot;\r\n    ]\r\n\r\nI then tried to add a conditional onto that filter like this:\r\n\r\n    jq -r &#39;.objectList[] | if .name == &quot;item1&quot; then .value == true else .value == false end&#39; apiResponse.json\r\n\r\n\r\nbut this simply printed out:\r\n\r\n    true\r\n    false\r\n\r\nEdit - a slightly improved filter:\r\n\r\n    jq -r &#39;.objectList[] | if .name == &quot;item1&quot; then {name: .name, value: true} else {name: .name, value: false} end&#39;\r\n\r\nThis prints out:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;item1&quot;,\r\n      &quot;value&quot;: true\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;item2&quot;,\r\n      &quot;value&quot;: false\r\n    }\r\n\r\n\r\nThis improved filter is better, however I&#39;m still unsure of how to add an item if it doesn&#39;t exist in the array (when it&#39;s finished looping over it).\r\n\r\nOne thing to note - this is being done in a bash script, inside a method where I have parameters (the names and values of the items).",
        "link": "https://stackoverflow.com/questions/48379728/add-to-list-of-objects-and-overwrite-if-already-present-in-array",
        "title": "Add to list of objects and overwrite if already present in array"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1516631521,
                "post_id": 48381878,
                "comment_id": 83754652,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1516630216,
                "creation_date": 1516630216,
                "answer_id": 48383476,
                "question_id": 48381878,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The `Resource` field seems to be in the root object so running `echo ${resource} | jq &quot;.Resource&quot;` should do the trick",
                "title": "How to retreive key value from JQ via bash script"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1516647756,
                "creation_date": 1516647756,
                "answer_id": 48388571,
                "question_id": 48381878,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The JSON included in the question is a JSON string (except that the initial double-quote is missing).  To convert it into a JSON object, you can use the `fromjson` filter, so you would write:\r\n \r\n     jq &#39;fromjson|.Resource&#39; \r\n\r\nWith the given JSON string (with the initial double-quote) as input, this produces:\r\n\r\n    &quot;arn:aws:lambda:us-west-2:xxxxxxxx:function:xxxxxx&quot;",
                "title": "How to retreive key value from JQ via bash script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1516777756,
                "creation_date": 1516777756,
                "answer_id": 48416706,
                "question_id": 48381878,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I made it work like below:-\r\n\r\nMade resource outputted in text format\r\n\r\n    resource=$(aws lambda add-permission --function-name $functionName --statement-id &quot;xxxxxx&quot; --action &quot;lambda:InvokeFunction&quot; --principal &quot;events.amazonaws.com&quot; --source-arn $rulearn --query &#39;Statement&#39; --output text )\r\n\r\nand then converted it to json using  below and then retreived resource\r\n\r\n    resource=$(echo ${resource} | jq &quot;.&quot; | jq &quot;.Resource&quot; | sed &quot;s|\\&quot;||g&quot;)",
                "title": "How to retreive key value from JQ via bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1516777756,
        "creation_date": 1516624943,
        "question_id": 48381878,
        "body_markdown": "I am trying to retrieve a key value from aws cli response via jq in shell script however not getting the intended response. \r\n\r\ncould you please help figure how to retrieve the desired key in below condition\r\n\r\n    resource=aws lambda add-permission --function-name $functionName --statement-id &quot;testing&quot; --action &quot;lambda:InvokeFunction&quot; --principal &quot;events.amazonaws.com&quot; --source-arn $rulearn\r\n    echo ${resource} | jq &quot;.[]&quot;\r\n   \r\n\r\nthis return me a response like\r\n\r\n     {\\&quot;Sid\\&quot;:\\&quot;xxxxxxxx\\&quot;,\\&quot;Effect\\&quot;:\\&quot;Allow\\&quot;,\\&quot;Principal\\&quot;:{\\&quot;Service\\&quot;:\\&quot;events.amazonaws.com\\&quot;},\\&quot;Action\\&quot;:\\&quot;lambda:InvokeFunction\\&quot;,\\&quot;Resource\\&quot;:\\&quot;arn:aws:lambda:us-west-2:xxxxxxxx:function:xxxxxx\\&quot;,\\&quot;Condition\\&quot;:{\\&quot;ArnLike\\&quot;:{\\&quot;AWS:SourceArn\\&quot;:\\&quot;arn:aws:events:us-west-2:xxxxxx:rule/xxxxx\\&quot;}}}&quot;\r\n\r\n\r\nI am trying to get value of resource using below line\r\n     \r\n       echo ${resource} | jq &quot;.[]&quot; | jq &quot;.Resource&quot;  \r\n\r\nhowever response is coming back as \r\n\r\n    [\r\n      133\r\n    ]\r\n\r\nWhat should be the correct way to retrieve value of key resource.\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48381878/how-to-retreive-key-value-from-jq-via-bash-script",
        "title": "How to retreive key value from JQ via bash script"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1516637981,
                "creation_date": 1516637981,
                "answer_id": 48385981,
                "question_id": 48384783,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`jq`** solution:\r\n\r\n    jq -c &#39;def del_empty($k): if (.[$k]|tonumber &gt; 0) then . else del(.[$k]) end;\r\n          .[] | {PLATFORM: .platform, ID: .id, PRI: .pri, SEC: .sec}\r\n          | del_empty(&quot;PRI&quot;)\r\n          | del_empty(&quot;SEC&quot;)&#39; test.json\r\nThe output:\r\n\r\n    {&quot;PLATFORM&quot;:&quot;p1&quot;,&quot;ID&quot;:&quot;5&quot;,&quot;SEC&quot;:&quot;20&quot;}\r\n    {&quot;PLATFORM&quot;:&quot;p2&quot;,&quot;ID&quot;:&quot;6&quot;,&quot;PRI&quot;:&quot;10&quot;}",
                "title": "jq query with condition and format output/labels"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1516641758,
                "last_edit_date": 1516641758,
                "creation_date": 1516638006,
                "answer_id": 48385989,
                "question_id": 48384783,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use conditional statements to remove the unwanted keys, e.g.:\r\n\r\n&lt;!-- language: lang-jq --&gt;\r\n\r\n    if (.sec == &quot;0&quot;) then del(.sec) else . end\r\n\r\nThe formatting could be done with `@tsv` by converting the data to an array, e.g.:\r\n\r\n**filter.jq**\r\n\r\n&lt;!-- language: lang-jq --&gt;\r\n\r\n    .[]                                        | \r\n    if (.sec == &quot;0&quot;) then del(.sec) else . end | \r\n    if (.pri == &quot;0&quot;) then del(.pri) else . end | \r\n    to_entries                                 |\r\n    map(&quot;\\(.key | ascii_upcase):\\(.value)&quot;)    |\r\n    @tsv\r\n\r\nRun it like this:\r\n\r\n    jq -crf filter.jq test.json\r\n\r\nOutput:\r\n\r\n&lt;!-- language: lang-none --&gt;\r\n\r\n    PLATFORM:p1\tID:5\tSEC:20\r\n    PLATFORM:p2\tID:6\tPRI:10\r\n\r\n",
                "title": "jq query with condition and format output/labels"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1516641758,
        "creation_date": 1516634204,
        "question_id": 48384783,
        "body_markdown": "I have a JSON file:\r\n\r\n    [\r\n      {\r\n        &quot;platform&quot;: &quot;p1&quot;,\r\n        &quot;id&quot;: &quot;5&quot;,\r\n        &quot;pri&quot;: &quot;0&quot;,\r\n        &quot;sec&quot;: &quot;20&quot;\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;platform&quot;: &quot;p2&quot;,\r\n        &quot;id&quot;: &quot;6&quot;,\r\n        &quot;pri&quot;: &quot;10&quot;,\r\n        &quot;sec&quot;: &quot;0&quot;\r\n      }\r\n    ]\r\n\r\nI can to format it to the form:\r\n\r\n    $ jq -c &#39;.[]|{PLATFORM: .platform, ID: .id, PRI: .pri, SEC: .sec}&#39; test.json\r\n    {&quot;PLATFORM&quot;:&quot;p1&quot;,&quot;ID&quot;:&quot;5&quot;,&quot;PRI&quot;:&quot;0&quot;,&quot;SEC&quot;:&quot;20&quot;}\r\n    {&quot;PLATFORM&quot;:&quot;p2&quot;,&quot;ID&quot;:&quot;6&quot;,&quot;PRI&quot;:&quot;10&quot;,&quot;SEC&quot;:&quot;0&quot;}\r\n    $\r\n\r\nbut how to ignore SEC/PRI with &quot;0&quot; and get output in form:\r\n\r\n    PLATFORM:p1, ID:5, SEC:20\r\n    PLATFORM:p2, ID:6, PRI:10\r\n\r\nI can process it with bash/awk command, but maybe someone have a solution with jq directly.\r\n\r\nthank you,\r\n    \r\n\r\n",
        "link": "https://stackoverflow.com/questions/48384783/jq-query-with-condition-and-format-output-labels",
        "title": "jq query with condition and format output/labels"
    },
    {
        "tags": [
            "json",
            "bash",
            "stdin",
            "jq",
            "chrome-native-messaging"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1516654899,
                "creation_date": 1516654899,
                "answer_id": 48390212,
                "question_id": 48385086,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming that file.json contains the JSON as indicated, I believe all you will need is:\r\n\r\n    json=$(jq &#39;{message: .}&#39; file.json)\r\n\r\nIf you then `echo &quot;$json&quot;`, the result will be:\r\n\r\n    {\r\n      &quot;message&quot;: {\r\n        &quot;text&quot;: &quot;abc&quot;\r\n      }\r\n    }\r\n\r\n",
                "title": "How to parse JSON from stdin at Native Messaging host?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1516654899,
        "creation_date": 1516635167,
        "question_id": 48385086,
        "body_markdown": "Utilizing the code at https://stackoverflow.com/questions/24764657/how-do-i-use-a-shell-script-as-chrome-native-messaging-host-application as a template and given the file `file.json` which contains\r\n\r\n    {&quot;text&quot;:&quot;abc&quot;}\r\n\r\n\r\nfollowing the code at https://stackoverflow.com/questions/48005870/iterate-over-json-with-jq/ and the [jq documentation][1]\r\n\r\n    $ cat file.json | jq --raw-output &#39;.text&#39;\r\n\r\noutputs\r\n\r\n    abc\r\n\r\nAm not certain how to incorporate the pattern at this [Answer][2]\r\n\r\n    while read -r id name date; do\r\n        echo &quot;Do whatever with ${id} ${name} ${date}&quot;\r\n    done&lt; &lt;(api-producing-json | jq --raw-output &#39;.newList[] | &quot;\\(.id) \\(.name) \\(.create.date)&quot;&#39;)\r\n\r\ninto the template at the former Answer for the purpose of capturing the single property `&quot;text&quot;` (`abc`) from the `JSON` within the loop using `jq` for the ability to pass that text to another system call then `printf` the message to client.\r\n\r\nWhat we are trying to achieve is \r\n\r\n    json=$(&lt;bash program&gt; &lt;captured JSON property&gt;)\r\n    message=&#39;{&quot;message&quot;: &quot;&#39;$json&#39;&quot;}&#39;\r\n\r\nwhere the `{&quot;text&quot;:&quot;abc&quot;}` is sent to the Native Messaging host from client (Chromium app).\r\n\r\nHow to use `jq` within the code at the former [Answer][3] to get the `JSON` property as a variable?\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/tutorial/\r\n  [2]: https://stackoverflow.com/a/48006169/\r\n  [3]: https://stackoverflow.com/a/24777120/",
        "link": "https://stackoverflow.com/questions/48385086/how-to-parse-json-from-stdin-at-native-messaging-host",
        "title": "How to parse JSON from stdin at Native Messaging host?"
    },
    {
        "tags": [
            "syntax",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1516713309,
                "last_edit_date": 1516713309,
                "creation_date": 1516691683,
                "answer_id": 48396077,
                "question_id": 48395816,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In JSON text, JSON keys are _always_ double-quoted. Perhaps your REST API was formatting it properly in double-quotes and your example in your last edit was incorrect. Because without the same `jq` cannot parse the syntax as a valid JSON.\r\n\r\nAs far the issue you are seeing, you need to put the field within quotes to let `jq` know that it is a single field `foo-bar` you are accessing and not as separate fields\r\n\r\n    jq &#39;.&quot;foo-bar&quot;&#39;\r\n\r\nOr more specifically use the array access operator as `jq &#39;.[&quot;foo-bar&quot;]&#39;`\r\n",
                "title": "jq not working with key including dash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1516950150,
        "creation_date": 1516690578,
        "last_edit_date": 1516950150,
        "question_id": 48395816,
        "body_markdown": "I have a REST API, which returns something like this:\r\n\r\n    {\r\n      &quot;foo&quot;: 1,\r\n      &quot;bar&quot;: 2,\r\n      &quot;foo-bar&quot;: 3\r\n    }\r\n\r\nwhen I do `http /endpoint/url | jq &#39;.foo-bar&#39;, it gave the following error:\r\n\r\n    jq: error (at &lt;stdin&gt;:1): null (null) and boolean (true) cannot be subtracted\r\n\r\nit looks like `jq` thinks I&#39;m trying to do arithmetic operation with `foo-bar`. \r\n\r\nHow do I correctly form this kind of path? Or this is a bug of jq?",
        "link": "https://stackoverflow.com/questions/48395816/jq-not-working-with-key-including-dash",
        "title": "jq not working with key including dash"
    },
    {
        "tags": [
            "json",
            "grep",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1516784035,
                "last_edit_date": 1516784035,
                "creation_date": 1516729782,
                "answer_id": 48407914,
                "question_id": 48407471,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Update: unexpectedly `grep` is sadly able to grep over multiple lines. See some other answers. And `jq` is realy tje right tool for the job.\r\n\r\nNonetheless, here is an `awk` solution :\r\n\r\n    $ awk &#39;/]/{p=0}p{print}/test1/{p=1}&#39; test \r\n        &quot;test_a&quot;,\r\n        &quot;test_b&quot;,\r\n        &quot;test_c&quot;\r\n\r\r\nOr a bit more generic\r\n\r\n    $ awk &#39;BEGIN{RS=&quot;\\&quot;test1\\&quot;: \\\\[\\n|\\n[[:blank:]]*\\\\]&quot;}(RT~/]/){print}&#39; test\r\n        &quot;test_a&quot;,\r\n        &quot;test_b&quot;,\r\n        &quot;test_c&quot;\r\n\r\nThe first solution searches for `test1` and sets a marker to print (`p=1`). If it finds a `]` it will set the print marker to zero.\r\n\r\nThe second solution defines a record separator to be or `\\&quot;test1\\&quot;: \\\\[\\n` or `\\n[[:blank:]]*\\\\]`. It will check the found record separator, if this is the correct one, it will print.\r\n\r\n\r\n[1]: https://stackoverflow.com/questions/2686147/how-to-find-patterns-across-multiple-lines-using-grep\r\n",
                "title": "Use grep for extract text between two word"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1516742302,
                "last_edit_date": 1516742302,
                "creation_date": 1516730194,
                "answer_id": 48408011,
                "question_id": 48407471,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "grep is not the best tool for this particular job, but if you must use it, this works:\r\n\r\n    cat test | grep -Pzo &#39;(?s)(?&lt;=test1\\&quot;: \\[)[^\\]]*(?=\\])&#39;\r\n\r\nWith the input above you specified, the output of this command is:\r\n\r\n        &quot;test_a&quot;,\r\n        &quot;test_b&quot;,\r\n        &quot;test_c&quot;\r\n\r\nThe -z option allows a pattern to match across multiple lines, in this case. The (?s) flag enables the [^\\\\]] pattern to also match newline characters.\r\n\r\nThe jq utility is designed for what you&#39;re trying to do:\r\n\r\n    cat test | jq &#39;.[&quot;test&quot;]&#39;\r\n\r\n",
                "title": "Use grep for extract text between two word"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1516731275,
                "last_edit_date": 1516731275,
                "creation_date": 1516730931,
                "answer_id": 48408186,
                "question_id": 48407471,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`sed -n &#39;/&quot;test1&quot;: \\[/,/\\]/{//!p}&#39; test`\r\n\r\n - `sed -n` only print lines from pattern buffer (modified input stream) when `p` command is used.\r\n - From pattern `/&quot;test1&quot;: \\[/` to pattern `/\\]/` using the `/START/,/END/{ ... }` syntax:\r\n - `//!p` print the line only if not matching the previous match\r\n\r\nThe generic form is `sed -n &#39;/START/,/END/{//!p}&#39; input-file` to omit START and END lines.  Or simply `sed -n &#39;/START/,/END/p&#39; input-file` if you want them.",
                "title": "Use grep for extract text between two word"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1516745757,
                "creation_date": 1516745757,
                "answer_id": 48411738,
                "question_id": 48407471,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Simply with **`jq`** tool:\r\n\r\n    jq -r &#39;.test1[]&#39; testfile\r\nThe output:\r\n\r\n    test_a\r\n    test_b\r\n    test_c\r\n\r\n",
                "title": "Use grep for extract text between two word"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1517114575,
        "creation_date": 1516728144,
        "last_edit_date": 1517114575,
        "question_id": 48407471,
        "body_markdown": "I hava a file:\r\n\r\n    {\r\n\t   &quot;test1&quot;: [\r\n\t\t    &quot;test_a&quot;,\r\n\t\t    &quot;test_b&quot;,\r\n\t\t    &quot;test_c&quot;\r\n\t   ]\r\n    }\r\n\r\n\r\nI am trying to extract the text that exists between `&quot;test1&quot;: [` and `]`\r\nI&#39;m trying this command:\r\n\r\n    cat test | grep -o -P &#39;(?&lt;=test&quot;: [).*(?=])&#39;\r\n\r\nBut it&#39;s not work. An idea?\r\n\r\nThanks !",
        "link": "https://stackoverflow.com/questions/48407471/use-grep-for-extract-text-between-two-word",
        "title": "Use grep for extract text between two word"
    },
    {
        "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": 1516740526,
                "post_id": 48410387,
                "comment_id": 83810756,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2027127,
                    "reputation": 113,
                    "user_id": 5208121,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bce1bbeb58ff227c78e7bd2ac4b2ff11?s=256&d=identicon&r=PG",
                    "display_name": "Ramaprakasha",
                    "link": "https://stackoverflow.com/users/5208121/ramaprakasha"
                },
                "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": 1516740527,
                "post_id": 48410387,
                "comment_id": 83810757,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1516743788,
                "last_edit_date": 1516743788,
                "creation_date": 1516740481,
                "answer_id": 48410540,
                "question_id": 48410387,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a solution that scans for all *.md strings:\r\n\r\n    jq -r &#39;.. | strings | select(endswith(&quot;.md&quot;))&#39;\r\n\r\nOutput:\r\n    \r\n    index.md\r\n    Aforeword.md\r\n    ch001.md\r\n    ch002.md\r\n\r\nIf you only want to check for strings that occur as key values:\r\n\r\n    .. | objects | .[] | strings | select( endswith(&quot;.md&quot;))\r\n\r\nYou might want to modify the selection criterion to allow for &quot;.MD&quot;, etc. So you might want to use `test(&quot;\\\\.md$&quot;; &quot;i&quot;)`",
                "title": "How to get only values from this json code?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1516743788,
        "creation_date": 1516739890,
        "last_edit_date": 1516740471,
        "question_id": 48410387,
        "body_markdown": "I want to list all values in form of string `*.md` no matter where they occur. How to achieve this in `jq`\r\n\r\n    [\r\n      {\r\n        &quot;Home Page&quot;: &quot;index.md&quot;\r\n      },\r\n      {\r\n        &quot;Chapters&quot;: [\r\n          {\r\n            &quot;Foreword&quot;: &quot;Aforeword.md&quot;\r\n          },\r\n          {\r\n            &quot;Chap1&quot;: &quot;ch001.md&quot;\r\n          },\r\n          {\r\n            &quot;Chap2&quot;: &quot;ch002.md&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/48410387/how-to-get-only-values-from-this-json-code",
        "title": "How to get only values from this json code?"
    },
    {
        "tags": [
            "json",
            "key",
            "edit",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1516753553,
                "creation_date": 1516753553,
                "answer_id": 48413027,
                "question_id": 48412767,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "### Q1\r\n\r\n    walk( if type==&quot;object&quot; and has(&quot;name&quot;) and .name[0:1] == &quot;_&quot;\r\n          then .name |= .[1:]\r\n          else . \r\n          end) \r\n\r\nIf your jq does not have `walk/1` then you can either upgrade to a more recent version of jq than 1.5, or include its `def`, which can be found at https://github.com/stedolan/jq/blob/master/src/builtin.jq\r\n\r\n\r\n### Q2\r\n    .. | objects | select(has(&quot;name&quot;) and .name[0:1] == &quot;_&quot;) | .value \r\n\r\nIf you are certain that the encoded string was a UTF-8 string, you could use jq&#39;s @base64d; otherwise, invoke jq with the -r option and pipe the results to a decoder as you indicated you planned to do.",
                "title": "JQ: How do I replace keys and values based on regex match?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1516939758,
        "creation_date": 1516751693,
        "last_edit_date": 1516939758,
        "question_id": 48412767,
        "body_markdown": "I have two questions:\r\n\r\n1. How can I use jq to search for &quot;name&quot; fields that start with an underscore (like `_RDS_PASSWORD`) and remove the leading underscore (so it becomes `RDS_PASSWORD`)\r\n\r\n2. How can I use jq for &quot;name&quot; fields that start with an underscore (like `_RDS_PASSWORD`) and pass the value of the value `cGFzc3dvcmQK` to be decoded via base64? (ex: &quot;cGFzc3dvcmQK&quot; | base64 --decode)\r\n\r\nInput:\r\n\r\n    [ \r\n      { \r\n        &quot;name&quot;: &quot;RDS_DB_NAME&quot;, \r\n        &quot;value&quot;: &quot;rds_db_name&quot; \r\n      }, \r\n      { \r\n        &quot;name&quot;: &quot;RDS_HOSTNAME&quot;, \r\n        &quot;value&quot;: &quot;rds_hostname&quot; \r\n      }, \r\n      { \r\n        &quot;name&quot;: &quot;RDS_PORT&quot;, \r\n        &quot;value&quot;: &quot;1234&quot; \r\n      }, \r\n      { \r\n        &quot;name&quot;: &quot;RDS_USERNAME&quot;, \r\n        &quot;value&quot;: &quot;rds_username&quot; \r\n      }, \r\n      { \r\n        &quot;name&quot;: &quot;_RDS_PASSWORD&quot;, \r\n        &quot;value&quot;: &quot;cGFzc3dvcmQK&quot; \r\n      } \r\n    ]\r\n\r\nDesired output:\r\n\r\n    [ \r\n      { \r\n        &quot;name&quot;: &quot;RDS_DB_NAME&quot;, \r\n        &quot;value&quot;: &quot;rds_db_name&quot; \r\n      }, \r\n      { \r\n        &quot;name&quot;: &quot;RDS_HOSTNAME&quot;, \r\n        &quot;value&quot;: &quot;rds_hostname&quot; \r\n      }, \r\n      { \r\n        &quot;name&quot;: &quot;RDS_PORT&quot;, \r\n        &quot;value&quot;: &quot;1234&quot; \r\n      }, \r\n      { \r\n        &quot;name&quot;: &quot;RDS_USERNAME&quot;, \r\n        &quot;value&quot;: &quot;rds_username&quot; \r\n      }, \r\n      { \r\n        &quot;name&quot;: &quot;RDS_PASSWORD&quot;, \r\n        &quot;value&quot;: &quot;password&quot; \r\n      } \r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48412767/jq-how-do-i-replace-keys-and-values-based-on-regex-match",
        "title": "JQ: How do I replace keys and values based on regex match?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1516799805,
                "post_id": 48423303,
                "comment_id": 83836282,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516800645,
                "post_id": 48423303,
                "comment_id": 83836827,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7730283,
                    "reputation": 534,
                    "user_id": 8683461,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/0e0261096af7948670d22e5cee928c0b?s=256&d=identicon&r=PG",
                    "display_name": "MarvinLeRouge",
                    "link": "https://stackoverflow.com/users/8683461/marvinlerouge"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516800821,
                "post_id": 48423303,
                "comment_id": 83836936,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7730283,
                    "reputation": 534,
                    "user_id": 8683461,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/0e0261096af7948670d22e5cee928c0b?s=256&d=identicon&r=PG",
                    "display_name": "MarvinLeRouge",
                    "link": "https://stackoverflow.com/users/8683461/marvinlerouge"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516801320,
                "post_id": 48423303,
                "comment_id": 83837277,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1777232,
                    "reputation": 22015,
                    "user_id": 1620779,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://i.sstatic.net/dlgGb.png?s=256",
                    "display_name": "sjsam",
                    "link": "https://stackoverflow.com/users/1620779/sjsam"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1516801378,
                "post_id": 48423303,
                "comment_id": 83837310,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1516812439,
                "creation_date": 1516812439,
                "answer_id": 48427638,
                "question_id": 48423303,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Extended solution with single **`jq`** invocation:\r\n\r\nSample `conf` array:\r\n\r\n    declare -A conf=([status]=&quot;finished&quot; [nextTo]=&quot;2018-01-24&quot; [result]=true)\r\nSample file `conf.json`:\r\n\r\n    {\r\n      &quot;status&quot;: &quot;running&quot;,\r\n      &quot;minFrom&quot;: &quot;2018-01-23&quot;,\r\n      &quot;maxTo&quot;: &quot;2018-01-24&quot;,\r\n      &quot;nextTo&quot;: &quot;2018-01-23&quot;,\r\n      &quot;nextFrom&quot;: &quot;2018-01-22&quot;\r\n    }\r\n\r\n\r\n----------\r\nProcessing:\r\n\r\n    jq --arg data &quot;$(paste -d&#39;:&#39; &lt;(printf &quot;%s\\n&quot; &quot;${!conf[@]}&quot;) &lt;(printf &quot;%s\\n&quot; &quot;${conf[@]}&quot;))&quot; \\\r\n       &#39;. as $conf | map($data | split(&quot;\\n&quot;)[] \r\n        | split(&quot;:&quot;) | {(.[0]) : .[1]}) \r\n        | add | $conf + .&#39; conf.json &gt; conf.tmp &amp;&amp; mv conf.tmp conf.json\r\n\r\n\r\n----------\r\n\r\n\r\nThe resulting `conf.json` contents:\r\n\r\n    {\r\n      &quot;status&quot;: &quot;finished&quot;,\r\n      &quot;minFrom&quot;: &quot;2018-01-23&quot;,\r\n      &quot;maxTo&quot;: &quot;2018-01-24&quot;,\r\n      &quot;nextTo&quot;: &quot;2018-01-24&quot;,\r\n      &quot;nextFrom&quot;: &quot;2018-01-22&quot;,\r\n      &quot;result&quot;: &quot;true&quot;\r\n    }\r\n\r\n",
                "title": "Send bash array to json file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1522329558,
                "creation_date": 1522329558,
                "answer_id": 49557158,
                "question_id": 48423303,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I finally run into the following solution : not as compact as RomanPerekhrest, but a bit more human-readable. Thanks.\r\n\r\n    function update_conf() {\r\n      echo update_conf\r\n      if [ -n &quot;$1&quot; ] &amp;&amp; [ -n &quot;$2&quot; ]; then\r\n        conf[$1]=$2\r\n      fi\r\n      for key in &quot;${!conf[@]}&quot;; do\r\n        value=${conf[$key]}\r\n        jq --arg key &quot;$key&quot; --arg value &quot;$value&quot; &#39;.[$key] = $value&#39; $confFile &gt; $confTempFile &amp;&amp; mv $confTempFile $confF$\r\n      done\r\n    }\r\n\r\n",
                "title": "Send bash array to json file"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1522329558,
        "creation_date": 1516799314,
        "question_id": 48423303,
        "body_markdown": "I pulled some config variables from a json file with jq.\r\nAnd once modified, i want to write the whole config array (which can contain keys that were not there at first) to the json file.\r\nThe &quot;foreach&quot; part seems quite obvious.\r\nBut how to express &quot;change keyA by value A or add keyA=&gt;valueA&quot; to the conf file ?\r\nI&#39;m stuck with something like\r\n\r\n    for key in &quot;${!conf[@]}&quot;; do\r\n        value=${conf[$key]}\r\n        echo $key $value\r\n        jq --arg key $key --arg value $value &#39;.$key = $value&#39; $conf_file &gt; $new_file\r\n    done\r\n\r\n \r\n\r\nThanks\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48423303/send-bash-array-to-json-file",
        "title": "Send bash array to json file"
    },
    {
        "tags": [
            "json",
            "utf-8",
            "binary",
            "jq",
            "implode"
        ],
        "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": 1516811410,
                "post_id": 48425781,
                "comment_id": 83844802,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2282940,
                    "reputation": 1596,
                    "user_id": 2007631,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3cfb97d041fd8f1d4c8a15b3f4d7b593?s=256&d=identicon&r=PG",
                    "display_name": "tsul",
                    "link": "https://stackoverflow.com/users/2007631/tsul"
                },
                "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": 1516816030,
                "post_id": 48425781,
                "comment_id": 83847771,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1516900316,
                "last_edit_date": 1516900316,
                "creation_date": 1516825484,
                "answer_id": 48431009,
                "question_id": 48425781,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    def btostring:\r\n      if length == 0 then &quot;&quot;\r\n    \r\n      elif .[0] &gt;= 240 then\r\n         ([((((.[0] - 240) * 64) + (.[1] - 128)) * 64 + (.[2] - 128)) * 64 + (.[3] - 128)]\r\n          | implode) + (.[4:] | btostring)\r\n    \r\n      elif .[0] &gt;= 224 then\r\n         ([  ((.[0] - 224) * 64 +  (.[1] - 128)) * 64 + (.[2] - 128)]\r\n          | implode) + (.[3:] | btostring)\r\n    \r\n      elif .[0] &gt;= 128 then\r\n         ([  (.[0] - 192)  * 64 +  (.[1] - 128) ]\r\n          | implode) + (.[2:] | btostring)\r\n    \r\n      else  (.[0:1] | implode ) + (.[1:] | btostring)\r\n      end;\r\n\r\n### Example:\r\n\r\n    def hi: [72,105,44,32,208,156,208,184,209,128,33] ;\r\n\r\n    hi | btostring\r\n\r\nOutput (using `jq -r`):\r\n\r\n    Hi, Мир!\r\n\r\n### Extended example:\r\n\r\n    def hi: [72,105,44,32,208,156,208,184,209,128,33];\r\n    def euro: [226,130,172];        # 11100010 10000010 10101100\r\n    def fire: [240,159,156,130];    # 11110000 10011111 10011100 10000010\r\n\r\n    (hi, euro, fire) | btostring\r\n\r\nOutput:\r\n\r\n    Hi, Мир!\r\n    €\r\n    &#128770;\r\n\r\n(On some devices, the last line above will be a box rather than a triangle.)\r\n",
                "title": "Convert an array of numeric byte values into a string with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1516828842,
                "last_edit_date": 1516828842,
                "creation_date": 1516827817,
                "answer_id": 48431552,
                "question_id": 48425781,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Yet another approach using `foreach`. The main idea is to keep the number of bytes left to read (`.[0]`) for the current char and the bits read so far (`.[1]`). Here is the filter:\r\n\r\n    [foreach .[] as $item (\r\n\t\t[0, 0]\r\n\t\t;\r\n\t\tif .[0] &gt; 0 then [.[0] - 1, .[1] * 64 + ($item % 64)]\r\n\t\telif $item &gt;= 240 then [3, $item % 8]\r\n\t\telif $item &gt;= 224 then [2, $item % 16]\r\n\t\telif $item &gt;= 192 then [1, $item % 32]\r\n\t\telif $item &lt; 128 then [0, $item]\r\n\t\telse error(&quot;Malformed UTF-8 bytes&quot;)\r\n\t\tend\r\n\t\t;\r\n\t\tif .[0] == 0 then .[1] else empty end\r\n\t)] | implode\r\n\r\nAlso, errors detection for malformed bytes is not complete.",
                "title": "Convert an array of numeric byte values into a string with jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1595272840,
                "last_edit_date": 1595272840,
                "creation_date": 1516860839,
                "answer_id": 48436690,
                "question_id": 48425781,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a non-recursive version of the recursive `btostring` given elsewhere on this page, mainly to illustrate how in jq a recursive implementation can be transmogrified into a non-recursive one. \r\n\r\n    def btostring:\r\n      . as $in\r\n      | [ foreach range(0;length) as $ix ({skip:0, point:[]};\r\n            if .skip &gt; 0 then .skip += -1\r\n            elif $in[$ix] &gt;= 240 then\r\n              .point = [(((($in[$ix]   - 240)  * 64)\r\n                         + ($in[$ix+1] - 128)) * 64\r\n                         + ($in[$ix+2] - 128)) * 64\r\n                         + ($in[$ix+3] - 128)]\r\n              | .skip = 3\r\n            elif $in[$ix] &gt;= 224 then\r\n              .point = [  (($in[$ix]   - 224)  * 64\r\n                         + ($in[$ix+1] - 128)) * 64\r\n                         + ($in[$ix+2] - 128)]\r\n              | .skip = 2\r\n            elif $in[$ix] &gt;= 128 then\r\n              .point = [   ($in[$ix]   - 192)  * 64\r\n                         + ($in[$ix+1] - 128)]\r\n              | .skip = 1\r\n            else .point = $in[$ix:$ix+1]\r\n            end;\r\n            if .skip == 0 then .point|implode else empty end) ]\r\n      | add ;\r\n\r\n\r\n\r\n",
                "title": "Convert an array of numeric byte values into a string with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1599070227,
                "creation_date": 1599070227,
                "answer_id": 63711319,
                "question_id": 48425781,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Based on the [answer of peak](https://stackoverflow.com/a/48431009) that I used successully, here&#39;s an extension that does not break or fail with invalid [UTF-8 encoding](https://en.wikipedia.org/wiki/UTF-8).\r\n\r\nInvalid UTF-8 start bytes (128-193, 245-255) or sequences are interpreted as ISO 8859-1.\r\n\r\n```\r\ndef btostring:\r\n\tif type != &quot;array&quot; then .\r\n\telif length == 0 then &quot;&quot;\r\n\telif .[0] &gt;= 245 then\r\n\t\t(.[0:1] | implode ) + (.[1:] | btostring)\r\n\telif .[0] &gt;= 240 then\r\n\t\tif length &gt;= 4 and .[1] &gt;= 128 and .[2] &gt;= 128 and .[3] &gt;= 128 then\r\n\t\t\t([((((.[0] - 240) * 64) + (.[1] - 128)) * 64 + (.[2] - 128)) * 64 + (.[3] - 128)] | implode) + (.[4:] | btostring)\r\n\t\telse\r\n\t\t\t(.[0:1] | implode ) + (.[1:] | btostring)\r\n\t\tend\r\n\telif .[0] &gt;= 224 then\r\n\t\tif length &gt;= 3 and .[1] &gt;= 128 and .[2] &gt;= 128 then\r\n\t\t\t([  ((.[0] - 224) * 64  + (.[1] - 128)) * 64 + (.[2] - 128)] | implode) + (.[3:] | btostring)\r\n\t\telse\r\n\t\t\t(.[0:1] | implode ) + (.[1:] | btostring)\r\n\t\tend\r\n\telif .[0] &gt;= 194 then\r\n\t\tif length &gt;= 2 and .[1] &gt;= 128 then\r\n\t\t\t([   (.[0] - 192) * 64  + (.[1] - 128) ] | implode) + (.[2:] | btostring)\r\n\t\telse\r\n\t\t\t(.[0:1] | implode ) + (.[1:] | btostring)\r\n\t\tend\r\n\telse\r\n\t\t(.[0:1] | implode ) + (.[1:] | btostring)\r\n\tend;\r\n```",
                "title": "Convert an array of numeric byte values into a string with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 3,
        "last_activity_date": 1599070227,
        "creation_date": 1516806799,
        "question_id": 48425781,
        "body_markdown": "I have the binary representation of an UTF-8 string as an array of numeric values, each in the range of 0..255.\r\n\r\nHow to convert that array into the string using `jq`? The built-in `implode` deals with the codepoint arrays only. Besides, there&#39;s no functions for bitwise operations in `jq`.\r\n\r\n----------\r\nSuch arrays are observed as values in the newman&#39;s (Postman CLI) json output, property `response.stream.data`.\r\n\r\nFor instance, the string &quot;Hi, Мир!&quot; goes into `[72,105,44,32,208,156,208,184,209,128,33]` byte array, while its codepoints are `[72,105,44,32,1052,1080,1088,33]`. `implode` of the latter gives the original string, while `implode` of the former gives &quot;Hi,&#208;&#208;&#184;&#209;!&quot; or something like that.",
        "link": "https://stackoverflow.com/questions/48425781/convert-an-array-of-numeric-byte-values-into-a-string-with-jq",
        "title": "Convert an array of numeric byte values into a string with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 86053,
                    "reputation": 19558,
                    "user_id": 239567,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/265b32c59a3233561c6cbfa25101537a?s=256&d=identicon&r=PG",
                    "display_name": "JAAulde",
                    "link": "https://stackoverflow.com/users/239567/jaaulde"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1516808150,
                "post_id": 48426052,
                "comment_id": 83842348,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 86053,
                    "reputation": 19558,
                    "user_id": 239567,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/265b32c59a3233561c6cbfa25101537a?s=256&d=identicon&r=PG",
                    "display_name": "JAAulde",
                    "link": "https://stackoverflow.com/users/239567/jaaulde"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1516808302,
                "post_id": 48426052,
                "comment_id": 83842486,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1495517,
                    "reputation": 17072,
                    "user_id": 1401560,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/347d89519bdf28150424b22543d0fbdb?s=256&d=identicon&r=PG",
                    "display_name": "Chris F",
                    "link": "https://stackoverflow.com/users/1401560/chris-f"
                },
                "reply_to_user": {
                    "account_id": 86053,
                    "reputation": 19558,
                    "user_id": 239567,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/265b32c59a3233561c6cbfa25101537a?s=256&d=identicon&r=PG",
                    "display_name": "JAAulde",
                    "link": "https://stackoverflow.com/users/239567/jaaulde"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516809228,
                "post_id": 48426052,
                "comment_id": 83843204,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 86053,
                    "reputation": 19558,
                    "user_id": 239567,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/265b32c59a3233561c6cbfa25101537a?s=256&d=identicon&r=PG",
                    "display_name": "JAAulde",
                    "link": "https://stackoverflow.com/users/239567/jaaulde"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516811079,
                "post_id": 48426052,
                "comment_id": 83844582,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 99786,
                    "reputation": 2247,
                    "user_id": 269361,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/124cda7f0e8d259e69d49ed43868639e?s=256&d=identicon&r=PG",
                    "display_name": "fool4jesus",
                    "link": "https://stackoverflow.com/users/269361/fool4jesus"
                },
                "edited": false,
                "score": 24,
                "creation_date": 1561723756,
                "post_id": 48426052,
                "comment_id": 100167276,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 127,
                "is_accepted": true,
                "score": 127,
                "last_activity_date": 1516816102,
                "last_edit_date": 1516816102,
                "creation_date": 1516809264,
                "answer_id": 48426543,
                "question_id": 48426052,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    $ jq -r &#39;.[].username&#39; my_file.json\r\n    jdoe\r\n    jadoe",
                "title": "How to extract a field from each object in an array with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 79,
        "last_activity_date": 1718656589,
        "creation_date": 1516807672,
        "last_edit_date": 1718656589,
        "question_id": 48426052,
        "body_markdown": "I performed a cURL request to get all the users in our Gitlab server, like this.\r\n\r\n    $ curl -H &quot;Private-Token: a;sldkfja;slkdfj&quot; https://gitlab.domain.com/api/v3/users?active=true &gt; my_file.json\r\n\r\n and (part of) my_file.json looks like:\r\n\r\n    [\r\n      {\r\n        &quot;username&quot; : &quot;jdoe&quot;,\r\n        &quot;name&quot; : &quot;John Doe&quot;,\r\n        ...\r\n      },\r\n      {\r\n        &quot;username&quot; : &quot;jadoe&quot;,\r\n        &quot;name&quot; : &quot;Jane Doe&quot;,\r\n        ...\r\n      }\r\n    ]\r\n\r\nI stored the response in `my_file.json`. How can I use `jq` to get all the `username` values?\r\n\r\n    $ cat my_file.json | jq -r &#39;what to put here?&#39;",
        "link": "https://stackoverflow.com/questions/48426052/how-to-extract-a-field-from-each-object-in-an-array-with-jq",
        "title": "How to extract a field from each object in an array with jq?"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1516865178,
                "last_edit_date": 1516865178,
                "creation_date": 1516864051,
                "answer_id": 48437372,
                "question_id": 48436391,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I try to use utility `sed` to extract keys list in **data** section. Here I assume the file name is `/tmp/data.json` which contains the origin json data.\r\n\r\n    sed -r -n &#39;/&quot;data&quot;/,/}/{/[{}]/d;s/^[[:space:]]*&quot;([^&quot;]+)&quot;:.*/\\U\\1/g;p}&#39; /tmp/data.json\r\n\r\nthe output is\r\n\r\n    HELLO1\r\n    SAMPLEKEY\r\n\r\n\r\n### Explanation\r\n1. The delimiter of json data is `&quot;data&quot;` and `}`, just use sed extract the lines list in them;\r\n2. `/[{}]/d` means remove lines which contain punctation `{` or `}`;\r\n3. Set `:` as field delimiter in a line, extract target characters befrom `:`, use `\\U` to upper all characters.\r\n\r\n### PS\r\nIf you wanna `export` them (export key=val), maybe you could try\r\n\r\n    sed -r -n &#39;/&quot;data&quot;/,/}/{/[{}]/d;s/^[[:space:]]*&quot;([^&quot;]+)&quot;:[[:space:]]*&quot;([^&quot;]+)&quot;.*$/\\1|\\2/g;p}&#39; /tmp/data.json | while IFS=&quot;|&quot; read -r item val;do item=&quot;${item^^}&quot;; item=&quot;${val}&quot;; export &quot;${item}&quot;; echo ${item}; done\r\n\r\nwhihin `while` loop.",
                "title": "reading keys shell"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1516866242,
                "creation_date": 1516866242,
                "answer_id": 48437902,
                "question_id": 48436391,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**`bash`** + **`jq`** solution:\r\n\r\nAssuming your *JSON* data is saved to `data.json` file:\r\n\r\n    IFS=$&#39;\\t&#39;; while read -r k v; do \r\n        export &quot;$k=\\&quot;$v\\&quot;&quot;\r\n    done &lt; &lt;(jq -r &#39;.data | to_entries[] | [(.key|ascii_upcase), .value] | @tsv&#39; data.json)\r\n\r\nResults:\r\n\r\n    $ echo &quot;$HELLO1&quot;\r\n    &quot;world1&quot;\r\n     echo &quot;$SAMPLEKEY&quot;\r\n    &quot;samplevalue&quot;\r\n\r\n\r\n",
                "title": "reading keys shell"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1517160945,
        "creation_date": 1516859231,
        "last_edit_date": 1517160945,
        "question_id": 48436391,
        "body_markdown": "Now, I have done the following: \r\n\r\n    for row in $(echo &quot;${values}&quot; | jq -r &#39;.[]&#39;); do\r\n    \t-jq() {\r\n    \t\techo ${row} | jq -r ${1}\r\n    \t}\r\n    \techo $(_jq &#39;.samplekey&#39;)\r\n    done\r\n\r\nHere, I am unable to figure out how to extract the keys without passing in the exact keyname. Please help me, thanks! \r\n  \r\n",
        "link": "https://stackoverflow.com/questions/48436391/reading-keys-shell",
        "title": "reading keys shell"
    },
    {
        "tags": [
            "syntax",
            "key",
            "jq",
            "abbreviation"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1604229432,
                "last_edit_date": 1604229432,
                "creation_date": 1516911751,
                "answer_id": 48451274,
                "question_id": 48450533,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could write:\r\n\r\n    ._source | .[&quot;index-pattern&quot;].fields\r\n\r\nor even:\r\n\r\n    ._source[&quot;index-pattern&quot;].fields\r\n\r\n\r\nExplanation: if &quot;x&quot; and &quot;y&quot; are alphanumeric strings that begin with an alphabetic character (where &quot;alphabetic&quot; includes &quot;_&quot;) then `.x | .y` can be abbreviated to `.x.y`.  \r\n\r\nThere are several other circumstances when `E | F` can be abbreviated, e.g. `E | .[]` can often be abbreviated to `E[]`. \r\n\r\nHowever, the general rule is: \r\n\r\n&gt; If an abbreviated form does not work, don&#39;t use it. ",
                "title": "jq special characters in nested keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1604229432,
        "creation_date": 1516908677,
        "last_edit_date": 1517826274,
        "question_id": 48450533,
        "body_markdown": "I have a json similar to the following:\r\n\r\n\r\n\r\n    {\r\n        &quot;_source&quot; : {\r\n            &quot;index-pattern&quot; : {\r\n                &quot;fields&quot; : &quot;&quot;\r\n            }\r\n        }\r\n    }\r\n\r\nI&#39;m trying to modify fields, but chaining the . identity operator, such as `&#39;jq ._source.[&quot;index-pattern&quot;].fields`&#39; produces the following error:\r\n\r\n    &#39;._source.[&quot;index-pattern&quot;]\r\n             ^\r\n    1 compile error&#39;\r\n\r\nAny ideas?\r\n\r\nthanks\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48450533/jq-special-characters-in-nested-keys",
        "title": "jq special characters in nested keys"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "missing-data",
            "tabular"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1516958530,
                "post_id": 48458395,
                "comment_id": 83909841,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10535450,
                    "reputation": 134,
                    "user_id": 7763491,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/82f6a41aadd199b02a90568dac472a2a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "am1991",
                    "link": "https://stackoverflow.com/users/7763491/am1991"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1516964645,
                "post_id": 48458395,
                "comment_id": 83912993,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1516964770,
                "creation_date": 1516964770,
                "answer_id": 48460130,
                "question_id": 48458395,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A partial solution for your problem.\r\n\r\nYou can put the values of an array on the same line if you use `@csv`.\r\n\r\nFor example, let&#39;s say you have \r\n\r\n    {\r\n      &quot;a&quot;: [1,2,3],\r\n      &quot;b&quot;: [\r\n        {\r\n          &quot;x&quot;: 10\r\n        },\r\n        {\r\n          &quot;x&quot;: 20\r\n        },\r\n        {\r\n          &quot;x&quot;: 30\r\n        }\r\n      ]\r\n    }\r\n\r\nTo obtain `1,2,3` you should use `jq &#39;.a | @csv&#39;`\r\n\r\nTo obtain `10,20,30` you should use `jq &#39;[.b[].x] | @csv&#39;`\r\n\r\nHope this helps!",
                "title": "Make JQ output a table"
            },
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1517003697,
                "last_edit_date": 1517003697,
                "creation_date": 1516975606,
                "answer_id": 48462929,
                "question_id": 48458395,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In the following, I&#39;ve used `@tsv` so the output can more easily be seen as a table, but you might want to use `@csv`.\r\n\r\nThe tricky part here is to put the 0s in the right place.  Creating a JSON &quot;dictionary&quot; (i.e. JSON object) makes it easy. Here, `normalize` takes advantage of the fact that jq will honor the order in which keys are added to an object. \r\n\r\n    def dates:\r\n      [&quot;2018-01-18&quot;, &quot;2018-01-19&quot;, &quot;2018-01-20&quot;, &quot;2018-01-21&quot;, &quot;2018-01-22&quot;, &quot;2018-01-23&quot;, &quot;2018-01-24&quot;, &quot;2018-01-25&quot;];\r\n    \r\n    def normalize:\r\n      . as $in \r\n      | reduce dates[] as $k ({}; .[$k] = ($in[$k] // 0));\r\n    \r\n    ([&quot;Asset&quot;] + dates),\r\n    (.aggregations.overall.buckets[].agg_per_name.buckets[]\r\n     | .key as $asset\r\n     | .totalMaxUptime_perDays.buckets\r\n     | map( { (.key_as_string | sub(&quot;T.*&quot;;&quot;&quot;) ): .totalMaxUptime.value } ) \r\n     | add\r\n     | normalize\r\n     | [$asset] + [.[]]\r\n     )\r\n    | @tsv\r\n\r\nYou might want to modify the above so that `dates` is computed from the data.\r\n\r\n### Output:\r\n\r\n    Asset\t2018-01-18\t2018-01-19\t2018-01-20\t2018-01-21\t2018-01-22\t2018-01-23\t2018-01-24\t2018-01-25\r\n    ASSET-DD583\t0\t0\t0\t0\t77598\t80789\t56885\t7392705\r\n    ASSET-DD568\t31241\t2952565\t2698235\t85436\t83201\t96467\t903\t12337946\r\n    ASSET-42631\t39054\t47634\t68264\t66243\t0\t0\t0\t47660\r\n\r\n\r\n**EDIT:** Parentheses around `$in[$k] // 0` have been added.",
                "title": "Make JQ output a table"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1546552979,
                "last_edit_date": 1546552979,
                "creation_date": 1546534812,
                "answer_id": 54026639,
                "question_id": 48458395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try the following:\r\n\r\n    cat input.json\r\n        | jq &#39;.aggregations.overall.buckets[0].agg_per_name.buckets[] |\r\n        .key + &quot;, &quot; + (.totalMaxUptime_perDays.buckets[] |\r\n        .key_as_string + &quot;, &quot; + (.totalMaxUptime.value | tostring))&#39; |column -t -s,",
                "title": "Make JQ output a table"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1630901384,
                "creation_date": 1630901384,
                "answer_id": 69069039,
                "question_id": 48458395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is a tool to this.\r\nhttps://github.com/uzimaru0000/tv\r\n\r\n    $ curl -s https://jsonplaceholder.typicode.com/users | tv\r\n    +--+------------------------+----------------+-------------------------+-------+---------------------+-------------+-------+\r\n    |id|name                    |username        |email                    |address|phone                |website      |company|\r\n    +--+------------------------+----------------+-------------------------+-------+---------------------+-------------+-------+\r\n    |1 |Leanne Graham           |Bret            |Sincere@april.biz        |...    |1-770-736-8031 x56442|hildegard.org|...    |\r\n    |2 |Ervin Howell            |Antonette       |Shanna@melissa.tv        |...    |010-692-6593 x09125  |anastasia.net|...    |\r\n    |3 |Clementine Bauch        |Samantha        |Nathan@yesenia.net       |...    |1-463-123-4447       |ramiro.info  |...    |\r\n    |4 |Patricia Lebsack        |Karianne        |Julianne.OConner@kory.org|...    |493-170-9623 x156    |kale.biz     |...    |\r\n    |5 |Chelsey Dietrich        |Kamren          |Lucio_Hettinger@annie.ca |...    |(254)954-1289        |demarco.info |...    |\r\n    |6 |Mrs. Dennis Schulist    |Leopoldo_Corkery|Karley_Dach@jasper.info  |...    |1-477-935-8478 x6430 |ola.org      |...    |\r\n    |7 |Kurtis Weissnat         |Elwyn.Skiles    |Telly.Hoeger@billy.biz   |...    |210.067.6132         |elvis.io     |...    |\r\n    |8 |Nicholas Runolfsdottir V|Maxime_Nienow   |Sherwood@rosamond.me     |...    |586.493.6943 x140    |jacynthe.com |...    |\r\n    |9 |Glenna Reichert         |Delphine        |Chaim_McDermott@dana.io  |...    |(775)976-6794 x41206 |conrad.com   |...    |\r\n    |10|Clementina DuBuque      |Moriah.Stanton  |Rey.Padberg@karina.biz   |...    |024-648-3804         |ambrose.net  |...    |\r\n    +--+------------------------+----------------+-------------------------+-------+---------------------+-------------+-------+",
                "title": "Make JQ output a table"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 3,
        "last_activity_date": 1630901384,
        "creation_date": 1516957795,
        "last_edit_date": 1516976221,
        "question_id": 48458395,
        "body_markdown": "My question is: how to make JQ output in a table format, replacing absent values with 0?\r\n   \r\nSo the input for JQ is the following Elastic Search JSON response:\r\n\r\n    {&quot;aggregations&quot;: {\r\n        &quot;overall&quot;: {\r\n            &quot;buckets&quot;: [\r\n                {\r\n                    &quot;key&quot;: &quot;2018-01-18T00:00:00.000Z-2018-01-25T19:33:16.010Z&quot;,\r\n                    &quot;from_as_string&quot;: &quot;2018-01-18T00:00:00.000Z&quot;,\r\n                    &quot;to&quot;: 1516908796010,\r\n                    &quot;to_as_string&quot;: &quot;2018-01-25T19:33:16.010Z&quot;,\r\n                    &quot;doc_count&quot;: 155569,\r\n                    &quot;agg_per_name&quot;: {\r\n                        &quot;doc_count_error_upper_bound&quot;: 0,\r\n                        &quot;sum_other_doc_count&quot;: 0,\r\n                        &quot;buckets&quot;: [\r\n                            {\r\n                                &quot;key&quot;: &quot;ASSET-DD583&quot;,\r\n                                &quot;doc_count&quot;: 3016,\r\n                                &quot;totalMaxUptime_perDays&quot;: {\r\n                                    &quot;buckets&quot;: [\r\n                                        {\r\n                                            &quot;key_as_string&quot;: &quot;2018-01-22T00:00:00.000Z&quot;,\r\n                                            &quot;key&quot;: 1516579200000,\r\n                                            &quot;doc_count&quot;: 161,\r\n                                            &quot;totalMaxUptime&quot;: {\r\n                                                &quot;value&quot;: 77598\r\n                                            }\r\n                                        },\r\n                                        {\r\n                                            &quot;key_as_string&quot;: &quot;2018-01-23T00:00:00.000Z&quot;,\r\n                                            &quot;key&quot;: 1516665600000,\r\n                                            &quot;doc_count&quot;: 251,\r\n                                            &quot;totalMaxUptime&quot;: {\r\n                                                &quot;value&quot;: 80789\r\n                                            }\r\n                                        },\r\n                                        {\r\n                                            &quot;key_as_string&quot;: &quot;2018-01-24T00:00:00.000Z&quot;,\r\n                                            &quot;key&quot;: 1516752000000,\r\n                                            &quot;doc_count&quot;: 192,\r\n                                            &quot;totalMaxUptime&quot;: {\r\n                                                &quot;value&quot;: 56885\r\n                                            }\r\n                                        },\r\n                                        {\r\n                                            &quot;key_as_string&quot;: &quot;2018-01-25T00:00:00.000Z&quot;,\r\n                                            &quot;key&quot;: 1516838400000,\r\n                                            &quot;doc_count&quot;: 2088,\r\n                                            &quot;totalMaxUptime&quot;: {\r\n                                                &quot;value&quot;: 7392705\r\n                                            }\r\n                                        }\r\n                                    ]\r\n                                }\r\n                            },\r\n                            {\r\n                                &quot;key&quot;: &quot;ASSET-DD568&quot;,\r\n                                &quot;doc_count&quot;: 2990,\r\n                                &quot;totalMaxUptime_perDays&quot;: {\r\n                                    &quot;buckets&quot;: [\r\n                                        {\r\n                                            &quot;key_as_string&quot;: &quot;2018-01-18T00:00:00.000Z&quot;,\r\n                                            &quot;key&quot;: 1516233600000,\r\n                                            &quot;doc_count&quot;: 106,\r\n                                            &quot;totalMaxUptime&quot;: {\r\n                                                &quot;value&quot;: 31241\r\n                                            }\r\n                                        },\r\n                                        {\r\n                                            &quot;key_as_string&quot;: &quot;2018-01-19T00:00:00.000Z&quot;,\r\n                                            &quot;key&quot;: 1516320000000,\r\n                                            &quot;doc_count&quot;: 241,\r\n                                            &quot;totalMaxUptime&quot;: {\r\n                                                &quot;value&quot;: 2952565\r\n                                            }\r\n                                        },\r\n                                        {\r\n                                            &quot;key_as_string&quot;: &quot;2018-01-20T00:00:00.000Z&quot;,\r\n                                            &quot;key&quot;: 1516406400000,\r\n                                            &quot;doc_count&quot;: 326,\r\n                                            &quot;totalMaxUptime&quot;: {\r\n                                                &quot;value&quot;: 2698235\r\n                                            }\r\n                                        },\r\n                                        {\r\n                                            &quot;key_as_string&quot;: &quot;2018-01-21T00:00:00.000Z&quot;,\r\n                                            &quot;key&quot;: 1516492800000,\r\n                                            &quot;doc_count&quot;: 214,\r\n                                            &quot;totalMaxUptime&quot;: {\r\n                                                &quot;value&quot;: 85436\r\n                                            }\r\n                                        },\r\n                                        {\r\n                                            &quot;key_as_string&quot;: &quot;2018-01-22T00:00:00.000Z&quot;,\r\n                                            &quot;key&quot;: 1516579200000,\r\n                                            &quot;doc_count&quot;: 279,\r\n                                            &quot;totalMaxUptime&quot;: {\r\n                                                &quot;value&quot;: 83201\r\n                                            }\r\n                                        },\r\n                                        {\r\n                                            &quot;key_as_string&quot;: &quot;2018-01-23T00:00:00.000Z&quot;,\r\n                                            &quot;key&quot;: 1516665600000,\r\n                                            &quot;doc_count&quot;: 50,\r\n                                            &quot;totalMaxUptime&quot;: {\r\n                                                &quot;value&quot;: 96467\r\n                                            }\r\n                                        },\r\n                                        {\r\n                                            &quot;key_as_string&quot;: &quot;2018-01-24T00:00:00.000Z&quot;,\r\n                                            &quot;key&quot;: 1516752000000,\r\n                                            &quot;doc_count&quot;: 5,\r\n                                            &quot;totalMaxUptime&quot;: {\r\n                                                &quot;value&quot;: 903\r\n                                            }\r\n                                        },\r\n                                        {\r\n                                            &quot;key_as_string&quot;: &quot;2018-01-25T00:00:00.000Z&quot;,\r\n                                            &quot;key&quot;: 1516838400000,\r\n                                            &quot;doc_count&quot;: 1769,\r\n                                            &quot;totalMaxUptime&quot;: {\r\n                                                &quot;value&quot;: 12337946\r\n                                            }\r\n                                        }\r\n                                    ]\r\n                                }\r\n                            },\r\n                            {\r\n                                &quot;key&quot;: &quot;ASSET-42631&quot;,\r\n                                &quot;doc_count&quot;: 2899,\r\n                                &quot;totalMaxUptime_perDays&quot;: {\r\n                                    &quot;buckets&quot;: [\r\n                                        {\r\n                                            &quot;key_as_string&quot;: &quot;2018-01-18T00:00:00.000Z&quot;,\r\n                                            &quot;key&quot;: 1516233600000,\r\n                                            &quot;doc_count&quot;: 132,\r\n                                            &quot;totalMaxUptime&quot;: {\r\n                                                &quot;value&quot;: 39054\r\n                                            }\r\n                                        },\r\n                                        {\r\n                                            &quot;key_as_string&quot;: &quot;2018-01-19T00:00:00.000Z&quot;,\r\n                                            &quot;key&quot;: 1516320000000,\r\n                                            &quot;doc_count&quot;: 172,\r\n                                            &quot;totalMaxUptime&quot;: {\r\n                                                &quot;value&quot;: 47634\r\n                                            }\r\n                                        },\r\n                                        {\r\n                                            &quot;key_as_string&quot;: &quot;2018-01-20T00:00:00.000Z&quot;,\r\n                                            &quot;key&quot;: 1516406400000,\r\n                                            &quot;doc_count&quot;: 214,\r\n                                            &quot;totalMaxUptime&quot;: {\r\n                                                &quot;value&quot;: 68264\r\n                                            }\r\n                                        },\r\n                                        {\r\n                                            &quot;key_as_string&quot;: &quot;2018-01-21T00:00:00.000Z&quot;,\r\n                                            &quot;key&quot;: 1516492800000,\r\n                                            &quot;doc_count&quot;: 220,\r\n                                            &quot;totalMaxUptime&quot;: {\r\n                                                &quot;value&quot;: 66243\r\n                                            }\r\n                                        },\r\n                                        {\r\n                                            &quot;key_as_string&quot;: &quot;2018-01-25T00:00:00.000Z&quot;,\r\n                                            &quot;key&quot;: 1516838400000,\r\n                                            &quot;doc_count&quot;: 128,\r\n                                            &quot;totalMaxUptime&quot;: {\r\n                                                &quot;value&quot;: 47660\r\n                                            }\r\n                                        }\r\n                                    ]\r\n                                }\r\n                            }\r\n                        ]\r\n                    }\r\n                }\r\n            ]\r\n        }\r\n    }\r\n    }\r\n\r\nThis JSON has some inherent properties:\r\n\r\n 1. There will be a variable number of buckets in agg_per_name.buckets\r\n 2. TotalMaxUptime_perDays.buckets represents a group by day for the last 7 days from the current date. The totalMaxUptime_perDays.buckets will have a number of buckets between 1 and 8 for every asset, each bucket corresponding to a certain date. \r\n\r\nThe desired output of JQ, for the given sample is a table where on horizontal you have the date from key_as_string (in this case from 18.01.2018 to 25.01.2018) and on vertical the all the asset keys (i.e. ASSET-DD583, ASSET-DD568, etc). The table is populated with totalMaxUptime.value for every corresponding date and if the date is not present in the result, a &quot;0&quot; value should be put instead:\r\n\r\n    XXXXXXXXXXX, 2018-01-18, 2018-01-19, 2018-01-20, 2018-01-21, 2018-01-22, 2018-01-23, 2018-01-24, 2018-01-25\r\n    ASSET-DD583, 0,           0,           0,         0,          77598,      80789,      56885,      7392705\r\n    ASSET-DD568, 31241,       2952565,     2698235,   85436,      83201,      96467,      903,        12337946\r\n    ASSET-42631, 39054,       47634,       68264,     66243,      0,          0,          0,          47660\r\n\r\n**EDIT 1:**\r\n\r\nThis is how far I got:\r\n\r\n    input.json | jq &#39;.aggregations.overall.buckets[0].agg_per_name.buckets[] | .key + &quot;, &quot; + (.totalMaxUptime_perDays.buckets[] | .key_as_string + &quot;, &quot; + (.totalMaxUptime.value | tostring))&#39; | sed &#39;s/&quot;//g&#39; | sed &#39;s/T00:00:00.000Z//g&#39;&gt; uptime.csv\r\n\r\nWhich produces this kind of output:\r\n\r\n    ASSET-DD583, 2018-01-22, 77598\r\n    ASSET-DD583, 2018-01-23, 80789\r\n    ASSET-DD583, 2018-01-24, 56885\r\n    ASSET-DD583, 2018-01-25, 7392705\r\n    ...............\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48458395/make-jq-output-a-table",
        "title": "Make JQ output a table"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1517242145,
                "post_id": 48505413,
                "comment_id": 84004888,
                "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": 1517242170,
                "post_id": 48505413,
                "comment_id": 84004910,
                "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": 1517242263,
                "post_id": 48505413,
                "comment_id": 84004968,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6591726,
                    "reputation": 1183,
                    "user_id": 5092659,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/hCBWY.png?s=256",
                    "display_name": "Samuel Kirschner",
                    "link": "https://stackoverflow.com/users/5092659/samuel-kirschner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1517243538,
                "post_id": 48505413,
                "comment_id": 84005804,
                "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": 1517246193,
                "post_id": 48505413,
                "comment_id": 84007538,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1574279416,
                "last_edit_date": 1574279416,
                "creation_date": 1517245338,
                "answer_id": 48506400,
                "question_id": 48505413,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This would be greatly simplified by only calling `jq` *once*.\r\n\r\n    host=${URL#http://}; host=${host#https://}; host=${host%%/*}\r\n    if ping -q -c 1 &quot;$host&quot;; then\r\n      result=SUCCESS\r\n    else\r\n      result=FAILED\r\n    fi\r\n    \r\n    JSON=$(\r\n      jq -c \\\r\n         --arg url &quot;$URL&quot; \\\r\n         --arg result &quot;$result&quot; \\\r\n         &#39;.metrics[].providerUrl |= $url\r\n          | .metrics[].providerResult |= $result\r\n      &#39; info.json\r\n    )",
                "title": "Update values in json with jq (shell script)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1574279416,
        "creation_date": 1517241992,
        "last_edit_date": 1517246081,
        "question_id": 48505413,
        "body_markdown": "I am trying to update a couple values in a json array (separate file) with a shell script. Basically the logic is, set an environment variable called URL, ping that URL and add it to the json-- if 0, update another json field to SUCCESS, else update to FAILED.\r\n\r\nHere is are the files:\r\n\r\ninfo.json:\r\n\r\n    {\r\n     &quot;name&quot;: &quot;PingTest&quot;,&quot;,\r\n     &quot;metrics&quot;: [\r\n    {\r\n      &quot;event_type&quot;: &quot;PingResult&quot;,\r\n      &quot;provider&quot;: &quot;test&quot;,\r\n      &quot;providerUrl&quot;: &quot;URL&quot;,\r\n      &quot;providerResult&quot;: &quot;RESULT&quot;\r\n    }\r\n    ]\r\n    }\r\n\r\n\r\npinger.sh:\r\n\r\n    #!/bin/sh\r\n\r\n    JSON=`cat info.json` #read in JSON\r\n\r\n    #Assume URL variable is set to www.dksmfdkf.com \r\n    ping -q -c 1 &quot;$URL&quot; &gt; /dev/null #ping url\r\n    if [ $? -eq 0 ]; then #if ping success, replace result in json template\r\n      JSON=`echo ${JSON} | jq --arg v &quot;$URL&quot; &#39;.metrics[].providerUrl |= $v&#39; \r\n      info.json`\r\n      JSON=`echo ${JSON} | jq &#39;.metrics[].providerResult |= &quot;SUCCESS&quot;&#39; info.json`\r\n    else\r\n      JSON=`echo ${JSON} | jq --arg v &quot;$URL&quot; &#39;.metrics[].providerUrl |= $v&#39; \r\n      info.json`\r\n      JSON=`echo ${JSON} | jq &#39;.metrics[].providerResult |= &quot;FAILED&quot;&#39; info.json`\r\n    fi\r\n\r\n    #Remove whitespace from json\r\n    JSON=`echo $JSON | tr -d &#39; \\t\\n\\r\\f&#39;`\r\n\r\n    #Print the result\r\n    echo &quot;$JSON&quot;\r\n\r\n\r\nThe problem is my json file isn&#39;t getting updated properly, example result when running:\r\n\r\n    home:InfraPingExtension home$ ./pinger.sh\r\n    ping: cannot resolve : Unknown host\r\n    {\r\n      &quot;name&quot;: &quot;PingTest&quot;,\r\n      &quot;metrics&quot;: [\r\n      {\r\n        &quot;event_type&quot;: &quot;PingResult&quot;,\r\n        &quot;provider&quot;: &quot;test&quot;,\r\n        &quot;providerUrl&quot;: &quot;&quot;,\r\n        &quot;providerResult&quot;: &quot;RESULT&quot;\r\n      }\r\n     ]\r\n     }\r\n    {\r\n      &quot;name&quot;: &quot;PingTest&quot;,\r\n      &quot;metrics&quot;: [\r\n    {\r\n      &quot;event_type&quot;: &quot;PingResult&quot;,\r\n      &quot;provider&quot;: &quot;test&quot;,\r\n      &quot;providerUrl&quot;: &quot;URL&quot;,\r\n      &quot;providerResult&quot;: &quot;FAILED&quot;\r\n    }\r\n      ]\r\n    }\r\n\r\n    {&quot;name&quot;:&quot;PingTest&quot;,&quot;metrics&quot;:[{&quot;event_type&quot;:&quot;PingResult&quot;,&quot;provider&quot;:&quot;test&quot;,&quot;providerUrl&quot;:&quot;URL&quot;,&quot;providerResult&quot;:&quot;RESULT&quot;}]}\r\n\r\n",
        "link": "https://stackoverflow.com/questions/48505413/update-values-in-json-with-jq-shell-script",
        "title": "Update values in json with jq (shell script)"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1517286765,
                "last_edit_date": 1517286765,
                "creation_date": 1517280060,
                "answer_id": 48513068,
                "question_id": 48512598,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following script produces the desired result, and should be fairly robust:\r\n \r\n    #!/bin/bash\r\n    \r\n    environments=(&#39;development&#39; &#39;stage&#39; &#39;production&#39;)\r\n    regions=(&#39;us-east-1&#39; &#39;us-west-2&#39;)\r\n    \r\n    jq -n --slurpfile e &lt;(for e in &quot;${environments[@]}&quot; ; do echo &quot;\\&quot;$e\\&quot;&quot;; done) \\\r\n       --slurpfile r &lt;(for r in &quot;${regions[@]}&quot; ; do echo &quot;\\&quot;$r\\&quot;&quot; ; done) \\\r\n       &#39;($r | map ({(.): {}}) | add) as $regions\r\n         | [{($e[]): $regions}] | add&#39;\r\n\r\nThe main point to note here is that in order to construct an object with a dynamically determined key, one has to use parentheses, as in `{(KEY): VALUE}`\r\n\r\nOf course, if the values for the &quot;environments&quot; and &quot;regions&quot; were available in a more convenient form, the above could be simplified.\r\n\r\n### Output\r\n\r\n    {\r\n      &quot;development&quot;: {\r\n        &quot;us-east-1&quot;: {},\r\n        &quot;us-west-2&quot;: {}\r\n      },\r\n      &quot;stage&quot;: {\r\n        &quot;us-east-1&quot;: {},\r\n        &quot;us-west-2&quot;: {}\r\n      },\r\n      &quot;production&quot;: {\r\n        &quot;us-east-1&quot;: {},\r\n        &quot;us-west-2&quot;: {}\r\n      }\r\n    }\r\n\r\n",
                "title": "add object to dynamic key using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1517286765,
        "creation_date": 1517276236,
        "last_edit_date": 1517286321,
        "question_id": 48512598,
        "body_markdown": "I&#39;m looking to build object using jq and add object key to dynamic key and I could not figure out. Here is my sample script:\r\n\r\n\r\n    #!/bin/bash -e\r\n    \r\n    environments=(&#39;development&#39; &#39;stage&#39; &#39;production&#39;)\r\n    regions=(&#39;us-east-1&#39; &#39;us-west-2&#39;)\r\n    \r\n    tree=&#39;{}&#39;\r\n    \r\n    for environment in &quot;${environments[@]}&quot;\r\n    do\r\n        echo &quot;${environment}&quot;\r\n        # Or do something else with environment\r\n\r\n        tree=&quot;$(jq --arg jqEnvironment &quot;${environment}&quot; &#39;. | .[$jqEnvironment] = {}&#39; &lt;&lt;&lt; &quot;${tree}&quot;)&quot;\r\n    \r\n        for region in &quot;${regions[@]}&quot;\r\n        do\r\n            echo &quot;${region}&quot;\r\n            # Or do something with region\r\n\r\n            tree=&quot;$(jq --arg jqEnvironment &quot;${environment}&quot; --arg jqRegion &quot;${region}&quot; &#39;. | .[$jqEnvironment] | .[$jqRegion] = {}&#39; &lt;&lt;&lt; &quot;${tree}&quot;)&quot;\r\n        done\r\n    done\r\n    \r\n    jq . &lt;&lt;&lt; &quot;${tree}&quot;\r\n\r\n\r\nactual outputs\r\n\r\n    {\r\n      &quot;us-west-2&quot;: {}\r\n    }\r\n\r\nBut what I want is this\r\n\r\n\r\n    {\r\n      &quot;development&quot;: {\r\n        &quot;us-east-1&quot;: {},\r\n        &quot;us-west-2&quot;: {}\r\n      },\r\n      &quot;stage&quot;: {\r\n        &quot;us-east-1&quot;: {},\r\n        &quot;us-west-2&quot;: {}\r\n      },\r\n      &quot;production&quot;: {\r\n        &quot;us-east-1&quot;: {},\r\n        &quot;us-west-2&quot;: {}\r\n      }\r\n    }\r\n\r\n\r\nI could not figure out, please help!\r\n",
        "link": "https://stackoverflow.com/questions/48512598/add-object-to-dynamic-key-using-jq",
        "title": "add object to dynamic key using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "environment-variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1592247,
                    "reputation": 11549,
                    "user_id": 1475324,
                    "user_type": "registered",
                    "accept_rate": 47,
                    "profile_image": "https://www.gravatar.com/avatar/59dca664e41227733ba8a0d1b4f9d73f?s=256&d=identicon&r=PG",
                    "display_name": "iamauser",
                    "link": "https://stackoverflow.com/users/1475324/iamauser"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1517280030,
                "post_id": 48512914,
                "comment_id": 84020898,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3824529,
                    "reputation": 7090,
                    "user_id": 3171657,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/J3bKr.png?s=256",
                    "display_name": "Turn",
                    "link": "https://stackoverflow.com/users/3171657/turn"
                },
                "reply_to_user": {
                    "account_id": 1592247,
                    "reputation": 11549,
                    "user_id": 1475324,
                    "user_type": "registered",
                    "accept_rate": 47,
                    "profile_image": "https://www.gravatar.com/avatar/59dca664e41227733ba8a0d1b4f9d73f?s=256&d=identicon&r=PG",
                    "display_name": "iamauser",
                    "link": "https://stackoverflow.com/users/1475324/iamauser"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1517280076,
                "post_id": 48512914,
                "comment_id": 84020913,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1517283035,
                "post_id": 48512914,
                "comment_id": 84021606,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2368034,
                    "reputation": 1417,
                    "user_id": 2073339,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/rtA7J.jpg?s=256",
                    "display_name": "Khaled AbuShqear",
                    "link": "https://stackoverflow.com/users/2073339/khaled-abushqear"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1597572994,
                "post_id": 48512914,
                "comment_id": 112171600,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 76,
                "is_accepted": true,
                "score": 74,
                "last_activity_date": 1593011850,
                "last_edit_date": 1593011850,
                "creation_date": 1517279833,
                "answer_id": 48513046,
                "question_id": 48512914,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Borrowing from [this answer][1] which does all of the hard work of turning the JSON into key=value pairs, you could get these into the environment by looping over the `jq` output and `export`ing them:\r\n\r\n    for s in $(echo $values | jq -r &quot;to_entries|map(\\&quot;\\(.key)=\\(.value|tostring)\\&quot;)|.[]&quot; ); do\r\n        export $s\r\n    done\r\n\r\nIf the variables being loaded contain embedded whitespace, this is also reasonable, if slightly more complex:\r\n\r\n    while read -rd $&#39;&#39; line\r\n    do\r\n        export &quot;$line&quot;\r\n    done &lt; &lt;(jq -r &lt;&lt;&lt;&quot;$values&quot; \\\r\n             &#39;to_entries|map(&quot;\\(.key)=\\(.value)\\u0000&quot;)[]&#39;)\r\n\r\n  [1]: https://stackoverflow.com/questions/25378013/how-to-convert-a-json-object-to-key-value-format-in-jq\r\n",
                "title": "Exporting JSON to environment variables"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1517283290,
                "creation_date": 1517283290,
                "answer_id": 48513487,
                "question_id": 48512914,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The approach illustrated by the following shell script avoids most (but not all) problems with special characters:\r\n\r\n    #!/bin/bash\r\n    \r\n    function json2keyvalue {\r\n       cat&lt;&lt;EOF | jq -r &#39;to_entries|map(&quot;\\(.key)\\t\\(.value|tostring)&quot;)[]&#39;\r\n    {\r\n        &quot;hello1&quot;: &quot;world1&quot;,\r\n        &quot;testk&quot;: &quot;testv&quot;\r\n    }\r\n    EOF\r\n    }\r\n    \r\n    while IFS=$&#39;\\t&#39; read -r key value\r\n    do\r\n        export &quot;$key&quot;=&quot;$value&quot;\r\n    done &lt; &lt;(json2keyvalue)\r\n    \r\n    echo hello1=&quot;$hello1&quot;\r\n    echo testk=&quot;$testk&quot;\r\n\r\nNote that the above assumes that there are no tabs in the keys themselves.",
                "title": "Exporting JSON to environment variables"
            },
            {
                "up_vote_count": 11,
                "is_accepted": false,
                "score": 11,
                "last_activity_date": 1517377844,
                "last_edit_date": 1517377844,
                "creation_date": 1517294268,
                "answer_id": 48515341,
                "question_id": 48512914,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using command substitution `$()` :\r\n\r\n    # $(jq -r &#39;keys[] as $k | &quot;export \\($k)=\\(.[$k])&quot;&#39; file.json)\r\n    # echo $testk\r\n    testv\r\n\r\n\r\n**Edit :** Responding to [this](https://stackoverflow.com/questions/48512914/exporting-json-to-environment-variables/48515341?noredirect=1#comment84051241_48515341) comment\r\n\r\nYou should do\r\n\r\n    $( echo &quot;$values&quot; | jq -r &#39;keys[] as $k | &quot;export \\($k)=\\(.[$k])&quot;&#39; )\r\n\r\nJust mind the `double` quotes around `$values`\r\n\r\n&lt;sup&gt;**Note:** Couldn&#39;t confirm if there is security implication to this approach, that is if the user could manipulate the `json` to wreak havoc.&lt;/sup&gt;",
                "title": "Exporting JSON to environment variables"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1573742795,
                "last_edit_date": 1592644375,
                "creation_date": 1573742795,
                "answer_id": 58859494,
                "question_id": 48512914,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another way, **without using [jq][1]**, is to parse the json with **grep &amp; sed**:\n\n    for keyval in $(grep -E &#39;&quot;: [^\\{]&#39; my.json | sed -e &#39;s/: /=/&#39; -e &quot;s/\\(\\,\\)$//&quot;); do\n        echo &quot;export $keyval&quot;\n        eval export $keyval\n    done\n\n***Explanation:***\n\n - First, grep will filter all ***&quot;key&quot; : value*** pairs (value can be\n   *&quot;string&quot;*, *number*, or *boolean*). \n - Then, sed will replace **`:`** with **`=`**, and remove trailing **`,`**.   \n - Lastly, exporting the `&quot;key&quot;=value` with eval\n\nHere&#39;s an output example, exporting json keys, from an AWS record-set:\n\n&gt; export &quot;Name&quot;=&quot;\\\\052.apps.nmanos-cluster-a.devcluster.openshift.com.&quot;\n&gt;\n&gt; export &quot;Type&quot;=&quot;A&quot; \n&gt;\n&gt; export &quot;HostedZoneId&quot;=&quot;Z67SXBLZRQ7X7T&quot; \n&gt;\n&gt; export &quot;DNSName&quot;=&quot;a24070461d50270e-1391692.us-east-1.elb.amazonaws.com.&quot;\n&gt;\n&gt; export &quot;EvaluateTargetHealth&quot;=false\n\n  [1]: https://stedolan.github.io/jq/",
                "title": "Exporting JSON to environment variables"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1597904687,
                "creation_date": 1597904687,
                "answer_id": 63499412,
                "question_id": 48512914,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[jtc][1] solution:\r\n```\r\nexport $(&lt;file.json jtc -w&#39;[:]&lt;&gt;a:&lt;L&gt;k&#39; -qqT&#39;&quot;{L}={}&quot;&#39;)\r\n```\r\n\r\n  [1]: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md",
                "title": "Exporting JSON to environment variables"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1713808502,
                "last_edit_date": 1713808502,
                "creation_date": 1633732140,
                "answer_id": 69502302,
                "question_id": 48512914,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "None of the existing answers preserve whitespace in the values in a POSIX shell. The following line will use `jq` to take each key:value of some JSON and export them as environment variables, properly escaping whitespace and special characters.\r\n\r\n**2023-01-28: BUGFIX UPDATE:** Please update your code to use the latest version of this answer.\r\n\r\nThis answer now appears to be the only one that handles all cases. There are no loops and it&#39;s one line to export all values.\r\n\r\n\r\n    eval &quot;export $(printf &quot;%s\\n&quot; &quot;$values&quot; | jq -r &#39;to_entries | map(&quot;\\(.key)=\\(.value)&quot;) | @sh&#39;)&quot;\r\n\r\n---\r\n\r\n\r\nSample JSON file:\r\n    \r\n    bash-5.2$ cat &lt;&lt;&#39;EOJSON&#39; &gt; foo.json\r\n    {\r\n     &quot;foo_1&quot;: &quot;bar 1&quot;,\r\n     &quot;foo_2&quot;: &quot;This ! is &#39; some @ weird $text { to ( escape \\&quot; here&quot;,\r\n     &quot;foo_3&quot;: &quot;this is some \\nsample new line\\n    text to\\ntry and escape&quot;\r\n    }\r\n    EOJSON\r\n\r\nSample script:\r\n\r\n    bash-5.2$ cat &lt;&lt;&#39;EOSH&#39; &gt; foo.sh\r\n    values=&quot;`cat foo.json`&quot;\r\n    eval &quot;export $(printf &quot;%s\\n&quot; &quot;$values&quot; | jq -r &#39;to_entries | map(&quot;\\(.key)=\\(.value)&quot;) | @sh&#39;)&quot;\r\n    export\r\n    echo &quot;foo_2: $foo_2&quot;\r\n    echo &quot;foo_3: $foo_3&quot;\r\n    EOSH\r\n\r\nRunning the sample script:\r\n\r\n    bash-5.2$ env -i sh foo.sh\r\n    export PWD=&#39;/path/to/my/home&#39;\r\n    export SHLVL=&#39;1&#39;\r\n    export foo_1=&#39;bar 1&#39;\r\n    export foo_2=&#39;This ! is &#39;&quot;&#39;&quot;&#39; some @ weird $text { to ( escape &quot; here&#39;\r\n    export foo_3=&#39;this is some \r\n    sample new line\r\n        text to\r\n    try and escape&#39;\r\n    foo_2: This ! is &#39; some @ weird $text { to ( escape &quot; here\r\n    foo_3: this is some \r\n    sample new line\r\n        text to\r\n    try and escape\r\n\r\nPros:\r\n - no need for Bash\r\n - preserves whitespace in values\r\n - no loops\r\n - **(bugfix 2023-01-28)** properly escapes all values for use in the shell\r\n\r\nCons:\r\n - uses `eval`, which is considered &quot;unsafe&quot;; however, because `jq` is escaping all input, this is unlikely to cause a security issue (unless `jq` is found to have a bug which does not properly escape data using the *@sh* filter).",
                "title": "Exporting JSON to environment variables"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1650642650,
                "creation_date": 1650642650,
                "answer_id": 71971471,
                "question_id": 48512914,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;ve come up with a solution (here in bash):\r\n\r\n```bash\r\nfunction source_json_as_environ() {\r\n  eval &quot;$(jq -r &#39;\r\n  def replace_dot:\r\n    . | gsub(&quot;\\\\.&quot;; &quot;_&quot;);\r\n  def trim_spaces:\r\n    . | gsub(&quot;^[ \\t]+|[ \\t]+$&quot;; &quot;&quot;);\r\n  to_entries|map(\r\n    &quot;export \\(.key|trim_spaces|replace_dot)=&quot;\r\n    + &quot;\\(.value|tostring|trim_spaces|@sh)&quot;\r\n    )|.[]&#39; $@)&quot;\r\n}\r\n```\r\n\r\nAnd you can use it like this:\r\n```\r\n$ source_json_as_environ values.json\r\n```",
                "title": "Exporting JSON to environment variables"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1680511386,
                "creation_date": 1680511386,
                "answer_id": 75917544,
                "question_id": 48512914,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "here&#39;s a improved version based on above answers, that handles well spaces and line breaks:\r\n\r\n```\r\nexport ENVS=&#39;{&quot;BASE_URL&quot;: &quot;JUICEFS_CONSOLE_URL/static&quot;, &quot;CFG_URL&quot;: &quot;JUICEFS_CONSOLE_URL/volume/mount&quot;}&#39;\r\nfor keyval in $(echo $ENVS | sed -e &#39;s/&quot;: &quot;/=/g&#39; -e &#39;s/{&quot;//g&#39; -e &#39;s/&quot;, &quot;/ /g&#39; -e &#39;s/&quot;}//g&#39; ); do\r\n    echo &quot;export $keyval&quot;\r\ndone\r\n\r\nexport ENVS=&#39;{&quot;BASE_URL&quot;: &quot;JUICEFS_CONSOLE_URL/static&quot;,\r\n    &quot;CFG_URL&quot;: &quot;JUICEFS_CONSOLE_URL/volume/mount&quot;}&#39;\r\nfor keyval in $(echo $ENVS | sed -e &#39;s/&quot;: &quot;/=/g&#39; -e &#39;s/{&quot;//g&#39; -e &#39;s/&quot;, &quot;/ /g&#39; -e &#39;s/&quot;}//g&#39; ); do\r\n    echo &quot;export $keyval&quot;\r\ndone\r\n\r\nexport ENVS=&#39;{&quot;BASE_URL&quot;: &quot;JUICEFS_CONSOLE_URL/static&quot;,   &quot;CFG_URL&quot;: &quot;JUICEFS_CONSOLE_URL/volume/mount&quot;}&#39;\r\nfor keyval in $(echo $ENVS | sed -e &#39;s/&quot;: &quot;/=/g&#39; -e &#39;s/{&quot;//g&#39; -e &#39;s/&quot;, &quot;/ /g&#39; -e &#39;s/&quot;}//g&#39; ); do\r\n    echo &quot;export $keyval&quot;\r\ndone\r\n```",
                "title": "Exporting JSON to environment variables"
            }
        ],
        "is_answered": true,
        "answer_count": 8,
        "score": 63,
        "last_activity_date": 1713808502,
        "creation_date": 1517278714,
        "last_edit_date": 1610048730,
        "question_id": 48512914,
        "body_markdown": "If I have a JSON like this, \r\n\r\n    {\r\n    \t&quot;hello1&quot;: &quot;world1&quot;,\r\n    \t&quot;testk&quot;: &quot;testv&quot;\r\n    }\r\n\r\nAnd I want to export each of these key-value pairs as environment variables, how to do it via shell script? So for example, when I write on the terminal, `echo $hello1`, `world1` should be printed and similarly for other key-value pairs? \r\nNote: The above JSON is present in a variable called `$values` and not in a file. \r\n\r\nI know it will be done via `jq` and written a shell script for this, but it doesn&#39;t work.\r\n\r\n    for row in $(echo &quot;${values}&quot; | jq -r &#39;.[]&#39;); do\r\n        -jq() {\r\n            echo ${row} | jq -r ${1}\r\n        }\r\n        echo $(_jq &#39;.samplekey&#39;)\r\n    done",
        "link": "https://stackoverflow.com/questions/48512914/exporting-json-to-environment-variables",
        "title": "Exporting JSON to environment variables"
    }
]