[
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 71,
                "is_accepted": true,
                "score": 71,
                "last_activity_date": 1500377775,
                "creation_date": 1500377775,
                "answer_id": 45165687,
                "question_id": 45165303,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to call `join()` on the `tags` list, not the individual tags. Try with:\r\n\r\n    jq -r &#39;.tickets[] | [.created_at, .id, .via.channel, (.tags | join(&quot;,&quot;))] | @csv&#39;",
                "title": "How to combine an array into a single string value when using CSV output in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 45,
        "last_activity_date": 1500377775,
        "creation_date": 1500376709,
        "question_id": 45165303,
        "body_markdown": "I have the following `jq` command:\r\n\r\n    cat myFile.json | jq -r &#39;.tickets[] | [.created_at, .id, .via.channel, .tags[]] | @csv&#39;\r\n\r\nAnd it outputs a line such as:\r\n\r\n    &quot;2016-02-02T10:00:00Z&quot;,99999,&quot;web&quot;,&quot;tag1&quot;,&quot;tag2&quot;,&quot;tag3&quot;,&quot;tag4&quot;\r\n\r\nI&#39;m trying to `join` the `.tags[]` array, so that I can get:\r\n\r\n    &quot;2016-02-19T13:25:55Z&quot;,99999,&quot;web&quot;,&quot;tag1,tag2,tag3,tag4&quot;\r\n\r\nI&#39;ve tried a few things, such as\r\n\r\n    cat myFile.json | jq -r &#39;.tickets[] | [.created_at, .id, .via.channel, (.tags[] | join(&quot;,&quot;))] | @csv&#39;\r\n\r\nBut it gives errors such as \r\n\r\n    jq: error (at &lt;stdin&gt;:0): Cannot iterate over string (&quot;tag1...)\r\n\r\nSo, how can I join `.tags[]` in the command above so that instead of separate fields, I get a single string value (containing comma separated tag values in it)?",
        "link": "https://stackoverflow.com/questions/45165303/how-to-combine-an-array-into-a-single-string-value-when-using-csv-output-in-jq",
        "title": "How to combine an array into a single string value when using CSV output in jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "command-line",
            "count",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7750510,
                    "reputation": 134447,
                    "user_id": 5866580,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/f69cec226400d61f887446d813471488?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RavinderSingh13",
                    "link": "https://stackoverflow.com/users/5866580/ravindersingh13"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1500391264,
                "post_id": 45170897,
                "comment_id": 77310004,
                "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": 1500392269,
                "post_id": 45170897,
                "comment_id": 77310820,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2032576,
                    "reputation": 2308,
                    "user_id": 1815837,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4b095ab1b2554345af93b82b7a9c02f0?s=256&d=identicon&r=PG",
                    "display_name": "skr",
                    "link": "https://stackoverflow.com/users/1815837/skr"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1500394132,
                "post_id": 45170897,
                "comment_id": 77312090,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 29,
                "is_accepted": true,
                "score": 29,
                "last_activity_date": 1636478410,
                "last_edit_date": 1636478410,
                "creation_date": 1500392172,
                "answer_id": 45171347,
                "question_id": 45170897,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one solution (assuming the input is a stream of valid JSON objects) and that you invoke jq with the -s option:\r\n\r\n    map({ItemId: .Properties.ItmId})             # extract the ItmID values\r\n    | group_by(.ItemId)                          # group by &quot;ItemId&quot;\r\n    | map({ItemId: .[0].ItemId, Count: length})  # store the counts\r\n    | .[]                                        # convert to a stream\r\n\r\nA slightly more memory-efficient approach would be to use `inputs` if your jq has it; but in that case, use -n instead of -s, and replace the first line above by: [inputs | {ItemId: .Properties.ItmId} ]\r\n\r\n## Efficient solution\r\n\r\nThe above solutions use the built-in `group_by`, which is convenient but leads to easily-avoided inefficiencies.  Using the following `counter` makes it easy to write a very efficient solution:\r\n\r\n    def counter(stream):\r\n      reduce stream as $s ({}; .[$s|tostring] += 1);\r\n\r\nUsing the -n command-line option, and applied as follows:\r\n    \r\n    counter(inputs | .Properties.ItmId)\r\n\r\nthis leads to a dictionary of counts:\r\n```\r\n{\r\n  &quot;1694738780&quot;: 1,\r\n  &quot;1347809133&quot;: 1\r\n}\r\n```\r\n\r\nSuch a dictionary is probably more useful than a stream of singleton objects as envisioned by the OP, but if such as stream is needed, one can modify the above as follows:\r\n\r\n    counter(inputs | .Properties.ItmId)\r\n    | to_entries[]\r\n    | {ItemId: (.key), Count: .value}\r\n\r\n\r\n",
                "title": "jq count the number of items in json by a specific key"
            },
            {
                "up_vote_count": 20,
                "is_accepted": false,
                "score": 20,
                "last_activity_date": 1500394220,
                "creation_date": 1500394220,
                "answer_id": 45172115,
                "question_id": 45170897,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using jq command\r\n\r\n    cat json.txt | jq &#39;.Properties .ItmId&#39; | sort | uniq -c | awk -F &quot; &quot; &#39;{print &quot;{\\&quot;ItmId\\&quot;:&quot; $2 &quot;,\\&quot;count\\&quot;:&quot; $1&quot;}&quot;}&#39;| jq .",
                "title": "jq count the number of items in json by a specific key"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1500433939,
                "last_edit_date": 1500433939,
                "creation_date": 1500407453,
                "answer_id": 45175841,
                "question_id": 45170897,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a super-efficient solution -- in particular, no sorting is required. The following implementation requires a version of jq with `inputs` but it is easy to adapt the program to use earlier versions of jq.  Please remember to use the -n command-line option if using the following:\r\n\r\n    # Count the occurrences of distinct values of (stream|tostring).\r\n    # To avoid unwanted collisions, or to recover the exact values,\r\n    # consider using tojson\r\n    def counter(stream):\r\n      reduce stream as $s ({}; .[$s|tostring] += 1);\r\n    \r\n    counter(inputs | .Properties.ItmId)\r\n    | to_entries[]\r\n    | {ItemId: (.key), Count: .value}\r\n\r\n",
                "title": "jq count the number of items in json by a specific key"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1501277298,
                "creation_date": 1501277298,
                "answer_id": 45382680,
                "question_id": 45170897,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a variation using **reduce**, **setpath** and **getpath** to do the aggregation and **to_entries** to do the final formatting which assumes you run jq as\r\n\r\n    jq --slurp -f query.jq &lt; data.json\r\n\r\nwhere **data.json** contains your data and **query.jq** contains\r\n\r\n      map(.Properties.ItmId)\r\n    | reduce .[] as $i (\r\n        {}; setpath([$i]; getpath([$i]) + 1)\r\n      )\r\n    | to_entries | .[] | { &quot;ItemId&quot;: .key, &quot;Count&quot;: .value }\r\n",
                "title": "jq count the number of items in json by a specific key"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1666980418,
                "creation_date": 1666980418,
                "answer_id": 74239333,
                "question_id": 45170897,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If text output suffices, you can do this simply with\r\n```\r\n$ jq -r &lt;test.json &#39;.Properties.ItmId&#39; |sort |uniq -c\r\n   2 1347809133\r\n   1 1694738780\r\n```\r\n\r\nIf you really need JSON lines, you could do this with\r\n```\r\n$ jq -r &lt;test.json &#39;.Properties.ItmId&#39; |sort |uniq -c |awk &#39;{printf &quot;{ItemId: %s, Count: %s}\\n&quot;,$2,$1 }&#39; \r\n{ItemId: 1347809133, Count: 2}\r\n{ItemId: 1694738780, Count: 1}\r\n```",
                "title": "jq count the number of items in json by a specific key"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 34,
        "last_activity_date": 1666980418,
        "creation_date": 1500391053,
        "last_edit_date": 1517441589,
        "question_id": 45170897,
        "body_markdown": "The following is the first two items in my json file\r\n\r\n    {\r\n    &quot;ReferringUrl&quot;: &quot;N&quot;,\r\n    &quot;OpenAccess&quot;: &quot;0&quot;,\r\n    &quot;Properties&quot;: {\r\n        &quot;ItmId&quot;: &quot;1694738780&quot;\r\n       }\r\n    }\r\n    {\r\n    &quot;ReferringUrl&quot;: &quot;L&quot;,\r\n    &quot;OpenAccess&quot;: &quot;1&quot;,\r\n    &quot;Properties&quot;: {\r\n        &quot;ItmId&quot;: &quot;1347809133&quot;\r\n      }\r\n    }\r\n\r\nI want to count the number of items by each ItmId appeared in the json. For example, items that with &quot;ItmId&quot; 1694738780 appears 10 times and items with &quot;ItmId&quot; 1347809133 appears 14 times in my json file. Then return a json like this\r\n\r\n    {&quot;ItemId&quot;: &quot;1694738780&quot;,\r\n     &quot;Count&quot;:  10\r\n    }\r\n    {&quot;ItemId&quot;: &quot;1347809133&quot;,\r\n     &quot;Count&quot;:  14\r\n    }\r\nI am using bash. And prefer do this totally by jq. But it&#39;s ok to use other method.\r\n\r\nThank you!!!",
        "link": "https://stackoverflow.com/questions/45170897/jq-count-the-number-of-items-in-json-by-a-specific-key",
        "title": "jq count the number of items in json by a specific key"
    },
    {
        "tags": [
            "json",
            "bash",
            "addition",
            "jq",
            "ndjson"
        ],
        "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": 1500478170,
                "post_id": 45194907,
                "comment_id": 77357405,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 9734066,
                    "reputation": 2907,
                    "user_id": 8228358,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/6ea83d263c43e790340b8f097ed1e36b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Eleanor",
                    "link": "https://stackoverflow.com/users/8228358/eleanor"
                },
                "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": 1500478202,
                "post_id": 45194907,
                "comment_id": 77357429,
                "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": 1500478301,
                "post_id": 45194907,
                "comment_id": 77357509,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1500478552,
                "creation_date": 1500478552,
                "answer_id": 45195146,
                "question_id": 45194907,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It&#39;s a bit kludgey, but given your input:\r\n\r\n    jq -c &#39;\r\n      reduce .[] as $item ({}; .[($item.id)] += ($item.Count))\r\n      | to_entries\r\n      | .[] | {&quot;id&quot;: .key, &quot;Count&quot;: .value}\r\n    &#39;\r\n\r\nYields the output:\r\n\r\n    {&quot;id&quot;:&quot;AQ&quot;,&quot;Count&quot;:0}\r\n    {&quot;id&quot;:&quot;AR&quot;,&quot;Count&quot;:34}\r\n    {&quot;id&quot;:&quot;AS&quot;,&quot;Count&quot;:0}",
                "title": "jq add value of a key in nested array and given to a new key"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1500518814,
                "last_edit_date": 1500518814,
                "creation_date": 1500480048,
                "answer_id": 45195630,
                "question_id": 45194907,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming the .id is the same in each array:\r\n\r\n    first + {Count: map(.Count) | add}\r\n\r\nOr perhaps more intelligibly:\r\n\r\n    (map(.Count) | add) as $sum | first | .Count = $sum\r\n\r\nOr more declaratively:\r\n\r\n    { id: (first|.id), Count: (map(.Count) | add) }\r\n",
                "title": "jq add value of a key in nested array and given to a new key"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1500481764,
                "creation_date": 1500481764,
                "answer_id": 45196158,
                "question_id": 45194907,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you want an efficient but generic solution that does NOT assume each input array has the same ids, then the following helper function makes a solution easy:\r\n\r\n    # Input: a JSON object representing the subtotals\r\n    # Output: the object augmented with additional subtotals\r\n    def adder(stream; id; filter):\r\n      reduce stream as $s (.; .[$s|id] += ($s|filter));\r\n\r\nAssuming your jq has `inputs`, then the most efficient approach is to use it (but remember to use the -n command-line option):\r\n\r\n    reduce inputs as $row ({}; adder($row[]; .id; .Count) )\r\n\r\nThis produces:\r\n\r\n    {&quot;AQ&quot;:0,&quot;AR&quot;:34,&quot;AS&quot;:0}\r\n\r\nFrom here, it&#39;s easy to get the answer you want, e.g. using `to_entries[] | {(.key): .value}`\r\n\r\nIf your jq does not have `inputs` and if you don&#39;t want to upgrade, then use the -s option (instead of -n) and replace `inputs` by `.[]`\r\n\r\n\r\n",
                "title": "jq add value of a key in nested array and given to a new key"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1500518814,
        "creation_date": 1500477924,
        "last_edit_date": 1500485185,
        "question_id": 45194907,
        "body_markdown": "I have a stream of JSON arrays like this\r\n\r\n    [{&quot;id&quot;:&quot;AQ&quot;,&quot;Count&quot;:0}]\r\n    [{&quot;id&quot;:&quot;AR&quot;,&quot;Count&quot;:1},{&quot;id&quot;:&quot;AR&quot;,&quot;Count&quot;:3},{&quot;id&quot;:&quot;AR&quot;,&quot;Count&quot;:13},\r\n    {&quot;id&quot;:&quot;AR&quot;,&quot;Count&quot;:12},{&quot;id&quot;:&quot;AR&quot;,&quot;Count&quot;:5}]\r\n    [{&quot;id&quot;:&quot;AS&quot;,&quot;Count&quot;:0}]\r\n\r\nI want to use jq to get a new json like this\r\n\r\n    {&quot;id&quot;:&quot;AQ&quot;,&quot;Count&quot;:0}\r\n    {&quot;id&quot;:&quot;AR&quot;,&quot;Count&quot;:34}\r\n    {&quot;id&quot;:&quot;AS&quot;,&quot;Count&quot;:0}\r\n\r\n34=1+3+13+12+5 which are in the second array.\r\nI don&#39;t know how to describe it in detail. But the basic idea is shown in my example. \r\nI use bash and prefer to use jq to solve this problem. Thank you!\r\n",
        "link": "https://stackoverflow.com/questions/45194907/jq-add-value-of-a-key-in-nested-array-and-given-to-a-new-key",
        "title": "jq add value of a key in nested array and given to a new key"
    },
    {
        "tags": [
            "json",
            "bash",
            "unix",
            "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": 1500580121,
                "post_id": 45223809,
                "comment_id": 77414110,
                "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": 1500580196,
                "post_id": 45223809,
                "comment_id": 77414144,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 16,
                "is_accepted": true,
                "score": 16,
                "last_activity_date": 1500580142,
                "last_edit_date": 1500580142,
                "creation_date": 1500579694,
                "answer_id": 45223887,
                "question_id": 45223809,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "What you want is:\r\n\r\n    jq -r &#39;.[&quot;ISBN:039397281X&quot;].preview_url&#39;\r\n\r\nor, more simply:\r\n\r\n    jq -r &#39;.[].preview_url&#39;\r\n\r\nThe syntax `.foo` can only be used to extract the value associated with key `foo` when `foo` is a valid identifier. Colons are not valid in identifier names, so a different syntax (`.[&quot;foo&quot;]`) must be used.",
                "title": "jq syntax error extracting key with colon in its name"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1500580142,
        "creation_date": 1500579408,
        "last_edit_date": 1500579898,
        "question_id": 45223809,
        "body_markdown": "I have the following JSON (which can be retrieved from https://openlibrary.org/api/books?bibkeys=ISBN:039397281X&amp;format=json) as input:\r\n\r\n    {\r\n      &quot;ISBN:039397281X&quot;: {\r\n        &quot;bib_key&quot;: &quot;ISBN:039397281X&quot;,\r\n        &quot;preview&quot;: &quot;borrow&quot;,\r\n        &quot;thumbnail_url&quot;: &quot;https://covers.openlibrary.org/b/id/7890978-S.jpg&quot;,\r\n        &quot;preview_url&quot;: &quot;https://archive.org/details/isbn_9780393972818&quot;,\r\n        &quot;info_url&quot;: &quot;https://openlibrary.org/books/OL348852M/Don_Quijote&quot;\r\n      }\r\n    }\r\n\r\nMy goal is to extract the `preview_url` -- thus, for the input above, to get the output `https://archive.org/details/isbn_9780393972818`.\r\n\r\nI&#39;m currently using the following:\r\n\r\n    curl &#39;https://openlibrary.org/api/books?bibkeys=ISBN:039397281X&amp;format=json&#39; \\\r\n      | jq -r &#39;.ISBN:039397281X&#39; | jq -r &#39;.preview_url&#39;\r\n\r\nHowever, this emits an error:\r\n\r\n    jq: error: syntax error, unexpected &#39;:&#39;, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .ISBN:039397281X     \r\n    jq: 1 compile error\r\n\r\nHow can it be resolved?\r\n",
        "link": "https://stackoverflow.com/questions/45223809/jq-syntax-error-extracting-key-with-colon-in-its-name",
        "title": "jq syntax error extracting key with colon in its name"
    },
    {
        "tags": [
            "json",
            "key",
            "grouping",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1500660478,
                "last_edit_date": 1500660478,
                "creation_date": 1500622902,
                "answer_id": 45231864,
                "question_id": 45228619,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This may seem like a rough ride, but to make things a bit more comprehensible, let&#39;s start with a helper function which will essentially make a JSON object when given an array of strings and a value, by creating a key from the array using a join character:\r\n\r\n    # input: [arrayOfStrings, value]\r\n    def squish(joinchar): { (.[0] | join(joinchar)): .[1] };\r\n\r\nFor example, `[[&quot;a&quot;,&quot;b&quot;], 10] | squish(&quot;.&quot;)` emits `{&quot;a.b&quot;, 10}`\r\n\r\nThe remainder of the solution to the problem is based on the built-in filters `paths` and `group_by`, which are documented elsewhere, but in brief, `paths` emits a stream of string arrays representing the paths; the associated value is then tacked on.  The [path, value] arrays are then grouped by date using `group_by`. Finally, the results are formatted according to the requirements.\r\n\r\n    . as $in\r\n    | [paths \r\n       | select(length==4)\r\n       | . as $path\r\n       | [ $path, ($in|getpath($path)) ] ]\r\n    | group_by( .[0][2] | tonumber )   # sort by numeric value\r\n    | map( {date: .[0][0][2] }\r\n            + ( map( del(.[0][2]) | squish(&quot;.&quot;) ) | add) )\r\n\r\n###Caveats\r\n\r\n1. The above solution groups paths globally by date, which seems to be in accordance with the requirements except for the sample output data. \r\n\r\n2. The `select(length==4)` criterion that has been used above may have to be modified if the data differs from the sample given.\r\n",
                "title": "Decompose nested JSON file to flat list with unique keys, using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1501213538,
                "creation_date": 1501213538,
                "answer_id": 45364521,
                "question_id": 45228619,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is solution using **to_entries** to get at the data, put it into a form **setpath** will accept, **group_by** to organize by date and **reduce** with **setpath** to build the final form.\r\n\r\nYou can see how this works step by step.  First start with\r\n\r\n      to_entries\r\n    | .[]\r\n    | .key as $k1\r\n    | ( .value | to_entries\r\n               | $k1, .[] )\r\n\r\nto get to the first key.  With my test data that gives me\r\n\r\n    &quot;key00&quot;\r\n    {\r\n      &quot;key&quot;: &quot;key10&quot;,\r\n      &quot;value&quot;: {\r\n        &quot;20170405&quot;: {\r\n          &quot;val0&quot;: 10,\r\n          &quot;valn&quot;: 12\r\n        },\r\n        &quot;20170404&quot;: {\r\n          &quot;val0&quot;: 5,\r\n          &quot;valn&quot;: 43\r\n        }\r\n      }\r\n    }\r\n    &quot;key01&quot;\r\n    ...\r\n\r\nthen drill down a little more to get to the next key\r\n\r\n      to_entries\r\n    | .[]\r\n    | .key as $k1\r\n    | ( .value | to_entries\r\n               | .[]\r\n               | .key as $k2\r\n               | ( .value | to_entries\r\n                          | $k1, $k2, .[] ) ) \r\n\r\nwhich gives\r\n\r\n    &quot;key00&quot;\r\n    &quot;key10&quot;\r\n    {\r\n      &quot;key&quot;: &quot;20170405&quot;,\r\n      &quot;value&quot;: {\r\n        &quot;val0&quot;: 10,\r\n        &quot;valn&quot;: 12\r\n      }\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;20170404&quot;,\r\n      &quot;value&quot;: {\r\n        &quot;val0&quot;: 5,\r\n        &quot;valn&quot;: 43\r\n      }\r\n    }\r\n    &quot;key01&quot;\r\n    &quot;key11&quot;\r\n    ...\r\n\r\nthen a little more to get to the date and the final value\r\n\r\n      to_entries\r\n    | .[]\r\n    | .key as $k1\r\n    | ( .value | to_entries\r\n               | .[]\r\n               | .key as $k2\r\n               | ( .value | to_entries\r\n                          | .[]\r\n                          | .key as $d\r\n                          | ( .value | to_entries\r\n                                     | .[]\r\n                                     | [$d, [$k1, $k2, .key], .value] ) ) )\r\n\r\nNow that we have\r\n\r\n    [\r\n      &quot;20170405&quot;,\r\n      [\r\n        &quot;key00&quot;,\r\n        &quot;key10&quot;,\r\n        &quot;val0&quot;\r\n      ],\r\n      10\r\n    ]\r\n    [\r\n      &quot;20170405&quot;,\r\n      [\r\n        &quot;key00&quot;,\r\n        &quot;key10&quot;,\r\n        &quot;valn&quot;\r\n      ],\r\n      12\r\n    ]\r\n    ...\r\n\r\nput that back into an array and use **group_by**, **reduce** and **setpath** \r\n\r\n    [\r\n      to_entries\r\n    | .[]\r\n    | .key as $k1\r\n    | ( .value | to_entries\r\n               | .[]\r\n               | .key as $k2\r\n               | ( .value | to_entries\r\n                          | .[]\r\n                          | .key as $d\r\n                          | ( .value | to_entries\r\n                                     | .[]\r\n                                     | [$d, [$k1, $k2, .key], .value]\r\n                            )                \r\n                 )\r\n       )\r\n    ]\r\n    | group_by(.[0])\r\n    | .[]\r\n    | .[0][0] as $d\r\n    | reduce .[] as $e (\r\n          {date:$d}\r\n        ; setpath([$e[1] | join(&quot;.&quot;)]; $e[2])\r\n      )\r\n\r\nto get the final answer\r\n\r\n    {\r\n      &quot;date&quot;: &quot;20170404&quot;,\r\n      &quot;key00.key10.val0&quot;: 5,\r\n      &quot;key00.key10.valn&quot;: 43\r\n    }\r\n    {\r\n      &quot;date&quot;: &quot;20170405&quot;,\r\n      &quot;key01.key11.val1&quot;: 1,\r\n      &quot;key00.key10.valn&quot;: 12,\r\n      &quot;key00.key10.val0&quot;: 10,\r\n      &quot;key01.key11.val2&quot;: 2\r\n    }\r\n    {\r\n      &quot;date&quot;: &quot;20170406&quot;,\r\n      &quot;key01.key11.val0&quot;: 0,\r\n      &quot;key01.key11.val9&quot;: 9\r\n    }\r\n    ...",
                "title": "Decompose nested JSON file to flat list with unique keys, using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1501213538,
        "creation_date": 1500608924,
        "last_edit_date": 1500658874,
        "question_id": 45228619,
        "body_markdown": "Given a JSON file of the format:\r\n\r\n    {\r\n        &quot;key00&quot; : {\r\n            &quot;key10&quot; : {\r\n                &quot;20170405&quot; : {\r\n                    &quot;val0&quot; : 10,\r\n                    ...\r\n                    &quot;valn&quot; : 12\r\n                }, \r\n                &quot;20170404&quot; : {\r\n                    &quot;val0&quot; : 5,\r\n                    ...\r\n                    &quot;valn&quot; : 43\r\n                },\r\n                ...\r\n             },\r\n             &quot;key11&quot; : {...},\r\n             ...\r\n         },\r\n         &quot;key01&quot; : {...},\r\n         &quot;key02&quot; : {...},\r\n         ...\r\n    }\r\n\r\nI want to use `jq` to decompose the tree into a flattened list whose format is such as below. This procedure should select one particular key in the hierarchy, the date, and for every instance of that date in the tree merge that date&#39;s values while making their key&#39;s unique based on the value&#39;s location in the tree:\r\n\r\n    [\r\n        {\r\n            &quot;date&quot; : &quot;20170405&quot;,\r\n            &quot;key00.key10.val0&quot; : 10,\r\n            ...\r\n            &quot;key00.key10.valn&quot; : 12\r\n        },\r\n        {\r\n            &quot;date&quot; : &quot;20170404&quot;,\r\n            &quot;key00.key10.val0&quot; : 10,\r\n            ...\r\n            &quot;key00.key10.valn&quot; : 12\r\n        },\r\n        ...\r\n        {\r\n            &quot;date&quot; : &quot;20170403&quot;,\r\n            &quot;key0n.key1n.val0&quot; : 10,\r\n            ...\r\n            &quot;key0n.key1n.valn&quot; : 12\r\n        },\r\n    ]\r\n\r\nKnowing the nesting structure, assuming it is rigid, I have performed this with a set of for-loops in Perl. But if the structure changes, the program breaks. Also, for every level of hierarchy, I need a for-loop. How would you go about traversing this tree recursively using jq&#39;s language?\r\n\r\n(I want to use jq because I am already using it to merge many files together of the format in the first code listing, so I figure I could build upon that. The merge is simple: `jq -s &#39;reduce .[] as $x ({}, . * $x)&#39; *.json &gt; merged.json`)",
        "link": "https://stackoverflow.com/questions/45228619/decompose-nested-json-file-to-flat-list-with-unique-keys-using-jq",
        "title": "Decompose nested JSON file to flat list with unique keys, using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1500626241,
                "last_edit_date": 1500626241,
                "creation_date": 1500625858,
                "answer_id": 45232823,
                "question_id": 45232603,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Apply string concatenation:\r\n\r\n    jq &#39;.elements[] | .id +&quot; &quot;+ .name&#39; file\r\nThe output:\r\n\r\n    &quot;e20a9cd8-8683-4986-b6c0-e5fbf51cbf7f Mike&quot;\r\n    &quot;d892f2eb-d7f3-49f8-9176-2113351cccf8 Steve&quot;\r\n\r\n\r\n----------\r\nTo output without double quotes use `-r` (`--raw-output`) option:\r\n\r\n    jq &#39;.elements[] | .id +&quot; &quot;+ .name&#39; -r file\r\n    e20a9cd8-8683-4986-b6c0-e5fbf51cbf7f Mike\r\n    d892f2eb-d7f3-49f8-9176-2113351cccf8 Steve\r\n\r\n",
                "title": "How to display two values serially with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1500626241,
        "creation_date": 1500625168,
        "last_edit_date": 1500625824,
        "question_id": 45232603,
        "body_markdown": "I am straggling some time with jq to parse json file. I have to grab ID and Name in the same line so I can do some logic after.\r\n\r\n    {\r\n\t&quot;elements&quot;: [{\r\n\t\t\t&quot;id&quot;: &quot;e20a9cd8-8683-4986-b6c0-e5fbf51cbf7f&quot;,\r\n\t\t\t&quot;name&quot;: &quot;Mike&quot;,\r\n\t\t\t&quot;components&quot;: [{\r\n\t\t\t\t&quot;id&quot;: &quot;15f959fc-6d2d-451a-a59e-430a05a1852c&quot;,\r\n\t\t\t\t&quot;pid&quot;: &quot;ZZZ1&quot;\r\n\t\t\t}],\r\n\t\t\t&quot;tenantIds&quot;: null,\r\n\t\t\t&quot;productIds&quot;: null\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;id&quot;: &quot;d892f2eb-d7f3-49f8-9176-2113351cccf8&quot;,\r\n\t\t\t&quot;name&quot;: &quot;Steve&quot;,\r\n\t\t\t&quot;components&quot;: [{\r\n\t\t\t\t&quot;id&quot;: &quot;0c44c917-e0e5-4fa3-b87c-89f9ac0815b4&quot;,\r\n\t\t\t\t&quot;pid&quot;: &quot;XXX3&quot;\r\n\t\t\t}],\r\n\t\t\t&quot;tenantIds&quot;: null,\r\n\t\t\t&quot;productIds&quot;: null\r\n\t\t}\r\n\t]\r\n}\r\n\r\nWith `jq &#39;{elements}[] | .[].id` I am getting ID&#39;s but I can&#39;t find solution how to add appropriate name beside ID. I tried something like\r\n\r\n    {elements}[] | .[].id + &quot; &quot; + .[].name \r\nand\r\n\r\n    {elements}[] | .[].id + .[].name\r\n\r\nbut it&#39;s not what I expected.\r\n\r\nI want to get:\r\n\r\n    15f959fc-6d2d-451a-a59e-430a05a1852c Mike\r\n    d892f2eb-d7f3-49f8-9176-2113351cccf8 Steve\r\n\r\nAny suggestion?\r\n\r\nThanks!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/45232603/how-to-display-two-values-serially-with-jq",
        "title": "How to display two values serially with jq?"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1500819308,
                "creation_date": 1500819308,
                "answer_id": 45266047,
                "question_id": 45263679,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "From the description and the fact that you only want the two items, I believe this is what you&#39;re looking for:\r\n\r\n    .[]\r\n    | select( .author as $author\r\n              | .reviewers\r\n              | map(select(.name != &quot;build&quot;))        # ignore &quot;build&quot;\r\n              | length==1 and .[0].name == $author )\r\n",
                "title": "jq filter query based on inner array items"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1500909651,
        "creation_date": 1500803120,
        "last_edit_date": 1500909651,
        "question_id": 45263679,
        "body_markdown": "I have a json as\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;:1,\r\n        &quot;author&quot;: &quot;hippy&quot;,\r\n        &quot;reviewers&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;hippy&quot;,\r\n            &quot;status&quot;: &quot;ok&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;other&quot;,\r\n            &quot;status&quot;: &quot;ok&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;:2,\r\n        &quot;author&quot;: &quot;hippy&quot;,\r\n        &quot;reviewers&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;hippy&quot;,\r\n            &quot;status&quot;: &quot;ok&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;build&quot;,\r\n            &quot;status&quot;: &quot;ok&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;:3,\r\n        &quot;author&quot;: &quot;hippy&quot;,\r\n        &quot;reviewers&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;hippy&quot;,\r\n            &quot;status&quot;: &quot;ok&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;:4,\r\n        &quot;author&quot;: &quot;other&quot;,\r\n        &quot;reviewers&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;hippy&quot;,\r\n            &quot;status&quot;: &quot;ok&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nand I want to get the items where the `reviewer` is the same as `author` after excluding the reviewer `build`.\r\n\r\ni.e. I want to get items with `id`s 2, 3.\r\n\r\nI was able to get so far\r\n\r\n    .[] \r\n\t| select(\r\n\t\t.author as $author \r\n\t\t| {reviewers} \r\n\t\t| .[] \r\n\t\t| map(.name) \r\n\t\t| select(.[] == $author)\r\n\t\t)\r\n\r\nbut item with `id` 1 is false positive and I want to filter that out too. \r\n",
        "link": "https://stackoverflow.com/questions/45263679/jq-filter-query-based-on-inner-array-items",
        "title": "jq filter query based on inner array items"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1500928373,
                "post_id": 45289450,
                "comment_id": 77541460,
                "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": 1500928451,
                "post_id": 45289450,
                "comment_id": 77541511,
                "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": 1500928569,
                "post_id": 45289450,
                "comment_id": 77541571,
                "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": 1500929450,
                "post_id": 45289450,
                "comment_id": 77542037,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2568036,
                    "reputation": 45,
                    "user_id": 2227562,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f3584cf67b695c7b7a04564aaa915ed2?s=256&d=identicon&r=PG",
                    "display_name": "RobP",
                    "link": "https://stackoverflow.com/users/2227562/robp"
                },
                "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": 1501077080,
                "post_id": 45289450,
                "comment_id": 77619498,
                "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": 1501078021,
                "post_id": 45289450,
                "comment_id": 77620344,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1500929280,
                "last_edit_date": 1500929280,
                "creation_date": 1500928654,
                "answer_id": 45289626,
                "question_id": 45289450,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "### If you really want your data to be parsed as syntax...\r\n\r\nThis is not an appropriate use case for `--arg`. Instead, substitute into the code:\r\n\r\n    select=&#39;a,b&#39;; jq -c -s &#39;.[]|{&#39;&quot;$select&quot;&#39;}&#39; &lt;&lt;&lt;&quot;$j&quot;\r\n\r\nNote that this has all the usual caveats of code injection: If the input is uncontrolled, the output (or other behavior of the script, particularly if `jq` gains more capable I/O features in the future) should be considered likewise.\r\n\r\n---\r\n\r\n### If you want to split the literal string into a list of keys...\r\n\r\nHere, we take your `select_str` (of the form `a,b`), and generate a map: `{&#39;a&#39;: &#39;a&#39;, &#39;b&#39;: &#39;b&#39;}`; then, we can break each data item into entries, select only the items in the map, and there&#39;s our output.\r\n\r\n    jq --arg select_str &quot;$select&quot; &#39;\r\n    ($select_str\r\n     | split(&quot;,&quot;)\r\n     | reduce .[] as $item ({}; .[$item]=$item)) as $select_map\r\n     | with_entries(select($select_map[.key]))&#39; &lt;&lt;&lt;&quot;$j&quot;",
                "title": "jq and bash: object construction with --arg is not working"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1500947092,
                "creation_date": 1500947092,
                "answer_id": 45292537,
                "question_id": 45289450,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; SELECT needs to be a variable and not hardcoded in the script.\r\n\r\nAssuming you want to avoid the risks of &quot;code injection&quot; and that you want the shell variable SELECT to be a simple string such as &quot;a,b&quot;, then consider this reduce-free solution along the lines you were attempting:\r\n\r\n    J=&#39;{&quot;a&quot;:1,&quot;b&quot;:10,&quot;c&quot;:100}&#39;\r\n    SELECT=&#39;a,b&#39;\r\n    echo &quot;$J&quot; |\r\n      jq -c --arg P1 &quot;$SELECT&quot; &#39;\r\n        . as $in | $P1 | split(&quot;,&quot;) | map( {(.): $in[.]} ) | add&#39;\r\n\r\nOutput:\r\n\r\n    {&quot;a&quot;:1,&quot;b&quot;:10}",
                "title": "jq and bash: object construction with --arg is not working"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1500947092,
        "creation_date": 1500927978,
        "question_id": 45289450,
        "body_markdown": "Given the following input:  \r\n\r\n    J=&#39;{&quot;a&quot;:1,&quot;b&quot;:10,&quot;c&quot;:100}  \r\n    {&quot;a&quot;:2,&quot;b&quot;:20,&quot;c&quot;:200}  \r\n    {&quot;a&quot;:3,&quot;b&quot;:30,&quot;c&quot;:300}&#39;  \r\n\r\n  \r\nThe command  \r\n\r\n    SELECT=&#39;a,b&#39;; echo $J | jq -c -s --arg P1 $SELECT &#39;.[]|{a,b}&#39;  \r\n\r\nproduces  \r\n\r\n    {&quot;a&quot;:1,&quot;b&quot;:10}  \r\n    {&quot;a&quot;:2,&quot;b&quot;:20}  \r\n    {&quot;a&quot;:3,&quot;b&quot;:30}  \r\n\r\nbut this command produces unexpected results:  \r\n\r\n    SELECT=&#39;a,b&#39;; echo $J | jq -c -s --arg P1 $SELECT &#39;.[]|{$P1}&#39;  \r\n    {&quot;P1&quot;:&quot;a,b&quot;}\r\n    {&quot;P1&quot;:&quot;a,b&quot;}\r\n    {&quot;P1&quot;:&quot;a,b&quot;}\r\n\r\nHow does one get jq to treat an arg string literally?  \r\n\r\nUsing tostring gives an error\r\n\r\n    SELECT=&#39;a,b&#39;; echo $J | jq -c -s --arg P1 $SELECT &#39;.[]|{$P1|tostring}&#39;  \r\n    jq: error: syntax error, unexpected &#39;|&#39;, expecting &#39;}&#39; (Unix shell quoting\r\n    issues?) at &lt;top-level&gt;, line 1:  \r\n    .[]|{$SELECT|tostring}           \r\n    jq: 1 compile error  \r\n\r\nSELECT needs to be a variable and not hardcoded in the script.\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/45289450/jq-and-bash-object-construction-with-arg-is-not-working",
        "title": "jq and bash: object construction with --arg is not working"
    },
    {
        "tags": [
            "windows",
            "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": 1501002796,
                "post_id": 45306246,
                "comment_id": 77581477,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7943529,
                    "reputation": 747,
                    "user_id": 5996722,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/800c439dfce31690465ac7a2f7d0cbb1?s=256&d=identicon&r=PG",
                    "display_name": "TimoC",
                    "link": "https://stackoverflow.com/users/5996722/timoc"
                },
                "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": 1501067022,
                "post_id": 45306246,
                "comment_id": 77611651,
                "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": 1501080666,
                "post_id": 45306246,
                "comment_id": 77622535,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7943529,
                    "reputation": 747,
                    "user_id": 5996722,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/800c439dfce31690465ac7a2f7d0cbb1?s=256&d=identicon&r=PG",
                    "display_name": "TimoC",
                    "link": "https://stackoverflow.com/users/5996722/timoc"
                },
                "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": 1501086408,
                "post_id": 45306246,
                "comment_id": 77627121,
                "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": 1501090571,
                "post_id": 45306246,
                "comment_id": 77629803,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7943529,
                    "reputation": 747,
                    "user_id": 5996722,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/800c439dfce31690465ac7a2f7d0cbb1?s=256&d=identicon&r=PG",
                    "display_name": "TimoC",
                    "link": "https://stackoverflow.com/users/5996722/timoc"
                },
                "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": 1501494328,
                "post_id": 45306246,
                "comment_id": 77785300,
                "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": 1501513813,
                "post_id": 45306246,
                "comment_id": 77799815,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662738250,
                "creation_date": 1662738250,
                "answer_id": 73664590,
                "question_id": 45306246,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This was a bug in jq 1.5. jq 1.6 no longer has this problem. Please upgrade your jq installation.",
                "title": "JQ: maximum file path length (windows)"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1662738250,
        "creation_date": 1500992833,
        "last_edit_date": 1501084214,
        "question_id": 45306246,
        "body_markdown": "i use jq (1.5) in a Windows 10 Environment for some json transformation operation (to load data from api to a SQL Server).\r\nI checked yesterday a new copy of the jq transform command on my test enviroment and run in the morning in a exception (jq command, source and Destination files are identical). The different between the old and the new one is the filepath:\r\n\r\nOld: C:\\Import\\\r\n\r\nNew: C:\\Import\\Test20170725\\\r\n\r\nFollowing command (in powershell) is used:\r\n\r\n    jq.exe -f C:\\Import\\Test20170725\\jqfilter_cruises.jq C:\\Import\\Test20170725\\Dreamlines_cruises.json | out-file -encoding UTF8 -filepath C:\\Import\\Test20170725\\import_cruises.json\r\n\r\nI experimented today and it looks like that the path from the input files is limited in the maximum length. If i reduce the filepath there the command works fine (like the original one). Any tips?\r\n\r\nRegards\r\nTimo\r\n",
        "link": "https://stackoverflow.com/questions/45306246/jq-maximum-file-path-length-windows",
        "title": "JQ: maximum file path length (windows)"
    },
    {
        "tags": [
            "path",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1501258355,
                "last_edit_date": 1501258355,
                "creation_date": 1501156540,
                "answer_id": 45350087,
                "question_id": 45345830,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Suppose you want to find the paths to objects with a key named &quot;b&quot;. One approach would be to use paths(objects) as illustrated here: \r\n\r\n    def data: {a:{b:1,c:{b:2}}};\r\n    \r\n    data\r\n    | paths(objects | has(&quot;b&quot;) )\r\n\r\n\r\nOr slightly more efficiently:\r\n\r\n    data\r\n    | paths\r\n    | select( .[-1] == &quot;b&quot; )\r\n    | .[:-1]\r\n\r\n \r\n\r\nInvocation: jq -n -c -f program.jq\r\n\r\nOutput: \r\n\r\n    [&quot;a&quot;]\r\n    [&quot;a&quot;,&quot;c&quot;]\r\n\r\n\r\n",
                "title": "jq: Search for property by name deep inside unknown input structure and print the path"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1602265850,
                "last_edit_date": 1602265850,
                "creation_date": 1589748786,
                "answer_id": 61858635,
                "question_id": 45345830,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Older question here, but this very much my typical use case.\r\n\r\nFor a solution for this specific type of problem see:   \r\nhttps://github.com/TomConlin/json_to_paths\r\n\r\nusage  e.g.  \r\n`json2jqpath.jq file.json | grep &quot;certain_name&quot;`\r\n\r\nBasically reduces an arbitrary .json file into   \r\nthe full list of paths addressable within it.\r\n\r\nAlso allows converting to like xml-xpath-like strings   \r\nand creating GraphVis renderings of the json structure.\r\n\r\n&lt;del&gt;One caveat is if there are empty arrays you will have to   \r\nappend you own `?` to the `[]` to make them optional.&lt;/del&gt;  \r\nnewer  versions figure it out in most cases",
                "title": "jq: Search for property by name deep inside unknown input structure and print the path"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1602265850,
        "creation_date": 1501145560,
        "last_edit_date": 1501156590,
        "question_id": 45345830,
        "body_markdown": "The title says it all: A jq program takes an input JSON document whose structure I&#39;m only vaguely familiar with, and I want it to print the path to all properties within it that have a certain name. ",
        "link": "https://stackoverflow.com/questions/45345830/jq-search-for-property-by-name-deep-inside-unknown-input-structure-and-print-th",
        "title": "jq: Search for property by name deep inside unknown input structure and print the path"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "cartesian-product"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1501280325,
                "creation_date": 1501280325,
                "answer_id": 45383162,
                "question_id": 45382817,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I think this will do what you want.\r\n\r\n    [\r\n      .quantities as $q\r\n    | .portions[]\r\n    | .percentage as $p\r\n    | {\r\n        customer,\r\n        quantities: [\r\n           $q[] | .quantity = .quantity * $p\r\n        ]\r\n      }\r\n    ]",
                "title": "How to use jq to produce a cartesian product of two arrays present in the input JSON"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1501298611,
                "last_edit_date": 1501298611,
                "creation_date": 1501283401,
                "answer_id": 45383588,
                "question_id": 45382817,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since you indicated you want the Cartesian product, and that you only gave the sample output as being indicative of what you&#39;re looking for, it may be worth mentioning that one can obtain the Cartesian product very simply:\r\n\r\n     .portions[] + .quantities[]\r\n\r\nThis produces objects such as:\r\n\r\n    {\r\n      &quot;product&quot;: &quot;B&quot;,\r\n      &quot;quantity&quot;: 10,\r\n      &quot;customer&quot;: &quot;C2&quot;,\r\n      &quot;percentage&quot;: 0.4\r\n    }\r\n\r\nYou could then use `reduce` or (less efficiently, `group_by`) to obtain the data in whatever form it is you really want. \r\n\r\nFor example, assuming .customer is always a string, we could transform\r\nthe input into the requested format as follows:\r\n\r\n    def add_by(f;g): reduce .[] as $x ({}; .[$x|f] += [$x|g]);\r\n    \r\n    [.quantities[] + .portions[]]\r\n    | map( {customer, quantities: {product, quantity: (.quantity * .percentage)}} )\r\n    | add_by(.customer; .quantities)\r\n    | to_entries\r\n    | map( {customer: .key, quantities: .value })\r\n\r\n\r\n",
                "title": "How to use jq to produce a cartesian product of two arrays present in the input JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1501378230,
        "creation_date": 1501278104,
        "last_edit_date": 1501378230,
        "question_id": 45382817,
        "body_markdown": "I&#39;d like to be able to use `jq` to output the &#39;product&#39; of 2 arrays in the input JSON... for example, given the following input JSON:\r\n\r\n     {\r\n         &quot;quantities&quot;: [\r\n             {\r\n                 &quot;product&quot;: &quot;A&quot;,\r\n                 &quot;quantity&quot;: 30\r\n             },\r\n             {\r\n                 &quot;product&quot;: &quot;B&quot;,\r\n                 &quot;quantity&quot;: 10\r\n             }\r\n             ],\r\n         &quot;portions&quot;: [\r\n             {\r\n                 &quot;customer&quot;: &quot;C1&quot;,\r\n                 &quot;percentage&quot;: .6\r\n             },\r\n             {\r\n                 &quot;customer&quot;: &quot;C2&quot;,\r\n                 &quot;percentage&quot;: .4\r\n             }\r\n         ]\r\n     }\r\n\r\nI&#39;d like to produce the following output (or similar...):\r\n\r\n    [\r\n        {\r\n         &quot;customer&quot;: &quot;C1&quot;,\r\n         &quot;quantities&quot;: [\r\n             {\r\n                 &quot;product&quot;: &quot;A&quot;,\r\n                 &quot;quantity&quot;: 18\r\n             },\r\n             {\r\n                 &quot;product&quot;: &quot;B&quot;,\r\n                 &quot;quantity&quot;: 6\r\n             }\r\n             ]\r\n        },\r\n        {\r\n         &quot;customer&quot;: &quot;C2&quot;,\r\n         &quot;quantities&quot;: [\r\n             {\r\n                 &quot;product&quot;: &quot;A&quot;,\r\n                 &quot;quantity&quot;: 12\r\n             },\r\n             {\r\n                 &quot;product&quot;: &quot;B&quot;,\r\n                 &quot;quantity&quot;: 4\r\n             }\r\n             ]\r\n        }\r\n    ]\r\n\r\nSo in other words, for each portion, use its value of percentage, and apply it to each product quantity.  Given 2 quantities and 2 portions should yield 4 results.. given 3 quantities and 2 portions should yield 6 results, etc...\r\n\r\nI&#39;ve made some attempts using `foreach` filters, but to no avail...",
        "link": "https://stackoverflow.com/questions/45382817/how-to-use-jq-to-produce-a-cartesian-product-of-two-arrays-present-in-the-input",
        "title": "How to use jq to produce a cartesian product of two arrays present in the input JSON"
    },
    {
        "tags": [
            "java",
            "json",
            "shell",
            "npm",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 427045,
                    "reputation": 5579,
                    "user_id": 808603,
                    "user_type": "registered",
                    "accept_rate": 73,
                    "profile_image": "https://www.gravatar.com/avatar/40f46f9ebbb5f9e66326cdb0ba6c1ece?s=256&d=identicon&r=PG",
                    "display_name": "Jerinaw",
                    "link": "https://stackoverflow.com/users/808603/jerinaw"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1501296322,
                "post_id": 45384683,
                "comment_id": 77730702,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1501353427,
                "last_edit_date": 1501353427,
                "creation_date": 1501299828,
                "answer_id": 45385014,
                "question_id": 45384683,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Thanks to the magic of jq&#39;s `-s` command-line option, you can &quot;add&quot; as many files as you like, like so:\r\n\r\n    $ jq -s add file1.json file2.json\r\n\r\nThe underpinning that provides the magic is jq&#39;s support for streams. This means, for example, that jq automatically supports JSONL (JSON Lines). The &quot;inverse&quot; of the -s option (i.e., for converting to JSONL) is the -c option.\r\n\r\n",
                "title": "Merge two JSON files in a particular structure"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1501353427,
        "creation_date": 1501295952,
        "last_edit_date": 1501296713,
        "question_id": 45384683,
        "body_markdown": "I have two json files of the follwoing structure \r\n**File 1**\r\n\r\n    [\r\n      {\r\n        &quot;line&quot;: 2,\r\n        &quot;elements&quot;: [\r\n          {}\r\n        ]\r\n      }\r\n    ]\r\n\r\n**File 2**\r\n\r\n    [\r\n      {\r\n        &quot;line&quot;: 3,\r\n        &quot;elements&quot;: [\r\n          {}\r\n        ]\r\n      }\r\n    ]\r\n\r\nI want to merge these files such that the output file looks like\r\n\r\n**Output File**\r\n\r\n    [\r\n      {\r\n        &quot;line&quot;: 2,\r\n        &quot;elements&quot;: [\r\n          {}\r\n        ]\r\n      },\r\n     {\r\n        &quot;line&quot;: 3,\r\n        &quot;elements&quot;: [\r\n          {}\r\n        ]\r\n      }\r\n    ]\r\n\r\n\r\nI can use npm, java or any shell library",
        "link": "https://stackoverflow.com/questions/45384683/merge-two-json-files-in-a-particular-structure",
        "title": "Merge two JSON files in a particular structure"
    },
    {
        "tags": [
            "json",
            "merge",
            "key",
            "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": 1501515721,
                "post_id": 45419527,
                "comment_id": 77801173,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1501546712,
                "creation_date": 1501546712,
                "answer_id": 45427132,
                "question_id": 45419527,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I believe this may be close to what you&#39;re looking for:\r\n\r\n    # input: an object\r\n    def merge_by_index(obj; ix):\r\n      ix as $index\r\n      | . + (obj | map( select( ix == $index)) [0] )\r\n      | del(ix) ;\r\n\r\nAfter cleaning up your sample input, and assuming a1, a2, and a3 are the\r\nthree top-level objects:\r\n\r\n    a1\r\n    | .Fan[0] |= merge_by_index(a2|.Degrees; .DegreesIndex)\r\n    | .Fan[0] |= merge_by_index(a3|.School; .SchoolIndex)\r\n\r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;Fan&quot;: [\r\n        {\r\n          &quot;Last Name&quot;: &quot;Mueller&quot;,\r\n          &quot;Firstname&quot;: &quot;Martin&quot;,\r\n          &quot;Adress&quot;: &quot;Madisson Square&quot;,\r\n          &quot;City&quot;: &quot;New York&quot;,\r\n          &quot;Key&quot;: 12759303,\r\n          &quot;Degrees&quot;: 1.6,\r\n          &quot;Teaser&quot;: 12759303.8,\r\n          &quot;Trainer&quot;: &quot;Miller&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "JQ: Merge several json arrays on index key"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1501636584,
                "creation_date": 1501636584,
                "answer_id": 45449943,
                "question_id": 45419527,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is how I would approach this.  This is a little more verbose then [peak](https://stackoverflow.com/users/997358/peak)&#39;s approach.\r\n\r\nFirst define some arrays with the data.  Note that I took the liberty of adding another entry for testing what happens when there isn&#39;t a matching **DegreesIndex** or **SchoolIndex** for the given **Fan**.  I like using functions here because you can easily replace these with whatever logic you need to get your real data.\r\n\r\n    def array1: {\r\n      &quot;Fan&quot;: [\r\n        {\r\n          &quot;Last Name&quot;:&quot;Mueller&quot;, &quot;First Name&quot;:&quot;Martin&quot;,\r\n          &quot;Address&quot;: &quot;Madisson Square&quot;, &quot;City&quot;: &quot;New York&quot;,\r\n          &quot;DegreesIndex&quot;: 3, &quot;SchoolIndex&quot;: 1\r\n        },\r\n        {\r\n          &quot;Last Name&quot;:&quot;Roberts&quot;, &quot;First Name&quot;:&quot;Bob&quot;,\r\n          &quot;DegreesIndex&quot;: 2, &quot;SchoolIndex&quot;: 4\r\n        },\r\n        {\r\n          &quot;Last Name&quot;:&quot;Skywalker&quot;, &quot;First Name&quot;:&quot;Luke&quot;,\r\n          &quot;DegreesIndex&quot;: 5, &quot;SchoolIndex&quot;: 1\r\n        }\r\n      ]};\r\n    \r\n    def array2: {\r\n     &quot;Degrees&quot;: [\r\n         { &quot;DegreesIndex&quot;:3, &quot;Key&quot;: &quot;12759303&quot;, &quot;Degrees&quot;:1.6 },\r\n         { &quot;DegreesIndex&quot;:2, &quot;Key&quot;: &quot;2&quot;,        &quot;Degrees&quot;:2 }\r\n      ]};\r\n    \r\n    def array3: {\r\n      &quot;School&quot;: [\r\n        { &quot;SchoolIndex&quot;:1, &quot;Teaser&quot;:&quot;12759303.8&quot;, &quot;Trainer&quot;:&quot;Miller&quot; },\r\n        { &quot;SchoolIndex&quot;:2, &quot;Teaser&quot;:&quot;2&quot;,          &quot;Trainer&quot;:&quot;Miller&quot; }\r\n      ]};\r\n    \r\nNow define a few simple lookup functions which will return the record matching the specified key.  Note the use of the [ ... ][0] construct to return a null if the item isn&#39;t found instead of causing the **Fan** to be ommitted entirely.\r\n    \r\n    def LookupDegrees($i):\r\n      [\r\n          array2\r\n        | .Degrees[]\r\n        | select(.DegreesIndex == $i)\r\n      ][0]\r\n    ;\r\n    \r\n    def LookupSchool($i):\r\n      [\r\n          array3\r\n        | .School[]\r\n        | select(.SchoolIndex == $i)\r\n      ][0]\r\n    ;\r\n    \r\nAll that makes the main routine simple:\r\n    \r\n      array1\r\n    | .Fan[] \r\n    | .Degrees = LookupDegrees(.DegreesIndex)\r\n    | .School = LookupSchool(.SchoolIndex)\r\n\r\nHere is the result I get when I run it with jq -n -f file.jq\r\n\r\n    {\r\n      &quot;Last Name&quot;: &quot;Mueller&quot;,\r\n      &quot;First Name&quot;: &quot;Martin&quot;,\r\n      &quot;Address&quot;: &quot;Madisson Square&quot;,\r\n      &quot;City&quot;: &quot;New York&quot;,\r\n      &quot;DegreesIndex&quot;: 3,\r\n      &quot;SchoolIndex&quot;: 1,\r\n      &quot;Degrees&quot;: {\r\n        &quot;DegreesIndex&quot;: 3,\r\n        &quot;Key&quot;: &quot;12759303&quot;,\r\n        &quot;Degrees&quot;: 1.6\r\n      },\r\n      &quot;School&quot;: {\r\n        &quot;SchoolIndex&quot;: 1,\r\n        &quot;Teaser&quot;: &quot;12759303.8&quot;,\r\n        &quot;Trainer&quot;: &quot;Miller&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;Last Name&quot;: &quot;Roberts&quot;,\r\n      &quot;First Name&quot;: &quot;Bob&quot;,\r\n      &quot;DegreesIndex&quot;: 2,\r\n      &quot;SchoolIndex&quot;: 4,\r\n      &quot;Degrees&quot;: {\r\n        &quot;DegreesIndex&quot;: 2,\r\n        &quot;Key&quot;: &quot;2&quot;,\r\n        &quot;Degrees&quot;: 2\r\n      },\r\n      &quot;School&quot;: null\r\n    }\r\n    {\r\n      &quot;Last Name&quot;: &quot;Skywalker&quot;,\r\n      &quot;First Name&quot;: &quot;Luke&quot;,\r\n      &quot;DegreesIndex&quot;: 5,\r\n      &quot;SchoolIndex&quot;: 1,\r\n      &quot;Degrees&quot;: null,\r\n      &quot;School&quot;: {\r\n        &quot;SchoolIndex&quot;: 1,\r\n        &quot;Teaser&quot;: &quot;12759303.8&quot;,\r\n        &quot;Trainer&quot;: &quot;Miller&quot;\r\n      }\r\n    }\r\n\r\nThis should be easy to adjust if you need a different nesting or output.",
                "title": "JQ: Merge several json arrays on index key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1501636584,
        "creation_date": 1501513982,
        "last_edit_date": 1501555957,
        "question_id": 45419527,
        "body_markdown": "I actually looking for an solution to merge several (3-4) arrays based on several &quot;index&quot; keys. \r\n\r\nExample Array 1:\r\n\r\n    {&quot;Fan&quot;:[{ &quot;Last Name&quot;:Mueller,&quot;Firstname&quot;:Martin,&quot;Adress&quot;:Madisson Square,&quot;City&quot;:&quot;New York&quot;,&quot;DegreesIndex&quot;:3,&quot;SchoolIndex2&quot;:1,}]\r\n\r\nDegreesIndex and Schoolindex refers to two different Keys in two other Arrays:\r\n\r\nexample Array 2:\r\n\r\n    {&quot;Degrees&quot;:[\r\n    {&quot;DegreesIndex&quot;:3,\r\n    &quot;Key&quot;:&quot;12759303,\r\n    &quot;Degrees&quot;:1.6}]}\r\n\r\nexample Array 3:\r\n\r\n{&quot;School&quot;:[\r\n{&quot;SchoolIndex&quot;:1,\r\n&quot;Teaser&quot;:&quot;12759303.8,\r\n&quot;Trainer&quot;:Miller}]}\r\n\r\nHow can i merge that arrays based on the &quot;index&quot; keys with JQ 1.5 under windows10? \r\n\r\nRegards\r\nTimo\r\n\r\n \r\n",
        "link": "https://stackoverflow.com/questions/45419527/jq-merge-several-json-arrays-on-index-key",
        "title": "JQ: Merge several json arrays on index key"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "jsonlines"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1501685033,
                "post_id": 45456414,
                "comment_id": 77888705,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4750029,
                    "reputation": 485,
                    "user_id": 3840303,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c8347e7aa56556389ae166b9d79a8971?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "JayBay2279",
                    "link": "https://stackoverflow.com/users/3840303/jaybay2279"
                },
                "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": 1501779486,
                "post_id": 45456414,
                "comment_id": 77942015,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1501782606,
                "post_id": 45456414,
                "comment_id": 77943959,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 52630,
                    "reputation": 4656,
                    "user_id": 157280,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/KBBVa.png?s=256",
                    "display_name": "Chris Sattinger",
                    "link": "https://stackoverflow.com/users/157280/chris-sattinger"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1540747404,
                "post_id": 45456414,
                "comment_id": 92968322,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 22,
                "is_accepted": true,
                "score": 20,
                "last_activity_date": 1511910268,
                "last_edit_date": 1511910268,
                "creation_date": 1501674589,
                "answer_id": 45460092,
                "question_id": 45456414,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It looks like `inputs` suffers from the same issue as slurp. I don&#39;t know how to accomplish this with `jq` on huge files, but `sed` can do it:\r\n\r\n    sed &#39;1s/^/[/; $!s/$/,/; $s/$/]/&#39; in.json &gt; out.json\r\n\r\nOutput:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    [{&quot;Header&quot;:{&quot;AssetClass&quot;:&quot;Commodities&quot;,&quot;InstrumentType&quot;:&quot;Forward&quot;,&quot;UseCase&quot;:&quot;Forward&quot;,&quot;Level&quot;:&quot;InstRefDataReporting&quot;},&quot;Attributes&quot;:{&quot;NotionalCurrency&quot;:&quot;EUR&quot;,&quot;ExpiryDate&quot;:&quot;2018-01-01&quot;,&quot;ReturnorPayoutTrigger&quot;:&quot;Contract for Difference (CFD)&quot;,&quot;DeliveryType&quot;:&quot;CASH&quot;,&quot;BaseProduct&quot;:&quot;AGRI&quot;,&quot;TransactionType&quot;:&quot;FUTR&quot;,&quot;FinalPriceType&quot;:&quot;ARGM&quot;,&quot;ReferenceRate&quot;:&quot;10PPM ULTRA LOW SULPHUR DIESEL-CARGOES CIF NWE/BASIS ARA-PLATTS EUROPEAN&quot;,&quot;SubProduct&quot;:&quot;GROS&quot;,&quot;AdditionalSubProduct&quot;:&quot;FWHT&quot;},&quot;ISIN&quot;:{&quot;ISIN&quot;:&quot;EZX27M86B860&quot;,&quot;Status&quot;:&quot;New&quot;},&quot;TemplateVersion&quot;:1,&quot;Derived&quot;:{&quot;CommodityDerivativeIndicator&quot;:&quot;TRUE&quot;,&quot;UnderlyingAssetType&quot;:&quot;Agriculture&quot;,&quot;IssuerorOperatoroftheTradingVenueIdentifier&quot;:&quot;NA&quot;,&quot;PriceMultiplier&quot;:1,&quot;FullName&quot;:&quot;Commodities Forward AGRI GROS FWHT EUR 20180101&quot;,&quot;ShortName&quot;:&quot;NA/Fwd AGRI FWHT EUR 20180101&quot;,&quot;ClassificationType&quot;:&quot;JTAXCC&quot;}},\r\n    {&quot;Header&quot;:{&quot;AssetClass&quot;:&quot;Commodities&quot;,&quot;InstrumentType&quot;:&quot;Swap&quot;,&quot;UseCase&quot;:&quot;Basis_Swap&quot;,&quot;Level&quot;:&quot;InstRefDataReporting&quot;},&quot;Attributes&quot;:{&quot;NotionalCurrency&quot;:&quot;SOS&quot;,&quot;ExpiryDate&quot;:&quot;2208-12-10&quot;,&quot;ReturnorPayoutTrigger&quot;:&quot;Total Return&quot;,&quot;DeliveryType&quot;:&quot;OPTL&quot;,&quot;TransactionType&quot;:&quot;ORIT&quot;,&quot;FinalPriceType&quot;:&quot;IHSM&quot;,&quot;ReferenceRate&quot;:&quot;NATURAL GAS-MONTHLY INDEX S. TEXAS (TETCO)-GAS DAILY PRICE GUIDE&quot;,&quot;OtherReferenceRate&quot;:&quot;NATURAL GAS-MONTHLY INDEX W. LOUISIANA (TETCO)-GAS DAILY PRICE GUIDE&quot;,&quot;BaseProduct&quot;:&quot;OTHR&quot;,&quot;OtherBaseProduct&quot;:&quot;OTHR&quot;,&quot;SubProduct&quot;:&quot;&quot;,&quot;AdditionalSubProduct&quot;:&quot;&quot;,&quot;OtherSubProduct&quot;:&quot;&quot;,&quot;OtherAdditionalSubProduct&quot;:&quot;&quot;},&quot;ISIN&quot;:{&quot;ISIN&quot;:&quot;EZBBH1XR9GV6&quot;,&quot;Status&quot;:&quot;New&quot;},&quot;TemplateVersion&quot;:1,&quot;Derived&quot;:{&quot;CommodityDerivativeIndicator&quot;:&quot;TRUE&quot;,&quot;UnderlyingAssetType&quot;:&quot;Multi Commodity&quot;,&quot;IssuerorOperatoroftheTradingVenueIdentifier&quot;:&quot;NA&quot;,&quot;PriceMultiplier&quot;:1,&quot;FullName&quot;:&quot;Commodities Swap Basis_Swap OTHR   OTHR   SOS 22081210&quot;,&quot;ShortName&quot;:&quot;NA/Swap OTHR   SOS 22081210&quot;,&quot;ClassificationType&quot;:&quot;STQTXE&quot;}},\r\n    {&quot;Header&quot;:{&quot;AssetClass&quot;:&quot;Commodities&quot;,&quot;InstrumentType&quot;:&quot;Swap&quot;,&quot;UseCase&quot;:&quot;Multi_Exotic_Swap&quot;,&quot;Level&quot;:&quot;InstRefDataReporting&quot;},&quot;Attributes&quot;:{&quot;NotionalCurrency&quot;:&quot;LRD&quot;,&quot;ExpiryDate&quot;:&quot;2200-01-31&quot;,&quot;ReturnorPayoutTrigger&quot;:&quot;Contract for Difference (CFD)&quot;,&quot;DeliveryType&quot;:&quot;CASH&quot;,&quot;TransactionType&quot;:&quot;TAPO&quot;,&quot;FinalPriceType&quot;:&quot;EXOF&quot;,&quot;UnderlyingInstrumentIndex&quot;:[&quot;BCOMF6&quot;,&quot;BCOMNG3&quot;]},&quot;ISIN&quot;:{&quot;ISIN&quot;:&quot;EZ286HJVY4Q2&quot;,&quot;Status&quot;:&quot;New&quot;},&quot;TemplateVersion&quot;:1,&quot;Derived&quot;:{&quot;CommodityDerivativeIndicator&quot;:&quot;TRUE&quot;,&quot;IssuerorOperatoroftheTradingVenueIdentifier&quot;:&quot;NA&quot;,&quot;PriceMultiplier&quot;:1,&quot;UnderlyingAssetType&quot;:&quot;Multi Commodity&quot;,&quot;BaseProduct&quot;:&quot;MCEX&quot;,&quot;SubProduct&quot;:&quot;&quot;,&quot;AdditionalSubProduct&quot;:&quot;&quot;,&quot;FullName&quot;:&quot;Commodities Multi_Exotic_Swap MCEX LRD 22000131&quot;,&quot;ShortName&quot;:&quot;NA/Swap MCEX LRD 22000131&quot;,&quot;ClassificationType&quot;:&quot;STQCXC&quot;}},\r\n    {&quot;Header&quot;:{&quot;AssetClass&quot;:&quot;Commodities&quot;,&quot;InstrumentType&quot;:&quot;Option&quot;,&quot;UseCase&quot;:&quot;Option&quot;,&quot;Level&quot;:&quot;InstRefDataReporting&quot;},&quot;Attributes&quot;:{&quot;NotionalCurrency&quot;:&quot;TND&quot;,&quot;ExpiryDate&quot;:&quot;2209-10-18&quot;,&quot;OptionType&quot;:&quot;OPTL&quot;,&quot;OptionExerciseStyle&quot;:&quot;AMER&quot;,&quot;ValuationMethodorTrigger&quot;:&quot;Asian&quot;,&quot;DeliveryType&quot;:&quot;CASH&quot;,&quot;TransactionType&quot;:&quot;OTHR&quot;,&quot;FinalPriceType&quot;:&quot;IHSM&quot;,&quot;ReferenceRate&quot;:&quot;NATURAL GAS-NGPL (NICOR, NIPSCO, PGLC CITYGATE), NBPL-NICOR-ICE/10X MONTHLY&quot;,&quot;BaseProduct&quot;:&quot;OTHR&quot;,&quot;SubProduct&quot;:&quot;&quot;,&quot;AdditionalSubProduct&quot;:&quot;&quot;},&quot;ISIN&quot;:{&quot;ISIN&quot;:&quot;EZ2TK5CWL9Y4&quot;,&quot;Status&quot;:&quot;New&quot;},&quot;TemplateVersion&quot;:1,&quot;Derived&quot;:{&quot;CommodityDerivativeIndicator&quot;:&quot;TRUE&quot;,&quot;UnderlyingAssetType&quot;:&quot;Other&quot;,&quot;IssuerorOperatoroftheTradingVenueIdentifier&quot;:&quot;NA&quot;,&quot;PriceMultiplier&quot;:1,&quot;FullName&quot;:&quot;Commodities Option OTHR   TND 22091018&quot;,&quot;ShortName&quot;:&quot;NA/O OTHR  OPTL TND 22091018&quot;,&quot;ClassificationType&quot;:&quot;HTMHAC&quot;}},\r\n    {&quot;Header&quot;:{&quot;AssetClass&quot;:&quot;Commodities&quot;,&quot;InstrumentType&quot;:&quot;Option&quot;,&quot;UseCase&quot;:&quot;Multi_Exotic_Option&quot;,&quot;Level&quot;:&quot;InstRefDataReporting&quot;},&quot;Attributes&quot;:{&quot;NotionalCurrency&quot;:&quot;SOS&quot;,&quot;ExpiryDate&quot;:&quot;2209-10-18&quot;,&quot;UnderlyingInstrumentIndex&quot;:[&quot;BCOMSI2&quot;,&quot;BCOMPR3T&quot;],&quot;OptionType&quot;:&quot;CALL&quot;,&quot;OptionExerciseStyle&quot;:&quot;AMER&quot;,&quot;ValuationMethodorTrigger&quot;:&quot;Other Path Dependent&quot;,&quot;DeliveryType&quot;:&quot;CASH&quot;,&quot;TransactionType&quot;:&quot;ORIT&quot;,&quot;FinalPriceType&quot;:&quot;BLTC&quot;},&quot;ISIN&quot;:{&quot;ISIN&quot;:&quot;EZ82L36B6225&quot;,&quot;Status&quot;:&quot;New&quot;},&quot;TemplateVersion&quot;:1,&quot;Derived&quot;:{&quot;CommodityDerivativeIndicator&quot;:&quot;TRUE&quot;,&quot;IssuerorOperatoroftheTradingVenueIdentifier&quot;:&quot;NA&quot;,&quot;PriceMultiplier&quot;:1,&quot;UnderlyingAssetType&quot;:&quot;Multi Commodity&quot;,&quot;BaseProduct&quot;:&quot;MCEX&quot;,&quot;SubProduct&quot;:&quot;&quot;,&quot;AdditionalSubProduct&quot;:&quot;&quot;,&quot;FullName&quot;:&quot;Commodities Multi_Exotic_Option MCEX SOS 22091018&quot;,&quot;ShortName&quot;:&quot;NA/O MCEX Call SOS 22091018&quot;,&quot;ClassificationType&quot;:&quot;HTQBPC&quot;}}]\r\n\r\n###Explanation\r\n\r\nThe sed script consists of three separate substitutions.  Here they are on  separate lines:\r\n\r\n&lt;!-- language: lang-sed --&gt;\r\n\r\n    1  s/^/[/      # Insert a left bracket at the beginning of the first line\r\n    $! s/$/,/      # On all but the last line append a comma\r\n    $  s/$/]/      # Append a right bracket to the last line",
                "title": "Convert JSON lines to JSON array using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1683718124,
                "last_edit_date": 1683718124,
                "creation_date": 1501682312,
                "answer_id": 45463005,
                "question_id": 45456414,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe awk is easier on the eyes:\r\n```shell\r\nawk &#39;\r\n  BEGIN{print &quot;[&quot;} \r\n  length(last)&gt;0 {print last &quot;,&quot;} {last=$0}\r\n  END {print last, &quot;]&quot;}\r\n&#39;\r\n```\r\nAnd for the record, here&#39;s a slurp-free solution using a version of jq with `input`:\r\n```shell\r\njq -nr &#39;&quot;[&quot;, try (input|tojson, repeat(&quot;,\\n\\(input|tojson)&quot;)), &quot;]&quot;&#39;\r\n```\r\n    \r\n\r\n",
                "title": "Convert JSON lines to JSON array using jq"
            },
            {
                "up_vote_count": 75,
                "is_accepted": false,
                "score": 75,
                "last_activity_date": 1696404781,
                "last_edit_date": 1696404781,
                "creation_date": 1589796649,
                "answer_id": 61867230,
                "question_id": 45456414,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe, I am late but this is what you are looking for!\r\n\r\n    jq --slurp &#39;.&#39; in.json &gt; out.json\r\n",
                "title": "Convert JSON lines to JSON array using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1601437397,
                "last_edit_date": 1601437397,
                "creation_date": 1601436615,
                "answer_id": 64130425,
                "question_id": 45456414,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I use one liner of node call:\r\n\r\n    $ cat input.ndjson | node -e &#39;const rl = readline.createInterface({ input: process.stdin }); !async function () { let idx = 0; for await (const line of rl) { process.stdout.write((++idx === 1 ? &quot;[&quot; : &quot;\\n,&quot;) + JSON.stringify(JSON.parse(line))); } process.stdout.write(&quot;]&quot;); }()&#39; | tee output.json | jq &#39;length&#39;\r\n    16814\r\n\r\nExplanation:\r\n\r\n    $ cat input.ndjson |      # pipe the ndjson input, can be a file or any stream\r\n      node -e &#39;\r\n        const rl = readline.createInterface({ input: process.stdin });\r\n        !async function () {  // to be able to use await, this function has to be async, and then `!` is to be able call it right away;\r\n          let idx = 0;\r\n          for await (const line of rl) {\r\n            process.stdout.write((++idx === 1 ? &quot;[&quot; : &quot;\\n,&quot;) + JSON.stringify(JSON.parse(line)));\r\n          }\r\n          process.stdout.write(&quot;]&quot;);\r\n        }()\r\n      &#39; | tee output.json     # save the output json file\r\n        | jq &#39;length&#39;         # call jq to calculate a length, also validate it, to make sure it&#39;s a valid single json file, this optional\r\n\r\nthe `readline` of Node is a good one to read a stream by lines, and it&#39;s `asyncIterable`, can use (await ... of) to get each line, then call `JSON.parse` to make sure validate each line is a valid json, and then `JSON.stringify` to convert back to a minified JSON, on each line;\r\n\r\nfor sure you can change to a local `const arr = [];` and push each line&#39;s obj into t, and once JSON.stringify at the end, to get the most minified JSON,\r\n\r\nbut I like to get this almost minified format, that each line&#39;s obj is minified, but still keep the outer array line by line, so that I can easily get its total count by a `wc -l` count its lines\r\n\r\n    [{...minified line1obj with no spaces...}\r\n    ,{...minified line2obj}\r\n    ,{...minified line3obj}\r\n    ,...\r\n    ,{...minified lineNobj}]\r\n\r\n",
                "title": "Convert JSON lines to JSON array using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1732550735,
                "creation_date": 1732550735,
                "answer_id": 79223772,
                "question_id": 45456414,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The way you would do this with `inputs` is like this:\r\n\r\n```\r\njq -nR &#39;[inputs | select(length&gt;0)]&#39; input.ndjson\r\n```\r\n\r\nThis will do it with streaming so you won&#39;t run into the slurp problem where the inputs all have to fit into memory..",
                "title": "Convert JSON lines to JSON array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 37,
        "last_activity_date": 1732550735,
        "creation_date": 1501665043,
        "last_edit_date": 1588281927,
        "question_id": 45456414,
        "body_markdown": "Firstly, I&#39;m new to `jq`, like 1 day new, I&#39;m also new to JSON, I&#39;m an SQL guy so I&#39;m learning fast but can&#39;t get my head around this ... so please bear with me.\r\n\r\nI&#39;m running Windows, using jq v1.5 on PowerShell. \r\n\r\nI have multiple JSON files downloaded and they look like this:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    {&quot;Header&quot;:{&quot;AssetClass&quot;:&quot;Commodities&quot;,&quot;InstrumentType&quot;:&quot;Forward&quot;,&quot;UseCase&quot;:&quot;Forward&quot;,&quot;Level&quot;:&quot;InstRefDataReporting&quot;},&quot;Attributes&quot;:{&quot;NotionalCurrency&quot;:&quot;EUR&quot;,&quot;ExpiryDate&quot;:&quot;2018-01-01&quot;,&quot;ReturnorPayoutTrigger&quot;:&quot;Contract for Difference (CFD)&quot;,&quot;DeliveryType&quot;:&quot;CASH&quot;,&quot;BaseProduct&quot;:&quot;AGRI&quot;,&quot;TransactionType&quot;:&quot;FUTR&quot;,&quot;FinalPriceType&quot;:&quot;ARGM&quot;,&quot;ReferenceRate&quot;:&quot;10PPM ULTRA LOW SULPHUR DIESEL-CARGOES CIF NWE/BASIS ARA-PLATTS EUROPEAN&quot;,&quot;SubProduct&quot;:&quot;GROS&quot;,&quot;AdditionalSubProduct&quot;:&quot;FWHT&quot;},&quot;ISIN&quot;:{&quot;ISIN&quot;:&quot;EZX27M86B860&quot;,&quot;Status&quot;:&quot;New&quot;},&quot;TemplateVersion&quot;:1,&quot;Derived&quot;:{&quot;CommodityDerivativeIndicator&quot;:&quot;TRUE&quot;,&quot;UnderlyingAssetType&quot;:&quot;Agriculture&quot;,&quot;IssuerorOperatoroftheTradingVenueIdentifier&quot;:&quot;NA&quot;,&quot;PriceMultiplier&quot;:1,&quot;FullName&quot;:&quot;Commodities Forward AGRI GROS FWHT EUR 20180101&quot;,&quot;ShortName&quot;:&quot;NA/Fwd AGRI FWHT EUR 20180101&quot;,&quot;ClassificationType&quot;:&quot;JTAXCC&quot;}}\r\n    {&quot;Header&quot;:{&quot;AssetClass&quot;:&quot;Commodities&quot;,&quot;InstrumentType&quot;:&quot;Swap&quot;,&quot;UseCase&quot;:&quot;Basis_Swap&quot;,&quot;Level&quot;:&quot;InstRefDataReporting&quot;},&quot;Attributes&quot;:{&quot;NotionalCurrency&quot;:&quot;SOS&quot;,&quot;ExpiryDate&quot;:&quot;2208-12-10&quot;,&quot;ReturnorPayoutTrigger&quot;:&quot;Total Return&quot;,&quot;DeliveryType&quot;:&quot;OPTL&quot;,&quot;TransactionType&quot;:&quot;ORIT&quot;,&quot;FinalPriceType&quot;:&quot;IHSM&quot;,&quot;ReferenceRate&quot;:&quot;NATURAL GAS-MONTHLY INDEX S. TEXAS (TETCO)-GAS DAILY PRICE GUIDE&quot;,&quot;OtherReferenceRate&quot;:&quot;NATURAL GAS-MONTHLY INDEX W. LOUISIANA (TETCO)-GAS DAILY PRICE GUIDE&quot;,&quot;BaseProduct&quot;:&quot;OTHR&quot;,&quot;OtherBaseProduct&quot;:&quot;OTHR&quot;,&quot;SubProduct&quot;:&quot;&quot;,&quot;AdditionalSubProduct&quot;:&quot;&quot;,&quot;OtherSubProduct&quot;:&quot;&quot;,&quot;OtherAdditionalSubProduct&quot;:&quot;&quot;},&quot;ISIN&quot;:{&quot;ISIN&quot;:&quot;EZBBH1XR9GV6&quot;,&quot;Status&quot;:&quot;New&quot;},&quot;TemplateVersion&quot;:1,&quot;Derived&quot;:{&quot;CommodityDerivativeIndicator&quot;:&quot;TRUE&quot;,&quot;UnderlyingAssetType&quot;:&quot;Multi Commodity&quot;,&quot;IssuerorOperatoroftheTradingVenueIdentifier&quot;:&quot;NA&quot;,&quot;PriceMultiplier&quot;:1,&quot;FullName&quot;:&quot;Commodities Swap Basis_Swap OTHR   OTHR   SOS 22081210&quot;,&quot;ShortName&quot;:&quot;NA/Swap OTHR   SOS 22081210&quot;,&quot;ClassificationType&quot;:&quot;STQTXE&quot;}}\r\n    {&quot;Header&quot;:{&quot;AssetClass&quot;:&quot;Commodities&quot;,&quot;InstrumentType&quot;:&quot;Swap&quot;,&quot;UseCase&quot;:&quot;Multi_Exotic_Swap&quot;,&quot;Level&quot;:&quot;InstRefDataReporting&quot;},&quot;Attributes&quot;:{&quot;NotionalCurrency&quot;:&quot;LRD&quot;,&quot;ExpiryDate&quot;:&quot;2200-01-31&quot;,&quot;ReturnorPayoutTrigger&quot;:&quot;Contract for Difference (CFD)&quot;,&quot;DeliveryType&quot;:&quot;CASH&quot;,&quot;TransactionType&quot;:&quot;TAPO&quot;,&quot;FinalPriceType&quot;:&quot;EXOF&quot;,&quot;UnderlyingInstrumentIndex&quot;:[&quot;BCOMF6&quot;,&quot;BCOMNG3&quot;]},&quot;ISIN&quot;:{&quot;ISIN&quot;:&quot;EZ286HJVY4Q2&quot;,&quot;Status&quot;:&quot;New&quot;},&quot;TemplateVersion&quot;:1,&quot;Derived&quot;:{&quot;CommodityDerivativeIndicator&quot;:&quot;TRUE&quot;,&quot;IssuerorOperatoroftheTradingVenueIdentifier&quot;:&quot;NA&quot;,&quot;PriceMultiplier&quot;:1,&quot;UnderlyingAssetType&quot;:&quot;Multi Commodity&quot;,&quot;BaseProduct&quot;:&quot;MCEX&quot;,&quot;SubProduct&quot;:&quot;&quot;,&quot;AdditionalSubProduct&quot;:&quot;&quot;,&quot;FullName&quot;:&quot;Commodities Multi_Exotic_Swap MCEX LRD 22000131&quot;,&quot;ShortName&quot;:&quot;NA/Swap MCEX LRD 22000131&quot;,&quot;ClassificationType&quot;:&quot;STQCXC&quot;}}\r\n    {&quot;Header&quot;:{&quot;AssetClass&quot;:&quot;Commodities&quot;,&quot;InstrumentType&quot;:&quot;Option&quot;,&quot;UseCase&quot;:&quot;Option&quot;,&quot;Level&quot;:&quot;InstRefDataReporting&quot;},&quot;Attributes&quot;:{&quot;NotionalCurrency&quot;:&quot;TND&quot;,&quot;ExpiryDate&quot;:&quot;2209-10-18&quot;,&quot;OptionType&quot;:&quot;OPTL&quot;,&quot;OptionExerciseStyle&quot;:&quot;AMER&quot;,&quot;ValuationMethodorTrigger&quot;:&quot;Asian&quot;,&quot;DeliveryType&quot;:&quot;CASH&quot;,&quot;TransactionType&quot;:&quot;OTHR&quot;,&quot;FinalPriceType&quot;:&quot;IHSM&quot;,&quot;ReferenceRate&quot;:&quot;NATURAL GAS-NGPL (NICOR, NIPSCO, PGLC CITYGATE), NBPL-NICOR-ICE/10X MONTHLY&quot;,&quot;BaseProduct&quot;:&quot;OTHR&quot;,&quot;SubProduct&quot;:&quot;&quot;,&quot;AdditionalSubProduct&quot;:&quot;&quot;},&quot;ISIN&quot;:{&quot;ISIN&quot;:&quot;EZ2TK5CWL9Y4&quot;,&quot;Status&quot;:&quot;New&quot;},&quot;TemplateVersion&quot;:1,&quot;Derived&quot;:{&quot;CommodityDerivativeIndicator&quot;:&quot;TRUE&quot;,&quot;UnderlyingAssetType&quot;:&quot;Other&quot;,&quot;IssuerorOperatoroftheTradingVenueIdentifier&quot;:&quot;NA&quot;,&quot;PriceMultiplier&quot;:1,&quot;FullName&quot;:&quot;Commodities Option OTHR   TND 22091018&quot;,&quot;ShortName&quot;:&quot;NA/O OTHR  OPTL TND 22091018&quot;,&quot;ClassificationType&quot;:&quot;HTMHAC&quot;}}\r\n    {&quot;Header&quot;:{&quot;AssetClass&quot;:&quot;Commodities&quot;,&quot;InstrumentType&quot;:&quot;Option&quot;,&quot;UseCase&quot;:&quot;Multi_Exotic_Option&quot;,&quot;Level&quot;:&quot;InstRefDataReporting&quot;},&quot;Attributes&quot;:{&quot;NotionalCurrency&quot;:&quot;SOS&quot;,&quot;ExpiryDate&quot;:&quot;2209-10-18&quot;,&quot;UnderlyingInstrumentIndex&quot;:[&quot;BCOMSI2&quot;,&quot;BCOMPR3T&quot;],&quot;OptionType&quot;:&quot;CALL&quot;,&quot;OptionExerciseStyle&quot;:&quot;AMER&quot;,&quot;ValuationMethodorTrigger&quot;:&quot;Other Path Dependent&quot;,&quot;DeliveryType&quot;:&quot;CASH&quot;,&quot;TransactionType&quot;:&quot;ORIT&quot;,&quot;FinalPriceType&quot;:&quot;BLTC&quot;},&quot;ISIN&quot;:{&quot;ISIN&quot;:&quot;EZ82L36B6225&quot;,&quot;Status&quot;:&quot;New&quot;},&quot;TemplateVersion&quot;:1,&quot;Derived&quot;:{&quot;CommodityDerivativeIndicator&quot;:&quot;TRUE&quot;,&quot;IssuerorOperatoroftheTradingVenueIdentifier&quot;:&quot;NA&quot;,&quot;PriceMultiplier&quot;:1,&quot;UnderlyingAssetType&quot;:&quot;Multi Commodity&quot;,&quot;BaseProduct&quot;:&quot;MCEX&quot;,&quot;SubProduct&quot;:&quot;&quot;,&quot;AdditionalSubProduct&quot;:&quot;&quot;,&quot;FullName&quot;:&quot;Commodities Multi_Exotic_Option MCEX SOS 22091018&quot;,&quot;ShortName&quot;:&quot;NA/O MCEX Call SOS 22091018&quot;,&quot;ClassificationType&quot;:&quot;HTQBPC&quot;}}\r\n\r\nThe files can be upwards of 1 GB in size.\r\n\r\nFor me to use these effectively, I need to turn the JSON lines into JSON Arrays, wrapping the file, prepending &quot;[&quot; and appending &quot;]&quot; and for each line separate with a comma (,).\r\n\r\nMaking the file look like this (in theory):\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    [\r\n    {\r\n    &quot;Header&quot;: {\r\n      &quot;AssetClass&quot;: &quot;Commodities&quot;,\r\n      &quot;InstrumentType&quot;: &quot;Swap&quot;,\r\n      &quot;UseCase&quot;: &quot;Basis_Swap&quot;,\r\n      &quot;Level&quot;: &quot;InstRefDataReporting&quot;\r\n    },\r\n    &quot;Attributes&quot;: {\r\n      &quot;NotionalCurrency&quot;: &quot;EUR&quot;,\r\n      &quot;ExpiryDate&quot;: &quot;2017-08-31&quot;,\r\n      &quot;ReturnorPayoutTrigger&quot;: &quot;Contract for Difference (CFD)&quot;,\r\n      &quot;DeliveryType&quot;: &quot;CASH&quot;,\r\n      &quot;BaseProduct&quot;: &quot;AGRI&quot;,\r\n      &quot;OtherBaseProduct&quot;: &quot;AGRI&quot;,\r\n      &quot;TransactionType&quot;: &quot;FUTR&quot;,\r\n      &quot;FinalPriceType&quot;: &quot;ARGM&quot;,\r\n      &quot;ReferenceRate&quot;: &quot;10PPM ULTRA LOW SULPHUR DIESEL-CARGOES CIF NWE/BASIS ARA-PLATTS EUROPEAN&quot;,\r\n      &quot;OtherReferenceRate&quot;: &quot;10PPM ULTRA LOW SULPHUR DIESEL-CARGOES CIF NWE/BASIS ARA-PLATTS EUROPEAN&quot;,\r\n      &quot;SubProduct&quot;: &quot;GROS&quot;,\r\n      &quot;AdditionalSubProduct&quot;: &quot;FWHT&quot;,\r\n      &quot;OtherSubProduct&quot;: &quot;GROS&quot;,\r\n      &quot;OtherAdditionalSubProduct&quot;: &quot;FWHT&quot;\r\n    },\r\n    &quot;ISIN&quot;: {\r\n      &quot;ISIN&quot;: &quot;EZ68CZDRFYY7&quot;,\r\n      &quot;Status&quot;: &quot;New&quot;\r\n    },\r\n    &quot;TemplateVersion&quot;: 1,\r\n    &quot;Derived&quot;: {\r\n      &quot;CommodityDerivativeIndicator&quot;: &quot;TRUE&quot;,\r\n      &quot;UnderlyingAssetType&quot;: &quot;Multi Commodity&quot;,\r\n      &quot;IssuerorOperatoroftheTradingVenueIdentifier&quot;: &quot;NA&quot;,\r\n      &quot;PriceMultiplier&quot;: 1,\r\n      &quot;FullName&quot;: &quot;Commodities Swap Basis_Swap AGRI GROS FWHT AGRI GROS FWHT EUR 20170831&quot;,\r\n      &quot;ShortName&quot;: &quot;NA/Swap AGRI FWHT FWHT EUR 20170831&quot;,\r\n      &quot;ClassificationType&quot;: &quot;STQCXC&quot;\r\n      }\r\n    },\r\n    {\r\n    &quot;Header&quot;: {\r\n      &quot;AssetClass&quot;: &quot;Commodities&quot;,\r\n      &quot;InstrumentType&quot;: &quot;Swap&quot;,\r\n      &quot;UseCase&quot;: &quot;Basis_Swap&quot;,\r\n      &quot;Level&quot;: &quot;InstRefDataReporting&quot;\r\n    },\r\n    &quot;Attributes&quot;: {\r\n      &quot;NotionalCurrency&quot;: &quot;EUR&quot;,\r\n      &quot;ExpiryDate&quot;: &quot;2017-08-31&quot;,\r\n      &quot;ReturnorPayoutTrigger&quot;: &quot;Contract for Difference (CFD)&quot;,\r\n      &quot;DeliveryType&quot;: &quot;CASH&quot;,\r\n      &quot;BaseProduct&quot;: &quot;AGRI&quot;,\r\n      &quot;OtherBaseProduct&quot;: &quot;AGRI&quot;,\r\n      &quot;TransactionType&quot;: &quot;FUTR&quot;,\r\n      &quot;FinalPriceType&quot;: &quot;ARGM&quot;,\r\n      &quot;ReferenceRate&quot;: &quot;10PPM ULTRA LOW SULPHUR DIESEL-CARGOES CIF NWE/BASIS ARA-PLATTS EUROPEAN&quot;,\r\n      &quot;OtherReferenceRate&quot;: &quot;10PPM ULTRA LOW SULPHUR DIESEL-CARGOES CIF NWE/BASIS ARA-PLATTS EUROPEAN&quot;,\r\n      &quot;SubProduct&quot;: &quot;GROS&quot;,\r\n      &quot;AdditionalSubProduct&quot;: &quot;FWHT&quot;,\r\n      &quot;OtherSubProduct&quot;: &quot;GROS&quot;,\r\n      &quot;OtherAdditionalSubProduct&quot;: &quot;FWHT&quot;\r\n    },\r\n    &quot;ISIN&quot;: {\r\n      &quot;ISIN&quot;: &quot;EZ68CZDRFYY7&quot;,\r\n      &quot;Status&quot;: &quot;New&quot;\r\n    },\r\n    &quot;TemplateVersion&quot;: 1,\r\n    &quot;Derived&quot;: {\r\n      &quot;CommodityDerivativeIndicator&quot;: &quot;TRUE&quot;,\r\n      &quot;UnderlyingAssetType&quot;: &quot;Multi Commodity&quot;,\r\n      &quot;IssuerorOperatoroftheTradingVenueIdentifier&quot;: &quot;NA&quot;,\r\n      &quot;PriceMultiplier&quot;: 1,\r\n      &quot;FullName&quot;: &quot;Commodities Swap Basis_Swap AGRI GROS FWHT AGRI GROS FWHT EUR 20170831&quot;,\r\n      &quot;ShortName&quot;: &quot;NA/Swap AGRI FWHT FWHT EUR 20170831&quot;,\r\n      &quot;ClassificationType&quot;: &quot;STQCXC&quot;\r\n    }\r\n    }\r\n    ]\r\n\r\nSo I&#39;ve found jq and from my understanding i can run this\r\n\r\n    jq --slurp &#39;map(select(. &gt;= 2))&#39; Inputfile.json &gt; OutputFile.json\r\n\r\nThis works but when running files larger than 200 MB i get &quot;system out out of memory&quot; error (if i use ISE) and if i use standard Powershell or CMD it takes ages. minutes (5+)\r\n\r\nIf i take `--slurp` out of the command, it works, it&#39;s quicker but the result looks like this:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    [\r\n    {\r\n    &quot;Header&quot;: {\r\n      &quot;AssetClass&quot;: &quot;Commodities&quot;,\r\n      &quot;InstrumentType&quot;: &quot;Swap&quot;,\r\n      &quot;UseCase&quot;: &quot;Basis_Swap&quot;,\r\n      &quot;Level&quot;: &quot;InstRefDataReporting&quot;\r\n    },\r\n    &quot;Attributes&quot;: {\r\n      &quot;NotionalCurrency&quot;: &quot;EUR&quot;,\r\n      &quot;ExpiryDate&quot;: &quot;2017-08-31&quot;,\r\n      &quot;ReturnorPayoutTrigger&quot;: &quot;Contract for Difference (CFD)&quot;,\r\n      &quot;DeliveryType&quot;: &quot;CASH&quot;,\r\n      &quot;BaseProduct&quot;: &quot;AGRI&quot;,\r\n      &quot;OtherBaseProduct&quot;: &quot;AGRI&quot;,\r\n      &quot;TransactionType&quot;: &quot;FUTR&quot;,\r\n      &quot;FinalPriceType&quot;: &quot;ARGM&quot;,\r\n      &quot;ReferenceRate&quot;: &quot;10PPM ULTRA LOW SULPHUR DIESEL-CARGOES CIF NWE/BASIS ARA-PLATTS EUROPEAN&quot;,\r\n      &quot;OtherReferenceRate&quot;: &quot;10PPM ULTRA LOW SULPHUR DIESEL-CARGOES CIF NWE/BASIS ARA-PLATTS EUROPEAN&quot;,\r\n      &quot;SubProduct&quot;: &quot;GROS&quot;,\r\n      &quot;AdditionalSubProduct&quot;: &quot;FWHT&quot;,\r\n      &quot;OtherSubProduct&quot;: &quot;GROS&quot;,\r\n      &quot;OtherAdditionalSubProduct&quot;: &quot;FWHT&quot;\r\n    },\r\n    &quot;ISIN&quot;: {\r\n      &quot;ISIN&quot;: &quot;EZ68CZDRFYY7&quot;,\r\n      &quot;Status&quot;: &quot;New&quot;\r\n    },\r\n    &quot;TemplateVersion&quot;: 1,\r\n    &quot;Derived&quot;: {\r\n      &quot;CommodityDerivativeIndicator&quot;: &quot;TRUE&quot;,\r\n      &quot;UnderlyingAssetType&quot;: &quot;Multi Commodity&quot;,\r\n      &quot;IssuerorOperatoroftheTradingVenueIdentifier&quot;: &quot;NA&quot;,\r\n      &quot;PriceMultiplier&quot;: 1,\r\n      &quot;FullName&quot;: &quot;Commodities Swap Basis_Swap AGRI GROS FWHT AGRI GROS FWHT EUR 20170831&quot;,\r\n      &quot;ShortName&quot;: &quot;NA/Swap AGRI FWHT FWHT EUR 20170831&quot;,\r\n      &quot;ClassificationType&quot;: &quot;STQCXC&quot;\r\n      }\r\n    }]\r\n    [{\r\n    &quot;Header&quot;: {\r\n      &quot;AssetClass&quot;: &quot;Commodities&quot;,\r\n      &quot;InstrumentType&quot;: &quot;Swap&quot;,\r\n      &quot;UseCase&quot;: &quot;Basis_Swap&quot;,\r\n      &quot;Level&quot;: &quot;InstRefDataReporting&quot;\r\n    },\r\n    &quot;Attributes&quot;: {\r\n      &quot;NotionalCurrency&quot;: &quot;EUR&quot;,\r\n      &quot;ExpiryDate&quot;: &quot;2017-08-31&quot;,\r\n      &quot;ReturnorPayoutTrigger&quot;: &quot;Contract for Difference (CFD)&quot;,\r\n      &quot;DeliveryType&quot;: &quot;CASH&quot;,\r\n      &quot;BaseProduct&quot;: &quot;AGRI&quot;,\r\n      &quot;OtherBaseProduct&quot;: &quot;AGRI&quot;,\r\n      &quot;TransactionType&quot;: &quot;FUTR&quot;,\r\n      &quot;FinalPriceType&quot;: &quot;ARGM&quot;,\r\n      &quot;ReferenceRate&quot;: &quot;10PPM ULTRA LOW SULPHUR DIESEL-CARGOES CIF NWE/BASIS ARA-PLATTS EUROPEAN&quot;,\r\n      &quot;OtherReferenceRate&quot;: &quot;10PPM ULTRA LOW SULPHUR DIESEL-CARGOES CIF NWE/BASIS ARA-PLATTS EUROPEAN&quot;,\r\n      &quot;SubProduct&quot;: &quot;GROS&quot;,\r\n      &quot;AdditionalSubProduct&quot;: &quot;FWHT&quot;,\r\n      &quot;OtherSubProduct&quot;: &quot;GROS&quot;,\r\n      &quot;OtherAdditionalSubProduct&quot;: &quot;FWHT&quot;\r\n    },\r\n    &quot;ISIN&quot;: {\r\n      &quot;ISIN&quot;: &quot;EZ68CZDRFYY7&quot;,\r\n      &quot;Status&quot;: &quot;New&quot;\r\n    },\r\n    &quot;TemplateVersion&quot;: 1,\r\n    &quot;Derived&quot;: {\r\n      &quot;CommodityDerivativeIndicator&quot;: &quot;TRUE&quot;,\r\n      &quot;UnderlyingAssetType&quot;: &quot;Multi Commodity&quot;,\r\n      &quot;IssuerorOperatoroftheTradingVenueIdentifier&quot;: &quot;NA&quot;,\r\n      &quot;PriceMultiplier&quot;: 1,\r\n      &quot;FullName&quot;: &quot;Commodities Swap Basis_Swap AGRI GROS FWHT AGRI GROS FWHT EUR 20170831&quot;,\r\n      &quot;ShortName&quot;: &quot;NA/Swap AGRI FWHT FWHT EUR 20170831&quot;,\r\n      &quot;ClassificationType&quot;: &quot;STQCXC&quot;\r\n    }\r\n    }\r\n    ]\r\n\r\nIt creates an array for each line but the array is not comma separated, and thats not what I wanted.\r\n\r\nSo, how can I process large files, of multiple JSON lines, and create one file for the input file that is generated as a single array, comma separated, without using slurp?\r\n\r\nI&#39;ve read about inputs but not sure if that is relevant to what I need to do?",
        "link": "https://stackoverflow.com/questions/45456414/convert-json-lines-to-json-array-using-jq",
        "title": "Convert JSON lines to JSON array using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "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": 2,
                "creation_date": 1501701149,
                "post_id": 45469133,
                "comment_id": 77899238,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1051929,
                    "reputation": 14277,
                    "user_id": 1055637,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://www.gravatar.com/avatar/8a8b9e4daac99ea95aa3e8e246716e73?s=256&d=identicon&r=PG",
                    "display_name": "Mazzy",
                    "link": "https://stackoverflow.com/users/1055637/mazzy"
                },
                "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": 1501701552,
                "post_id": 45469133,
                "comment_id": 77899428,
                "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": 1501702035,
                "post_id": 45469133,
                "comment_id": 77899683,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 31,
                "is_accepted": true,
                "score": 31,
                "last_activity_date": 1501705990,
                "creation_date": 1501705990,
                "answer_id": 45470487,
                "question_id": 45469133,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "So your code doesn&#39;t work because included the variable inside double quotes which gets treated as string. That is why it is not working\r\n\r\nAs @Jeff Mercado, pointed out the solution is \r\n\r\n    jq -n --arg greeting world &#39;{&quot;hello&quot;:$greeting}&#39; &gt; file.json\r\n\r\nAbout the `-` in a name. This is actually possible. But as of now this is not available in released version of jq. If you compile the master branch of jq on your system. There is a new variable called `$ARGS.named` which can be used to access the information.\r\n\r\nI just compiled and check the below command and it works like a charm\r\n\r\n    ./jq -n --arg name-is tarun &#39;{&quot;name&quot;: $ARGS.named[&quot;name-is&quot;]}&#39;\r\n    {\r\n      &quot;name&quot;: &quot;tarun&quot;\r\n    }",
                "title": "Create JSON file using jq"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1501708855,
                "creation_date": 1501708855,
                "answer_id": 45471200,
                "question_id": 45469133,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To add to what [Jeff](https://stackoverflow.com/users/390278/jeff-mercado) and [Tarun](https://stackoverflow.com/users/2830850/tarun-lalwani) have already said, you might want to use the `\\()` string interpolation syntax in your command. eg.\r\n\r\n    jq -n --arg greeting world &#39;{&quot;hello&quot;:&quot;\\($greeting)&quot;}&#39;\r\n\r\nfor me this produces\r\n\r\n    {\r\n      &quot;hello&quot;: &quot;world&quot;\r\n    }\r\n\r\nRegarding your reply to Jeff&#39;s comment, the argument name you choose has to be a valid jq variable name so an arg like `greeting-for-you` won&#39;t work but you could use underscores so `greeting_for_you` would be ok.  Or you could use the version Tarun described.",
                "title": "Create JSON file using jq"
            },
            {
                "up_vote_count": 13,
                "is_accepted": false,
                "score": 13,
                "last_activity_date": 1579175697,
                "creation_date": 1579175697,
                "answer_id": 59769162,
                "question_id": 45469133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`$ARGS` provides access to named (`--arg name value`) and positional (`--args one two three`) arguments from the jq command line, and allows you to build up objects easily &amp; safely.\r\n\r\nNamed arguments:\r\n```console\r\n$ jq -n &#39;{christmas: $ARGS.named}&#39; \\\r\n  --arg one &#39;partridge in a &quot;pear&quot; tree&#39; \\\r\n  --arg two &#39;turtle doves&#39;\r\n\r\n{\r\n  &quot;christmas&quot;: {\r\n    &quot;one&quot;: &quot;partridge in a \\&quot;pear\\&quot; tree&quot;,\r\n    &quot;two&quot;: &quot;turtle doves&quot;\r\n  }\r\n}\r\n```\r\n\r\nPositional arguments:\r\n```\r\n$ jq -n &#39;{numbers: $ARGS.positional}&#39; --args 1 2 3\r\n\r\n{\r\n  &quot;numbers&quot;: [\r\n    &quot;1&quot;,\r\n    &quot;2&quot;,\r\n    &quot;3&quot;\r\n  ]\r\n}\r\n```\r\n\r\nNote you can access individual items of the positional array, and that the named arguments are directly available as variables:\r\n```\r\njq -n &#39;{first: {name: $one, count: $ARGS.positional[0]}, all: $ARGS}&#39; \\\r\n  --arg one &#39;partridge in a &quot;pear&quot; tree&#39; \\\r\n  --arg two &#39;turtle doves&#39; \\\r\n  --args 1 2 3\r\n\r\n{\r\n  &quot;first&quot;: {\r\n    &quot;name&quot;: &quot;partridge in a \\&quot;pear\\&quot; tree&quot;,\r\n    &quot;count&quot;: &quot;1&quot;\r\n  },\r\n  &quot;all&quot;: {\r\n    &quot;positional&quot;: [\r\n      &quot;1&quot;,\r\n      &quot;2&quot;,\r\n      &quot;3&quot;\r\n    ],\r\n    &quot;named&quot;: {\r\n      &quot;one&quot;: &quot;partridge in a \\&quot;pear\\&quot; tree&quot;,\r\n      &quot;two&quot;: &quot;turtle doves&quot;\r\n    }\r\n  }\r\n}\r\n```",
                "title": "Create JSON file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 23,
        "last_activity_date": 1740523458,
        "creation_date": 1501701008,
        "last_edit_date": 1740523458,
        "question_id": 45469133,
        "body_markdown": "I&#39;m trying to create a JSON file by executing the following command:\r\n\r\n```shell\r\njq --arg greeting world &#39;{&quot;hello&quot;:&quot;$greeting&quot;}&#39; &gt; file.json\r\n```\r\n\r\nThis command stuck without any input. While\r\n\r\n```shell\r\njq -n --arg greeting world &#39;{&quot;hello&quot;:&quot;$greeting&quot;}&#39; &gt; file.json\r\n```\r\n\r\ndoesn&#39;t parse correctly. I&#39;m just wondering is really possible to create a JSON file.",
        "link": "https://stackoverflow.com/questions/45469133/create-json-file-using-jq",
        "title": "Create JSON file using jq"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "merge",
            "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": 1501717025,
                "post_id": 45472525,
                "comment_id": 77906110,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1501768911,
                "last_edit_date": 1501768911,
                "creation_date": 1501765567,
                "answer_id": 45485113,
                "question_id": 45472525,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I believe it&#39;s just the syntax used in your keyfile - It is causing a string literal `&quot;value[0]&quot;` to be created instead of the array index 0 being referenced in the path substitution.\r\n\r\n**Try use the syntax**\r\n    \r\n&lt;pre&gt;&lt;code&gt;&quot;value&quot;&lt;strong&gt;,0,&lt;/strong&gt;&quot;account_name&quot;&lt;/code&gt;&lt;/pre&gt;\r\n**Instead of**\r\n\r\n&lt;pre&gt;&lt;code&gt;&quot;value&lt;strong&gt;[0]&lt;/strong&gt;&quot;,&quot;account_name&quot;&lt;/code&gt;&lt;/pre&gt;\r\n\r\n\r\n\r\nUsing the below as `keyfile.json`:\r\n&lt;pre&gt;&lt;code&gt;[\r\n  [[&quot;properties.on_demand_service_plans_collection&quot;, &quot;value&quot;,0, &quot;account_name&quot;], [&quot;appd&quot;, &quot;account_name&quot;]],\r\n  [[&quot;properties.on_demand_service_plans_collection&quot;, &quot;value&quot;,0, &quot;account_access_key&quot;], [&quot;appd&quot;, &quot;account_key&quot;]],\r\n  [[&quot;properties.on_demand_service_plans_collection&quot;, &quot;value&quot;,1, &quot;account_name&quot;], [&quot;appd&quot;, &quot;account_name&quot;]],\r\n  [[&quot;properties.on_demand_service_plans_collection&quot;, &quot;value&quot;,1, &quot;account_access_key&quot;], [&quot;appd&quot;, &quot;account_key&quot;]]\r\n]&lt;/code&gt;&lt;/pre&gt;\r\n&lt;br&gt;\r\nProduces desired.json:\r\n\r\n    {\r\n      &quot;.properties.on_demand_service_plans_collection&quot;: {\r\n        &quot;type&quot;: &quot;collection&quot;,\r\n        &quot;value&quot;: [\r\n          {\r\n            &quot;plan_name&quot;: &quot;my-plan&quot;,\r\n            &quot;plan_description&quot;: &quot;my-plan&quot;,\r\n            &quot;account_name&quot;: &quot;appd-user&quot;,\r\n            &quot;account_access_key&quot;: &quot;appd-key&quot;\r\n          },\r\n          {\r\n            &quot;plan_name&quot;: &quot;my-plan-test&quot;,\r\n            &quot;plan_description&quot;: &quot;my-plan-test&quot;,\r\n            &quot;account_name&quot;: &quot;appd-user&quot;,\r\n            &quot;account_access_key&quot;: &quot;appd-key&quot;\r\n          }\r\n        ],\r\n        &quot;optional&quot;: false\r\n      }\r\n    }\r\n\r\n\r\n\r\n\r\n---\r\n**Sidenote:**\r\nIf it helps, the way I came across the proper syntax after some headscratching was to view the output as a stream in compact format:\r\n\r\n    jq -c &#39;. | tostream&#39; input.json\r\n\r\n&lt;pre&gt;&lt;code&gt;&lt;!-- language: lang-json --&gt;[[&quot;.properties.on_demand_service_plans_collection&quot;,&quot;optional&quot;],false]\r\n[[&quot;.properties.on_demand_service_plans_collection&quot;,&quot;type&quot;],&quot;collection&quot;]\r\n[[&quot;.properties.on_demand_service_plans_collection&quot;,&quot;value&quot;,0,&quot;account_access_key&quot;],&quot;vault-supplied-value&quot;]\r\n[[&quot;.properties.on_demand_service_plans_collection&quot;,&quot;value&quot;,0,&quot;account_name&quot;],&quot;vault-supplied-value&quot;]\r\n[[&quot;.properties.on_demand_service_plans_collection&quot;,&quot;value&quot;,0,&quot;plan_description&quot;],&quot;my-plan&quot;]\r\n[[&quot;.properties.on_demand_service_plans_collection&quot;,&quot;value&quot;,0,&quot;plan_name&quot;],&quot;my-plan&quot;]\r\n[[&quot;.properties.on_demand_service_plans_collection&quot;,&quot;value&quot;,0,&quot;plan_name&quot;]]\r\n[[&quot;.properties.on_demand_service_plans_collection&quot;,&quot;value&quot;,1,&quot;account_access_key&quot;],&quot;vault-supplied-value&quot;]\r\n[[&quot;.properties.on_demand_service_plans_collection&quot;,&quot;value&quot;,1,&quot;account_name&quot;],&quot;vault-supplied-value&quot;]\r\n[[&quot;.properties.on_demand_service_plans_collection&quot;,&quot;value&quot;,1,&quot;plan_description&quot;],&quot;my-plan-test&quot;]\r\n[[&quot;.properties.on_demand_service_plans_collection&quot;,&quot;value&quot;,1,&quot;plan_name&quot;],&quot;my-plan-test&quot;]\r\n[[&quot;.properties.on_demand_service_plans_collection&quot;,&quot;value&quot;,1,&quot;plan_name&quot;]]\r\n[[&quot;.properties.on_demand_service_plans_collection&quot;,&quot;value&quot;,1]]\r\n[[&quot;.properties.on_demand_service_plans_collection&quot;,&quot;value&quot;]]\r\n[[&quot;.properties.on_demand_service_plans_collection&quot;]]\r\n&lt;/code&gt;&lt;/pre&gt;",
                "title": "Update one JSON array element with a second JSON based on third JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1501768911,
        "creation_date": 1501716557,
        "question_id": 45472525,
        "body_markdown": "I have four files:\r\n\r\ninput.json\r\n\r\n    {\r\n      &quot;.properties.on_demand_service_plans_collection&quot;: {\r\n        &quot;type&quot;: &quot;collection&quot;,\r\n        &quot;value&quot;: [\r\n          {\r\n            &quot;plan_name&quot;: &quot;my-plan&quot;,\r\n            &quot;plan_description&quot;: &quot;my-plan&quot;,\r\n            &quot;account_name&quot;: &quot;vault-supplied-value&quot;\r\n            &quot;account_access_key&quot;: &quot;vault-supplied-value&quot;\r\n          },\r\n          {\r\n            &quot;plan_name&quot;: &quot;my-plan-test&quot;,\r\n            &quot;plan_description&quot;: &quot;my-plan-test&quot;,\r\n            &quot;account_name&quot;: &quot;vault-supplied-value&quot;,\r\n            &quot;account_access_key&quot;: &quot;vault-supplied-value&quot;\r\n          }\r\n        ],\r\n        &quot;optional&quot;: false\r\n      }\r\n    }\r\n\r\nvault.json\r\n\r\n    {\r\n      &quot;appd&quot;: {\r\n        &quot;account_key&quot;: &quot;appd-key&quot;,\r\n        &quot;account_name&quot;: &quot;appd-user&quot;\r\n      },\r\n      &quot;aws&quot;: {\r\n        &quot;access_key_id&quot;: &quot;my-key-id&quot;,\r\n        &quot;region&quot;: &quot;us-east-1&quot;,\r\n        &quot;secret_access_key&quot;: &quot;my-secret-key&quot;\r\n      }\r\n    }\r\n\r\nkeyfile.json\r\n\r\n    [\r\n      [[&quot;.properties.on_demand_service_plans_collection&quot;, &quot;value[0]&quot;, &quot;account_name&quot;], [&quot;appd&quot;, &quot;account_name&quot;]],\r\n      [[&quot;.properties.on_demand_service_plans_collection&quot;, &quot;value[0]&quot;, &quot;account_access_key&quot;], [&quot;appd&quot;, &quot;account_key&quot;]],\r\n      [[&quot;.properties.on_demand_service_plans_collection&quot;, &quot;value[1]&quot;, &quot;account_name&quot;], [&quot;appd&quot;, &quot;account_name&quot;]],\r\n      [[&quot;.properties.on_demand_service_plans_collection&quot;, &quot;value[1]&quot;, &quot;account_access_key&quot;], [&quot;appd&quot;, &quot;account_key&quot;]]\r\n    ]\r\n\r\nvalut.jq\r\n\r\n    reduce $keyfile[] as $p (.; setpath(($p|.[0]); $vault|getpath($p|.[1])))\r\n\r\nThis is my jq command:\r\n\r\n    jq --argfile keyfile keyfile.json --argfile vault vault.json -f vault.jq input.json &gt; desired.json\r\n\r\n\r\ndesired.json\r\n\r\n    {\r\n      &quot;.properties.on_demand_service_plans_collection&quot;: {\r\n        &quot;type&quot;: &quot;collection&quot;,\r\n        &quot;value&quot;: [\r\n          {\r\n            &quot;plan_name&quot;: &quot;my-plan&quot;,\r\n            &quot;plan_description&quot;: &quot;my-plan&quot;,\r\n            &quot;account_name&quot;: &quot;appd-key&quot;,\r\n            &quot;account_access_key&quot;: &quot;appd-user&quot;\r\n          },\r\n          {\r\n            &quot;plan_name&quot;: &quot;my-plan-test&quot;,\r\n            &quot;plan_description&quot;: &quot;my-plan-test&quot;,\r\n            &quot;account_name&quot;: &quot;appd-key&quot;,\r\n            &quot;account_access_key&quot;: &quot;appd-user&quot;,\r\n            &quot;controller_host&quot;: &quot;example.com&quot;\r\n          }\r\n        ],\r\n        &quot;optional&quot;: false\r\n      }\r\n    }\r\n\r\nI&#39;m not coding the keyfile.json file correctly, because I am not getting the desired results.\r\nI&#39;ve tried every iteration of the keyfile.json I can think of, but to no avail.\r\n\r\nDoes anyone have any ideas?\r\nThanks in advance.\r\n\r\nwhat-i-get.json\r\n\r\n    {\r\n      &quot;.properties.on_demand_service_plans_collection&quot;: {\r\n        &quot;type&quot;: &quot;collection&quot;,\r\n        &quot;value&quot;: [\r\n          {\r\n            &quot;plan_name&quot;: &quot;my-plan&quot;,\r\n            &quot;plan_description&quot;: &quot;my-plan&quot;,\r\n            &quot;account_name&quot;: &quot;vault-supplied-value&quot;,\r\n            &quot;account_access_key&quot;: &quot;vault-supplied-value&quot;\r\n          },\r\n          {\r\n            &quot;plan_name&quot;: &quot;my-plan-test&quot;,\r\n            &quot;plan_description&quot;: &quot;my-plan-test&quot;,\r\n            &quot;account_name&quot;: &quot;vault-supplied-value&quot;,\r\n            &quot;account_access_key&quot;: &quot;vault-supplied-value&quot;\r\n          }\r\n        ],\r\n        &quot;optional&quot;: false,\r\n        &quot;value[0]&quot;: {\r\n          &quot;account_name&quot;: &quot;appd-user&quot;,\r\n          &quot;account_access_key&quot;: &quot;appd-key&quot;\r\n        },\r\n        &quot;value[1]&quot;: {\r\n          &quot;account_name&quot;: &quot;appd-user&quot;,\r\n          &quot;account_access_key&quot;: &quot;appd-key&quot;\r\n        }\r\n      }\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/45472525/update-one-json-array-element-with-a-second-json-based-on-third-json-with-jq",
        "title": "Update one JSON array element with a second JSON based on third JSON with jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1501773153,
                "post_id": 45486380,
                "comment_id": 77937497,
                "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": 1501788962,
                "post_id": 45486380,
                "comment_id": 77947651,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1501777482,
                "creation_date": 1501777482,
                "answer_id": 45489790,
                "question_id": 45486380,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Not really a jq question, but instead of\r\n\r\n    variable=&quot;$file&quot; | jq -j &quot;.rows[].example&quot;\r\n\r\nI suspect you intended something like this:\r\n\r\n    variable=$(cat &quot;$file&quot; | jq -j &quot;.rows[].example&quot;)\r\n",
                "title": "Using jq to store part of JSON in variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1501777482,
        "creation_date": 1501768625,
        "question_id": 45486380,
        "body_markdown": "Hello i have problem with shell and jq.\r\n\r\ni have file , lets say text.txt and it contains only JSON, lets say {&quot;rows&quot;:[{&quot;example&quot;:&quot;20&quot;}]}.\r\ni need to write a script in shell that will read this text file as a first argument and stores the value of &quot;example&quot; from that JSON in variable,\r\nusing jq.\r\n\r\nthis is what i have so far , but it just prints out an empty line:\r\n\r\n    file=$( readlink -f &quot;$1&quot; )\r\n    variable=&quot;$file&quot; | jq -j &quot;.rows[].example&quot;\r\n    echo &quot;$variable&quot;\r\ninteresting for me is that this code work properly \r\n\r\n    file=$( readlink -f &quot;$1&quot; )\r\n    cat &quot;$file&quot; | jq -j &quot;.rows[].example&quot;\r\nmeaning that it will prints out 20.\r\n\r\nDoes anybody knows what am i doing wrong.\r\nThx guys",
        "link": "https://stackoverflow.com/questions/45486380/using-jq-to-store-part-of-json-in-variable",
        "title": "Using jq to store part of JSON in variable"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7996476,
                    "reputation": 4525,
                    "user_id": 6069012,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/bKlmM.png?s=256",
                    "display_name": "Gavin",
                    "link": "https://stackoverflow.com/users/6069012/gavin"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1501782917,
                "post_id": 45491352,
                "comment_id": 77944157,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 235515,
                    "reputation": 33176,
                    "user_id": 502381,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/7d8ebea94fc72b30f303c73826e343b9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "JJJ",
                    "link": "https://stackoverflow.com/users/502381/jjj"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1501783129,
                "post_id": 45491352,
                "comment_id": 77944294,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "reply_to_user": {
                    "account_id": 235515,
                    "reputation": 33176,
                    "user_id": 502381,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/7d8ebea94fc72b30f303c73826e343b9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "JJJ",
                    "link": "https://stackoverflow.com/users/502381/jjj"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1501783945,
                "post_id": 45491352,
                "comment_id": 77944734,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2144458,
                    "reputation": 307,
                    "user_id": 1902402,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://www.gravatar.com/avatar/ce97de020d835f042c2503cd50542fb7?s=256&d=identicon&r=PG",
                    "display_name": "Geek Grid",
                    "link": "https://stackoverflow.com/users/1902402/geek-grid"
                },
                "reply_to_user": {
                    "account_id": 7996476,
                    "reputation": 4525,
                    "user_id": 6069012,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/bKlmM.png?s=256",
                    "display_name": "Gavin",
                    "link": "https://stackoverflow.com/users/6069012/gavin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1501787218,
                "post_id": 45491352,
                "comment_id": 77946540,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1501788852,
                "creation_date": 1501788852,
                "answer_id": 45493101,
                "question_id": 45491352,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Consider also:\r\n\r\n    $ jq -r &#39;.data.translations[].translatedText&#39; input.json\r\n    El r&#225;pido zorro marr&#243;n salt&#243; sobre el perro perezoso.\r\n\r\nor even:\r\n\r\n    jq -r &#39;.data.translations[][]&#39; input.json\r\n    El r&#225;pido zorro marr&#243;n salt&#243; sobre el perro perezoso.\r\n\r\nWhich is appropriate will of course depend on the detailed requirements.\r\n\r\n\r\n    \r\n\r\n",
                "title": "JQ to Parse JSON Response"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1501788852,
        "creation_date": 1501782719,
        "last_edit_date": 1501787274,
        "question_id": 45491352,
        "body_markdown": "I&#39;ve tried a ton of combos on this handy tool here:\r\nhttps://jqplay.org\r\nBut I can&#39;t seem to get the piece I need. Here&#39;s my JSON:\r\n\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;translations&quot;: [\r\n          {\r\n            &quot;translatedText&quot;: &quot;El r&#225;pido zorro marr&#243;n salt&#243; sobre el perro perezoso.&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nI&#39;m trying to get just this part &quot;El r&#225;pido zorro marr&#243;n salt&#243; sobre el perro perezoso.&quot; without quotes.\r\n\r\nThe closest I got was with this: \r\n\r\n    .data.translations \r\n\r\n(but this fails to get what I&#39;m looking for) Any help would be great, thanks.\r\n\r\nI got flagged for a duplicate question, but this isn&#39;t using Javascript.",
        "link": "https://stackoverflow.com/questions/45491352/jq-to-parse-json-response",
        "title": "JQ to Parse JSON Response"
    },
    {
        "tags": [
            "json",
            "elasticsearch",
            "jq",
            "tcpdump",
            "tshark"
        ],
        "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": 1501862455,
                "post_id": 45510641,
                "comment_id": 77983277,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11485236,
                    "reputation": 48,
                    "user_id": 8418106,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bddd8695b4ee4a6abf449a5516a5a557?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "8ur",
                    "link": "https://stackoverflow.com/users/8418106/8ur"
                },
                "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": 1502095848,
                "post_id": 45510641,
                "comment_id": 78045424,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1501867069,
                "creation_date": 1501867069,
                "answer_id": 45512332,
                "question_id": 45510641,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is not really a jq problem - **Unknown key for a START_OBJECT** is an elasticsearch error.  The **`[layers]`** is a hint that the problem is in the object there which unfortunately was elided in the problem description so there&#39;s really not much to go on here.  \r\n\r\nSince the jq filter you specified is just `{index:.[]}`, jq is doing nothing to the part of the json elasticsearch is complaining about.  If your workflow is expecting jq to correct that portion somehow you&#39;ll need to investigate the data closer and use a more sophisticated filter.\r\n\r\nFor reference, the [elasticsearch test suite](https://github.com/elastic/elasticsearch/blob/43efcffcc217f5e49ed15593bc3156c2b4db1c73/modules/reindex/src/test/resources/rest-api-spec/test/reindex/20_validation.yml#L17-L23) contains an example of this particular error:\r\n\r\n    ---\r\n    &quot;junk in source fails&quot;:\r\n      - do:\r\n          catch: /Unknown key for a START_OBJECT in \\[junk\\]./\r\n          reindex:\r\n            body:\r\n              source:\r\n                junk: {}\r\n\r\nHope this helps.",
                "title": "Unknown key for a START_OBJECT in [layers]"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1504780994,
        "creation_date": 1501860799,
        "last_edit_date": 1502095617,
        "question_id": 45510641,
        "body_markdown": "When trying to send my json formatted tcpdump to elasticsearch, I get the following error:\r\n\r\n    curl -X PUT --data-binary @myjson &#39;localhost:9200/_bulk?pretty&#39;\r\n    {\r\n      &quot;error&quot; : {\r\n        &quot;root_cause&quot; : [\r\n          {\r\n            &quot;type&quot; : &quot;parsing_exception&quot;,\r\n            &quot;reason&quot; : &quot;Unknown key for a START_OBJECT in [layers].&quot;,\r\n            &quot;line&quot; : 1,\r\n            &quot;col&quot; : 95\r\n          }\r\n        ],\r\n        &quot;type&quot; : &quot;parsing_exception&quot;,\r\n        &quot;reason&quot; : &quot;Unknown key for a START_OBJECT in [layers].&quot;,\r\n        &quot;line&quot; : 1,\r\n        &quot;col&quot; : 95\r\n      },\r\n      &quot;status&quot; : 400\r\n    }\r\n\r\nThe json file was obtained using tshark with the &quot;-T json&quot; option.\r\nThe json file was modified using jq with the filter &quot;{index: .[]}&quot; and the option -c since elasticsearch requires an entry to fit in a single line.\r\nI am using elasticsearch 5.5.1 with the standard configuration.\r\njsonformatter marks the json object as valid.\r\n\r\nA json object that produces the error looks as follows:\r\n\r\n    {&quot;index&quot;:{&quot;_index&quot;:&quot;packets-2017-08-04&quot;,&quot;_type&quot;:&quot;pcap_file&quot;,&quot;_score&quot;:null,&quot;_source&quot;:{&quot;layers&quot;:{&quot;frame&quot;:{&quot;frame.encap_type&quot;:&quot;25&quot;,&quot;frame.time&quot;:&quot;Aug  5, 2001 13:10:06.559762000 CEST&quot;,&quot;frame.offset_shift&quot;:&quot;0.000000000&quot;,&quot;frame.time_epoch&quot;:&quot;1501773006.559765000&quot;,&quot;frame.time_delta&quot;:&quot;0.000000000&quot;,&quot;frame.time_delta_displayed&quot;:&quot;0.000000000&quot;,&quot;frame.time_relative&quot;:&quot;0.000000000&quot;,&quot;frame.number&quot;:&quot;1&quot;,&quot;frame.len&quot;:&quot;200&quot;,&quot;frame.cap_len&quot;:&quot;200&quot;,&quot;frame.marked&quot;:&quot;0&quot;,&quot;frame.ignored&quot;:&quot;0&quot;,&quot;frame.protocols&quot;:&quot;sll:ethertype:ip:tcp:data&quot;},&quot;sll&quot;:{&quot;sll.pkttype&quot;:&quot;4&quot;,&quot;sll.hatype&quot;:&quot;65135&quot;,&quot;sll.halen&quot;:&quot;0&quot;,&quot;sll.etype&quot;:&quot;0x00000800&quot;},&quot;ip&quot;:{&quot;ip.version&quot;:&quot;4&quot;,&quot;ip.hdr_len&quot;:&quot;20&quot;,&quot;ip.dsfield&quot;:&quot;0x00000010&quot;,&quot;ip.dsfield_tree&quot;:{&quot;ip.dsfield.dscp&quot;:&quot;4&quot;,&quot;ip.dsfield.ecn&quot;:&quot;0&quot;},&quot;ip.len&quot;:&quot;184&quot;,&quot;ip.id&quot;:&quot;0x000093f2&quot;,&quot;ip.flags&quot;:&quot;0x00000002&quot;,&quot;ip.flags_tree&quot;:{&quot;ip.flags.rb&quot;:&quot;0&quot;,&quot;ip.flags.df&quot;:&quot;1&quot;,&quot;ip.flags.mf&quot;:&quot;0&quot;},&quot;ip.frag_offset&quot;:&quot;0&quot;,&quot;ip.ttl&quot;:&quot;64&quot;,&quot;ip.proto&quot;:&quot;6&quot;,&quot;ip.checksum&quot;:&quot;0x0000ef4b&quot;,&quot;ip.checksum.status&quot;:&quot;2&quot;,&quot;ip.src&quot;:&quot;0.0.00&quot;,&quot;ip.addr&quot;:&quot;0.0.0.0&quot;,&quot;ip.src_host&quot;:&quot;0.0.0.0&quot;,&quot;ip.host&quot;:&quot;0.0.0.0&quot;,&quot;ip.dst&quot;:&quot;0.0.0.0&quot;,&quot;ip.dst_host&quot;:&quot;0.0.0.0&quot;,&quot;Source GeoIP: Germany&quot;:{&quot;ip.geoip.src_country&quot;:&quot;Germany&quot;,&quot;ip.geoip.country&quot;:&quot;Germany&quot;,&quot;ip.geoip.src_city&quot;:&quot;Frankfurt, 1&quot;,&quot;ip.geoip.city&quot;:&quot;Berlin, 1&quot;,&quot;ip.geoip.src_asnum&quot;:&quot;123&quot;,&quot;ip.geoip.asnum&quot;:&quot;123&quot;,&quot;ip.geoip.src_lat&quot;:&quot;701&quot;,&quot;ip.geoip.lat&quot;:&quot;523,01&quot;,&quot;ip.geoip.src_lon&quot;:&quot;2313,4&quot;,&quot;ip.geoip.lon&quot;:&quot;12,13&quot;},&quot;Destination GeoIP: Germany&quot;:{&quot;ip.geoip.dst_country&quot;:&quot;Germany&quot;,&quot;ip.geoip.country&quot;:&quot;Germany&quot;,&quot;ip.geoip.dst_asnum&quot;:&quot;123&quot;,&quot;ip.geoip.asnum&quot;:&quot;123&quot;,&quot;ip.geoip.dst_lat&quot;:&quot;3321&quot;,&quot;ip.geoip.lat&quot;:&quot;41&quot;,&quot;ip.geoip.dst_lon&quot;:&quot;1&quot;,&quot;ip.geoip.lon&quot;:&quot;2&quot;}},&quot;tcp&quot;:{&quot;tcp.srcport&quot;:&quot;41&quot;,&quot;tcp.dstport&quot;:&quot;124&quot;,&quot;tcp.port&quot;:&quot;234&quot;,&quot;tcp.stream&quot;:&quot;3&quot;,&quot;tcp.len&quot;:&quot;134&quot;,&quot;tcp.seq&quot;:&quot;1&quot;,&quot;tcp.nxtseq&quot;:&quot;133&quot;,&quot;tcp.ack&quot;:&quot;4&quot;,&quot;tcp.hdr_len&quot;:&quot;32&quot;,&quot;tcp.flags&quot;:&quot;0x00000018&quot;,&quot;tcp.flags_tree&quot;:{&quot;tcp.flags.res&quot;:&quot;0&quot;,&quot;tcp.flags.ns&quot;:&quot;0&quot;,&quot;tcp.flags.cwr&quot;:&quot;0&quot;,&quot;tcp.flags.ecn&quot;:&quot;0&quot;,&quot;tcp.flags.urg&quot;:&quot;0&quot;,&quot;tcp.flags.ack&quot;:&quot;1&quot;,&quot;tcp.flags.push&quot;:&quot;1&quot;,&quot;tcp.flags.reset&quot;:&quot;0&quot;,&quot;tcp.flags.syn&quot;:&quot;0&quot;,&quot;tcp.flags.fin&quot;:&quot;0&quot;,&quot;tcp.flags.str&quot;:&quot;&#194;&#183;&#194;&#183;&#194;&#183;&#194;&#183;&#194;&#183;&#194;&#183;&#194;&#183;AP&#194;&#183;&#194;&#183;&#194;&#183;&quot;},&quot;tcp.window_size_value&quot;:&quot;223&quot;,&quot;tcp.window_size&quot;:&quot;31&quot;,&quot;tcp.window_size_scalefactor&quot;:&quot;-1&quot;,&quot;tcp.checksum&quot;:&quot;0x0000b79c&quot;,&quot;tcp.checksum.status&quot;:&quot;1&quot;,&quot;tcp.urgent_pointer&quot;:&quot;0&quot;,&quot;tcp.options&quot;:&quot;123&quot;,&quot;tcp.options_tree&quot;:{&quot;No-Operation (NOP)&quot;:{&quot;tcp.options.type&quot;:&quot;1&quot;,&quot;tcp.options.type_tree&quot;:{&quot;tcp.options.type.copy&quot;:&quot;0&quot;,&quot;tcp.options.type.class&quot;:&quot;0&quot;,&quot;tcp.options.type.number&quot;:&quot;1&quot;}},&quot;Timestamps: TSval 1875055084, TSecr 5726840&quot;:{&quot;tcp.option_kind&quot;:&quot;8&quot;,&quot;tcp.option_len&quot;:&quot;10&quot;,&quot;tcp.options.timestamp.tsval&quot;:&quot;185084&quot;,&quot;tcp.options.timestamp.tsecr&quot;:&quot;1116840&quot;}},&quot;tcp.analysis&quot;:{&quot;tcp.analysis.bytes_in_flight&quot;:&quot;123&quot;,&quot;tcp.analysis.push_bytes_sent&quot;:&quot;133&quot;}},&quot;data&quot;:{&quot;data.data&quot;:&quot;01:01:02&quot;,&quot;data.len&quot;:&quot;265&quot;}}}}}\r\n\r\nMy question is: What is wrong with this json, so that elasticsearch rejects it?",
        "link": "https://stackoverflow.com/questions/45510641/unknown-key-for-a-start-object-in-layers",
        "title": "Unknown key for a START_OBJECT in [layers]"
    },
    {
        "tags": [
            "json",
            "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": 1501948255,
                "post_id": 45523425,
                "comment_id": 78007562,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11460325,
                    "reputation": 765,
                    "user_id": 8400163,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7eaa87861ec6e5c4ab827e199ac678d2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Miss Alena",
                    "link": "https://stackoverflow.com/users/8400163/miss-alena"
                },
                "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": 1501949150,
                "post_id": 45523425,
                "comment_id": 78007826,
                "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": 1501950113,
                "post_id": 45523425,
                "comment_id": 78008057,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 101,
                "is_accepted": true,
                "score": 101,
                "last_activity_date": 1501955487,
                "last_edit_date": 1501955487,
                "creation_date": 1501949874,
                "answer_id": 45524015,
                "question_id": 45523425,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Evidently one of the items in the array is a string. If your jq supports &quot;?&quot;, then one possibility would be to use it:\r\n\r\n    .response[].text?\r\n\r\nAnother would be to check the type explicitly, e.g.:\r\n\r\n    .response[] | objects | .text\r\n\r\nYet another possibility:\r\n\r\n    .response[] | select(type==&quot;object&quot; and has(&quot;text&quot;)) | .text\r\n\r\nIf you want to have a placeholder value when there is no &quot;text&quot; field:\r\n\r\n     .response[] | if type==&quot;object&quot; and has(&quot;text&quot;) then .text else null end\r\n\r\nSo it really depends on your requirements and perhaps the version of jq that you are using.",
                "title": "getting all the values of an array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 76,
        "last_activity_date": 1670212475,
        "creation_date": 1501945967,
        "last_edit_date": 1670212475,
        "question_id": 45523425,
        "body_markdown": "I parse a json file with jq:\r\n\r\n&lt;!-- language: none --&gt;\r\n    jq .response[1].text file.json\r\n\r\nIt works fine, but each time I have to enter the number .response[2].text, .response[3].text etc. I want to get all the values at once (200 values)\r\n\r\nBut when I do:\r\n\r\n&lt;!-- language: none --&gt;\r\n    jq .response[].text file.json\r\n\r\nIt gives an error: Cannot index number with string &quot;text&quot;\r\n\r\nThe file looks like this:\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    {\r\n      &quot;response&quot;: [\r\n        1000,\r\n        {\r\n          &quot;id&quot;: ,\r\n          &quot;date&quot;: ,\r\n          &quot;owner_id&quot;: ,\r\n          &quot;from_id&quot;: ,\r\n          &quot;post_type&quot;: &quot;post&quot;,\r\n          &quot;text&quot;: &quot;blabla&quot;,\r\n          &quot;attachment&quot;: {\r\n            &quot;type&quot;: &quot;photo&quot;,\r\n            &quot;photo&quot;: {\r\n              &quot;pid&quot;: ,\r\n              &quot;aid&quot;: -7,\r\n              &quot;owner_id&quot;: \r\n            }\r\n          },\r\n          &quot;attachments&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;photo&quot;,\r\n              &quot;photo&quot;: {\r\n              }\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;link&quot;,\r\n              &quot;link&quot;: {\r\n                &quot;url&quot;: &quot;&quot;,\r\n                &quot;title&quot;: &quot;&quot;,\r\n                &quot;description&quot;: &quot;&quot;,\r\n                &quot;target&quot;: &quot;external&quot;\r\n              }\r\n            }\r\n          ],\r\n          &quot;post_source&quot;: {\r\n            &quot;type&quot;: &quot;vk&quot;\r\n          },\r\n          &quot;comments&quot;: {\r\n            &quot;count&quot;: 0,\r\n            &quot;groups_can_post&quot;: true,\r\n            &quot;can_post&quot;: 1\r\n          },\r\n        },\r\n        {\r\n          &quot;id&quot;: ,\r\n          &quot;date&quot;: ,\r\n          &quot;owner_id&quot;: ,\r\n          &quot;from_id&quot;: ,\r\n          &quot;post_type&quot;: &quot;post&quot;,\r\n          &quot;text&quot;:    &quot;blabla&quot;,\r\n          &quot;attachment&quot;: {\r\n            &quot;type&quot;: &quot;link&quot;,\r\n            &quot;link&quot;: {\r\n              &quot;url&quot;: &quot;&quot;,\r\n              &quot;title&quot;: &quot;&quot;,\r\n              &quot;description&quot;: &quot;&quot;,\r\n              &quot;target&quot;: &quot;external&quot;,\r\n              &quot;\r\n            }\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/45523425/getting-all-the-values-of-an-array-with-jq",
        "title": "getting all the values of an array with jq"
    },
    {
        "tags": [
            "json",
            "object",
            "merge",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1502004247,
                "post_id": 45529418,
                "comment_id": 78019533,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502004908,
                "creation_date": 1502004908,
                "answer_id": 45529700,
                "question_id": 45529418,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Below should work for you\r\n\r\n    jq &#39;map({(.key): .value}) | add&#39; test.json\r\n\r\nOutputs\r\n\r\n    {\r\n      &quot;first_name&quot;: &quot;Jane&quot;,\r\n      &quot;last_name&quot;: &quot;Doe&quot;\r\n    }\r\n\r\nPS: Answer taken from https://github.com/stedolan/jq/issues/70\r\n",
                "title": "Combine two objects with the same keys"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1502007879,
                "creation_date": 1502007879,
                "answer_id": 45530064,
                "question_id": 45529418,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "***jq*** solution (using **`reduce`** function):\r\n\r\n    jq -s &#39;reduce .[] as $o ({}; .[$o.key]=$o.value)&#39; yourfile\r\n\r\nOr even simpler using **`from_entries`** function:\r\n\r\n    jq -s &#39;from_entries&#39; yourfile\r\n\r\nThe output (for both approaches):\r\n\r\n    {\r\n      &quot;first_name&quot;: &quot;Jane&quot;,\r\n      &quot;last_name&quot;: &quot;Doe&quot;\r\n    }\r\n\r\n\r\n----------\r\n- `--slurp/-s` - option, read the entire input stream into a large array and run the filter just once\r\n\r\n",
                "title": "Combine two objects with the same keys"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1502037637,
        "creation_date": 1502002487,
        "last_edit_date": 1502037637,
        "question_id": 45529418,
        "body_markdown": "I have two objects with the same keys:\r\n\r\n    {&quot;key&quot;: &quot;first_name&quot;, &quot;value&quot;: &quot;Jane&quot;}\r\n    {&quot;key&quot;: &quot;last_name&quot;, &quot;value&quot;: &quot;Doe&quot;}\r\n\r\nand I want\r\n\r\n    {&quot;first_name&quot;: &quot;Jane&quot;, &quot;last_name&quot;: &quot;Doe&quot;}\r\n\r\nHow can I do this in `jq`?",
        "link": "https://stackoverflow.com/questions/45529418/combine-two-objects-with-the-same-keys",
        "title": "Combine two objects with the same keys"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 174911,
                    "reputation": 18753,
                    "user_id": 404556,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/39lHi.jpg?s=256",
                    "display_name": "randomir",
                    "link": "https://stackoverflow.com/users/404556/randomir"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502040758,
                "post_id": 45534673,
                "comment_id": 78029454,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2386458,
                    "reputation": 2772,
                    "user_id": 2087348,
                    "user_type": "registered",
                    "accept_rate": 35,
                    "profile_image": "https://www.gravatar.com/avatar/2736520b671d62959a145daf52dcdb79?s=256&d=identicon&r=PG",
                    "display_name": "zeroweb",
                    "link": "https://stackoverflow.com/users/2087348/zeroweb"
                },
                "reply_to_user": {
                    "account_id": 174911,
                    "reputation": 18753,
                    "user_id": 404556,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/39lHi.jpg?s=256",
                    "display_name": "randomir",
                    "link": "https://stackoverflow.com/users/404556/randomir"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502040903,
                "post_id": 45534673,
                "comment_id": 78029490,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2386458,
                    "reputation": 2772,
                    "user_id": 2087348,
                    "user_type": "registered",
                    "accept_rate": 35,
                    "profile_image": "https://www.gravatar.com/avatar/2736520b671d62959a145daf52dcdb79?s=256&d=identicon&r=PG",
                    "display_name": "zeroweb",
                    "link": "https://stackoverflow.com/users/2087348/zeroweb"
                },
                "reply_to_user": {
                    "account_id": 174911,
                    "reputation": 18753,
                    "user_id": 404556,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/39lHi.jpg?s=256",
                    "display_name": "randomir",
                    "link": "https://stackoverflow.com/users/404556/randomir"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502040925,
                "post_id": 45534673,
                "comment_id": 78029500,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 174911,
                    "reputation": 18753,
                    "user_id": 404556,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/39lHi.jpg?s=256",
                    "display_name": "randomir",
                    "link": "https://stackoverflow.com/users/404556/randomir"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502041009,
                "post_id": 45534673,
                "comment_id": 78029529,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2386458,
                    "reputation": 2772,
                    "user_id": 2087348,
                    "user_type": "registered",
                    "accept_rate": 35,
                    "profile_image": "https://www.gravatar.com/avatar/2736520b671d62959a145daf52dcdb79?s=256&d=identicon&r=PG",
                    "display_name": "zeroweb",
                    "link": "https://stackoverflow.com/users/2087348/zeroweb"
                },
                "reply_to_user": {
                    "account_id": 174911,
                    "reputation": 18753,
                    "user_id": 404556,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/39lHi.jpg?s=256",
                    "display_name": "randomir",
                    "link": "https://stackoverflow.com/users/404556/randomir"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502041136,
                "post_id": 45534673,
                "comment_id": 78029567,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 228130,
                    "reputation": 656,
                    "user_id": 490240,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4c64a9d5c93890e5043388e0f8508fc5?s=256&d=identicon&r=PG",
                    "display_name": "jrw32982",
                    "link": "https://stackoverflow.com/users/490240/jrw32982"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1611250795,
                "post_id": 45534673,
                "comment_id": 116397184,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1502042033,
                "last_edit_date": 1502042033,
                "creation_date": 1502041383,
                "answer_id": 45534857,
                "question_id": 45534673,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using the &quot;-s&quot; command-line option of jq, the following meets the requirements as I understand them, while generalizing them as well:\r\n\r\n    map(.value | tonumber)\r\n    | unique\r\n    | (1+max - min) as $length\r\n    | if $length &gt; length then ([range(min;max+1)] - .)[]\r\n      else max+1\r\n      end\r\n\r\nIf you just want the least missing value, then replace the &#39;[]&#39; on the &#39;if&#39; line by `[0]`,\r\n\r\n   \r\n\r\n\r\n",
                "title": "jq - return json as bash array"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1502051966,
                "last_edit_date": 1502051966,
                "creation_date": 1502041790,
                "answer_id": 45534924,
                "question_id": 45534673,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To convert your JSON to a `bash` array, with help of `jq`:\r\n\r\n    $ readarray -t arr &lt; &lt;(jq &#39;.value&#39; file)\r\n    $ printf &#39;%s\\n&#39; &quot;${arr[@]}&quot;\r\n    &quot;1&quot;\r\n    &quot;3&quot;\r\n    &quot;4&quot;\r\n\r\nTo fix your expanded example (the exact command), just don&#39;t use object construction `{value: .Value}`, but instead only `.Value`:\r\n\r\n    $ readarray -t arr &lt; &lt;(aws ec2 describe-instances --region=us-east-1 --filters --filters &quot;Name=tag:NodeType,Values=worker&quot; --query &quot;Reservations[].Instances[].Tags[]&quot; | jq -r &#39;.[] | select(.Key == &quot;NodeNumber&quot;) | .Value&#39;)\r\n    $ printf &#39;%s\\n&#39; &quot;${arr[@]}&quot;\r\n    1\r\n    3\r\n    4\r\n\r\nNotice the lack of double quotes, since the `-r` option now prints only raw string values, not raw JSON Objects.\r\n\r\nAfter you get `arr` populated with values like this, you can easily iterate over it and perform tests, just as you described in your question.\r\n",
                "title": "jq - return json as bash array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502044649,
                "last_edit_date": 1502044649,
                "creation_date": 1502043274,
                "answer_id": 45535130,
                "question_id": 45534673,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This might give you some ideas:\r\n\r\n    #!/bin/bash\r\n\r\n    complete=true\r\n\r\n    while read value;do\r\n\r\n        n=${n:-$value}\r\n\r\n        if (( value != n ));then\r\n                complete=false\r\n                echo $n\r\n                break\r\n        fi\r\n\r\n        let n++\r\n\r\n    done &lt; &lt;(jq -r &#39;.value&#39; json_file)\r\n    # or: done &lt; &lt;( command_that_outputs_json | jq -r &#39;.value&#39; )\r\n\r\n    $complete &amp;&amp; echo $n\r\n",
                "title": "jq - return json as bash array"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1502043763,
                "creation_date": 1502043763,
                "answer_id": 45535208,
                "question_id": 45534673,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "## First, Store the Data\r\nGiven your raw data stored as a string in a *json* variable, perhaps with a here-document:\r\n\r\n    json=$(\r\n        cat &lt;&lt;- EOF\r\n            {\r\n              &quot;value&quot;: &quot;1&quot;\r\n            }\r\n            {\r\n              &quot;value&quot;: &quot;3&quot;\r\n            }\r\n            {\r\n              &quot;value&quot;: &quot;4&quot;\r\n            }\r\n    EOF\r\n    )\r\n\r\nBash itself will do a reasonable job of prettifying it:\r\n\r\n    $ echo $json\r\n    { &quot;value&quot;: &quot;1&quot; } { &quot;value&quot;: &quot;3&quot; } { &quot;value&quot;: &quot;4&quot; }\r\n\r\n## Parsing the Data Into a Bash Array\r\nThere&#39;s more than one way to do this. Two of the more obvious ways are to use use *jq* or *grep* to extract the values into a Bash array with the shell&#39;s simple array notation:\r\n\r\n    values=( `echo $json | jq .value` )\r\n    echo &quot;${values[@]}&quot;\r\n    &quot;1&quot; &quot;3&quot; &quot;4&quot;\r\n\r\n    unset values\r\n    values=$(egrep -o &#39;[[:digit:]]+&#39; &lt;&lt;&lt; &quot;$json&quot;)\r\n    echo &quot;${values[@]}&quot;\r\n    1\r\n    3\r\n    4\r\n\r\nThere are certainly other ways to accomplish this task, but this seems like the low-hanging fruit. Your mileage may vary.\r\n\r\n## Caveat\r\nThe main thing to remember about Bash arrays is that they need to use expansions such as `&quot;${foo[@]}&quot;` when quoted, or `${bar[*]}` when unquoted, if you want to use them for loops rather than indexing into them directly. Once they&#39;re in an array, though, you can access the entire array easily as long as you understand the different expansions and quoting rules.",
                "title": "jq - return json as bash array"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 8,
        "last_activity_date": 1502051966,
        "creation_date": 1502040290,
        "last_edit_date": 1502042376,
        "question_id": 45534673,
        "body_markdown": "My question is similar to [this question][1] but I need something more to be done and can&#39;t quite figure out how to do. \r\n\r\nThis is my JSON string\r\n\r\n    \r\n    {\r\n      &quot;value&quot;: &quot;1&quot;\r\n    }\r\n    {\r\n      &quot;value&quot;: &quot;3&quot;\r\n    }\r\n    {\r\n      &quot;value&quot;: &quot;4&quot;\r\n    }\r\n\r\n\r\nI need to write a script in BASH to output \r\n\r\n - 2 - If the sequence is missing a number \r\n - 5 - If the sequence isn&#39;t missing a number\r\n\r\n\r\nIn the above example, 2 is missing from the json array. And the script should return 2. If 2 is present in the array it should return 5.\r\n\r\n\r\nI think I may be able to write the logic to increment the number using a while loop in bash, but I am stuck at this point where I can&#39;t figure out how to convert this JSON string to bash array with just the value.\r\n\r\nBelow is the exact command that I used to get the JSON output. This is AWS CLI command to get all the instances from AWS that has a specific TAG. \r\n\r\n\r\n    readarray -t arr &lt; &lt;(aws ec2 describe-instances --region=us-east-1 --filters --filters &quot;Name=tag:NodeType,Values=worker&quot; --query &quot;Reservations[].Instances[].Tags[]&quot; | jq -r &#39;.[] | select(.Key == &quot;NodeNumber&quot;) | {value: .Value}&#39;)\r\n    printf &#39;%s\\n&#39; &quot;${arr[@]}&quot;\r\n\r\nThe above returns me \r\n\r\n    {\r\n      &quot;value&quot;: &quot;1&quot;\r\n    }\r\n    {\r\n      &quot;value&quot;: &quot;3&quot;\r\n    }\r\n    {\r\n      &quot;value&quot;: &quot;4&quot;\r\n    }\r\n\r\nHowever, I need to get just the VALUE field &quot;value&quot; as a bash array\r\n\r\n  [1]: https://stackoverflow.com/questions/35005893/how-do-i-convert-json-array-to-bash-array-of-strings-with-jq\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/45534673/jq-return-json-as-bash-array",
        "title": "jq - return json as bash array"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1502058197,
                "last_edit_date": 1502058197,
                "creation_date": 1502055603,
                "answer_id": 45536911,
                "question_id": 45536418,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you&#39;re reading myfile with python, the [`splitstream`](https://github.com/evolvIQ/splitstream) module [described here](https://stackoverflow.com/a/31060923) may be what you want. Here is a test example (test.py) which uses [jq.py](https://github.com/mwilliamson/jq.py). \r\n\r\n    import splitstream\r\n    from jq import jq\r\n    \r\n    def slurp(filename):\r\n        with open(filename) as f:\r\n            for s in splitstream.splitfile(f, format=&quot;json&quot;):\r\n                yield s\r\n    \r\n    obj = {}\r\n    for jstr in slurp(&#39;myfile&#39;):\r\n        obj = jq(&quot;[%s, .] | add&quot; % obj).transform(text=jstr, text_output=True)\r\n    \r\n    print obj\r\n\r\n\r\nHere is a sample run\r\n\r\n    $ cat myfile\r\n    {&quot;a&quot;:1}\r\n    {&quot;b&quot;:2}\r\n    \r\n    $ python test.py\r\n    {&quot;a&quot;:1,&quot;b&quot;:2}\r\n\r\nAlthough this appears to do what you asked for using [jq.py](https://github.com/mwilliamson/jq.py) I don&#39;t think its a good solution because sharing the state between python and jq is clumsy and inefficient.  \r\n\r\nA better approach might be to use jq as a subprocess.  Here is an example (test2.py):\r\n\r\n    import json\r\n    import sh\r\n    \r\n    cmd = sh.jq(&#39;-M&#39;, &#39;-s&#39;, &#39;add&#39;, &#39;myfile&#39;)\r\n    obj = json.loads( cmd.stdout )\r\n    print json.dumps(obj, indent=2)\r\n\r\nSample run:  \r\n\r\n    $ python test2.py\r\n    {\r\n      &quot;a&quot;: 1, \r\n      &quot;b&quot;: 2\r\n    }",
                "title": "Combine jq objects with distinct keys into single object without --slurp"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1502065362,
                "creation_date": 1502065362,
                "answer_id": 45537901,
                "question_id": 45536418,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This produces the desired output.\r\n\r\n`jq -nc &#39;[inputs] | add&#39;`\r\n\r\nI can&#39;t say if it would work with jq.py, however.",
                "title": "Combine jq objects with distinct keys into single object without --slurp"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1502116805,
                "last_edit_date": 1502116805,
                "creation_date": 1502108310,
                "answer_id": 45546726,
                "question_id": 45536418,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Less demanding on memory than using [inputs] would be:\r\n\r\n    reduce inputs as $in ({}; . + $in)\r\n\r\nThe above assumes the -n command-line option is in effect.  If this is not possible with py.jq, then the following filter should be used instead:\r\n\r\n    reduce inputs as $in (.; . + $in)\r\n\r\np.s. \r\nPerhaps the author of py.jq will be willing to address the issue concerning command-line options if made aware of it?",
                "title": "Combine jq objects with distinct keys into single object without --slurp"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1502272707,
        "creation_date": 1502051952,
        "last_edit_date": 1502272707,
        "question_id": 45536418,
        "body_markdown": "I have \r\n\r\n    {&quot;a&quot;:1} {&quot;b&quot;:2}\r\n\r\nand I want to use `jq` to get\r\n\r\n    {&quot;a&quot;: 1, &quot;b&quot;:2}\r\n\r\n`jq --slurp add myfile` works great. However, I want to use it with `jq.py`, which doesn&#39;t have `slurp` mode. Does `jq` have a way to do this for arbitrary sequences of objects (with distinct keys) without using `--slurp`?",
        "link": "https://stackoverflow.com/questions/45536418/combine-jq-objects-with-distinct-keys-into-single-object-without-slurp",
        "title": "Combine jq objects with distinct keys into single object without --slurp"
    },
    {
        "tags": [
            "json",
            "timestamp",
            "jq",
            "epoch"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1502132201,
                "last_edit_date": 1502132201,
                "creation_date": 1502102841,
                "answer_id": 45545074,
                "question_id": 45540191,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. Drop the call to &#39;map&#39;.\r\n\r\n2. &#39;todate&#39; expects its input to be numeric, so you will need to add a call to &#39;tonumber&#39;:\r\n\r\n        .timestamp |= (tonumber|todate)",
                "title": "JSON: convert epoch timestamp - jq: error (at &lt;stdin&gt;): Cannot index string with string &quot;timestamp&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1502132201,
        "creation_date": 1502085193,
        "last_edit_date": 1502103321,
        "question_id": 45540191,
        "body_markdown": "raw file\r\n\r\n    $ &lt; galera-healthcheck.stdout.log  jq &#39;.&#39; | head -n 40\r\n    {\r\n      &quot;timestamp&quot;: &quot;1499779398.544612646&quot;,\r\n      &quot;source&quot;: &quot;Galera Healthcheck&quot;,\r\n      &quot;message&quot;: &quot;Galera Healthcheck.Opened DB connection&quot;,\r\n      &quot;log_level&quot;: 1,\r\n      &quot;data&quot;: {\r\n        &quot;dbHost&quot;: &quot;0.0.0.0&quot;,\r\n        &quot;dbPort&quot;: 3306,\r\n        &quot;dbUser&quot;: &quot;galera-healthcheck&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;timestamp&quot;: &quot;1499779398.544713974&quot;,\r\n      &quot;source&quot;: &quot;Galera Healthcheck&quot;,\r\n      &quot;message&quot;: &quot;Galera Healthcheck.Serving healthcheck endpoint&quot;,\r\n      &quot;log_level&quot;: 1,\r\n      &quot;data&quot;: {\r\n        &quot;url&quot;: &quot;http://0.0.0.0:9200/&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;timestamp&quot;: &quot;1499779398.544794559&quot;,\r\n      &quot;source&quot;: &quot;Galera Healthcheck&quot;,\r\n      &quot;message&quot;: &quot;Galera Healthcheck.Attempting to GET endpoint...&quot;,\r\n      &quot;log_level&quot;: 1,\r\n      &quot;data&quot;: {\r\n        &quot;url&quot;: &quot;http://0.0.0.0:9200/&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;timestamp&quot;: &quot;1499779398.545407295&quot;,\r\n      &quot;source&quot;: &quot;Galera Healthcheck&quot;,\r\n      &quot;message&quot;: &quot;Galera Healthcheck.Failed to process request&quot;,\r\n      &quot;log_level&quot;: 2,\r\n      &quot;data&quot;: {\r\n        &quot;error&quot;: &quot;Cannot get status from galera&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;timestamp&quot;: &quot;1499779398.545511246&quot;,\r\n\r\n\r\nI wish the same raw file, but the timestamps in human readable form. \r\n\r\nI tried:\r\n\r\n    &lt; galera-healthcheck.stdout.log  jq &#39;map(if .timestamp then .timestamp |= todate else . end)&#39;\r\n\r\nand got this error for every line in file\r\n\r\n    (...)\r\n    jq: error (at &lt;stdin&gt;:968): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:969): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:970): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:971): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:972): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:973): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:974): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:975): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:976): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:977): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:978): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:979): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:980): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:981): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:982): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:983): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:984): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:985): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:986): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:987): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:988): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:989): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:990): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:991): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:992): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:993): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:994): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:995): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:996): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:997): Cannot index string with string &quot;timestamp&quot;\r\n    jq: error (at &lt;stdin&gt;:998): Cannot index string with string &quot;timestamp&quot;\r\n\r\nUpdate after first answer:\r\n\r\n&gt; Drop the call to &#39;map&#39;.\r\n\r\n&gt; &#39;todate&#39; expects its input to be numeric, so\r\n&gt; you will need to add a call to &#39;tonumber&#39;.\r\n\r\ntimestamps still in epoch format, not human readable:\r\n\r\n    &lt; galera-healthcheck.stdout.log  jq &#39;(if .timestamp then .timestamp |= tonumber else . end)&#39; | head\r\n    {\r\n      &quot;timestamp&quot;: 1499779398.5446126,\r\n      &quot;source&quot;: &quot;Galera Healthcheck&quot;,\r\n      &quot;message&quot;: &quot;Galera Healthcheck.Opened DB connection&quot;,\r\n      &quot;log_level&quot;: 1,\r\n      &quot;data&quot;: {\r\n        &quot;dbHost&quot;: &quot;0.0.0.0&quot;,\r\n        &quot;dbPort&quot;: 3306,\r\n        &quot;dbUser&quot;: &quot;galera-healthcheck&quot;\r\n      }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/45540191/json-convert-epoch-timestamp-jq-error-at-stdin-cannot-index-string-with",
        "title": "JSON: convert epoch timestamp - jq: error (at &lt;stdin&gt;): Cannot index string with string &quot;timestamp&quot;"
    },
    {
        "tags": [
            "arrays",
            "json",
            "slice",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1502144394,
                "last_edit_date": 1502144394,
                "creation_date": 1502115084,
                "answer_id": 45549004,
                "question_id": 45548604,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. Drop the -s option.  Your input is already an array.\r\n\r\n2. The filter to use: [.[-3,-4]]\r\n\r\nExplanation: `.[a,b]` is like `.[a],.[b]`.  The outer brackets turn this into an array.\r\n\r\n\r\nAny number of indices may be specified in this manner, and the order in which they are presented will determine the order of the items in the result.",
                "title": "jq: Select range"
            },
            {
                "up_vote_count": 30,
                "is_accepted": false,
                "score": 29,
                "last_activity_date": 1502129727,
                "creation_date": 1502129727,
                "answer_id": 45553282,
                "question_id": 45548604,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you want to select ranges of values in an array, you could use the slice syntax:\r\n\r\n    &lt;start-index&gt;:&lt;end-index&gt;\r\n\r\nJust remember that the ending index is exclusive (and not inclusive) and should be increasing order.\r\n\r\nSo to get the third/fourth from the end:\r\n\r\n    .[-4:-2]",
                "title": "jq: Select range"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 12,
        "last_activity_date": 1502144394,
        "creation_date": 1502113876,
        "last_edit_date": 1502139338,
        "question_id": 45548604,
        "body_markdown": "TL;DR: Given an input file with a series of keypairs, I want to select the 3rd-to-last and 4th-to-last pairs. I can get them individually, but I want to grab both at once if possible. Can this be done?\r\n\r\nMy input file is structured like this;\r\n\r\n    [\r\n     {\r\n      &quot;foo&quot;: &quot;bar&quot;,\r\n      &quot;foo2&quot;: &quot;bar2&quot;\r\n     },\r\n     {\r\n      &quot;foo3&quot;: &quot;bar3&quot;,\r\n      &quot;foo4&quot;: &quot;bar4&quot;\r\n     },\r\n     {\r\n      &quot;foo5&quot;: &quot;bar5&quot;,\r\n      &quot;foo6&quot;: &quot;bar6&quot;\r\n     },\r\n     {\r\n      &quot;foo7&quot;: &quot;bar7&quot;,\r\n      &quot;foo8&quot;: &quot;bar8&quot;\r\n     },\r\n     {\r\n      &quot;foo9&quot;: &quot;bar9&quot;,\r\n      &quot;foo10&quot;: &quot;bar10&quot;\r\n     }\r\n    ]\r\n\r\nAnd my output should be\r\n\r\n    [ \r\n     {\r\n      &quot;foo3&quot;: &quot;bar3&quot;,\r\n      &quot;foo4&quot;: &quot;bar4&quot;\r\n     },\r\n     {\r\n      &quot;foo5&quot;: &quot;bar5&quot;,\r\n      &quot;foo6&quot;: &quot;bar6&quot;\r\n     }\r\n    ]\r\n\r\nI know I can do `jq -s &#39;.[-3]&#39;` to get the 3rd-to-last (and swap with a 4 for the 4th-to-last) but that grabs them separately. \r\n\r\nI thought from the documentation that `jq -s &#39;.[-3;-4]&#39;` would grab both but that throws an error.\r\n\r\nI could grab them individually and work on each separately but that&#39;s sloppy code. Is there a cleaner way to grab both at once?",
        "link": "https://stackoverflow.com/questions/45548604/jq-select-range",
        "title": "jq: Select range"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5689050,
                    "reputation": 1438,
                    "user_id": 4497621,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b970dd971bad78b9d4a86ca67e070ad8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "John Hayes-Reed",
                    "link": "https://stackoverflow.com/users/4497621/john-hayes-reed"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502180688,
                "post_id": 45562926,
                "comment_id": 78085149,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11460798,
                    "reputation": 3,
                    "user_id": 8400512,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9159423b4ddfbf1009d25a53ccf23a2f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ant J",
                    "link": "https://stackoverflow.com/users/8400512/ant-j"
                },
                "reply_to_user": {
                    "account_id": 5689050,
                    "reputation": 1438,
                    "user_id": 4497621,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b970dd971bad78b9d4a86ca67e070ad8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "John Hayes-Reed",
                    "link": "https://stackoverflow.com/users/4497621/john-hayes-reed"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502192985,
                "post_id": 45562926,
                "comment_id": 78094010,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1502206428,
                "creation_date": 1502206428,
                "answer_id": 45572497,
                "question_id": 45562926,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There is a filter, &#39;startswith/0&#39;, but since you have gone to the trouble of using &#39;test/2&#39; with the &quot;i&quot; option, let&#39;s stick with that: \r\n\r\n    test(&quot;^A&quot;; &quot;i&quot;)",
                "title": "JQ - Filtering JSON file by using Startswith and making the search case insensitive"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1502206428,
        "creation_date": 1502180246,
        "last_edit_date": 1502189879,
        "question_id": 45562926,
        "body_markdown": "Below is an example of the JSON file I am trying to run:\r\n\r\n    {\r\n        &quot;$itemsPerPage&quot;: 1208,\r\n        &quot;$resources&quot;: [\r\n            {\r\n                &quot;$uuid&quot;: &quot;7b44f5b6-a5bd-4c7a-8d4a-581ff36a1072&quot;,\r\n                &quot;$etag&quot;: &quot;2016-08-12T12:29:33Z&quot;,\r\n                &quot;BPSNAM&quot;: &quot;InfoCenter&quot;,\r\n                &quot;BPSNUM&quot;: &quot;AO011&quot;,\r\n                &quot;BPSNUM_REF&quot;: {\r\n                    &quot;$title&quot;: &quot;InfoCenter&quot;,\r\n                    &quot;$description&quot;: &quot;InfoCenter&quot;\r\n                },\r\n                &quot;CUR&quot;: &quot;AOA&quot;,\r\n                &quot;CUR_REF&quot;: {\r\n                    &quot;$title&quot;: &quot;Kwanza&quot;,\r\n                    &quot;$description&quot;: &quot;Angolan kwanza&quot;,\r\n                    &quot;$symbol&quot;: &quot;&quot;,\r\n                    &quot;$scale&quot;: 2,\r\n                    &quot;$precision&quot;: 11\r\n                }\r\n            },\r\n            {\r\n                &quot;$uuid&quot;: &quot;25ee60e6-dd55-4c0a-842d-8e66234342b8&quot;,\r\n                &quot;$etag&quot;: &quot;2015-01-23T09:18:55Z&quot;,\r\n                &quot;BPSNAM&quot;: &quot;NeoPneus - Componentes e Pneus&quot;,\r\n                &quot;BPSNUM&quot;: &quot;AO051&quot;,\r\n                &quot;BPSNUM_REF&quot;: {\r\n                    &quot;$title&quot;: &quot;NeoPneus&quot;,\r\n                    &quot;$description&quot;: &quot;NeoPneus - Componentes e Pneus&quot;\r\n                },\r\n                &quot;CUR&quot;: &quot;AOA&quot;,\r\n                &quot;CUR_REF&quot;: {\r\n                    &quot;$title&quot;: &quot;Kwanza&quot;,\r\n                    &quot;$description&quot;: &quot;Angolan kwanza&quot;,\r\n                    &quot;$symbol&quot;: &quot;&quot;,\r\n                    &quot;$scale&quot;: 2,\r\n                    &quot;$precision&quot;: 11\r\n                }\r\n            },\r\n            {\r\n                &quot;$uuid&quot;: &quot;00682755-d9c7-4755-928a-439f09555e77&quot;,\r\n                &quot;$etag&quot;: &quot;2014-02-04T18:49:06Z&quot;,\r\n                &quot;BPSNAM&quot;: &quot;SuperBikes - Acessorios&quot;,\r\n                &quot;BPSNUM&quot;: &quot;AO052&quot;,\r\n                &quot;BPSNUM_REF&quot;: {\r\n                    &quot;$title&quot;: &quot;SuperBikes&quot;,\r\n                    &quot;$description&quot;: &quot;SuperBikes - Acessorios&quot;\r\n                },\r\n                &quot;CUR&quot;: &quot;AOA&quot;,\r\n                &quot;CUR_REF&quot;: {\r\n                    &quot;$title&quot;: &quot;Kwanza&quot;,\r\n                    &quot;$description&quot;: &quot;Angolan kwanza&quot;,\r\n                    &quot;$symbol&quot;: &quot;&quot;,\r\n                    &quot;$scale&quot;: 2,\r\n                    &quot;$precision&quot;: 11\r\n                }\r\n            }\r\n\r\nI&#39;m using the below which outputs the 3 results I want. However, this is a insensitive contains but I want to search by startswith:\r\n\r\n    .[&quot;$resources&quot;]|.[]|(select(.BPSNAM | test(&quot;A&quot;;&quot;i&quot;)))|.BPSNAM,.BPSNUM,.CUR\r\n\r\nHow do I search by startswith? Thanks in advance for any guidance.\r\n",
        "link": "https://stackoverflow.com/questions/45562926/jq-filtering-json-file-by-using-startswith-and-making-the-search-case-insensit",
        "title": "JQ - Filtering JSON file by using Startswith and making the search case insensitive"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1502210026,
                "creation_date": 1502210026,
                "answer_id": 45573626,
                "question_id": 45573261,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that uses the `-r` and `--arg` options with **select** and **index**.  \r\n\r\n      .states[]\r\n    | select(.city.zipcodes | index($zip|tonumber))\r\n    | &quot;\\(.key) \\(.name) \\($zip)&quot;\r\n\r\nNote that in your example you only show the zip you searched for but if you want other zipcodes to be shown as well you can change the final format string.\r\n\r\nIf you put the filter above in `filter.jq` and your data is in `data.json` you can run it like this:\r\n\r\n    $ jq -r --arg zip 73707802 -f filter.jq data.json\r\n    12 abc 73707802\r\n    32 cde 73707802\r\n    99 xyz 73707802\r\n",
                "title": "jq parsing for elements from sub array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1502210026,
        "creation_date": 1502208748,
        "question_id": 45573261,
        "body_markdown": "Need to parse following for key, which have zipcodes == 73707802. For example, need to search for state key and name where one of the zipcodes is 73707802.So if I search for 73707802, it should return all names and keys (key name zipcode)\r\n\r\n    12 abc 73707802\r\n    32 cde 73707802\r\n    99 xyz 73707802\r\n\r\nThanks in advance..\r\n\r\n########################\r\n\r\n    {\r\n      &quot;states&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;12&quot;,\r\n          &quot;name&quot;: &quot;abc&quot;,\r\n          &quot;city&quot;: {\r\n            &quot;zipcodes&quot;: [\r\n              73707802,\r\n              71444504,\r\n              72646331,\r\n              73707802\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;32&quot;,\r\n          &quot;name&quot;: &quot;cde&quot;,\r\n          &quot;city&quot;: {\r\n            &quot;zipcodes&quot;: [\r\n              71444504,\r\n              72646331,\r\n              73707802\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;99&quot;,\r\n          &quot;name&quot;: &quot;xyz&quot;,\r\n          &quot;city&quot;: {\r\n            &quot;zipcodes&quot;: [\r\n              72754781,\r\n              71444504,\r\n              72646331,\r\n              73707802\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n########################",
        "link": "https://stackoverflow.com/questions/45573261/jq-parsing-for-elements-from-sub-array",
        "title": "jq parsing for elements from sub array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1502212933,
                "last_edit_date": 1502212933,
                "creation_date": 1502212527,
                "answer_id": 45574365,
                "question_id": 45574029,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is your original solution using fixed network keys with some slight reformatting\r\n\r\n        .[]\r\n      | {\r\n           Name: .Name,\r\n           Id:   .Id,\r\n           Path: .Path,\r\n           Networks: (\r\n                .NetworkSettings.Networks\r\n              | {\r\n                 ingress: { IPAddress: .ingress.IPAddress, NetworkID:.ingress.NetworkID }, \r\n                 webnet:  { IPAddress: .webnet.IPAddress,  NetworkID:.webnet.NetworkID  }\r\n              }\r\n           )\r\n         }\r\n\r\nHere is a more general solution which uses **reduce** and **keys** to construct the Networks object\r\n\r\n        .[]\r\n      | {\r\n           Name: .Name,\r\n           Id:   .Id,\r\n           Path: .Path,\r\n           Networks: (\r\n                .NetworkSettings.Networks as $n\r\n              | reduce ($n|keys[]) as $k (\r\n                   {}\r\n                 ; .[$k] = ( $n[$k] | {IPAddress, NetworkID} )\r\n                )\r\n           )\r\n         }\r\n\r\nWhich can be simplified a little bit using `|=` to update Networks instead of constructing a new object\r\n\r\n        .[]\r\n      | {\r\n           Name: .Name,\r\n           Id:   .Id,\r\n           Path: .Path,\r\n           Networks: (\r\n                .NetworkSettings.Networks\r\n              | reduce keys[] as $k (\r\n                   .\r\n                 ; .[$k] |= {IPAddress, NetworkID}\r\n                )\r\n           )\r\n         }",
                "title": "How to access parent dictionary key with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1502212933,
        "creation_date": 1502211447,
        "question_id": 45574029,
        "body_markdown": "I am trying to JQ to output a JSON snippet from a `docker inspect ...` that include details on all of the networks. The problem is that the number an name of the networks varies.\r\n\r\nIf have shared a snippet if that helps, [JQ Snippet](https://jqplay.org/s/IFZ5z8K_y8).\r\n\r\nMy first attempt works because I explicitly name each network, `ingress` and `webnet`. I want my final solution to not mention the network names in the filter but have them in the output.\r\n\r\n    jq &#39;.[] | { Networks: (.NetworkSettings .Networks | {ingress: .ingress .IPAddress, webnet: .webnet .IPAddress})}&#39; \r\n\r\nHere is the output.\r\n\r\n    {\r\n      &quot;Networks&quot;: {\r\n        &quot;ingress&quot;: &quot;10.255.0.5&quot;,\r\n        &quot;webnet&quot;: &quot;10.0.0.3&quot;\r\n      }\r\n    }\r\n\r\nI did some research and found I can assign variables to the node I want but not the parent key.\r\n\r\n    jq &#39;.[] | .NetworkSettings .Networks[] as $parent | { IPAddress: $parent .IPAddress, NetworkID: $parent .NetworkID }&#39;\r\n\r\nHere are the details of the nodes but no parent key.\r\n\r\n    {\r\n      &quot;IPAddress&quot;: &quot;10.255.0.5&quot;,\r\n      &quot;NetworkID&quot;: &quot;zznyce2va5pfggq14su51zygn&quot;\r\n    }\r\n    {\r\n      &quot;IPAddress&quot;: &quot;10.0.0.3&quot;,\r\n      &quot;NetworkID&quot;: &quot;g66ea3npnaiwvvdy66rijt5yo&quot;\r\n    }\r\n\r\nNext I was able to access the keys but not the details.\r\n\r\n    jq &#39;.[] | .NetworkSettings .Networks | keys[] as $key | $key&#39;\r\n\r\nHere is the output.\r\n\r\n    &quot;ingress&quot;\r\n    &quot;webnet&quot;\r\n\r\nHow do I access the parent key name as a label with outputting child details? I think I need something like the following but don&#39;t know if it is correct or how to get there.\r\n\r\n    ($key): { IPAddress: $parent[$key] .IPAddress, NetworkID: $parent[$key] .NetworkID }\r\n\r\nMy final solution is to combine details at several levels with details on all the networks. I think if I can solve the above issue I can solve the below issue but I am including it in case it helps.\r\n\r\n    .[] | {Name: .Name, Id: .Id, Path: .Path, Networks: (.NetworkSettings .Networks | {ingress: { IPAddress: .ingress .IPAddress, NetworkID: .ingress .NetworkID }, \r\n    webnet: {IPAddress: .webnet .IPAddress, NetworkID: .webnet .NetworkID}})}\r\n\r\nHere is the output.\r\n\r\n    {\r\n      &quot;Name&quot;: &quot;/nginx.1.attiwcma8h39wclpsncp608tk&quot;,\r\n      &quot;Id&quot;: &quot;f2ee9caae862326a7a62304659121c506f8afb9d74080475702da3595576937a&quot;,\r\n      &quot;Path&quot;: &quot;nginx&quot;,\r\n      &quot;Networks&quot;: {\r\n        &quot;ingress&quot;: {\r\n          &quot;IPAddress&quot;: &quot;10.255.0.5&quot;,\r\n          &quot;NetworkID&quot;: &quot;zznyce2va5pfggq14su51zygn&quot;\r\n        },\r\n        &quot;webnet&quot;: {\r\n          &quot;IPAddress&quot;: &quot;10.0.0.3&quot;,\r\n          &quot;NetworkID&quot;: &quot;g66ea3npnaiwvvdy66rijt5yo&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nThanks, Wes.\r\n\r\nHere is the input in case you can&#39;t access the snippet.\r\n\r\n    [\r\n        {\r\n            &quot;Id&quot;: &quot;f2ee9caae862326a7a62304659121c506f8afb9d74080475702da3595576937a&quot;,\r\n            &quot;Created&quot;: &quot;2017-08-08T14:17:47.911028584Z&quot;,\r\n            &quot;Path&quot;: &quot;nginx&quot;,\r\n            &quot;Args&quot;: [\r\n                &quot;-g&quot;,\r\n                &quot;daemon off;&quot;\r\n            ],\r\n            &quot;State&quot;: {\r\n                &quot;Status&quot;: &quot;running&quot;,\r\n                &quot;Running&quot;: true,\r\n                &quot;Paused&quot;: false,\r\n                &quot;Restarting&quot;: false,\r\n                &quot;OOMKilled&quot;: false,\r\n                &quot;Dead&quot;: false,\r\n                &quot;Pid&quot;: 18628,\r\n                &quot;ExitCode&quot;: 0,\r\n                &quot;Error&quot;: &quot;&quot;,\r\n                &quot;StartedAt&quot;: &quot;2017-08-08T14:17:48.299360684Z&quot;,\r\n                &quot;FinishedAt&quot;: &quot;0001-01-01T00:00:00Z&quot;\r\n            },\r\n            &quot;Image&quot;: &quot;sha256:b8efb18f159bd948486f18bd8940b56fd2298b438229f5bd2bcf4cedcf037448&quot;,\r\n            &quot;ResolvConfPath&quot;: &quot;/var/lib/docker/containers/f2ee9caae862326a7a62304659121c506f8afb9d74080475702da3595576937a/resolv.conf&quot;,\r\n            &quot;HostnamePath&quot;: &quot;/var/lib/docker/containers/f2ee9caae862326a7a62304659121c506f8afb9d74080475702da3595576937a/hostname&quot;,\r\n            &quot;HostsPath&quot;: &quot;/var/lib/docker/containers/f2ee9caae862326a7a62304659121c506f8afb9d74080475702da3595576937a/hosts&quot;,\r\n            &quot;LogPath&quot;: &quot;/var/lib/docker/containers/f2ee9caae862326a7a62304659121c506f8afb9d74080475702da3595576937a/f2ee9caae862326a7a62304659121c506f8afb9d74080475702da3595576937a-json.log&quot;,\r\n            &quot;Name&quot;: &quot;/nginx.1.attiwcma8h39wclpsncp608tk&quot;,\r\n            &quot;RestartCount&quot;: 0,\r\n            &quot;Driver&quot;: &quot;overlay&quot;,\r\n            &quot;MountLabel&quot;: &quot;&quot;,\r\n            &quot;ProcessLabel&quot;: &quot;&quot;,\r\n            &quot;AppArmorProfile&quot;: &quot;&quot;,\r\n            &quot;ExecIDs&quot;: null,\r\n            &quot;HostConfig&quot;: {\r\n                &quot;Binds&quot;: null,\r\n                &quot;ContainerIDFile&quot;: &quot;&quot;,\r\n                &quot;LogConfig&quot;: {\r\n                    &quot;Type&quot;: &quot;json-file&quot;,\r\n                    &quot;Config&quot;: {}\r\n                },\r\n                &quot;NetworkMode&quot;: &quot;default&quot;,\r\n                &quot;PortBindings&quot;: {},\r\n                &quot;RestartPolicy&quot;: {\r\n                    &quot;Name&quot;: &quot;&quot;,\r\n                    &quot;MaximumRetryCount&quot;: 0\r\n                },\r\n                &quot;AutoRemove&quot;: false,\r\n                &quot;VolumeDriver&quot;: &quot;&quot;,\r\n                &quot;VolumesFrom&quot;: null,\r\n                &quot;CapAdd&quot;: null,\r\n                &quot;CapDrop&quot;: null,\r\n                &quot;Dns&quot;: null,\r\n                &quot;DnsOptions&quot;: null,\r\n                &quot;DnsSearch&quot;: null,\r\n                &quot;ExtraHosts&quot;: null,\r\n                &quot;GroupAdd&quot;: null,\r\n                &quot;IpcMode&quot;: &quot;&quot;,\r\n                &quot;Cgroup&quot;: &quot;&quot;,\r\n                &quot;Links&quot;: null,\r\n                &quot;OomScoreAdj&quot;: 0,\r\n                &quot;PidMode&quot;: &quot;&quot;,\r\n                &quot;Privileged&quot;: false,\r\n                &quot;PublishAllPorts&quot;: false,\r\n                &quot;ReadonlyRootfs&quot;: false,\r\n                &quot;SecurityOpt&quot;: null,\r\n                &quot;UTSMode&quot;: &quot;&quot;,\r\n                &quot;UsernsMode&quot;: &quot;&quot;,\r\n                &quot;ShmSize&quot;: 67108864,\r\n                &quot;Runtime&quot;: &quot;runc&quot;,\r\n                &quot;ConsoleSize&quot;: [\r\n                    0,\r\n                    0\r\n                ],\r\n                &quot;Isolation&quot;: &quot;&quot;,\r\n                &quot;CpuShares&quot;: 0,\r\n                &quot;Memory&quot;: 0,\r\n                &quot;NanoCpus&quot;: 0,\r\n                &quot;CgroupParent&quot;: &quot;&quot;,\r\n                &quot;BlkioWeight&quot;: 0,\r\n                &quot;BlkioWeightDevice&quot;: null,\r\n                &quot;BlkioDeviceReadBps&quot;: null,\r\n                &quot;BlkioDeviceWriteBps&quot;: null,\r\n                &quot;BlkioDeviceReadIOps&quot;: null,\r\n                &quot;BlkioDeviceWriteIOps&quot;: null,\r\n                &quot;CpuPeriod&quot;: 0,\r\n                &quot;CpuQuota&quot;: 0,\r\n                &quot;CpuRealtimePeriod&quot;: 0,\r\n                &quot;CpuRealtimeRuntime&quot;: 0,\r\n                &quot;CpusetCpus&quot;: &quot;&quot;,\r\n                &quot;CpusetMems&quot;: &quot;&quot;,\r\n                &quot;Devices&quot;: null,\r\n                &quot;DeviceCgroupRules&quot;: null,\r\n                &quot;DiskQuota&quot;: 0,\r\n                &quot;KernelMemory&quot;: 0,\r\n                &quot;MemoryReservation&quot;: 0,\r\n                &quot;MemorySwap&quot;: 0,\r\n                &quot;MemorySwappiness&quot;: -1,\r\n                &quot;OomKillDisable&quot;: false,\r\n                &quot;PidsLimit&quot;: 0,\r\n                &quot;Ulimits&quot;: null,\r\n                &quot;CpuCount&quot;: 0,\r\n                &quot;CpuPercent&quot;: 0,\r\n                &quot;IOMaximumIOps&quot;: 0,\r\n                &quot;IOMaximumBandwidth&quot;: 0\r\n            },\r\n            &quot;GraphDriver&quot;: {\r\n                &quot;Data&quot;: {\r\n                    &quot;LowerDir&quot;: &quot;/var/lib/docker/overlay/f7e30463365de46a74cbdf5835ad6d5ab6f390a4d53fb42c25b6a43a59cf6910/root&quot;,\r\n                    &quot;MergedDir&quot;: &quot;/var/lib/docker/overlay/6a3ac9fc31cda9ace1b7b02935cb2467be7a97984fe33f01a73706a8eae07968/merged&quot;,\r\n                    &quot;UpperDir&quot;: &quot;/var/lib/docker/overlay/6a3ac9fc31cda9ace1b7b02935cb2467be7a97984fe33f01a73706a8eae07968/upper&quot;,\r\n                    &quot;WorkDir&quot;: &quot;/var/lib/docker/overlay/6a3ac9fc31cda9ace1b7b02935cb2467be7a97984fe33f01a73706a8eae07968/work&quot;\r\n                },\r\n                &quot;Name&quot;: &quot;overlay&quot;\r\n            },\r\n            &quot;Mounts&quot;: [],\r\n            &quot;Config&quot;: {\r\n                &quot;Hostname&quot;: &quot;f2ee9caae862&quot;,\r\n                &quot;Domainname&quot;: &quot;&quot;,\r\n                &quot;User&quot;: &quot;&quot;,\r\n                &quot;AttachStdin&quot;: false,\r\n                &quot;AttachStdout&quot;: false,\r\n                &quot;AttachStderr&quot;: false,\r\n                &quot;ExposedPorts&quot;: {\r\n                    &quot;80/tcp&quot;: {}\r\n                },\r\n                &quot;Tty&quot;: false,\r\n                &quot;OpenStdin&quot;: false,\r\n                &quot;StdinOnce&quot;: false,\r\n                &quot;Env&quot;: [\r\n                    &quot;PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin&quot;,\r\n                    &quot;NGINX_VERSION=1.13.3-1~stretch&quot;,\r\n                    &quot;NJS_VERSION=1.13.3.0.1.11-1~stretch&quot;\r\n                ],\r\n                &quot;Cmd&quot;: [\r\n                    &quot;nginx&quot;,\r\n                    &quot;-g&quot;,\r\n                    &quot;daemon off;&quot;\r\n                ],\r\n                &quot;ArgsEscaped&quot;: true,\r\n                &quot;Image&quot;: &quot;nginx:latest@sha256:788fa27763db6d69ad3444e8ba72f947df9e7e163bad7c1f5614f8fd27a311c3&quot;,\r\n                &quot;Volumes&quot;: null,\r\n                &quot;WorkingDir&quot;: &quot;&quot;,\r\n                &quot;Entrypoint&quot;: null,\r\n                &quot;OnBuild&quot;: null,\r\n                &quot;Labels&quot;: {\r\n                    &quot;com.docker.swarm.node.id&quot;: &quot;3hq6jrjhs4ndk5lffpg52xj13&quot;,\r\n                    &quot;com.docker.swarm.service.id&quot;: &quot;w787z4alcw4t3p0nesgwhj1yn&quot;,\r\n                    &quot;com.docker.swarm.service.name&quot;: &quot;nginx&quot;,\r\n                    &quot;com.docker.swarm.task&quot;: &quot;&quot;,\r\n                    &quot;com.docker.swarm.task.id&quot;: &quot;attiwcma8h39wclpsncp608tk&quot;,\r\n                    &quot;com.docker.swarm.task.name&quot;: &quot;nginx.1.attiwcma8h39wclpsncp608tk&quot;\r\n                },\r\n                &quot;StopSignal&quot;: &quot;SIGTERM&quot;\r\n            },\r\n            &quot;NetworkSettings&quot;: {\r\n                &quot;Bridge&quot;: &quot;&quot;,\r\n                &quot;SandboxID&quot;: &quot;66e098ef6e1bea3b2f66dcc7460eab9fc23436cb39836918a46e1d38692a55cb&quot;,\r\n                &quot;HairpinMode&quot;: false,\r\n                &quot;LinkLocalIPv6Address&quot;: &quot;&quot;,\r\n                &quot;LinkLocalIPv6PrefixLen&quot;: 0,\r\n                &quot;Ports&quot;: {\r\n                    &quot;80/tcp&quot;: null\r\n                },\r\n                &quot;SandboxKey&quot;: &quot;/var/run/docker/netns/66e098ef6e1b&quot;,\r\n                &quot;SecondaryIPAddresses&quot;: null,\r\n                &quot;SecondaryIPv6Addresses&quot;: null,\r\n                &quot;EndpointID&quot;: &quot;&quot;,\r\n                &quot;Gateway&quot;: &quot;&quot;,\r\n                &quot;GlobalIPv6Address&quot;: &quot;&quot;,\r\n                &quot;GlobalIPv6PrefixLen&quot;: 0,\r\n                &quot;IPAddress&quot;: &quot;&quot;,\r\n                &quot;IPPrefixLen&quot;: 0,\r\n                &quot;IPv6Gateway&quot;: &quot;&quot;,\r\n                &quot;MacAddress&quot;: &quot;&quot;,\r\n                &quot;Networks&quot;: {\r\n                    &quot;ingress&quot;: {\r\n                        &quot;IPAMConfig&quot;: {\r\n                            &quot;IPv4Address&quot;: &quot;10.255.0.5&quot;\r\n                        },\r\n                        &quot;Links&quot;: null,\r\n                        &quot;Aliases&quot;: [\r\n                            &quot;f2ee9caae862&quot;\r\n                        ],\r\n                        &quot;NetworkID&quot;: &quot;zznyce2va5pfggq14su51zygn&quot;,\r\n                        &quot;EndpointID&quot;: &quot;09b287a8d82e85d0790a8ea8634e97844481cb478ded89f6ac1dfda7e3c31f76&quot;,\r\n                        &quot;Gateway&quot;: &quot;&quot;,\r\n                        &quot;IPAddress&quot;: &quot;10.255.0.5&quot;,\r\n                        &quot;IPPrefixLen&quot;: 16,\r\n                        &quot;IPv6Gateway&quot;: &quot;&quot;,\r\n                        &quot;GlobalIPv6Address&quot;: &quot;&quot;,\r\n                        &quot;GlobalIPv6PrefixLen&quot;: 0,\r\n                        &quot;MacAddress&quot;: &quot;02:42:0a:ff:00:05&quot;,\r\n                        &quot;DriverOpts&quot;: null\r\n                    },\r\n                    &quot;webnet&quot;: {\r\n                        &quot;IPAMConfig&quot;: {\r\n                            &quot;IPv4Address&quot;: &quot;10.0.0.3&quot;\r\n                        },\r\n                        &quot;Links&quot;: null,\r\n                        &quot;Aliases&quot;: [\r\n                            &quot;f2ee9caae862&quot;\r\n                        ],\r\n                        &quot;NetworkID&quot;: &quot;g66ea3npnaiwvvdy66rijt5yo&quot;,\r\n                        &quot;EndpointID&quot;: &quot;46b7ef9ba2d82cf56f34ade3a80a094b5f92f05d5e9051dab0542e2992298bb2&quot;,\r\n                        &quot;Gateway&quot;: &quot;&quot;,\r\n                        &quot;IPAddress&quot;: &quot;10.0.0.3&quot;,\r\n                        &quot;IPPrefixLen&quot;: 24,\r\n                        &quot;IPv6Gateway&quot;: &quot;&quot;,\r\n                        &quot;GlobalIPv6Address&quot;: &quot;&quot;,\r\n                        &quot;GlobalIPv6PrefixLen&quot;: 0,\r\n                        &quot;MacAddress&quot;: &quot;02:42:0a:00:00:03&quot;,\r\n                        &quot;DriverOpts&quot;: null\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/45574029/how-to-access-parent-dictionary-key-with-jq",
        "title": "How to access parent dictionary key with JQ"
    },
    {
        "tags": [
            "json",
            "powershell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11300425,
                    "reputation": 161,
                    "user_id": 8286516,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e7a90d37f98e5d5eea67ae81a29ae1d4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jmoon",
                    "link": "https://stackoverflow.com/users/8286516/jmoon"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502236701,
                "post_id": 45579569,
                "comment_id": 78118885,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1502240708,
                "creation_date": 1502240708,
                "answer_id": 45580118,
                "question_id": 45579569,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For reference, when I put your (slightly formatted) filter in a file called `filter.jq`\r\n\r\n      (map(keys) | add | unique) as $cols\r\n    | map(. as $row | $cols | map($row[.])) as $rows\r\n    | $cols, $rows[]\r\n    | @csv\r\n\r\nand your data in a file called `json.data` and run\r\n\r\n    jq -r -f filter.jq json.data\r\n\r\nI see the following output\r\n\r\n    &quot;key1&quot;,&quot;key2&quot;,&quot;key3&quot;\r\n    &quot;field1&quot;,&quot;field2&quot;,&quot;field3&quot;\r\n    &quot;field4&quot;,&quot;field5&quot;,&quot;field6&quot;\r\n\r\nSo the problem is likely in the exact command you&#39;re running.  Without seeing that it&#39;s difficult to say but putting your filter in a separate file would probably prevent any command-line quoting/escaping problems.\r\n",
                "title": "Using $ variables in jq from PowerShell"
            },
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1502289735,
                "last_edit_date": 1502289735,
                "creation_date": 1502241432,
                "answer_id": 45580221,
                "question_id": 45579569,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your `jq` script:\r\n\r\n*  **must be passed as a _literal_ PowerShell string (`&#39;...&#39;`)**, \r\n* because **an _interpolating_ PowerShell string (`&quot;...&quot;`) by design interprets `$`-prefixed tokens as _PowerShell_ variable references**; e.g., `$cols` (or PowerShell *subexpressions* (`$(...)`), which doesn&#39;t apply in this case):\r\n\r\n&lt;!-- language-all: powershell --&gt;\r\n\r\n    jq -r &#39;(map(keys) | add | unique) as $cols | \r\n           map(. as $row | $cols | map($row[.])) as $rows | \r\n             $cols, $rows[] | @csv&#39; output2.json &gt; output3.csv\r\n\r\n&lt;sup&gt;* I&#39;ve added line breaks for readability. PowerShell string literals can span multiple lines, so you should be able to paste the multi-line command as-is. Of course, you can format it as a single line.  \r\n* `-r` ensures that the results are output &quot;raw&quot;, i.e., without JSON value escaping.  \r\n* If you save a `jq` script to a _file_ to be used with the `-f` option, be sure to save it as UTF-8 _without a BOM_.&lt;/sup&gt;\r\n\r\n\r\n---\r\n\r\nHere&#39;s a simplified example that demonstrates the difference:\r\n\r\n    # OK: SINGLE-quoted jq script:\r\n    PS&gt; &#39;{ &quot;foo&quot;: &quot;bar&quot; }&#39; | jq &#39;. as $cols | .foo&#39;\r\n    &quot;bar&quot;\r\n\r\n    # BROKEN: DOUBLE-quoted jq script: PowerShell expands `$cols` up front, \r\n    #         resulting in an empty string, if no such PowerShell variable exists. \r\n    #         jq then effectively sees &#39;. as  | .foo&#39;, which explains the syntax error.\r\n    PS&gt; &#39;{ &quot;foo&quot;: &quot;bar&quot; }&#39; | jq &quot;. as $cols | .foo&quot;\r\n    jq: error: syntax error, unexpected &#39;|&#39;, expecting &#39;$&#39; or &#39;[&#39; or &#39;{&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    . as  | .foo      \r\n    jq: 1 compile error\r\n\r\n\r\n\r\n",
                "title": "Using $ variables in jq from PowerShell"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1502289735,
        "creation_date": 1502235844,
        "last_edit_date": 1502283034,
        "question_id": 45579569,
        "body_markdown": "I am using this code:\r\n\r\n    jq --raw-output &quot;(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @csv&quot; output2.json &gt; output3.csv\r\n\r\nto create CSV from my JSON database:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;key1&quot;: &quot;field1&quot;,\r\n        &quot;key2&quot;: &quot;field2&quot;,\r\n        &quot;key3&quot;: &quot;field3&quot;\r\n      },\r\n      {\r\n        &quot;key1&quot;: &quot;field4&quot;,\r\n        &quot;key2&quot;: &quot;field5&quot;,\r\n        &quot;key3&quot;: &quot;field6&quot;\r\n      }\r\n    ]\r\n\r\nThe output is perfect on https://jqplay.org/, but doesn&#39;t seem to work at all when running on my command line.\r\nI use PowerShell inside VSCode.\r\n\r\nI keep getting this error.\r\n\r\n&lt;pre&gt;\r\njq: error: syntax error, unexpected &#39;|&#39;, expecting &#39;$&#39; or &#39;[&#39; or &#39;{&#39; (Windows cmd shell quoting issues?) at &lt;top-level&gt;, \r\nline 1: (map(keys) | add | unique) as  | map(. as  |  | map([.])) as  | , [] | @csv\r\njq: 1 compile error\r\n&lt;/pre&gt;\r\n\r\nI guessed that the `$` were the problem as they are not shown in the error text, so I tried escaping them in various ways but made no progress.\r\nI have searched extensively and no-one seems to have this problem, so I must be getting something very simple very wrong.\r\n",
        "link": "https://stackoverflow.com/questions/45579569/using-variables-in-jq-from-powershell",
        "title": "Using $ variables in jq from PowerShell"
    },
    {
        "tags": [
            "json",
            "stream",
            "jq",
            "skip"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1502320503,
                "last_edit_date": 1502320503,
                "creation_date": 1502243374,
                "answer_id": 45580461,
                "question_id": 45580088,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    def skip(n; stream):\r\n      foreach stream as $s (0; .+1; select(. &gt; n) | $s);\r\n\r\nExample:\r\n\r\n    skip(1000; inputs)\r\n\r\n(When using `inputs` and/or `input`, don&#39;t forget you&#39;ll probably want to use the -n command-line option.)\r\n\r\n## Sledgehammer Approach\r\n\r\n    try (range(0; 1000) | input | empty), inputs\r\n\r\nIn this case, the `try` is necessary to avoid an error should there be fewer than the requested number of items.",
                "title": "How to skip first n objects in jq input"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1502320503,
        "creation_date": 1502240427,
        "last_edit_date": 1502247055,
        "question_id": 45580088,
        "body_markdown": "I have a VERY large stream of objects, which I am trying to import into MongoDB.  I keep getting a broken pipe after about 10k objects, so I would like to be able to update my import script to skip the already imported objects and begin with the first one that was missed.\r\n\r\nIt seems to me that the tool for this would be jq.  What I need is a way to skip (yield empty) all items before the *n*th, and then output the rest as-is.\r\n\r\nI&#39;ve tried using foreach to maintain an object counter, but I keep ending up with 1 as the value of the counter, for all objects in my small test sample (using a bash here document):\r\n\r\n    $ jq &#39;foreach . as $item (0; (.+1); [ . , if . &lt; 2 then empty else $item end ])&#39; &lt;&lt;&quot;end&quot;\r\n    &gt; { &quot;item&quot;: &quot;first&quot; }\r\n    &gt; { &quot;item&quot;: &quot;second&quot; }\r\n    &gt; { &quot;item&quot;: &quot;third&quot; }\r\n    &gt; { &quot;item&quot;: &quot;fourth&quot; }\r\n    &gt; end\r\n\r\nThe output from this is:\r\n\r\n    [\r\n      1\r\n    ]\r\n    [\r\n      1\r\n    ]\r\n    [\r\n      1\r\n    ]\r\n    [\r\n      1\r\n    ]\r\n\r\nAny suggestions would be most welcome.\r\n",
        "link": "https://stackoverflow.com/questions/45580088/how-to-skip-first-n-objects-in-jq-input",
        "title": "How to skip first n objects in jq input"
    },
    {
        "tags": [
            "amazon-web-services",
            "aws-cloudformation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502290671,
                "creation_date": 1502290671,
                "answer_id": 45594197,
                "question_id": 45592982,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You may want to consider using `--argfile`.  Here are some answers that demonstrate it:\r\n\r\n - [replace json node with another json file with command line jq](https://stackoverflow.com/a/43058133/8379597)\r\n - [Value map with JQ](https://stackoverflow.com/a/31890081/8379597)\r\n - [Update one JSON file values with values from another JSON using JQ](https://stackoverflow.com/a/44855405/8379597)",
                "title": "Using JQ to generate AWS CloudFormation Parameters File"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1502297993,
        "creation_date": 1502287465,
        "last_edit_date": 1502297993,
        "question_id": 45592982,
        "body_markdown": "Trying to generate an AWS Parameter file using JQ for use in a call to CloudFormation\r\n\r\n    aws cloudformation create-stack --stack-name test --parameters file://params.json --template-body file://cfn.yaml\r\n\r\nI was thinking of taking template like this:\r\n\r\n    &#39;[{&quot;ParameterKey&quot;:&quot;KEY&quot;,&quot;ParameterValue&quot;:&quot;VALUE&quot;,&quot;UsePreviousValue&quot;:false}]&#39;\r\n\r\nAnd then adding some parameters in JQ and trying to do some string operations on an arg such as jq --arg params &#39;key1,value1:key2,value2&#39; then split on &#39;:&#39; to duplicate it and populate each with the comma separated values.\r\n\r\nThe best I can do is create the correct number of top level nodes ahead of time and then do a static replacement, supplying each argument individually.  Not dynamic enough to even bother -- better to just write a bash script and do substitutions in a loop.\r\n\r\nAny help would be appreciated.\r\n\r\nCurrently the best I&#39;ve been able to do is this\r\n\r\n    echo &#39;[{&quot;ParameterKey&quot;:&quot;KEY&quot;,&quot;ParameterValue&quot;:&quot;VALUE&quot;,&quot;UsePreviousValue&quot;:false}]&#39; | jq --arg vars &quot;key1,val1:key2,val2&quot; &#39;.[0].ParameterKey = ($vars|split(&quot;:&quot;)|.[]|split(&quot;,&quot;)|.[0]) | .[0].ParameterValue = ($vars|split(&quot;:&quot;)|.[]|split(&quot;,&quot;)|.[1])&#39;\r\n\r\nBut the output is a combination of all values (e.g. key1 val1, key1 val2, etc.)\r\n",
        "link": "https://stackoverflow.com/questions/45592982/using-jq-to-generate-aws-cloudformation-parameters-file",
        "title": "Using JQ to generate AWS CloudFormation Parameters File"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1502296506,
                "post_id": 45594724,
                "comment_id": 78151873,
                "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": 1502296566,
                "post_id": 45594724,
                "comment_id": 78151916,
                "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": 1502296642,
                "post_id": 45594724,
                "comment_id": 78151953,
                "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": 2,
                "creation_date": 1502296719,
                "post_id": 45594724,
                "comment_id": 78151998,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2764317,
                    "reputation": 125,
                    "user_id": 2380526,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/fc99826884204b6595aa05af6dcaa9e0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sash Sheen",
                    "link": "https://stackoverflow.com/users/2380526/sash-sheen"
                },
                "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": 1,
                "creation_date": 1502349544,
                "post_id": 45594724,
                "comment_id": 78172615,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1502296232,
                "creation_date": 1502296232,
                "answer_id": 45596134,
                "question_id": 45594724,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Backticks aren&#39;t the problem -- it&#39;s because the variable occurs within single quotes. Do this:\r\n\r\n    id=$(my_api myrouter myroutername getsomething&#39;{&quot;uid&quot;:&quot;&#39;&quot;$servername&quot;&#39;&quot;,&quot;meta_type&quot;:&quot;system&quot;}&#39;| $SCRIPTS_DIR/jq -M &#39;.result.data[].uid&#39;)\r\n    # ............................................a........b^^^^^^^^^^^^^c.......................d\r\n\r\nSo, the single quoted string starts at &quot;a&quot;, ends at &quot;b&quot;, the variable is substituted within double quotes to extend the string, and then the rest of the single quoted string goes from &quot;c&quot; to &quot;d&quot;",
                "title": "Passing variable inside backticks"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1502296232,
        "creation_date": 1502292088,
        "question_id": 45594724,
        "body_markdown": "Here is  a bit of code I am having issues with\r\n\r\n    id=`my_api myrouter myroutername getsomething&#39;{&quot;uid&quot;:&quot;$servername&quot;,&quot;meta_type&quot;:&quot;system&quot;}&#39;| $SCRIPTS_DIR/jq -M &#39;.result.data[].uid&#39;`\r\n\r\n    for i in `echo $id`;\r\n    do\r\n\r\n        echo $i\r\n        echo &quot;&quot;\r\n    done\r\n\r\n\r\nI am not able to pass the variable $servername inside backticks. Hardcoding the servername works absolutly fine\r\n\r\nI am using a bash script. Tried escaping but it doesnt work. I know am missing something very trivial but it is not coming across to me.\r\n",
        "link": "https://stackoverflow.com/questions/45594724/passing-variable-inside-backticks",
        "title": "Passing variable inside backticks"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1502357544,
                "creation_date": 1502357544,
                "answer_id": 45609764,
                "question_id": 45609601,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You are looking for the `add` function:\r\n\r\n    jq &#39;add&#39; file.json",
                "title": "how to convert multiple json object into one object using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502370408,
                "creation_date": 1502370408,
                "answer_id": 45614576,
                "question_id": 45609601,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    [.[]] | add\r\n\r\nshould do the trick.",
                "title": "how to convert multiple json object into one object using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1502370408,
        "creation_date": 1502357163,
        "last_edit_date": 1502357738,
        "question_id": 45609601,
        "body_markdown": "Input:\r\n\r\n    {\r\n      &quot;ip&quot;: {\r\n        &quot;ip_ip_dst&quot;: &quot;4.2.2.2&quot;,\r\n        &quot;ip_ip_src&quot;: &quot;192.168.2.208&quot;\r\n      },\r\n      &quot;dns&quot;: {\r\n        &quot;text_dns_qry_class&quot;: &quot;0x00000001&quot;,\r\n        &quot;text_dns_a&quot;: &quot;104.199.136.182&quot;,\r\n        &quot;text_dns_qry_name_len&quot;: &quot;15&quot;,\r\n        &quot;text_dns_qry_name&quot;: &quot;vehere.odoo.com&quot;,\r\n        &quot;text_dns_resp_type&quot;: &quot;1&quot;,\r\n        &quot;text_dns_qry_type&quot;: &quot;1&quot;\r\n      },\r\n      &quot;frame&quot;: {\r\n        &quot;frame_frame_len&quot;: &quot;79&quot;,\r\n        &quot;frame_frame_time&quot;: &quot;Aug 9, 2017 13:21:29.987979869 IST&quot;\r\n      }\r\n    }\r\n    \r\nOutput should be:\r\n\r\n    {\r\n        &quot;ip_ip_dst&quot;: &quot;4.2.2.2&quot;,\r\n        &quot;ip_ip_src&quot;: &quot;192.168.2.208&quot;\r\n        &quot;text_dns_qry_class&quot;: &quot;0x00000001&quot;,\r\n        &quot;text_dns_a&quot;: &quot;104.199.136.182&quot;,\r\n        &quot;text_dns_qry_name_len&quot;: &quot;15&quot;,\r\n        &quot;text_dns_qry_name&quot;: &quot;vehere.odoo.com&quot;,\r\n        &quot;text_dns_resp_type&quot;: &quot;1&quot;,\r\n        &quot;text_dns_qry_type&quot;: &quot;1&quot;\r\n        &quot;frame_frame_len&quot;: &quot;79&quot;,\r\n        &quot;frame_frame_time&quot;: &quot;Aug 9, 2017 13:21:29.987979869 IST&quot;\r\n      \r\n    }",
        "link": "https://stackoverflow.com/questions/45609601/how-to-convert-multiple-json-object-into-one-object-using-jq",
        "title": "how to convert multiple json object into one object using jq?"
    },
    {
        "tags": [
            "windows",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 98281,
                    "reputation": 152343,
                    "user_id": 266143,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/487f6927f37c3005e5b918d131892715?s=256&d=identicon&r=PG",
                    "display_name": "CodeCaster",
                    "link": "https://stackoverflow.com/users/266143/codecaster"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502372501,
                "post_id": 45613545,
                "comment_id": 78189580,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2725103,
                    "reputation": 29,
                    "user_id": 2350409,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/6883b3ad7f5fc5113c90fc566f040821?s=256&d=identicon&r=PG",
                    "display_name": "William Buckingham",
                    "link": "https://stackoverflow.com/users/2350409/william-buckingham"
                },
                "reply_to_user": {
                    "account_id": 98281,
                    "reputation": 152343,
                    "user_id": 266143,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/487f6927f37c3005e5b918d131892715?s=256&d=identicon&r=PG",
                    "display_name": "CodeCaster",
                    "link": "https://stackoverflow.com/users/266143/codecaster"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502381424,
                "post_id": 45613545,
                "comment_id": 78196653,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1538640372,
                "last_edit_date": 1592644375,
                "creation_date": 1502370126,
                "answer_id": 45614466,
                "question_id": 45613545,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; This includes the simplest command:\n&gt;\n&gt; jq -r . /path/to/json.json\n\nTo ascertain the nature of the problem, it would probably be better to start with an even simpler command, such as:\n\n    jq -n .\n\nIf that fails, maybe there is a 32-bit/64-bit mismatch.\n\nAlso, when specifying pathnames, you will have to use Windows conventions. \n\nPlease note that jq 1.5 cannot handle long Windows pathnames.  You can obtain a more recent version of jq pre-compiled for Windows from Appveyor, as explained at\nhttps://github.com/stedolan/jq/wiki/Installation#windows-using-appveyor\n\n",
                "title": "jq crashing under Windows 10 using any command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1538640372,
        "creation_date": 1502367506,
        "question_id": 45613545,
        "body_markdown": "I&#39;ve used jq on Mac/Unix successfully for several years and have now been asked to port a project from Mac to Windows.\r\n\r\nMy problem is that I am unable to run any command in jq under Windows with the .json files that work perfectly on the Mac.\r\n\r\nThis includes the simplest command:\r\n\r\njq -r . /path/to/json.json\r\n\r\nAll commands cause a crash of jq. I&#39;m running Windows 10 Pro.\r\n\r\nWhat I&#39;ve tried:\r\n\r\n   -Installing jq using chocolatey as well as downloading the precompiled 32-bit and 64-bit binaries directly.\r\n   \r\n   -Using a standard command prompt, an elevated command prompt and PowerShell.\r\n\r\nThe .json files all have UTF-8 encoding without BOM and I&#39;ve tried them with both Windows and Unix line endings. jq crashes regardless.\r\n\r\nCan anyone please provide any guidance as to why a simple port to Windows would be so problematic, or maybe some simple issue I am overlooking?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/45613545/jq-crashing-under-windows-10-using-any-command",
        "title": "jq crashing under Windows 10 using any command"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1502444090,
                "last_edit_date": 1502444090,
                "creation_date": 1502371758,
                "answer_id": 45615154,
                "question_id": 45613775,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First, jq is a JSON processor, so you will have to convert your file and dictionary to valid JSON.  (For some guidance in doing so, see the [jq FAQ][1]). \r\n\r\nSecond, you haven&#39;t indicated where the dictionary is to be found.  In the following, I&#39;ll assume it can be included in the program file but there are many other options (see e.g. the manual regarding --argjson).\r\n\r\nThird, there are various ways to specify a program.  I&#39;ll assume you have the following in a file named program.jq:\r\n\r\n\r\n    def dict: {&quot;1001&quot;: &quot;a&quot;, &quot;1002&quot;: &quot;b&quot;, &quot;1003&quot;: &quot;c&quot;, &quot;1004&quot;: &quot;d&quot;, &quot;1005&quot;: \r\n    &quot;e&quot;, &quot;1006&quot;: &quot;f&quot;};\r\n\r\n    .client_visited |= map(dict[tostring])\r\n\r\nThe invocation: jq -f program.jq input.json\r\n\r\nyields the desired result (but of course it will be valid JSON).\r\n\r\n## Postscript\r\nIn the comments, the OP asked about using a distinguished value rather than null should the dictionary be missing a lookup value.  To do so, consider:\r\n\r\n    .client_visited |= map(tostring as $s\r\n                           | if dict|has($s) then dict[$s] else 0 end)\r\n\r\nThe following might also be worth considering:\r\n\r\n    .client_visited |= map(dict[tostring] // 0)\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ &quot;jq FAQ&quot;",
                "title": "Replace value in json from another json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502469754,
                "last_edit_date": 1502469754,
                "creation_date": 1502376593,
                "answer_id": 45617013,
                "question_id": 45613775,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Not as succinct as [peak](https://stackoverflow.com/users/997358/peak)&#39;s answer but here is a solution using **reduce** to iterate over the indices of `client_visited` updating each element. \r\n\r\n    reduce (.client_visited|range(length)) as $i (\r\n        .\r\n      ; .client_visited[$i] |= $arg[tostring]\r\n    )\r\n\r\nTo specify `$arg` you can use `--argfile` and invoke with something like\r\n\r\n    jq --argfile arg mapping.json -f filter.jq data.json\r\n\r\n",
                "title": "Replace value in json from another json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1502469754,
        "creation_date": 1502368126,
        "last_edit_date": 1502379881,
        "question_id": 45613775,
        "body_markdown": "I have a json file with the following format:\r\n\r\n    {userid: 1, client_visited: [1001, 1002]}\r\n    {userid: 2, client_visited: [1001, 1004]}\r\n    {userid: 3, client_visited: [1004, 1006]}\r\n    {userid: 4, client_visited: [1003, 1005, 1006]}\r\n    {userid: 5, client_visited: [1006]}\r\n\r\nI have a mapping of clients that is output from MYSQL db:\r\n\r\n    {&quot;1001&quot;: a, &quot;1002&quot;: b, &quot;1003&quot;: c, &quot;1004&quot;: d, &quot;1005&quot;: e, &quot;1006&quot;: f}\r\n\r\nHow can I update the above json file for the following output?\r\n\r\n    {userid: 1, client_visited: [&#39;a&#39;, &#39;b&#39;]}\r\n    {userid: 2, client_visited: [&#39;a&#39;, &#39;d&#39;]}\r\n    {userid: 3, client_visited: [&#39;d&#39;, &#39;f&#39;]}\r\n    {userid: 4, client_visited: [&#39;c&#39;, &#39;e&#39;, &#39;f&#39;]}\r\n    {userid: 5, client_visited: [&#39;f&#39;]}\r\n\r\nI am looking at `jq` command to achieve this in a shell script.",
        "link": "https://stackoverflow.com/questions/45613775/replace-value-in-json-from-another-json",
        "title": "Replace value in json from another json"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1502378907,
                "post_id": 45616953,
                "comment_id": 78194916,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502470589,
                "last_edit_date": 1502470589,
                "creation_date": 1502381344,
                "answer_id": 45618647,
                "question_id": 45616953,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One way(since you said bash) would be to use `awk`. \r\n\r\n\r\n    tr -d &quot;[]}&quot; &lt;input.json | awk -F &quot;:&quot; &#39;{split($3,a,&quot;,&quot;) ;o=0;for (i in a)  {o = or(o,a[i])};print $1&quot;:&quot;$2&quot;:&quot;o&quot;}&quot;  }&#39; \r\n\r\nawk has bitwise `OR` function - which is used as `or(arg1,arg2,..argn)`.\r\n\r\n`tr -d &quot;[]}&quot;` is used to eliminate extra characters before performing operations.\r\n\r\n`split()` stores a delimiter (,)  separated values into arrays.\r\n\r\nThis gives :\r\n\r\n    {&quot;userid&quot;:&quot;04f&quot;,&quot;clients&quot;:3}                                                                                                                                             \r\n    {&quot;userid&quot;:&quot;07f&quot;,&quot;clients&quot;:7}                                                                                                                                             \r\n    {&quot;userid&quot;:&quot;082&quot;,&quot;clients&quot;:7}                                                                                                                                             \r\n    {&quot;userid&quot;:&quot;0c1&quot;,&quot;clients&quot;:11}                                                                                                                                            \r\n    {&quot;userid&quot;:&quot;13f&quot;,&quot;clients&quot;:4}    \r\n\r\n**Note**:This might not work for some other json formats.",
                "title": "Bitwise Operation in json array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1502381367,
                "creation_date": 1502381367,
                "answer_id": 45618659,
                "question_id": 45616953,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Unfortunately `jq` doesn&#39;t support bitwise operations yet. I&#39;d recommend to write a small Python program:\r\n\r\n&lt;!-- language: python --&gt;\r\n\r\n    from collections import OrderedDict\r\n    from functools import reduce\r\n    import json\r\n    \r\n    with open(&#39;file.json&#39;, &#39;r&#39;) as fd:\r\n        for line in fd:\r\n            data = json.loads(line, object_pairs_hook=OrderedDict)\r\n            data[&#39;clients&#39;] = reduce(lambda x,y : x|y, data[&#39;clients&#39;])\r\n            print(json.dumps(data))\r\n\r\nOutput:\r\n\r\n    {&quot;userid&quot;: &quot;04f&quot;, &quot;clients&quot;: 3}\r\n    {&quot;userid&quot;: &quot;07f&quot;, &quot;clients&quot;: 7}\r\n    {&quot;userid&quot;: &quot;082&quot;, &quot;clients&quot;: 7}\r\n    {&quot;userid&quot;: &quot;0c1&quot;, &quot;clients&quot;: 11}\r\n    {&quot;userid&quot;: &quot;13f&quot;, &quot;clients&quot;: 4}",
                "title": "Bitwise Operation in json array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502560870,
                "last_edit_date": 1502560870,
                "creation_date": 1502386871,
                "answer_id": 45620260,
                "question_id": 45616953,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a jq solution.  The constant 128 in `twopowers` can be changed to whatever makes sense for your data (or you could even replace it with a simpler function that returns a constant stream)\r\n    \r\n    def twopowers:               # return sequence of powers of 2\r\n          128                    # largest power (change as desired)\r\n        | log2 as $maxp          # e.g.   7\r\n        | $maxp - range($maxp+1) #        7, 6, 5, 4, 3, 2, 1, 0\r\n        | pow(2; .)              #        128, 64, 32, 16, 8, 4, 2, 1\r\n    ; \r\n    \r\n    def base2powers:             # e.g 81 -&gt; [0,64,0,16,0,0,0,1]\r\n        [\r\n          foreach twopowers as $p (\r\n              { v: . }\r\n            ;   .diff = .v - $p\r\n              | .v    = if .diff &gt;= 0 then .diff else .v end\r\n              | .bit  = if .diff &gt;= 0 then 1     else  0 end\r\n            ; .bit * $p\r\n          )\r\n        ]\r\n    ;\r\n    \r\n    def combine:                 # given an array of base2powers arrays\r\n          reduce .[] as $a (     # compute the element-wise max array\r\n             []                  # and return its sum\r\n           ; [ . as $b\r\n               | $a\r\n               | range(length)\r\n               | [ $a[.], $b[.] ]\r\n               | max\r\n             ]\r\n          )\r\n        | add\r\n    ;\r\n    \r\n    .clients = (.clients | map(base2powers) | combine)\r\n\r\nThinking a little more, we can eliminate the constant in `twopowers` by using the largest value from the `.clients` array to calculate the powers to use for each input.  Here is a version which does this.\r\n\r\n    def twopowers_v2:             # return sequence of powers of 2 less than given value\r\n          .                       # e.g. 129\r\n        | log2                    #        7.011227255423254\r\n        | floor as $maxp          #        7\r\n        | $maxp - range($maxp+1)  #        7, 6, 5, 4, 3, 2, 1, 0\r\n        | pow(2; .)               #        128, 64, 32, 16, 8, 4, 2, 1\r\n    ; \r\n    \r\n    def base2powers_v2($powers):  # e.g 81 -&gt; [64,0,16,0,0,0,1]\r\n        [\r\n          foreach $powers[] as $p (\r\n              { v: . }\r\n            ;   .diff = .v - $p\r\n              | .v    = if .diff &gt;= 0 then .diff else .v end\r\n              | .pow  = if .diff &gt;= 0 then $p    else  0 end\r\n            ; .pow\r\n          )\r\n        ]\r\n    ;\r\n\r\n    .clients = (\r\n          .clients\r\n        | [max|twopowers_v2] as $powers\r\n        | map(base2powers_v2($powers))\r\n        | combine\r\n     )\r\n\r\n[Nishant Kumar](https://stackoverflow.com/users/7321201/nishant-kumar) observes that if `.clients`\r\nis `[0]` the final result is `null`.  This is because `0 | twopowers_v2` returns no values.  To compensate for this we can add an explicit check:\r\n\r\n    def twopowers_v3:             # return sequence of powers of 2 less than given value\r\n        if . &gt; 0 then             # e.g. 129\r\n          log2                    #        7.011227255423254\r\n        | floor as $maxp          #        7\r\n        | $maxp - range($maxp+1)  #        7, 6, 5, 4, 3, 2, 1, 0\r\n        | pow(2; .)               #        128, 64, 32, 16, 8, 4, 2, 1\r\n        else                      # \r\n          0                       # but if input is 0, return 0\r\n        end                       #\r\n    ; \r\n\r\n    .clients = (\r\n          .clients\r\n        | [max|twopowers_v3] as $powers\r\n        | map(base2powers_v2($powers))\r\n        | combine\r\n     )\r\n\r\nLooking at [peak&#39;s second solution](https://stackoverflow.com/a/45646075/8379597) I notice two things:\r\n\r\n - `combine` is the same as `elementwise(max) | add`\r\n - `elementwise(max)` is the same as `transpose | map(max)`\r\n\r\nHere is a version without `combine`\r\n \r\n    .clients = (\r\n          .clients\r\n        | [max|twopowers_v3] as $powers\r\n        | map(base2powers_v2($powers))\r\n        | transpose\r\n        | map(max)\r\n        | add\r\n     )\r\n\r\nAlso using a &quot;little-endian&quot; representation for the bit array is simpler then this approach.",
                "title": "Bitwise Operation in json array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1502397899,
                "creation_date": 1502397899,
                "answer_id": 45623173,
                "question_id": 45616953,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following builds on the two generic filters (`convert/1` and `to_i/1`) available at https://rosettacode.org/wiki/Non-decimal_radices/Convert#jq \r\nTheir definitions are included below for completeness and ease of reference.\r\n\r\n    # input: an array of decimal numbers\r\n    def bitwise_or:\r\n       map(convert(2) | explode | reverse | map(.-48))\r\n       | transpose | map(max)\r\n       | reverse\r\n       | join(&quot;&quot;)\r\n       | to_i(2) ;\r\n\r\n    .clients |= bitwise_or\r\n\r\n### convert and to_i \r\n\r\n    # Convert the input integer to a string in the specified base (2 to 36 inclusive)\r\n    def convert(base):\r\n      def stream:\r\n        recurse(if . &gt; 0 then ./base|floor else empty end) | . % base ;\r\n      if . == 0 then &quot;0&quot;\r\n      else  [stream] | reverse | .[1:]\r\n      | if   base &lt;  10 then map(tostring) | join(&quot;&quot;)\r\n        elif base &lt;= 36 then map(if . &lt; 10 then 48 + . else . + 87 end) | implode\r\n        else error(&quot;base too large&quot;)\r\n        end\r\n      end;\r\n     \r\n    # input string is converted from &quot;base&quot; to an integer, within limits\r\n    # of the underlying arithmetic operations, and without error-checking:\r\n    def to_i(base):\r\n      explode\r\n      | reverse\r\n      | map(if . &gt; 96  then . - 87 else . - 48 end)  # &quot;a&quot; ~ 97 =&gt; 10 ~ 87\r\n      | reduce .[] as $c\r\n          # state: [power, ans]\r\n          ([1,0]; (.[0] * base) as $b | [$b, .[1] + (.[0] * $c)])\r\n      | .[1];\r\n\r\n",
                "title": "Bitwise Operation in json array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1502599518,
                "last_edit_date": 1502599518,
                "creation_date": 1502506732,
                "answer_id": 45646075,
                "question_id": 45616953,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a stand-alone, efficient solution that only assumes the availability of jq 1.4 or later. It defines two generic functions: `elementwise/1` and `bitwise_or/0`:\r\n\r\n    # transpose | map(f) \r\n    def elementwise(f):\r\n      reduce .[1:][] as $a (.[0];\r\n        reduce range(0; $a|length) as $i (.; .[$i] |= ([$a[$i], . ] | f) )) ;\r\n    \r\n    # input: an array of decimal integers\r\n    def bitwise_or:\r\n\r\n      # Input: an integer\r\n      # Output: a stream of 0s and 1\r\n      def stream:\r\n        recurse(if . &gt; 0 then ./2|floor else empty end) | . % 2 ;\r\n    \r\n      # Input: a 0-1 array \r\n      def toi:\r\n        reduce .[] as $c ( {power:1, ans: 0};\r\n          .ans += ($c * .power) | .power *= 2 )\r\n        | .ans;\r\n    \r\n      map([stream])\r\n      | elementwise(max)\r\n      | toi ;\r\n    \r\n    \r\n    # The problem at hand:\r\n    .clients |= bitwise_or\r\n\r\nInvocation:\r\n\r\n    $ jq -f program.jq input.json\r\n",
                "title": "Bitwise Operation in json array"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 0,
        "last_activity_date": 1502599518,
        "creation_date": 1502376462,
        "question_id": 45616953,
        "body_markdown": "I have a json file `input.json` with data in the following format:\r\n\r\n    {&quot;userid&quot;:&quot;04f&quot;,&quot;clients&quot;:[1,2]}\r\n    {&quot;userid&quot;:&quot;07f&quot;,&quot;clients&quot;:[1,6,7]}\r\n    {&quot;userid&quot;:&quot;082&quot;,&quot;clients&quot;:[2,6,1]}\r\n    {&quot;userid&quot;:&quot;0c1&quot;,&quot;clients&quot;:[3,9,8]}\r\n    {&quot;userid&quot;:&quot;13f&quot;,&quot;clients&quot;:[4]}\r\n\r\nThe clients array can contain numbers from 1-10 and there could be multiple elements but no duplicates. I would like to perform bitwise operation on this file.\r\n\r\nI am expecting an output something like this (for bitwise OR operation on the elements of client array):\r\n\r\n    {&quot;userid&quot;:&quot;04f&quot;,&quot;clients&quot;:3}  #$((1|2))=3\r\n    {&quot;userid&quot;:&quot;07f&quot;,&quot;clients&quot;:7}  #$((1|6|7))=7\r\n    {&quot;userid&quot;:&quot;082&quot;,&quot;clients&quot;:7}  #$((1|6|2))=7\r\n    {&quot;userid&quot;:&quot;0c1&quot;,&quot;clients&quot;:11} #$((3|9|8))=11\r\n    {&quot;userid&quot;:&quot;13f&quot;,&quot;clients&quot;:4}  #$((4))=4\r\n\r\nMy file is huge around 250 million lines. I am looking for a solution in bash. What would be the fastest and the most optimal way to achieve this?",
        "link": "https://stackoverflow.com/questions/45616953/bitwise-operation-in-json-array",
        "title": "Bitwise Operation in json array"
    },
    {
        "tags": [
            "json",
            "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": 1502377415,
                "post_id": 45617267,
                "comment_id": 78193748,
                "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": 1502377485,
                "post_id": 45617267,
                "comment_id": 78193805,
                "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": 1502377741,
                "post_id": 45617267,
                "comment_id": 78194006,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3560832,
                    "reputation": 707,
                    "user_id": 2973562,
                    "user_type": "registered",
                    "accept_rate": 52,
                    "profile_image": "https://www.gravatar.com/avatar/eabe4ec26c14d2e1d32606ea5abd264e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "damjandd",
                    "link": "https://stackoverflow.com/users/2973562/damjandd"
                },
                "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": 1502378566,
                "post_id": 45617267,
                "comment_id": 78194620,
                "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": 1502378633,
                "post_id": 45617267,
                "comment_id": 78194668,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3560832,
                    "reputation": 707,
                    "user_id": 2973562,
                    "user_type": "registered",
                    "accept_rate": 52,
                    "profile_image": "https://www.gravatar.com/avatar/eabe4ec26c14d2e1d32606ea5abd264e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "damjandd",
                    "link": "https://stackoverflow.com/users/2973562/damjandd"
                },
                "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": 1502378799,
                "post_id": 45617267,
                "comment_id": 78194808,
                "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": 1502378869,
                "post_id": 45617267,
                "comment_id": 78194881,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3560832,
                    "reputation": 707,
                    "user_id": 2973562,
                    "user_type": "registered",
                    "accept_rate": 52,
                    "profile_image": "https://www.gravatar.com/avatar/eabe4ec26c14d2e1d32606ea5abd264e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "damjandd",
                    "link": "https://stackoverflow.com/users/2973562/damjandd"
                },
                "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": 1502378946,
                "post_id": 45617267,
                "comment_id": 78194944,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1502380034,
                "last_edit_date": 1502380034,
                "creation_date": 1502378455,
                "answer_id": 45617702,
                "question_id": 45617267,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Code to extract the titles and URLs into distinct shell variables may look like:\r\n\r\n    jq_program=&#39;\r\n    .items[].playlists[]            # we only care about playlist contents\r\n    | .title as $level_title        # store the level title before recursing\r\n    | .courses[]                    # ...into elements of the array in .courses...\r\n    | .title as $course_title       # repeat to store the course title\r\n    | .lessons[]                    # ...before recursing into the lesson...\r\n    # ...and emitting the stored level and course titles, plus the lesson title and url\r\n    | [$level_title, $course_title, .title, .url] | @tsv                              \r\n    &#39;\r\n\r\n    while IFS=$&#39;\\t&#39; read -r level_title course_title lesson_title lesson_url &lt;&amp;3; do\r\n      mkdir -p -- &quot;$level_title/$course_title&quot;\r\n      ## For test purposes, just store the URL in the file\r\n      printf &#39;%s\\n&#39; &quot;$lesson_url&quot; &gt;&quot;$level_title/$course_title/$lesson_title&quot;\r\n      ## If we had real data, we might instead be running something like:\r\n      # curl -o &quot;$level_title/$course_title/$lesson_title&quot; &quot;$lesson_url&quot;\r\n    done 3&lt; &lt;(jq -r &quot;$jq_program&quot; &lt;input.json)\r\n\r\nHere, we have `jq` doing the work of recursing and emitting a flat (tab-separated) list, and are reading that list in bash. For obvious reasons, this only works if content can&#39;t contain tabs; if you need to work with arbitrary strings (within the range that bash can store), it&#39;s possible to generate NUL-delimited output from `jq`, but requires one of the workarounds discussed in [stedolan/jq#1271](https://github.com/stedolan/jq/issues/1271).\r\n\r\nSee [BashFAQ #1](http://mywiki.wooledge.org/BashFAQ/001) discussing the technique we&#39;re using here to read tab-separated data in from the output of `jq`.",
                "title": "Iterate through JSON objects with jq in shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1502380034,
        "creation_date": 1502377250,
        "last_edit_date": 1502379358,
        "question_id": 45617267,
        "body_markdown": "I&#39;m trying to parse a json file in a shell script program, using jq.\r\n\r\nThe JSON structure looks something like this:\r\n\r\n    {\r\n       &quot;items&quot;:[\r\n          {\r\n             &quot;playlists&quot;:[\r\n                {\r\n                   &quot;title&quot;:&quot;Level One Title&quot;,\r\n                   &quot;courses&quot;:[\r\n                      {\r\n                         &quot;title&quot;:&quot;Level One Course One Title&quot;,\r\n                         &quot;lessons&quot;:[\r\n                            {\r\n                               &quot;title&quot;:&quot;lesson 1 title&quot;,\r\n                               &quot;url&quot;:&quot;lesson 1 url&quot;\r\n                            },\r\n                            {\r\n                               &quot;title&quot;:&quot;lesson 2 title&quot;,\r\n                               &quot;url&quot;:&quot;lesson 2 url&quot;\r\n                            }\r\n                         ]\r\n                      },\r\n                      {\r\n                         &quot;title&quot;:&quot;Level One Course Two Title&quot;,\r\n                         &quot;lessons&quot;:[\r\n                            {\r\n                               &quot;title&quot;:&quot;lesson 1 title&quot;,\r\n                               &quot;url&quot;:&quot;lesson 1 url&quot;\r\n                            },\r\n                            {\r\n                               &quot;title&quot;:&quot;lesson 2 title&quot;,\r\n                               &quot;url&quot;:&quot;lesson 2 url&quot;\r\n                            }\r\n                         ]\r\n                      }\r\n                   ]\r\n                },\r\n                {\r\n                   &quot;title&quot;:&quot;Level Two Title&quot;,\r\n                   &quot;courses&quot;:[\r\n                      {\r\n                         &quot;title&quot;:&quot;Level Two Course One Title&quot;,\r\n                         &quot;lessons&quot;:[\r\n                            {\r\n                               &quot;title&quot;:&quot;lesson 1 title&quot;,\r\n                               &quot;url&quot;:&quot;lesson 1 url&quot;\r\n                            },\r\n                            {\r\n                               &quot;title&quot;:&quot;lesson 2 title&quot;,\r\n                               &quot;url&quot;:&quot;lesson 2 url&quot;\r\n                            }\r\n                         ]\r\n                      },\r\n                      {\r\n                         &quot;title&quot;:&quot;Level Two Course Two Title&quot;,\r\n                         &quot;lessons&quot;:[\r\n                            {\r\n                               &quot;title&quot;:&quot;lesson 1 title&quot;,\r\n                               &quot;url&quot;:&quot;lesson 1 url&quot;\r\n                            },\r\n                            {\r\n                               &quot;title&quot;:&quot;lesson 2 title&quot;,\r\n                               &quot;url&quot;:&quot;lesson 2 url&quot;\r\n                            }\r\n                         ]\r\n                      }\r\n                   ]\r\n                }\r\n             ]\r\n          }\r\n       ]\r\n    }\r\n\r\nSince I&#39;m an iOS developer, I have written a mock piece of Swift code which would achieve what I want. It looks like this:\r\n\r\n    for level in levels {\r\n    \tlet title = level[&quot;title&quot;]\r\n    \t//TODO: create a folder with title and set as pwd\r\n    \tfor course in level[&quot;courses&quot;] {\r\n    \t\tlet courseTitle = course[&quot;title&quot;]\r\n    \t\t//TODO: create a folder with title and set as pwd\r\n    \t\tfor lesson in course[&quot;lessons&quot;] {\r\n    \t\t\tlet title = lesson[&quot;title&quot;]\r\n    \t\t\tlet videoURL = lesson[&quot;url&quot;]\r\n    \t\t\t//TODO: download video in current folder with title\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\n`levels` is an `Array` of `Dictionaries`, `level` is one of those `Dictionaries`. Each level contains an `Array` of `courses`, each of which is a `Dictionary`, containing an `Array` of `lesson` dictionaries.\r\n\r\nComing from Swift, I found jq&#39;s syntax quite confusing, especially assigning function return values to variables. Here is how far I&#39;ve gotten:\r\n\r\n    levels=$(jq &quot;.items[0].playlists&quot; data.json)\r\n    for level in $levels\r\n    do\r\n    \ttitle=$($level | jq &quot;.title&quot;)\r\n    \techo $title\r\n    done\r\n\r\nThis doesn&#39;t seem to work at all. I guess my logic to use for-loops is totally wrong here. Any ideas how this is done?",
        "link": "https://stackoverflow.com/questions/45617267/iterate-through-json-objects-with-jq-in-shell-script",
        "title": "Iterate through JSON objects with jq in shell script"
    },
    {
        "tags": [
            "bash",
            "ubuntu",
            "sed",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1502439484,
                "last_edit_date": 1502439484,
                "creation_date": 1502435462,
                "answer_id": 45629058,
                "question_id": 45628947,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use this `jq`,\r\n\r\n    jq &#39;.successfulSet[].event += { &quot;new_key&quot; : &quot;new_value&quot; }&#39; file.json\r\n\r\n**EDIT:**\r\n\r\nTry this:\r\n\r\n    jq --argjson argval &quot;$new_value&quot; &#39;.successfulSet[].event += { &quot;affected_entities&quot; : $argval }&#39; file.json\r\n\r\nTest:\r\n\r\n    sat~$ new_value=&#39;[\r\n        &quot;arn:aws:acm:us-east-1:xxxxxxxxxxxxxx:certificate/xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxx&quot;\r\n    ]&#39;\r\n\r\n    sat~$ jq --argjson argval &quot;$new_value&quot; &#39;.successfulSet[].event += { &quot;affected_entities&quot; : $argval }&#39; file.json\r\n\r\nNote that `--argjson` works with jq 1.5 and above.",
                "title": "Append an array to a json using jq in BASH"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1502439484,
        "creation_date": 1502435089,
        "last_edit_date": 1502436706,
        "question_id": 45628947,
        "body_markdown": "I have a json that looks like this:\r\n\r\n    {\r\n    \t&quot;failedSet&quot;: [],\r\n    \t&quot;successfulSet&quot;: [{\r\n    \t\t&quot;event&quot;: {\r\n    \t\t\t&quot;arn&quot;: &quot;arn:aws:health:us-east-1::event/AWS_RDS_MAINTENANCE_SCHEDULED_xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxx&quot;,\r\n    \t\t\t&quot;endTime&quot;: 1502841540.0,\r\n    \t\t\t&quot;eventTypeCategory&quot;: &quot;scheduledChange&quot;,\r\n    \t\t\t&quot;eventTypeCode&quot;: &quot;AWS_RDS_MAINTENANCE_SCHEDULED&quot;,\r\n    \t\t\t&quot;lastUpdatedTime&quot;: 1501208541.93,\r\n    \t\t\t&quot;region&quot;: &quot;us-east-1&quot;,\r\n    \t\t\t&quot;service&quot;: &quot;RDS&quot;,\r\n    \t\t\t&quot;startTime&quot;: 1502236800.0,\r\n    \t\t\t&quot;statusCode&quot;: &quot;open&quot;\r\n    \t\t},\r\n    \t\t&quot;eventDescription&quot;: {\r\n    \t\t\t&quot;latestDescription&quot;: &quot;We are contacting you to inform you that one or more of your Amazon RDS DB instances is scheduled to receive system upgrades during your maintenance window between August 8 5:00 PM and August 15 4:59 PM PDT. Please see the affected resource tab for a list of these resources. \\r\\n\\r\\nWhile the system upgrades are in progress, Single-AZ deployments will be unavailable for a few minutes during your maintenance window. Multi-AZ deployments will be unavailable for the amount of time it takes a failover to complete, usually about 60 seconds, also in your maintenance window. \\r\\n\\r\\nPlease ensure the maintenance windows for your affected instances are set appropriately to minimize the impact of these system upgrades. \\r\\n\\r\\nIf you have any questions or concerns, contact the AWS Support Team. The team is available on the community forums and by contacting AWS Premium Support. \\r\\n\\r\\nhttp://aws.amazon.com/support\\r\\n&quot;\r\n    \t\t}\r\n    \t}]\r\n    }\r\n\r\nI&#39;m trying to add a new key/value under `successfulSet[].event` (key name as `affectedEntities`) using jq, I&#39;ve seen some examples, like [here][1] and [here][2], but none of those answers really show how to add a possible one key with multiple values (the reason why I say possible is because as of now, AWS is returning one value for the affected entity, but if there are more, then I&#39;d like to list them).\r\n\r\nEDIT: The value of the new key that I want to add is stored in a variable called `$affected_entities` and a sample of that value looks like this:\r\n\r\n    [\r\n        &quot;arn:aws:acm:us-east-1:xxxxxxxxxxxxxx:certificate/xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxx&quot;\r\n    ]\r\n\r\nThe value could look like this:\r\n\r\n    [\r\n        &quot;arn:aws:acm:us-east-1:xxxxxxxxxxxxxx:certificate/xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxx&quot;, \r\n        &quot;arn:aws:acm:us-east-1:xxxxxxxxxxxxxx:certificate/xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxx&quot;,\r\n        ...\r\n        ...\r\n        ...\r\n    ]\r\n\r\n  [1]: https://stackoverflow.com/a/39016052/4557537\r\n  [2]: https://stackoverflow.com/questions/39015374/changing-the-json-using-jq-in-bash",
        "link": "https://stackoverflow.com/questions/45628947/append-an-array-to-a-json-using-jq-in-bash",
        "title": "Append an array to a json using jq in BASH"
    },
    {
        "tags": [
            "json",
            "edit",
            "jq",
            "in-place"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1502447508,
                "creation_date": 1502447508,
                "answer_id": 45633053,
                "question_id": 45632645,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The key is to use `|=`.  In the present case, you could use the following pattern:\r\n\r\n    .children |= map(select(...))",
                "title": "Filter only part of input using select"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1502449397,
        "creation_date": 1502446352,
        "last_edit_date": 1502449397,
        "question_id": 45632645,
        "body_markdown": "Given input like this:\r\n\r\n    {\r\n      &quot;type&quot;: &quot;collection&quot;,\r\n      &quot;foo&quot;: &quot;bar&quot;,\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;properties&quot;: {\r\n            &quot;country&quot;: &quot;GB&quot;\r\n          },\r\n          &quot;data&quot;: &quot;...&quot;\r\n        },\r\n        {\r\n          &quot;properties&quot;: {\r\n            &quot;country&quot;: &quot;PL&quot;\r\n          },\r\n          &quot;data&quot;: &quot;...&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nHow can I use `jq` to retain all of the JSON structure, but filter out some of the children using `select()`. For instance, If I wanted to return only children with country GB, I would expect the following output:\r\n\r\n    {\r\n      &quot;type&quot;: &quot;collection&quot;,\r\n      &quot;foo&quot;: &quot;bar&quot;,\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;properties&quot;: {\r\n            &quot;country&quot;: &quot;GB&quot;\r\n          },\r\n          &quot;data&quot;: &quot;...&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nIf I only want the children, this is easy with `.children[] | select(.properties.country == &quot;GB&quot;)`, but does not retain the rest of the JSON.",
        "link": "https://stackoverflow.com/questions/45632645/filter-only-part-of-input-using-select",
        "title": "Filter only part of input using select"
    },
    {
        "tags": [
            "json",
            "object",
            "nested",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11162290,
                    "reputation": 2784,
                    "user_id": 8191975,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b356c1c679e606407f3034fc093a595e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "BogdanC",
                    "link": "https://stackoverflow.com/users/8191975/bogdanc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502587499,
                "post_id": 45656255,
                "comment_id": 78270742,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 959793,
                    "reputation": 1424,
                    "user_id": 984407,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/899e39ce4e87fad8ed88bd4a0b7d5126?s=256&d=identicon&r=PG",
                    "display_name": "aaaaaa",
                    "link": "https://stackoverflow.com/users/984407/aaaaaa"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502591755,
                "post_id": 45656255,
                "comment_id": 78271301,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1502605699,
                "last_edit_date": 1502605699,
                "creation_date": 1502592398,
                "answer_id": 45656614,
                "question_id": 45656255,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The requirements are not very clear in several respects, but the following is probably close to what you have in mind.  The output, however, is valid JSON.\r\n\r\n    .item[]\r\n    | .name as $name\r\n    | .item[]\r\n    | {name: &quot;\\($name) _ \\(.name1)&quot;,\r\n       code: (if .event then .event[].script.exec[0]|split(&quot;=&quot;)[1]\r\n              else null end) }\r\n\r\nWith your input, this produces:\r\n\r\n    {&quot;name&quot;:&quot;Joe _ item1&quot;,&quot;code&quot;:null}\r\n    {&quot;name&quot;:&quot;Joe _ item2&quot;,&quot;code&quot;:null}\r\n    {&quot;name&quot;:&quot;Jim _ item3&quot;,&quot;code&quot;:&quot;gst-70&quot;}\r\n    {&quot;name&quot;:&quot;Jim _ item4&quot;,&quot;code&quot;:&quot;gst-50&quot;}\r\n\r\nYou might want to obtain the substring of interest in some other way, e.g.:\r\n\r\n     .[1+index(&quot;=&quot;):]\r\n\r\nor:\r\n\r\n     sub(&quot;^[^=]*=&quot;; &quot;&quot;)\r\n",
                "title": "jq with nested objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1502605699,
        "creation_date": 1502587072,
        "last_edit_date": 1502605083,
        "question_id": 45656255,
        "body_markdown": "Here is my JSON file\r\n\r\n    {  \r\n    &quot;variables&quot;: [],  \r\n    &quot;item&quot;:[  \r\n    {  \r\n      &quot;name&quot;: &quot;Joe&quot;,\r\n      &quot;item&quot;: [\r\n        {\r\n          &quot;name1&quot;: &quot;item1&quot;,\r\n          &quot;request&quot;: {},\r\n          &quot;response&quot;: []\r\n        },\r\n        {\r\n          &quot;name1&quot;: &quot;item2&quot;,\r\n          &quot;request&quot;: {},\r\n          &quot;response&quot;: []\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Jim&quot;,\r\n      &quot;item&quot;: [\r\n        {\r\n          &quot;name1&quot;: &quot;item3&quot;,\r\n          &quot;event&quot;: [\r\n            {\r\n              &quot;listen&quot;: &quot;test&quot;,\r\n              &quot;script&quot;: {\r\n                &quot;type&quot;: &quot;text/javascript&quot;,\r\n                &quot;exec&quot;: [\r\n                  &quot;//code=gst-70&quot;\r\n                ]\r\n              }\r\n            }\r\n          ],\r\n          &quot;request&quot;: {},\r\n          &quot;response&quot;: []\r\n        },\r\n        {\r\n          &quot;name1&quot;: &quot;item4&quot;,\r\n          &quot;event&quot;: [\r\n            {\r\n              &quot;listen&quot;: &quot;test&quot;,\r\n              &quot;script&quot;: {\r\n                &quot;type&quot;: &quot;text/javascript&quot;,\r\n                &quot;exec&quot;: [\r\n                  &quot;//code=gst-50&quot;\r\n                ]\r\n              }\r\n            }\r\n          ],      \r\n          &quot;request&quot;: {},\r\n          &quot;response&quot;: []\r\n        }\r\n      ]\r\n    }\r\n    ]\r\n    }\r\n\r\nand my output has to be:\r\n\r\n    [{&quot;name&quot;:&quot;Joe _ item1&quot;,&quot;code&quot;: }]\r\n    [{&quot;name&quot;:&quot;Joe _ item2&quot;,&quot;code&quot;: }]\r\n    [{&quot;name&quot;:&quot;Jim _ item3&quot;,&quot;code&quot;:gst-70}]\r\n    [{&quot;name&quot;:&quot;Jim _ item4&quot;,&quot;code&quot;:gst-50}]\r\n\r\nI am trying to achieve it through jq, however the null event values make it very complex and unable to achieve the output as above. Can this be done using jq?\r\nHere is my code:\r\n\r\n     .item[] \r\n     | (&quot;[{\\&quot;name\\&quot;:\\&quot;&quot;  +  .name  +  &quot; _ &quot; +  .item[].name1+&quot;,\\&quot;code\\&quot;:&quot;) ,  \r\n        (.item[]?.event[]?.script.exec[0]  + &quot;}]&quot; ) \r\n",
        "link": "https://stackoverflow.com/questions/45656255/jq-with-nested-objects",
        "title": "jq with nested objects"
    },
    {
        "tags": [
            "json",
            "node.js",
            "bash",
            "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": 1502740656,
                "post_id": 45681136,
                "comment_id": 78322043,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1522944,
                    "reputation": 2391,
                    "user_id": 1801040,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/01f28fb4378d94430189ae39010f5ada?s=256&d=identicon&r=PG",
                    "display_name": "Fred Lackey",
                    "link": "https://stackoverflow.com/users/1801040/fred-lackey"
                },
                "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": 1502741266,
                "post_id": 45681136,
                "comment_id": 78322349,
                "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": 1502746188,
                "post_id": 45681136,
                "comment_id": 78324666,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1522944,
                    "reputation": 2391,
                    "user_id": 1801040,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/01f28fb4378d94430189ae39010f5ada?s=256&d=identicon&r=PG",
                    "display_name": "Fred Lackey",
                    "link": "https://stackoverflow.com/users/1801040/fred-lackey"
                },
                "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": 1502749123,
                "post_id": 45681136,
                "comment_id": 78325755,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502743028,
                "creation_date": 1502743028,
                "answer_id": 45682654,
                "question_id": 45681136,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As an FYI for anyone who needs it now, I **am** currently doing this using `xargs` and a utility called [`package-utils`](https://github.com/tcurdt/package-utils).  The `jq` thing was more of a _want_ than anything.\r\n\r\nHere&#39;s the current makefile, if you&#39;d like to use it:\r\n\r\n    prenode:\r\n      @find $(CURDIR)/node -type d -name &quot;.tmp&quot; -exec rm -rf {} +;\r\n      @mkdir -p $(CURDIR)/node/.tmp\r\n      @find ../../projects -type f -name &quot;package.json&quot; -maxdepth 4 -print0 | xargs -0 package-merge &gt; $(CURDIR)/node/.tmp/package.json\r\n\r\nMy overall goal with this is for use within Docker and Docker Compose.  I am using it to pre-cache all of the NPM modules, used within a single solution, in a base image.  Basically, it creates a temporary `package.json` file that is used during the build process.\r\n\r\nWithin my `Dockerfile` is the following:\r\n\r\n    COPY ./.tmp/package.json /var/www/package.json\r\n\r\n    VOLUME /var/www\r\n    VOLUME /var/www/node_modules\r\n\r\n    WORKDIR /var/www\r\n\r\n    RUN npm install\r\n    RUN rm package.json\r\n\r\nThis allows the Node cache to be populated so any container based on this image will be able to install mostly everything from the cache.\r\n\r\nThere **is** a reason I&#39;m doing this instead of a common volume for `node_modules` but that&#39;s a different story.",
                "title": "Find and merge all package.json files into one using jq in bash?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1502744577,
                "last_edit_date": 1502744577,
                "creation_date": 1502743053,
                "answer_id": 45682660,
                "question_id": 45681136,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming the following find command works for you (adjust if necessary)\r\n\r\n    find ../../projects -name package.json\r\n\r\nHere is a solution which uses the jq **`*`** operator along with **reduce** and the `-s` option to merge the objects:\r\n\r\n    jq -s &#39;reduce .[] as $d ({}; . *= $d)&#39; $(find ../../projects -name package.json)\r\n\r\nIf you prefer you can just as easily concatenate the files and send them to jq\r\n\r\n    find ../../projects -name package.json -exec cat {} \\; | \\\r\n      jq -M -s &#39;reduce .[] as $d ({}; . *= $d)&#39;\r\n\r\nAs noted in my reply to your comment if you&#39;re doing this in a makefile you need to take extra steps to deal with the $ or put your filter in a file and use `-f`\r\n",
                "title": "Find and merge all package.json files into one using jq in bash?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1502761314,
                "last_edit_date": 1502761314,
                "creation_date": 1502756961,
                "answer_id": 45684920,
                "question_id": 45681136,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If your jq has `inputs`, here is a more efficient solution than is possible using the -s (&quot;slurp&quot;) option:\r\n\r\n    reduce inputs as $i ({};\r\n      .dependencies += ($i | .dependencies )\r\n      | .devDependencies += ($i | .devDependencies ) )\r\n\r\nThis also produces a &quot;clean&quot; result (i.e., no &quot;name&quot; field).\r\n\r\nRemember to use the -n command-line option with `inputs`, e.g. along the lines of:\r\n\r\n    jq -n -f program.jq $(find ...)\r\n\r\n### reduce-free solution\r\n\r\nIn case your jq does not have `inputs`, here is a reduce-free solution when used with the &quot;-s&quot; command-line option:\r\n\r\n    map([.dependencies, .devDependencies])\r\n    | transpose\r\n    | map(add)\r\n    | {dependencies: .[0], devDependencies: .[1]}\r\n\r\n",
                "title": "Find and merge all package.json files into one using jq in bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1502761314,
        "creation_date": 1502736702,
        "last_edit_date": 1502741234,
        "question_id": 45681136,
        "body_markdown": "How can I find all `package.json` files and merge them into one file using `jq` within Bash?  The following snippet is as far as I have gotten, however it **appends** the files:\r\n\r\n    find ../../projects -maxdepth 4 -type f -name &quot;package.json&quot; \\\r\n      -exec cat {} + | jq -s . &gt; $(CURDIR)/node/.tmp/package.json\r\n\r\nI have tried using &#39;add&#39; but that seems to overwrite the target each time without merging the two.\r\n\r\nMy project structure **initially** looks like this:\r\n\r\n    \\ projects\r\n      \\ webapp\r\n         \\ package.json\r\n      \\ service\r\n         \\ package.json\r\n      \\ admin\r\n         \\ package.json\r\n    \\ solutions\r\n      \\ killersolution\r\n           Makefile\r\n         \\ node\r\n\r\nAnd **should** look like this after `make prenode` (see below):\r\n\r\n    \\ projects\r\n      \\ webapp\r\n         \\ package.json\r\n      \\ service\r\n         \\ package.json\r\n      \\ admin\r\n         \\ package.json\r\n    \\ solutions\r\n      \\ killersolution\r\n           Makefile\r\n         \\ node\r\n            \\ .tmp\r\n              \\ package.json   &lt;- created\r\n\r\nI am using a `Makefile` to kick this off:\r\n\r\n    prenode:                                                                 \r\n      @find ./node -type d -name &quot;.tmp&quot; -exec rm -rf {} +;                 \r\n      @mkdir -p ./node/.tmp                                                \r\n      @find ../../solutions -maxdepth 4 -type f -name &quot;package.json&quot; -exec cat {} + ... \r\n\r\n**Edit #1 : Example Input &amp; Output**  \r\nLet us assume 3 `package.json` files were found.  The `dependencies` and `devDependencies` are different but must be combined:\r\n\r\nFound file #1 ...\r\n\r\n\t{\r\n\t  &quot;name&quot;:&quot;project-a&quot;,\r\n\t  &quot;dependencies&quot;:{\r\n\t    &quot;module-a&quot;:&quot;1.2.3&quot;\r\n\t  }\r\n\t}\r\n\r\nFound file #2 ...\r\n\r\n\t{\r\n\t  &quot;name&quot;:&quot;project-b&quot;,\r\n\t  &quot;dependencies&quot;:{\r\n\t    &quot;module-b&quot;:&quot;2.3.4&quot;\r\n\t  }\r\n\t}\r\n\r\nFound file #3 ...  \r\n\r\n\t{\r\n\t  &quot;name&quot;:&quot;project-c&quot;,\r\n\t  &quot;devDependencies&quot;:{\r\n\t    &quot;gulp&quot;:&quot;*&quot;\r\n\t  }\r\n\t}\r\n\r\n... would all be combined to make the following file:\r\n\r\n\t{\r\n\t  &quot;name&quot;:&quot;project-c&quot;,\r\n\t  &quot;dependencies&quot;:{\r\n\t    &quot;module-a&quot;:&quot;1.2.3&quot;,\r\n\t    &quot;module-b&quot;:&quot;2.3.4&quot;\r\n\t  },\r\n\t  &quot;devDependencies&quot;:{\r\n\t    &quot;gulp&quot;:&quot;*&quot;\r\n\t  }\r\n\t}\r\n\r\n*Note: \r\nThe `name` property, in the final output file, is irrelevant.  The key here is the merge of the `dependencies` and `devDependencies` objects.",
        "link": "https://stackoverflow.com/questions/45681136/find-and-merge-all-package-json-files-into-one-using-jq-in-bash",
        "title": "Find and merge all package.json files into one using jq in bash?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502821088,
                "post_id": 45698434,
                "comment_id": 78356417,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11557714,
                    "reputation": 13,
                    "user_id": 8468393,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/dfd42742f4d786e5b6622a60a9b8ea3e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jared",
                    "link": "https://stackoverflow.com/users/8468393/jared"
                },
                "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": 1502821994,
                "post_id": 45698434,
                "comment_id": 78356893,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1502825888,
                "last_edit_date": 1502825888,
                "creation_date": 1502823976,
                "answer_id": 45699788,
                "question_id": 45698434,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Perhaps this will help.  Start by writing a function to go from your output&#39;s nested representation to a flat one:\r\n    \r\n    def flatten:\r\n        {\r\n          title: .title,\r\n          id:    .channels[].id,\r\n          story: .description,\r\n        } + .new_files[]\r\n    ;\r\n\r\nThis will convert your sample json to a stream of objects:\r\n\r\n    {\r\n      &quot;title&quot;: &quot;New Story&quot;,\r\n      &quot;id&quot;: &quot;65tyc2TLUZsO&quot;,\r\n      &quot;story&quot;: &quot;Story Description Here&quot;,\r\n      &quot;filename&quot;: &quot;419155345a7b449df3baca76694b64efbec9bcf3983b51e02f92e7ef29fc26ee.pptx&quot;,\r\n      &quot;description&quot;: &quot;File Description ABC&quot;\r\n    }\r\n    {\r\n      &quot;title&quot;: &quot;New Story&quot;,\r\n      &quot;id&quot;: &quot;65tyc2TLUZsO&quot;,\r\n      &quot;story&quot;: &quot;Story Description Here&quot;,\r\n      &quot;filename&quot;: &quot;5cdd90989c03d3fb619df6f9294b1fcb537b4f3b55737465930b220507f30e75.pdf&quot;,\r\n      &quot;description&quot;: &quot;File Description XYZ&quot;\r\n    }\r\n\r\nWhich can be easily converted to csv like\r\n\r\n    &quot;New Story&quot;,&quot;65tyc2TLUZsO&quot;,&quot;Story Description Here&quot;,&quot;419155345a7b449df3baca76694b64efbec9bcf3983b51e02f92e7ef29fc26ee.pptx&quot;,&quot;File Description ABC&quot;\r\n    &quot;New Story&quot;,&quot;65tyc2TLUZsO&quot;,&quot;Story Description Here&quot;,&quot;5cdd90989c03d3fb619df6f9294b1fcb537b4f3b55737465930b220507f30e75.pdf&quot;,&quot;File Description XYZ&quot;\r\n\r\nwith a filter like:\r\n\r\n      flatten\r\n    | [.title, .id, .story, .filename, .description ]\r\n    | @csv\r\n\r\nTo go from this csv representation to a stream of objects you can use the jq `-s` and `-R` option with a function like\r\n\r\n    def readcsv:\r\n          split(&quot;\\n&quot;)\r\n        | .[]\r\n        | select(length &gt; 0)  \r\n        | split(&quot;,&quot;)\r\n        | map(fromjson)\r\n        | {\r\n              title:       .[0]\r\n            , id:          .[1]\r\n            , story:       .[2]\r\n            , filename:    .[3]\r\n            , description: .[4]\r\n          }\r\n    ;\r\n\r\nand to reassemble that object stream into your original json you can use a function like\r\n\r\n    def unflatten:\r\n          group_by(.title)\r\n        | .[]\r\n        | {\r\n              title:       .[0].title\r\n            , description: .[0].story\r\n          }\r\n          + { channels:    map(.id) | unique | map({id:.}) }\r\n          + { new_files:   map({filename, description}) | unique }\r\n    ;\r\n\r\nby combining the filters\r\n\r\n      [ readcsv ]\r\n    | unflatten\r\n\r\nThese functions made some assumptions about the relationships between the fields in your data that will likely need review.  In particular, you probably don&#39;t want to completely denormalize the id and filename/description columns as I did.  But once you have tools like these to convert back and forth from nested json to flat csv you can experiment with each representation until you&#39;re satisified.  ",
                "title": "jq - bash script for csv to json with arrays?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502850604,
                "last_edit_date": 1592644375,
                "creation_date": 1502838684,
                "answer_id": 45702846,
                "question_id": 45698434,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution which, for clarity, involves two invocations of jq:\n\n     jq -R &#39;split(&quot;,&quot;)&#39; input.csv | jq -f program.jq\n\n(These two calls could easily be rendered into one as explained below.)\n\nThe first invocation emits a stream of arrays.  The first array corresponds to the headers, which again for clarity, will simply be discarded.  The discarding is done here by using `inputs` *without* the -n command-line option.\n\nHere then is program.jq:\n\n\n    # Input: an array of &quot;filename, description&quot; pairs\n    # Output: an array of {filename: _, description: _} objects\n    def new_files:\n      if length == 0 then []\n      else [{filename: .[0], description: .[1]}] + (.[2:] | new_files)\n      end;\n       \n    inputs\n    | {title: .[0], channels: [{id: .[1]}], description: .[2] } \n    + {new_files: (.[3:] | new_files) }\n\nIf your jq does not have `inputs`, then you&#39;d use the `-s` command-line option and replace `inputs` above by `.[1:][]`.\n\n### Output\nWith your input, the output in either case (using `inputs` or `.[1:][]`) would be:\n\n     {\n      &quot;title&quot;: &quot;New Story&quot;,\n      &quot;channels&quot;: [\n        {\n          &quot;id&quot;: &quot;65tyc2TLUZsO&quot;\n        }\n      ],\n      &quot;description&quot;: &quot;Story Description Here&quot;,\n      &quot;new_files&quot;: [\n        {\n          &quot;filename&quot;: &quot;419155345a7b449df3baca76694b64efbec9bcf3983b51e02f92e7e‌​f29fc26ee.pptx&quot;,\n          &quot;description&quot;: &quot;File Description ABC New Story&quot;\n        },\n        {\n          &quot;filename&quot;: &quot;65tyc2TLUZsO&quot;,\n          &quot;description&quot;: &quot;Story Description Here&quot;\n        },\n        {\n          &quot;filename&quot;: &quot;5cdd90989c03d3fb619df6f9294b1fcb537b4f3b55737465930b220‌​507f30e75.pdf&quot;,\n          &quot;description&quot;: &quot;File Description XYZ &quot;\n        }\n      ]\n    }\n\n## Single invocation\n\nOne way to avoid invoking jq twice would be to invoke jq with the -R and -s options, using the above definition of `new_files` and the following program:\n\n    split(&quot;\\n&quot;)\n    | map(split(&quot;,&quot;))\n    | .[1:][]\n    | {title: .[0], channels: [{id: .[1]}], description: .[2] } \n    + {new_files: (.[3:] | new_files) }\n\n",
                "title": "jq - bash script for csv to json with arrays?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1502878864,
        "creation_date": 1502818885,
        "last_edit_date": 1502878864,
        "question_id": 45698434,
        "body_markdown": "I&#39;ve been using jq to parse JSON from curl responses and it&#39;s been super cool for that. \r\n\r\nWhat I&#39;m trying to do now is take various bits of information I&#39;ve cobbled together in a CSV and get it into JSON so that I can curl it to an API. Here&#39;s my example JSON that I&#39;m trying to replicate programmatically: \r\n\r\n    {\r\n      &quot;title&quot;: &quot;New Story&quot;,\r\n      &quot;channels&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;65tyc2TLUZsO&quot;\r\n        }\r\n      ],\r\n      &quot;description&quot;: &quot;Story Description Here&quot;,\r\n      &quot;new_files&quot;: [\r\n        {\r\n          &quot;filename&quot;: &quot;419155345a7b449df3baca76694b64efbec9bcf3983b51e02f92e7ef29fc26ee.pptx&quot;,\r\n          &quot;description&quot;: &quot;File Description ABC&quot;\r\n        },\r\n        {\r\n        &quot;filename&quot;: &quot;5cdd90989c03d3fb619df6f9294b1fcb537b4f3b55737465930b220507f30e75.pdf&quot;,\r\n        &quot;description&quot;:&quot;File Description XYZ&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nThe title, id, description, filename, and (file) description values are all in a CSV. What I can&#39;t figure out is how to generate JSON from what I&#39;ve got. \r\n\r\nI don&#39;t know how I should be formatting my CSV file given that:  \r\n1. I have some key:value pairs at the top level (title, description) and then some arrays with key:value pairs as well. I can tell you I will always have 1 value in the &quot;channels&quot; array.  \r\n2. I won&#39;t have the same number of files in the new_files array so being able to dynamically build that array would be great.  \r\n\r\nIf anyone&#39;s got a tutorial to point me to on this kind of thing, that&#39;d be awesome. I&#39;m sure I&#39;m not the first to try this. I&#39;m using bash scripts for this stuff (as it&#39;s what I know) but I&#39;m not opposed to other solutions. (It&#39;d just take longer for me to learn.)\r\n\r\nAt a high level I understand what I want to do and where to pull my information from, what variables I should have where etc, I just have some issues with getting down and dirty with the implementation details.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/45698434/jq-bash-script-for-csv-to-json-with-arrays",
        "title": "jq - bash script for csv to json with arrays?"
    },
    {
        "tags": [
            "json",
            "bash",
            "date",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502826453,
                "post_id": 45700109,
                "comment_id": 78359071,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8344031,
                    "reputation": 2835,
                    "user_id": 6268432,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/pnLBv.png?s=256",
                    "display_name": "Alex",
                    "link": "https://stackoverflow.com/users/6268432/alex"
                },
                "reply_to_user": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502827863,
                "post_id": 45700109,
                "comment_id": 78359831,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1502826907,
                "creation_date": 1502826907,
                "answer_id": 45700538,
                "question_id": 45700109,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is an all-jq solution (i.e. one that does not depend on calling the `date` command). You might like to try a variation, e.g. passing some form of the date in, using one of the command-line options such as `--arg`.\r\n\r\njq currently does not quite understand the SnapshotCreateTime format; that&#39;s where the call to `sub` comes in:\r\n\r\n    def ago(days): now - (days*24*3600);\r\n      \r\n    select(.SnapshotCreateTime | sub(&quot;\\\\.[0-9]*&quot;;&quot;&quot;) &lt; (ago(60) | todate))\r\n    | .DBSnapshotIdentifier\r\n\r\nAfter fixing the sample input so that it is valid JSON, the output would be:\r\n\r\n    &quot;alex-dbs-16opfr84gq4h9-snapshot-rtsmdbinstance-fr84gq4h9&quot;\r\n    &quot;alex3-20170422-update&quot;\r\n\r\nTo strip the quotation marks, use the -r command-line option.",
                "title": "jq: extract value based on different (calculated) value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502828238,
                "creation_date": 1502828238,
                "answer_id": 45700868,
                "question_id": 45700109,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which defines a filter function which uses **select**, **sub**, **fromdate** and **now**.\r\n\r\n    def too_old:\r\n        select(   .SnapshotCreateTime\r\n                | sub(&quot;[.][0-9]+Z&quot;;&quot;Z&quot;)   # remove fractional seconds\r\n                | fromdate                # convert to unix time\r\n                | now - .                 # convert to age in seconds\r\n                | . &gt;  (86400 * 60)       # true if older than 60 days in seconds\r\n        )\r\n    ;\r\n\r\n      too_old\r\n    | .DBSnapshotIdentifier\r\n\r\nIf you place this in a file `filter.jq` and run jq with the `-r` option e.g\r\n\r\n    jq -M -r -f filter.jq input.json\r\n\r\nit will produce the output you requested:\r\n\r\n    alex-dbs-16opfr84gq4h9-snapshot-rtsmdbinstance-fr84gq4h9\r\n    alex3-20170422-update ",
                "title": "jq: extract value based on different (calculated) value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1502828238,
        "creation_date": 1502825222,
        "last_edit_date": 1502827840,
        "question_id": 45700109,
        "body_markdown": "I am trying to filter down a very large json file (AWS output from `aws rds describe-db-snapshots`) into just a list of snapshots for deletion. \r\n\r\nThe final list of snapshots should be older than 60 days. I can discern their age via their `SnapshotCreateTime`, but I need their `DBSnapshotIdentifier` value to be able to delete them.\r\n\r\nGreatly stripped down for SO purposes, below is the input.json file. \r\n\r\n    {\r\n      &quot;Engine&quot;: &quot;postgres&quot;,\r\n      &quot;SnapshotCreateTime&quot;: &quot;2017-08-22T16:35:42.302Z&quot;,\r\n      &quot;AvailabilityZone&quot;: &quot;us-east-1b&quot;,\r\n      &quot;DBSnapshotIdentifier&quot;: &quot;alex2-20170822-0108-bkup&quot;,\r\n      &quot;AllocatedStorage&quot;: 5\r\n    }\r\n    {\r\n      &quot;Engine&quot;: &quot;postgres&quot;,\r\n      &quot;SnapshotCreateTime&quot;: &quot;2017-06-02T16:35:42.302Z&quot;,\r\n      &quot;AvailabilityZone&quot;: &quot;us-east-1a&quot;,\r\n      &quot;DBSnapshotIdentifier&quot;: &quot;alex-dbs-16opfr84gq4h9-snapshot-rtsmdbinstance-fr84gq4h9&quot;,\r\n      &quot;AllocatedStorage&quot;: 5\r\n    }\r\n    {\r\n      &quot;Engine&quot;: &quot;postgres&quot;,\r\n      &quot;SnapshotCreateTime&quot;: &quot;2017-04-22T16:35:42.302Z&quot;,\r\n      &quot;AvailabilityZone&quot;: &quot;us-east-1a&quot;,\r\n      &quot;DBSnapshotIdentifier&quot;: &quot;alex3-20170422-update&quot;,\r\n      &quot;AllocatedStorage&quot;: 5\r\n    }\r\n\r\nI know about `select` but from what I can tell it can&#39;t handle the math needed for the time comparison in a one-liner. I figured I&#39;d need to branch out to bash, so I&#39;ve been messing with the following (clunky) workaround. It&#39;s not working, but I figured I&#39;d include it as proof of effort.\r\n\r\n    THEN=$(date +&#39;%Y%m%d&#39; -d &quot;`date`-60days&quot;)\r\n\r\n    while IFS= read -r i\r\n        do\r\n            awsDate=$(jq -r &#39;.SnapshotCreateTime&#39; &lt; $i) // get time\r\n    \t\tsnapDate=$(date -d $awsDate +&#39;%Y%m%d&#39;) //convert to correct format\r\n    \r\n    \t\tif [ $snapDate -gt $THEN ] //compare times\r\n    \t\tthen\r\n                // something to copy the ID\r\n    \r\n            fi\r\n    \r\n        done &lt; input.json\r\n\r\nIn this case I&#39;d be looking for an output of \r\n\r\n    alex-dbs-16opfr84gq4h9-snapshot-rtsmdbinstance-fr84gq4h9\r\n    alex3-20170422-update",
        "link": "https://stackoverflow.com/questions/45700109/jq-extract-value-based-on-different-calculated-value",
        "title": "jq: extract value based on different (calculated) value"
    },
    {
        "tags": [
            "python",
            "json",
            "dictionary",
            "jq",
            "jsonparser"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1623138,
                    "reputation": 17456,
                    "user_id": 1499296,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/0bda7604e94b30bfb1bc2a4357a09305?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "AKS",
                    "link": "https://stackoverflow.com/users/1499296/aks"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502843841,
                "post_id": 45703291,
                "comment_id": 78365158,
                "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": 1502845862,
                "post_id": 45703291,
                "comment_id": 78365547,
                "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": 1502845881,
                "post_id": 45703291,
                "comment_id": 78365550,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1623138,
                    "reputation": 17456,
                    "user_id": 1499296,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/0bda7604e94b30bfb1bc2a4357a09305?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "AKS",
                    "link": "https://stackoverflow.com/users/1499296/aks"
                },
                "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": 1502904139,
                "post_id": 45703291,
                "comment_id": 78397434,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502842847,
                "creation_date": 1502842847,
                "answer_id": 45703341,
                "question_id": 45703291,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I don&#39;t know about jq, but you put python in the tags so:\r\n\r\n    $ cat test.json | python -c &quot;import sys, json; print(json.load(sys.stdin)[&#39;content&#39;][&#39;book1&#39;][&#39;field-three&#39;][&#39;name&#39;])&quot;\r\n    THIRD\r\n\r\nor without the pipe:\r\n\r\n    $ python -c &quot;import json; print(json.load(open(&#39;test.json&#39;))[&#39;content&#39;][&#39;book1&#39;][&#39;field-three&#39;][&#39;name&#39;])&quot;\r\n",
                "title": "Parse or view JSON data fields using JQ tool utility where field names have a &quot;-&quot; dash in the key name"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1502843985,
                "creation_date": 1502843985,
                "answer_id": 45703456,
                "question_id": 45703291,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As explained in the [jq manual](https://github.com/stedolan/jq/blob/master/docs/content/3.manual/manual.yml#L293-L322), to handle keys with non-identifier characters like `-` you can use double quotes.  \r\n\r\nFrom the shell this is easiest if you use single quotes around your filter.  For example, try the following commands:\r\n\r\n    cat /tmp/my.data.json | jq &#39;.pages&#39;\r\n    cat /tmp/my.data.json | jq &#39;.pages.book1[0]&#39;\r\n    cat /tmp/my.data.json | jq &#39;.pages.book1[1]&#39;\r\n    cat /tmp/my.data.json | jq &#39;.content&#39;\r\n    cat /tmp/my.data.json | jq &#39;.content.book1&#39;\r\n    cat /tmp/my.data.json | jq &#39;.content.book1.name&#39;\r\n    cat /tmp/my.data.json | jq &#39;.content.book1.field1&#39;\r\n    cat /tmp/my.data.json | jq &#39;.content.book1.&quot;field-2&quot;&#39;\r\n    cat /tmp/my.data.json | jq &#39;.content.book1.&quot;field-three&quot;&#39;\r\n    cat /tmp/my.data.json | jq &#39;.content.book1.&quot;field-three&quot;.url&#39;\r\n    cat /tmp/my.data.json | jq &#39;.content.book1.authur&#39;\r\n    cat /tmp/my.data.json | jq &#39;.content.book1.route&#39;\r\n\r\n",
                "title": "Parse or view JSON data fields using JQ tool utility where field names have a &quot;-&quot; dash in the key name"
            },
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1502844045,
                "creation_date": 1502844045,
                "answer_id": 45703463,
                "question_id": 45703291,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&quot;-&quot; is used for negation in jq.  For key names with special characters such as &quot;-&quot;, one cannot use the simplified &quot;.keyname&quot; syntax.  There are several alternatives, but the most robust is simply to use the form `.[&quot;KEY NAME&quot;]`, which can be abbreviated to [&quot;KEY NAME&quot;] when chained, e.g. `.a[&quot;b-c&quot;]` is shorthand for `.a | .[&quot;b-c&quot;]`.  \r\n\r\nIf in doubt, use the pipe explicitly.\r\n\r\nFor further information, please consult the jq manual and/or https://github.com/stedolan/jq/wiki/FAQ",
                "title": "Parse or view JSON data fields using JQ tool utility where field names have a &quot;-&quot; dash in the key name"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502903904,
                "last_edit_date": 1502903904,
                "creation_date": 1502844429,
                "answer_id": 45703499,
                "question_id": 45703291,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Hm..took some time but finally it seems like we need to **DOUBLE QUOTE** it and back slash just the double quote for any key name containing a `-` in it&#39;s name.\r\n\r\n    $ cat /tmp/my.data.json| jq &quot;.content.book1.\\&quot;field-2\\&quot;&quot;                    \r\n    &quot;value-2&quot;\r\n    \r\n    $ cat /tmp/my.data.json| jq &quot;.content.book1.\\&quot;field-three\\&quot;.\\&quot;url\\&quot;&quot;  \r\n    &quot;book1/field-three/&quot;\r\n\r\nOR\r\nif you wrap everything in a single quotes `&#39;`, then we do NOT need to backslash `&quot;` double quotes but use double quotes for key names with `-` in their name.\r\n\r\n    $ cat /tmp/my.data.json| jq &#39;.content.book1.&quot;field-three&quot;.&quot;url&quot;&#39;  \r\n    &quot;book1/field-three/&quot;\r\n \r\nHope it helps! Took some help/hint from https://jqplay.org/\r\n\r\nSee this for more: https://github.com/stedolan/jq/issues/38#issuecomment-9770240",
                "title": "Parse or view JSON data fields using JQ tool utility where field names have a &quot;-&quot; dash in the key name"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1502903904,
        "creation_date": 1502842365,
        "last_edit_date": 1502844801,
        "question_id": 45703291,
        "body_markdown": "I have a JSON data file (as shown below) and I&#39;m trying to find field values using [jq][1] utility. \r\n\r\nIt&#39;s working fine except for fields if the key name contains a `-` dash character in it. \r\n\r\nHow can I get the values of &quot;**field-2**&quot;, &quot;**field-three**&quot; or &quot;**field-three.url**&quot; for element under `content.book1` (using `jq` at least)?\r\n\r\nI tried the following to get the values but it&#39;s giving me the following errors for fields whose key name contains a dash `-` in it&#39;s name. I tried to back slash `-` character but that didn&#39;t help either.\r\n\r\n**Error types found:**\r\n======================\r\n\r\n    jq: error (at &lt;stdin&gt;:27): null (null) and number (2) cannot be subtracted\r\n    jq: 1 compile error\r\n\r\n    jq: error: three/0 is not defined at &lt;top-level&gt;\r\n    \r\n    jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;\r\n\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\r\nCommands:\r\n \r\n\r\n\r\n    $ cat /tmp/my.data.json\r\n    {\r\n      &quot;pages&quot;: {\r\n        &quot;book1&quot;: [\r\n          &quot;page1&quot;,\r\n          &quot;page2-para1&quot;,\r\n          &quot;page3-para1-sentence1&quot;,\r\n          &quot;page3-para2-sentence3-word4&quot;\r\n        ]\r\n      },\r\n      &quot;content&quot;: {\r\n        &quot;book1&quot;: {\r\n          &quot;name&quot;: &quot;giga&quot;,\r\n          &quot;url&quot;: &quot;-&quot;,\r\n          &quot;field1&quot;: &quot;value1&quot;,\r\n          &quot;field-2&quot;: &quot;value-2&quot;,\r\n          &quot;field-three&quot;: {\r\n            &quot;name&quot;: &quot;THIRD&quot;,\r\n            &quot;url&quot;: &quot;book1/field-three/&quot;,\r\n            &quot;short-url&quot;: &quot;book1/field-three/chota-chetan&quot;\r\n          },\r\n          &quot;authur&quot;: {\r\n            &quot;name&quot;: &quot;lori CHUCK&quot;,\r\n            &quot;displayIndex&quot;: 4\r\n          },\r\n          &quot;route&quot;: &quot;/in-gc/hindi-chini-bhai-bhai&quot;\r\n        }\r\n      }\r\n    }\r\n    \r\n    $ cat /tmp/my.data.json| jq &quot;.pages&quot;\r\n    {\r\n      &quot;book1&quot;: [\r\n        &quot;page1&quot;,\r\n        &quot;page2-para1&quot;,\r\n        &quot;page3-para1-sentence1&quot;,\r\n        &quot;page3-para2-sentence3-word4&quot;\r\n      ]\r\n    }\r\n    \r\n    $ cat /tmp/my.data.json| jq &quot;.pages.book1[0]&quot;\r\n    &quot;page1&quot;\r\n\r\n    $ cat /tmp/my.data.json| jq &quot;.pages.book1[1]&quot;\r\n    &quot;page2-para1&quot;\r\n\r\n    $ cat /tmp/my.data.json| jq &quot;.content&quot;\r\n    {\r\n      &quot;book1&quot;: {\r\n        &quot;name&quot;: &quot;giga&quot;,\r\n        &quot;url&quot;: &quot;-&quot;,\r\n        &quot;field1&quot;: &quot;value1&quot;,\r\n        &quot;field-2&quot;: &quot;value-2&quot;,\r\n        &quot;field-three&quot;: {\r\n          &quot;name&quot;: &quot;THIRD&quot;,\r\n          &quot;url&quot;: &quot;book1/field-three/&quot;\r\n        },\r\n        &quot;authur&quot;: {\r\n          &quot;name&quot;: &quot;lori CHUCK&quot;,\r\n          &quot;displayIndex&quot;: 4\r\n        },\r\n        &quot;route&quot;: &quot;/in-gc/hindi-chini-bhai-bhai&quot;\r\n      }\r\n    }\r\n    \r\n    $ cat /tmp/my.data.json| jq &quot;.content.book1&quot;\r\n    {\r\n      &quot;name&quot;: &quot;giga&quot;,\r\n      &quot;url&quot;: &quot;-&quot;,\r\n      &quot;field1&quot;: &quot;value1&quot;,\r\n      &quot;field-2&quot;: &quot;value-2&quot;,\r\n      &quot;field-three&quot;: {\r\n        &quot;name&quot;: &quot;THIRD&quot;,\r\n        &quot;url&quot;: &quot;book1/field-three/&quot;\r\n      },\r\n      &quot;authur&quot;: {\r\n        &quot;name&quot;: &quot;lori CHUCK&quot;,\r\n        &quot;displayIndex&quot;: 4\r\n      },\r\n      &quot;route&quot;: &quot;/in-gc/hindi-chini-bhai-bhai&quot;\r\n    }\r\n    \r\n    $ cat /tmp/my.data.json| jq &quot;.content.book1.name&quot;\r\n    &quot;giga&quot;\r\n    \r\n    $ cat /tmp/my.data.json| jq &quot;.content.book1.field1&quot;\r\n    &quot;value1&quot;\r\n    \r\n    $ cat /tmp/my.data.json| jq &quot;.content.book1.field-2&quot;\r\n    jq: error (at &lt;stdin&gt;:27): null (null) and number (2) cannot be subtracted\r\n    \r\n    $ cat /tmp/my.data.json| jq &quot;.content.book1.field-three&quot;\r\n    jq: error: three/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .content.book1.field-three\r\n    jq: 1 compile error\r\n    \r\n    $ cat /tmp/my.data.json| jq &quot;.content.book1.field-three.url&quot;\r\n    jq: error: three/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .content.book1.field-three.url\r\n    jq: 1 compile error\r\n    \r\n    $ cat /tmp/my.data.json| jq &quot;.content.book1.field\\-2&quot;       \r\n    jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .content.book1.field\\-2                    \r\n    jq: 1 compile error\r\n    \r\n    $ cat /tmp/my.data.json| jq &quot;.content.book1.field\\\\-2&quot;\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .content.book1.field\\-2                    \r\n    jq: 1 compile error\r\n\r\n    $ cat /tmp/my.data.json| jq &quot;.content.book1.&#39;field-2&#39;&quot;\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .content.book1.&#39;field-2&#39;               \r\n    jq: 1 compile error\r\n\r\n    $ cat /tmp/my.data.json| jq &quot;.content.book1.authur&quot;\r\n    {\r\n      &quot;name&quot;: &quot;lori CHUCK&quot;,\r\n      &quot;displayIndex&quot;: 4\r\n    }\r\n    \r\n    $ cat /tmp/my.data.json| jq &quot;.content.book1.route&quot;\r\n    &quot;/in-gc/hindi-chini-bhai-bhai&quot;\r\n    \r\n    $\r\n\r\n**PS:** \r\nI already know `egrep` so that&#39;s not what I&#39;m looking for.\r\n\r\n    cat /tmp/my.data.json| jq &quot;.content.book1&quot;|egrep &quot;short-url|field-2&quot;\r\n      &quot;field-2&quot;: &quot;value-2&quot;,\r\n        &quot;short-url&quot;: &quot;book1/field-three/chota-chetan&quot;\r\nand\r\nsomeone really did a great job here: https://jqplay.org/\r\n\r\n  [1]: https://stedolan.github.io/jq/tutorial/",
        "link": "https://stackoverflow.com/questions/45703291/parse-or-view-json-data-fields-using-jq-tool-utility-where-field-names-have-a",
        "title": "Parse or view JSON data fields using JQ tool utility where field names have a &quot;-&quot; dash in the key name"
    },
    {
        "tags": [
            "windows",
            "batch-file",
            "aws-cli",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 662142,
                    "reputation": 1135,
                    "user_id": 3627676,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/edfa1ded8fdac295c87254b030f68a52?s=256&d=identicon&r=PG",
                    "display_name": "jsxt",
                    "link": "https://stackoverflow.com/users/3627676/jsxt"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502858222,
                "post_id": 45704869,
                "comment_id": 78368476,
                "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": 1502860988,
                "post_id": 45704869,
                "comment_id": 78369290,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11528211,
                    "reputation": 777,
                    "user_id": 8447984,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b4e1b9f26cc38578acb557f06483ae73?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Dwarrior",
                    "link": "https://stackoverflow.com/users/8447984/dwarrior"
                },
                "reply_to_user": {
                    "account_id": 662142,
                    "reputation": 1135,
                    "user_id": 3627676,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/edfa1ded8fdac295c87254b030f68a52?s=256&d=identicon&r=PG",
                    "display_name": "jsxt",
                    "link": "https://stackoverflow.com/users/3627676/jsxt"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1502865483,
                "post_id": 45704869,
                "comment_id": 78371156,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11528211,
                    "reputation": 777,
                    "user_id": 8447984,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b4e1b9f26cc38578acb557f06483ae73?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Dwarrior",
                    "link": "https://stackoverflow.com/users/8447984/dwarrior"
                },
                "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": 1502865958,
                "post_id": 45704869,
                "comment_id": 78371423,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502867753,
                "creation_date": 1502867753,
                "answer_id": 45707282,
                "question_id": 45704869,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since you have jq in your environment, it seems reasonable to assume that you could also use awk without too much difficulty.  If so, you could pipe the JSONLines output of jq (invoked with the -c option) to an awk command along the following lines:\r\n\r\n    awk -v mx=2 &#39;BEGIN{n=0}\r\n         n%mx == 0 {\r\n           nf++; close(out);\r\n           out=&quot;OUTPUT.&quot;nf&quot;.json&quot;;\r\n         }\r\n         {n++; print &gt; out}&#39; \r\n",
                "title": "splitting json into multiple files in windows"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1502915079,
                "last_edit_date": 1502915079,
                "creation_date": 1502869566,
                "answer_id": 45707870,
                "question_id": 45704869,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This one allows you to split putRequest to set of arrays having no more than 2 items\r\n\r\n```jq -c &quot;[ .MusicCollection[] ] | range(0; length; 2) as $i | { MusicCollection: .[ $i:$i+2 ] }&quot; input.json\r\n```\r\n\r\nI guess this could help you to understand the following script. It assumes that the names of each file generated match the pattern `FileN` (where `N` is a number).\r\n\r\n\r\n    @echo off\r\n    \r\n    rem stop variable expansion while using them under loop\r\n    setlocal enabledelayedexpansion\r\n    \r\n    rem initialize the counters\r\n    set /a &quot;FILENUM=0&quot;\r\n    set /a &quot;ARRAYLENGTH=2&quot;\r\n    \r\n    for /f &quot;tokens=*&quot; %%a in ( &#39;\r\n    \tjq -c --argjson L &quot;!ARRAYLENGTH!&quot; &quot;[ .MusicCollection[] ] | range(0; length; $L) as $i | { MusicCollection: .[ $i:$i+$L ] }&quot; input.json\r\n    &#39; ) do (\r\n    \trem set the counter to the next file\r\n    \tset /a &quot;FILENUM+=1&quot;\r\n    \r\n    \trem print results\r\n    \techo:File !FILENUM!:\r\n    \techo:%%~a\r\n    \techo:\r\n    \r\n    \trem uncomment to turn on printing to files called FileN\r\n    \trem echo:%%~a&gt;File!FILENUM!\r\n    )\r\n\r\n",
                "title": "splitting json into multiple files in windows"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1502915079,
        "creation_date": 1502855709,
        "last_edit_date": 1502860900,
        "question_id": 45704869,
        "body_markdown": "I am trying to split my json object into multiple json arrays.\r\n\r\n    {\r\n        &quot;MusicCollection&quot;: [\r\n            {\r\n                &quot;PutRequest&quot;: {\r\n                    &quot;Item&quot;: {\r\n                        &quot;Artist&quot;: {&quot;S&quot;: &quot;No One You Know&quot;},\r\n                        &quot;SongTitle&quot;: {&quot;S&quot;: &quot;Call Me Today&quot;},\r\n                        &quot;AlbumTitle&quot;: {&quot;S&quot;: &quot;Somewhat Famous&quot;}\r\n                    }\r\n                }\r\n            },\r\n            {\r\n                &quot;PutRequest&quot;: {\r\n                    &quot;Item&quot;: {\r\n                        &quot;Artist&quot;: {&quot;S&quot;: &quot;Acme Band&quot;},\r\n                        &quot;SongTitle&quot;: {&quot;S&quot;: &quot;Happy Day&quot;},\r\n                        &quot;AlbumTitle&quot;: {&quot;S&quot;: &quot;Songs About Life&quot;}\r\n                    }\r\n                }\r\n            },\r\n            {\r\n                &quot;PutRequest&quot;: {\r\n                    &quot;Item&quot;: {\r\n                        &quot;Artist&quot;: {&quot;S&quot;: &quot;No One You Know&quot;},\r\n                        &quot;SongTitle&quot;: {&quot;S&quot;: &quot;Scared of My Shadow&quot;},\r\n                        &quot;AlbumTitle&quot;: {&quot;S&quot;: &quot;Blue Sky Blues&quot;}\r\n                    }\r\n                }\r\n            }\r\n        ]\r\n    }\r\n\r\nCommand in below post works in linux for splitting the file into multiple putRequest arrays.\r\n\r\n    jq -cM --argjson sublen &#39;2&#39; &#39;range(0; length; $sublen) as $i | .[$i:$i+$sublen]&#39; \\\r\n    input.json | split -l 1 -da 3 - meta2_\r\n\r\nReference:\r\nhttps://stackoverflow.com/questions/40385830/split-a-json-array-into-multiple-files-using-command-line-tools\r\n\r\nDirectly running below command in command prompt gives me 3 put requests.\r\n\r\n    jq &quot;.MusicCollection[]&quot; music.json\r\n\r\nHowever, when I used below for loop in batch script, it just gives me `}`.\r\n\r\n        for /f &quot;tokens=*&quot; %%a in (&#39;music.json&#39;) do (\r\n        \tjq &quot;.MusicCollection[]&quot; music.json\r\n            set array_value=%%a\r\n        )\r\n    \r\n    echo Array: %array_value%\r\n\r\nCan someone please guide me as how I should get the same output of command prompt with the for loop?",
        "link": "https://stackoverflow.com/questions/45704869/splitting-json-into-multiple-files-in-windows",
        "title": "splitting json into multiple files in windows"
    },
    {
        "tags": [
            "json",
            "grouping",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1502859879,
                "creation_date": 1502859879,
                "answer_id": 45705442,
                "question_id": 45705279,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This should do it:\r\n\r\n    .results |= [group_by({repo,path})[] | sort_by(.modified)[-2:][]]\r\n\r\nAfter grouping the items in the array by `repo` and `path`, you sort the groups by `modified` and keep the last two items of the sorted group. Then split the groups up again and collect them into a new array.",
                "title": "Sorting and filtering a json file using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1502864445,
                "creation_date": 1502864445,
                "answer_id": 45706354,
                "question_id": 45705279,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a more cumbersome solution which uses **reduce** to maintain a temporary object with the last two values for each `repo` and `path`.  It&#39;s probably not better than [Jeff](https://stackoverflow.com/users/390278/jeff-mercado)&#39;s solution unless the input contains a large number of entries for each combination of (repo, path):\r\n\r\n        {\r\n          results: [\r\n            reduce .results[] as $r (\r\n                 {}                                 # temporary object\r\n               ; (\r\n                    getpath([$r.repo, $r.path])     # keep the latest two\r\n                  | . + [$r]                        # elements for each\r\n                  | sort_by(.modified)[-2:]         # repo and path in a\r\n                 ) as $new                          # temporary object\r\n               | setpath([$r.repo, $r.path]; $new)  #\r\n            )\r\n            | .[] | .[] | .[]                       # extract saved elements\r\n          ]\r\n        }\r\n",
                "title": "Sorting and filtering a json file using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1502893157,
                "last_edit_date": 1502893157,
                "creation_date": 1502866538,
                "answer_id": 45706920,
                "question_id": 45705279,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "@jq170727 makes a good point about the potential inefficiency of using `group_by`, since `group_by` involves sorting.  In practice, the sort is probably too fast to matter, but if it is of concern, we can define our own sort-free version of `group_by` very easily:\r\n\r\n    # sort-free variant of group_by/1\r\n    # f must always evaluate to a string.\r\n    # Output: an object\r\n    def GROUP_BY(f): reduce .[] as $x ({}; .[$x|f] += [$x] );\r\n\r\n@JeffMercado&#39;s solution can now be used with the help of `tojson` as follows:\r\n\r\n    .results |= [GROUP_BY({repo,path}|tojson)[] | sort_by(.modified)[-2:][]]\r\n\r\n### GROUP_BY/2\r\n\r\nTo avoid the call to `tojson`, we can tweak the above to produce the following even faster solution:\r\n\r\n\r\n    def GROUP_BY(f;g): reduce .[] as $x ({}; .[$x|f][$x|g] += [$x]);\r\n\r\n    .results |= [GROUP_BY(.repo;.path)[][] | sort_by(.modified)[-2:][]]\r\n\r\n\r\n",
                "title": "Sorting and filtering a json file using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1502893238,
                "last_edit_date": 1502893238,
                "creation_date": 1502871835,
                "answer_id": 45708582,
                "question_id": 45705279,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Comments aside, here is a more concise (and more jq-esque (*)) way to express @jq170727&#39;s solution:\r\n\r\n    .results |= [reduce .[] as $r ( {};\r\n                   .[$r.repo][$r.path] |= ((.+[$r]) | sort_by(.modified)[-2:])) \r\n                 | .[][]]\r\n\r\n(*) Specifically no getpath, setpath, or $new; and `|=` lessens redundancy.",
                "title": "Sorting and filtering a json file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1503031115,
        "creation_date": 1502858852,
        "last_edit_date": 1503031115,
        "question_id": 45705279,
        "body_markdown": "I&#39;m trying to parse a json file in order to create a deletion list for an artifactory instance.\r\n\r\nI&#39;d like group them by two fields: repo and path. And then keep the two objects for each grouping with the most recent &quot;modified&quot; timestamp and delete all the other objects in the json file. \r\n\r\nSo, an original file that looks like this:\r\n\r\n    {\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;repo&quot;: &quot;repo1&quot;,\r\n          &quot;path&quot;: &quot;docker_image_dynamic&quot;,\r\n          &quot;size&quot;: 3624,\r\n          &quot;modified&quot;: &quot;2016-10-01T06:22:16.335Z&quot;\r\n        },\r\n        {\r\n          &quot;repo&quot;: &quot;repo1&quot;,\r\n          &quot;path&quot;: &quot;docker_image_dynamic&quot;,\r\n          &quot;size&quot;: 3646,\r\n          &quot;modified&quot;: &quot;2016-10-01T07:03:58.465Z&quot;\r\n        },\r\n        {\r\n          &quot;repo&quot;: &quot;repo1&quot;,\r\n          &quot;path&quot;: &quot;docker_image_dynamic&quot;,\r\n          &quot;size&quot;: 3646,\r\n          &quot;modified&quot;: &quot;2016-10-01T07:06:36.522Z&quot;\r\n        },\r\n        {\r\n          &quot;repo&quot;: &quot;repo2&quot;,\r\n          &quot;path&quot;: &quot;docker_image_static&quot;,\r\n          &quot;size&quot;: 3624,\r\n          &quot;modified&quot;: &quot;2016-09-29T20:31:44.054Z&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nshould become this:\r\n\r\n    {\r\n      &quot;results&quot;: [\r\n        {\r\n          &quot;repo&quot;: &quot;repo1&quot;,\r\n          &quot;path&quot;: &quot;docker_image_dynamic&quot;,\r\n          &quot;size&quot;: 3646,\r\n          &quot;modified&quot;: &quot;2016-10-01T07:03:58.465Z&quot;\r\n        },\r\n        {\r\n          &quot;repo&quot;: &quot;repo1&quot;,\r\n          &quot;path&quot;: &quot;docker_image_dynamic&quot;,\r\n          &quot;size&quot;: 3646,\r\n          &quot;modified&quot;: &quot;2016-10-01T07:06:36.522Z&quot;\r\n        },\r\n        {\r\n          &quot;repo&quot;: &quot;repo2&quot;,\r\n          &quot;path&quot;: &quot;docker_image_static&quot;,\r\n          &quot;size&quot;: 3624,\r\n          &quot;modified&quot;: &quot;2016-09-29T20:31:44.054Z&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/45705279/sorting-and-filtering-a-json-file-using-jq",
        "title": "Sorting and filtering a json file using jq"
    },
    {
        "tags": [
            "json",
            "grouping",
            "jq",
            "jsonlines"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5298,
                    "reputation": 92375,
                    "user_id": 8446,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/8f9c683775bfbe76ed4855a19b73dc81?s=256&d=identicon&r=PG",
                    "display_name": "Roger Lipscombe",
                    "link": "https://stackoverflow.com/users/8446/roger-lipscombe"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1502889403,
                "post_id": 45714384,
                "comment_id": 78387368,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 25,
                "is_accepted": false,
                "score": 25,
                "last_activity_date": 1502888898,
                "creation_date": 1502888898,
                "answer_id": 45714453,
                "question_id": 45714384,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**Use the `--slurp` (or `-s`) switch:**\r\n\r\n    ./tool | jq --slurp &#39;group_by(.id)&#39;\r\n\r\nIt outputs the following:\r\n\r\n    [\r\n      [\r\n        {\r\n          &quot;ts&quot;: &quot;2017-08-15T21:20:47.029Z&quot;,\r\n          &quot;id&quot;: &quot;123&quot;,\r\n          &quot;elapsed_ms&quot;: 10\r\n        }\r\n      ],\r\n      [\r\n        {\r\n          &quot;ts&quot;: &quot;2017-08-15T21:20:47.044Z&quot;,\r\n          &quot;id&quot;: &quot;456&quot;,\r\n          &quot;elapsed_ms&quot;: 13\r\n        }\r\n      ]\r\n    ]\r\n\r\n...which you can then process further. For example:\r\n\r\n    ./tool | jq -s &#39;group_by(.id) | map({id: .[0].id, count: length})&#39;\r\n",
                "title": "Parsing JSON record-per-line with jq?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1502914231,
                "last_edit_date": 1502914231,
                "creation_date": 1502892254,
                "answer_id": 45715729,
                "question_id": 45714384,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As @JeffMercado pointed out, jq handles streams of JSON just fine, but if you use `group_by`, then you&#39;d have to ensure its input is an array.  That could be done in this case using the `-s` command-line option; if your jq has the `inputs` filter, then it can also be done using that filter in conjunction with the `-n` option. \r\n\r\nIf you have a version of jq with `inputs` (which is available in jq 1.5), however, then a better approach would be to use the following streaming variant of `group_by`:\r\n\r\n     # sort-free stream-oriented variant of group_by/1\r\n     # f should always evaluate to a string.\r\n     # Output: a stream of arrays, one array per group\r\n     def GROUPS_BY(stream; f): reduce stream as $x ({}; .[$x|f] += [$x] ) | .[] ;\r\n\r\nUsage example: `GROUPS_BY(inputs; .id)`\r\n\r\n**Note that you will want to use this with the `-n` command line option.**\r\n\r\nSuch a streaming variant has two main advantages:\r\n\r\n1. it generally requires less memory in that it does not require a copy of the entire input stream to be kept in memory while it is being processed;\r\n2. it is potentially faster because it does not require any sort operation, unlike `group_by/1`.\r\n\r\nPlease note that the above definition of `GROUPS_BY/2` follows the convention for such streaming filters in that it produces a stream. Other variants are of course possible.\r\n\r\n## Handling a large amount of data\r\nThe following illustrates how to economize on memory.  Suppose the task is to produce a frequency count of .id values.  The humdrum solution would be:\r\n\r\n    GROUPS_BY(inputs; .id) | [(.[0]|.id), length]\r\n\r\nA more economical and indeed far better solution would be:\r\n\r\n    GROUPS_BY(inputs|.id; .) | [.[0], length]",
                "title": "Parsing JSON record-per-line with jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1745959051,
                "creation_date": 1745959051,
                "answer_id": 79599177,
                "question_id": 45714384,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Slightly differently, I wanted to grab only certain fields from my line-delimited JSON file. In that case, remember that `-s` wraps your docs in a top-level array.\r\n\r\n`input.json`:\r\n\r\n```json\r\n{&quot;ts&quot;:&quot;2017-08-15T21:20:47.029Z&quot;,&quot;id&quot;:&quot;123&quot;,&quot;elapsed_ms&quot;:10}\r\n{&quot;ts&quot;:&quot;2017-08-15T21:20:47.044Z&quot;,&quot;id&quot;:&quot;456&quot;,&quot;elapsed_ms&quot;:13}\r\n```\r\n\r\n```bash\r\ncat /tmp/json | jq -s &#39;.id&#39;\r\n&gt; jq: error (at &lt;stdin&gt;:7): Cannot index array with string &quot;id&quot;\r\ncat /tmp/json | jq -s &#39;.[].id&#39;\r\n&gt; 123\r\n&gt; 456\r\n```",
                "title": "Parsing JSON record-per-line with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 24,
        "last_activity_date": 1745959051,
        "creation_date": 1502888739,
        "last_edit_date": 1502896401,
        "question_id": 45714384,
        "body_markdown": "I&#39;ve got a tool that outputs a JSON record on each line, and I&#39;d like to process it with `jq`.\r\n\r\nThe output looks something like this:\r\n\r\n    {&quot;ts&quot;:&quot;2017-08-15T21:20:47.029Z&quot;,&quot;id&quot;:&quot;123&quot;,&quot;elapsed_ms&quot;:10}\r\n    {&quot;ts&quot;:&quot;2017-08-15T21:20:47.044Z&quot;,&quot;id&quot;:&quot;456&quot;,&quot;elapsed_ms&quot;:13}\r\n\r\nWhen I pass this to `jq` as follows:\r\n\r\n    ./tool | jq &#39;group_by(.id)&#39;\r\n\r\n...it outputs an error:\r\n\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;id&quot;\r\n\r\nHow do I get `jq` to handle JSON-record-per-line data?",
        "link": "https://stackoverflow.com/questions/45714384/parsing-json-record-per-line-with-jq",
        "title": "Parsing JSON record-per-line with jq?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "object",
            "jq",
            "subtraction"
        ],
        "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": 1502944665,
                "post_id": 45726428,
                "comment_id": 78410729,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1502950001,
                "post_id": 45726428,
                "comment_id": 78412783,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1502958786,
                "last_edit_date": 1502958786,
                "creation_date": 1502951197,
                "answer_id": 45727966,
                "question_id": 45726428,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses `--argfile` and `project/1` from [pull/1062](https://github.com/stedolan/jq/pull/1062/commits/02b4637d4f1742deb28aebecdbf89aed351e9480)\r\n    \r\n    def project(q):\r\n        . as $in\r\n      | reduce (q | if type == &quot;object&quot; then keys[] else .[] end) as $k (\r\n          {}\r\n          ; . + { ($k) : ($in[$k]) }\r\n        )\r\n    ;\r\n\r\n      map(\r\n        reduce $arg[] as $a (\r\n            .\r\n          ; select(project($a) != $a)\r\n        )\r\n        | values\r\n      )\r\n\r\nIf you place the &quot;second&quot; file in `second.json`, the data in `data.json` and the above filter in `filter.jq` you can run this with \r\n\r\n    jq -M --argfile arg second.json -f filter.jq data.json\r\n\r\nto produce \r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Elise&quot;,\r\n        &quot;surname&quot;: &quot;Long&quot;,\r\n        &quot;isActive&quot;: false,\r\n        &quot;balance&quot;: &quot;$1,892.72&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Hyde&quot;,\r\n        &quot;surname&quot;: &quot;Adkins&quot;,\r\n        &quot;isActive&quot;: true,\r\n        &quot;balance&quot;: &quot;$1,769.34&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Matthews&quot;,\r\n        &quot;surname&quot;: &quot;Jefferson&quot;,\r\n        &quot;isActive&quot;: true,\r\n        &quot;balance&quot;: &quot;$1,991.42&quot;\r\n      }\r\n    ]\r\n\r\nYou can replace the expression `select(project($a) != $a)` with something else if you want to revise the equality criteria for the objects.\r\n\r\nThinking about this a little more we can eliminate the need for `project/1` by using `contains`.  This should be more efficient as it eliminates construction of a temporary object.\r\n\r\n      map(\r\n        reduce $arg[] as $a (\r\n            .\r\n          ; select(.!=null and contains($a)==false)\r\n        )\r\n        | values\r\n      )\r\n\r\nthis can be further simplified using `any`:\r\n\r\n    map(select(any(.; contains($arg[]))==false))\r\n\r\nwhich is short enough to be used directly on the command line:\r\n\r\n    jq -M --argfile arg second.json &#39;map(select(any(.; contains($arg[]))==false))&#39; data.json\r\n",
                "title": "subtracting one json file from another in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1502961291,
                "creation_date": 1502961291,
                "answer_id": 45731064,
                "question_id": 45726428,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "***jq*** solution:\r\n\r\n    jq --slurpfile s f2.json &#39;[ .[] | . as $o | if (reduce $s[0][] as $i\r\n         ([]; . + [($o | contains($i))]) | any) then empty else $o end ]&#39; f1.json\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Elise&quot;,\r\n        &quot;surname&quot;: &quot;Long&quot;,\r\n        &quot;isActive&quot;: false,\r\n        &quot;balance&quot;: &quot;$1,892.72&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Hyde&quot;,\r\n        &quot;surname&quot;: &quot;Adkins&quot;,\r\n        &quot;isActive&quot;: true,\r\n        &quot;balance&quot;: &quot;$1,769.34&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Matthews&quot;,\r\n        &quot;surname&quot;: &quot;Jefferson&quot;,\r\n        &quot;isActive&quot;: true,\r\n        &quot;balance&quot;: &quot;$1,991.42&quot;\r\n      }\r\n    ]\r\n\r\n\r\n",
                "title": "subtracting one json file from another in jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1503022611,
                "last_edit_date": 1503022611,
                "creation_date": 1503010693,
                "answer_id": 45746104,
                "question_id": 45726428,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following solution is intended to be generic, efficient and as simple as possible subject to the first two objectives.\r\n\r\n## Genericity\r\n\r\nFor genericity, let us suppose that $one and $two are two arrays of\r\nJSON entities, and that we wish to find those items, $x, in $one\r\nsuch that ($x|filter) does not appear in map($two | filter), where `filter` is an arbitrary filter.  (In the present instance, it is `{surname, name}`.)\r\n\r\nThe solution uses `INDEX/1`, which was added to jq after the official 1.5 release, so we begin by reproducing its definition:\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    def INDEX(idx_expr): INDEX(.[]; idx_expr);\r\n\r\n## Efficiency\r\n\r\nFor efficiency, we will need to use a JSON object as a dictionary;\r\nsince keys must be strings, we will need to ensure that when converting an object\r\nto a string, the objects are normalized.  For this, we define `normalize` as follows:\r\n\r\n    # Normalize the input with respect to the order of keys in objects\r\n    def normalize:\r\n      . as $in\r\n      | if type == &quot;object&quot; then reduce keys[] as $key\r\n             ( {}; . + { ($key):  ($in[$key] | normalize) } ) \r\n        elif type == &quot;array&quot; then map( normalize )\r\n        else .\r\n        end;\r\n    \r\nTo construct the dictionary, we simply apply (normalize|tojson):\r\n    \r\n    def todict(filter):\r\n      INDEX(filter| normalize | tojson);\r\n\r\n### The solution\r\nThe solution is now quite simple:\r\n\r\n    # select those items from the input stream for which \r\n    # (normalize|tojson) is NOT in dict:\r\n    def MINUS(filter; $dict):\r\n     select( $dict[filter | normalize | tojson] | not);\r\n      \r\n    def difference($one; $two; filter):\r\n      ($two | todict(filter)) as $dict\r\n      | $one[] | MINUS( filter; $dict );\r\n    \r\n    difference( $one; $two; {surname, name} )\r\n\r\n### Invocation\r\n\r\n    $ jq -n --argfile one one.json --argfile two two.json -f difference.jq\r\n",
                "title": "subtracting one json file from another in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1503022611,
        "creation_date": 1502942909,
        "last_edit_date": 1503010770,
        "question_id": 45726428,
        "body_markdown": "Is there a way to compare two json files in jq? Specifically, I&#39;d like to be able to remove objects from one json file if they occur in another json file. Basically, subtract one file from another. It would be a bonus if I could generalize this so that I could define the equality criteria for the objects, but this is not strictly necessary, it can be based strictly on the objects being identical. \r\n\r\nSo the more general case would look like this. Let&#39;s say I have a file that looks like this:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Cynthia&quot;,\r\n        &quot;surname&quot;: &quot;Craig&quot;,\r\n        &quot;isActive&quot;: true,\r\n        &quot;balance&quot;: &quot;$2,426.88&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Elise&quot;,\r\n        &quot;surname&quot;: &quot;Long&quot;,\r\n        &quot;isActive&quot;: false,\r\n        &quot;balance&quot;: &quot;$1,892.72&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Hyde&quot;,\r\n        &quot;surname&quot;: &quot;Adkins&quot;,\r\n        &quot;isActive&quot;: true,\r\n        &quot;balance&quot;: &quot;$1,769.34&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Matthews&quot;,\r\n        &quot;surname&quot;: &quot;Jefferson&quot;,\r\n        &quot;isActive&quot;: true,\r\n        &quot;balance&quot;: &quot;$1,991.42&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Kris&quot;,\r\n        &quot;surname&quot;: &quot;Norris&quot;,\r\n        &quot;isActive&quot;: false,\r\n        &quot;balance&quot;: &quot;$2,137.11&quot;\r\n      }\r\n    ]\r\n\r\n\r\nAnd I have a second file that looks like this:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Cynthia&quot;,\r\n        &quot;surname&quot;: &quot;Craig&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Kris&quot;,\r\n        &quot;surname&quot;: &quot;Norris&quot;\r\n      }\r\n    ] \r\n\r\nI&#39;d like to remove any objects from the first file where the name and surname fields match an object of the second file, so that the results should look like this:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Elise&quot;,\r\n        &quot;surname&quot;: &quot;Long&quot;,\r\n        &quot;isActive&quot;: false,\r\n        &quot;balance&quot;: &quot;$1,892.72&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Hyde&quot;,\r\n        &quot;surname&quot;: &quot;Adkins&quot;,\r\n        &quot;isActive&quot;: true,\r\n        &quot;balance&quot;: &quot;$1,769.34&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Matthews&quot;,\r\n        &quot;surname&quot;: &quot;Jefferson&quot;,\r\n        &quot;isActive&quot;: true,\r\n        &quot;balance&quot;: &quot;$1,991.42&quot;\r\n      }\r\n    ] \r\n",
        "link": "https://stackoverflow.com/questions/45726428/subtracting-one-json-file-from-another-in-jq",
        "title": "subtracting one json file from another in jq"
    },
    {
        "tags": [
            "python",
            "python-2.7",
            "unicode",
            "jq",
            "python-unicode"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6475833,
                    "reputation": 97317,
                    "user_id": 5014455,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/JTknr.png?s=256",
                    "display_name": "juanpa.arrivillaga",
                    "link": "https://stackoverflow.com/users/5014455/juanpa-arrivillaga"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1503007968,
                "post_id": 45745684,
                "comment_id": 78448901,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6475833,
                    "reputation": 97317,
                    "user_id": 5014455,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/JTknr.png?s=256",
                    "display_name": "juanpa.arrivillaga",
                    "link": "https://stackoverflow.com/users/5014455/juanpa-arrivillaga"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1503008149,
                "post_id": 45745684,
                "comment_id": 78448948,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6509886,
                    "reputation": 62796,
                    "user_id": 5037551,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/BYnIO.jpg?s=256",
                    "display_name": "Dekel",
                    "link": "https://stackoverflow.com/users/5037551/dekel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1503008160,
                "post_id": 45745684,
                "comment_id": 78448949,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6475833,
                    "reputation": 97317,
                    "user_id": 5014455,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/JTknr.png?s=256",
                    "display_name": "juanpa.arrivillaga",
                    "link": "https://stackoverflow.com/users/5014455/juanpa-arrivillaga"
                },
                "reply_to_user": {
                    "account_id": 6509886,
                    "reputation": 62796,
                    "user_id": 5037551,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/BYnIO.jpg?s=256",
                    "display_name": "Dekel",
                    "link": "https://stackoverflow.com/users/5037551/dekel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1503008187,
                "post_id": 45745684,
                "comment_id": 78448964,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6509886,
                    "reputation": 62796,
                    "user_id": 5037551,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/BYnIO.jpg?s=256",
                    "display_name": "Dekel",
                    "link": "https://stackoverflow.com/users/5037551/dekel"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1503008360,
                "post_id": 45745684,
                "comment_id": 78449012,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6509886,
                    "reputation": 62796,
                    "user_id": 5037551,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/BYnIO.jpg?s=256",
                    "display_name": "Dekel",
                    "link": "https://stackoverflow.com/users/5037551/dekel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1503008448,
                "post_id": 45745684,
                "comment_id": 78449036,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 145428,
                    "reputation": 123827,
                    "user_id": 355230,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/JEycE.png?s=256",
                    "display_name": "martineau",
                    "link": "https://stackoverflow.com/users/355230/martineau"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1503009118,
                "post_id": 45745684,
                "comment_id": 78449241,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1503009061,
                "creation_date": 1503009061,
                "answer_id": 45745866,
                "question_id": 45745684,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It is still printing `u` because there are elements in your object which are *`unicode` objects*, and that is how python prints objects that contain unicode objects. \r\n\r\n\r\n    &gt;&gt;&gt; x = {u&#39;giga-10&#39;: [u&#39;overview&#39;]}\r\n    &gt;&gt;&gt; print x\r\n    {u&#39;giga-10&#39;: [u&#39;overview&#39;]}\r\n\r\n\r\nIt makes sense that you have `unicode` objects, since you are deserializing JSON, and the appropriate data-structure that corresponds to JSON string is a Python 2 `unicode` object. \r\n\r\n\r\nNote, if you print a `unicode` object, it doesn&#39;t print the `u`, since the `u` isn&#39;t actually a part of the unicode string:\r\n\r\n    &gt;&gt;&gt; print u&quot;hello&quot;\r\n    hello\r\n\r\nThis really doesn&#39;t matter. You should just let it stop bothering you. But if you insist, for some crazy reason, to want to get rid of those `u`s, then you have to convert any unicode objects inside an arbitrary object deserialized from JSON to `str` types. That requires *decoding* the unicode object. As long as you aren&#39;t providing any hooks, the following should work for any result of `json.load`:\r\n\r\n    &gt;&gt;&gt; def stringify(obj):\r\n    ...     if isinstance(obj, unicode):\r\n    ...         return obj.encode(&#39;utf8&#39;)\r\n    ...     elif isinstance(obj, list):\r\n    ...         return [stringify(x) for x in obj]\r\n    ...     elif isinstance(obj, dict):\r\n    ...         return {stringify(k):stringify(v) for k,v in obj.iteritems()}\r\n    ...     else:\r\n    ...         return obj\r\n    ...\r\n    &gt;&gt;&gt; print stringify(x)\r\n    {&#39;giga-10&#39;: [&#39;overview&#39;]}\r\n\r\nBut there is no good reason to do this, unless you really, truely, need Python 2 `str`, i.e. &quot;byte-strings&quot;. You almost certainly do not, or at least, haven&#39;t indicated any reason why you would. ",
                "title": "Why are &#39;u&#39; prefixes still printing even though I used str()?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1503080188,
                "last_edit_date": 1503080188,
                "creation_date": 1503009752,
                "answer_id": 45745958,
                "question_id": 45745684,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For this, why not use `jq` [JQ][1] utility for a one liner. \r\n\r\nYou can achieve the:\r\n\r\n    $ echo `jq &quot;.pages&quot; /tmp/2.json`\r\n    { &quot;giga-10&quot;: [ &quot;overview&quot; ] }\r\n\r\nDon&#39;t forget to check out this URL: https://jqplay.org/ it really helped me learn / watch how `jq` will play with the input data. \r\n  [1]: https://stedolan.github.io/jq/tutorial/",
                "title": "Why are &#39;u&#39; prefixes still printing even though I used str()?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1503081097,
                "creation_date": 1503081097,
                "answer_id": 45762987,
                "question_id": 45745684,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you are going to use python, you probably want `json.dumps()`. e.g\r\n \r\n    $ cat data.json\r\n    {&quot;pages&quot;: {&quot;giga-10&quot;: [&quot;overview&quot;]}}\r\n    \r\n    $ python -c &#39;import sys, json; x = json.load(open(sys.argv[1])); print json.dumps(x[&quot;pages&quot;])&#39; data.json\r\n    {&quot;giga-10&quot;: [&quot;overview&quot;]}\r\n\r\n",
                "title": "Why are &#39;u&#39; prefixes still printing even though I used str()?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1503081097,
        "creation_date": 1503007893,
        "last_edit_date": 1503079177,
        "question_id": 45745684,
        "body_markdown": "New to Python, Python version: 2.7.10, Machine: Mac OS Sierra.\r\n\r\n\r\n    Susi Sushanti Don $ python -c &quot;import sys, json; print(json.load(open(&#39;/tmp/2.json&#39;))[&#39;pages&#39;])&quot;\r\n    {u&#39;giga-10&#39;: [u&#39;overview&#39;]}\r\n\r\n    Susi Sushanti Don $ python -c &quot;import sys, json; print(str(json.load(open(&#39;/tmp/2.json&#39;))[&#39;pages&#39;]))&quot;\r\n    {u&#39;giga-10&#39;: [u&#39;overview&#39;]}\r\n\r\n\r\nWhy is python still printing `u` character even though I used `str()`? I read in other post that using string will not print it in the std output. Is there any similar str() function which can work on any Python data object (rather than writing a reusable function myself)?\r\n\r\nI&#39;m expecting the output to be just `{&#39;giga-10&#39;: [&#39;overview&#39;]}`",
        "link": "https://stackoverflow.com/questions/45745684/why-are-u-prefixes-still-printing-even-though-i-used-str",
        "title": "Why are &#39;u&#39; prefixes still printing even though I used str()?"
    },
    {
        "tags": [
            "json",
            "edit",
            "jq",
            "in-place"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1503026365,
                "creation_date": 1503026365,
                "answer_id": 45747977,
                "question_id": 45747895,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a viable solution:\r\n\r\n    cat some.json | jq &#39;.some_array = (.some_array | map(if .k1 == &quot;B&quot; then . + {&quot;k2&quot;:&quot;changed&quot;} else . end))&#39;\r\n\r\nproduces the output:\r\n\r\n\r\n      &quot;some_array&quot;: [\r\n        {\r\n          &quot;k1&quot;: &quot;A&quot;,\r\n          &quot;k2&quot;: &quot;XXX&quot;\r\n        },\r\n        {\r\n          &quot;k1&quot;: &quot;B&quot;,\r\n          &quot;k2&quot;: &quot;changed&quot;\r\n        }\r\n      ]\r\n    }",
                "title": "How do I update a single value in a nested array of objects in a json document using jq?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1503027837,
                "creation_date": 1503027837,
                "answer_id": 45748202,
                "question_id": 45747895,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s another solution.\r\n\r\n    jq &#39;(.some_array[] | select(.k1 == &quot;B&quot;) | .k2) |= &quot;new_value&quot;&#39;\r\n\r\nOutput\r\n\r\n    {\r\n      &quot;some_array&quot;: [\r\n        {\r\n          &quot;k1&quot;: &quot;A&quot;,\r\n          &quot;k2&quot;: &quot;XXX&quot;\r\n        },\r\n        {\r\n          &quot;k1&quot;: &quot;B&quot;,\r\n          &quot;k2&quot;: &quot;new_value&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "How do I update a single value in a nested array of objects in a json document using jq?"
            },
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1503027846,
                "creation_date": 1503027846,
                "answer_id": 45748203,
                "question_id": 45747895,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a slightly simpler version of [zayquan](https://stackoverflow.com/users/3344695/zayquan)&#39;s filter:\r\n\r\n    .some_array |= map(if .k1==&quot;B&quot; then .k2=&quot;changed&quot; else . end)",
                "title": "How do I update a single value in a nested array of objects in a json document using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 6,
        "last_activity_date": 1503038203,
        "creation_date": 1503025807,
        "last_edit_date": 1503038203,
        "question_id": 45747895,
        "body_markdown": "I have a JSON document that looks like the following. Note this is a simplified example of the real JSON, which is included at bottom of question:\r\n\r\n    {\r\n      &quot;some_array&quot;: [\r\n        {\r\n          &quot;k1&quot;: &quot;A&quot;,\r\n          &quot;k2&quot;: &quot;XXX&quot;\r\n        },\r\n        {\r\n          &quot;k1&quot;: &quot;B&quot;,\r\n          &quot;k2&quot;: &quot;YYY&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI would like to change the value of all the `k2` keys in the `some_array` array where the value of the `k1` key is &quot;B&quot;.\r\n\r\nIs this possible using jq ? \r\n\r\nFor reference this is the actual JSON document, which is an environment variable file for use in [postman][1] / [newman][2] tool. I am attempting this conversion using JQ because the tool does not yet support [command line overrides of specific environment variables][3]\r\n\r\nActual JSON\r\n\r\n    {\r\n      &quot;name&quot;: &quot;Local-Stack-Env-Config&quot;,\r\n      &quot;values&quot;: [\r\n        {\r\n          &quot;enabled&quot;: true,\r\n          &quot;key&quot;: &quot;KC_master_host&quot;,\r\n          &quot;type&quot;: &quot;text&quot;,\r\n          &quot;value&quot;: &quot;http://localhost:8087&quot;\r\n        },\r\n        {\r\n          &quot;enabled&quot;: true,\r\n          &quot;key&quot;: &quot;KC_user_guid&quot;,\r\n          &quot;type&quot;: &quot;text&quot;,\r\n          &quot;value&quot;: &quot;11111111-1111-1111-1111-11111111111&quot;\r\n        }\r\n      ],\r\n      &quot;timestamp&quot;: 1502768145037,\r\n      &quot;_postman_variable_scope&quot;: &quot;environment&quot;,\r\n      &quot;_postman_exported_at&quot;: &quot;2017-08-15T03:36:41.474Z&quot;,\r\n      &quot;_postman_exported_using&quot;: &quot;Postman/5.1.3&quot;\r\n    }\r\n\r\n  [1]: https://www.getpostman.com/postman\r\n  [2]: https://github.com/postmanlabs/newman\r\n  [3]: https://github.com/postmanlabs/newman/issues/647",
        "link": "https://stackoverflow.com/questions/45747895/how-do-i-update-a-single-value-in-a-nested-array-of-objects-in-a-json-document-u",
        "title": "How do I update a single value in a nested array of objects in a json document using jq?"
    },
    {
        "tags": [
            "json",
            "field",
            "filtering",
            "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": 1503066241,
                "post_id": 45758631,
                "comment_id": 78475646,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 205662,
                    "reputation": 192281,
                    "user_id": 454533,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://www.gravatar.com/avatar/c7715e765817254e0534f89a4092c0aa?s=256&d=identicon&r=PG",
                    "display_name": "Explosion Pills",
                    "link": "https://stackoverflow.com/users/454533/explosion-pills"
                },
                "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": 1503066691,
                "post_id": 45758631,
                "comment_id": 78476002,
                "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": 1503067435,
                "post_id": 45758631,
                "comment_id": 78476485,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1503073228,
                "creation_date": 1503073228,
                "answer_id": 45761046,
                "question_id": 45758631,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following transforms the given input to the desired output and may well be what you want:\r\n\r\n    {catalog}\r\n    | .catalog |= map( {name, catalog} )\r\n    | .catalog[].catalog |= map( {name, uniqueId} )\r\n    | .catalog |= .[0:1]\r\n\r\nHowever, it&#39;s not clear to me that this is really what you want, as you don&#39;t discuss the duplication in the given JSON input.  So maybe you don&#39;t really want the last line in the above, or maybe you want duplicates to be handled in some other way, or ....\r\n\r\nAnyway, the trick to keeping things simple here is to use `|=`.\r\n\r\nAn alternative approach would be to use `del` to delete the unwanted properties (rather than selecting the ones you want), but in the present case, that would be (at best) tedious.\r\n\r\n",
                "title": "Getting only desired properties from nested array values with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503075181,
                "creation_date": 1503075181,
                "answer_id": 45761510,
                "question_id": 45758631,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could start by using **tostream** to convert your `sample.json`\r\ninto a stream of [path, value] arrays as you can see by running\r\n\r\n    jq -c tostream sample.json\r\n\r\nThis will generate\r\n\r\n    [[&quot;catalog&quot;,0,&quot;catalog&quot;,0,&quot;name&quot;],&quot;Y&quot;]\r\n    [[&quot;catalog&quot;,0,&quot;catalog&quot;,0,&quot;prop11&quot;],&quot;&quot;]\r\n    [[&quot;catalog&quot;,0,&quot;catalog&quot;,0,&quot;uniqueId&quot;],&quot;Z&quot;]\r\n    [[&quot;catalog&quot;,0,&quot;catalog&quot;,0,&quot;uniqueId&quot;]]\r\n    [[&quot;catalog&quot;,0,&quot;catalog&quot;,1,&quot;name&quot;],&quot;Y&quot;]\r\n    [[&quot;catalog&quot;,0,&quot;catalog&quot;,1,&quot;prop11&quot;],&quot;&quot;]\r\n    ...\r\n\r\n**reduce** and **setpath** can be used to convert back into the\r\noriginal form with a filter such as:\r\n    \r\n    reduce (tostream|select(length==2)) as [$p,$v] (\r\n      {};\r\n      setpath($p;$v)\r\n    )\r\n\r\nAdding conditionals makes it easy to omit properties at any level.\r\nFor example the following removes leaf attributes starting with &quot;prop&quot;:\r\n          \r\n    reduce (tostream|select(length==2)) as [$p,$v] (\r\n      {};\r\n      if $p[-1]|startswith(&quot;prop&quot;)\r\n      then .\r\n      else setpath($p;$v)\r\n      end\r\n    )\r\n\r\nWith your `sample.json` this produces\r\n\r\n    {\r\n      &quot;catalog&quot;: [\r\n        {\r\n          &quot;catalog&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Y&quot;,\r\n              &quot;uniqueId&quot;: &quot;Z&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Y&quot;,\r\n              &quot;uniqueId&quot;: &quot;Z&quot;\r\n            }\r\n          ],\r\n          &quot;name&quot;: &quot;X&quot;\r\n        },\r\n        {\r\n          &quot;catalog&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Y&quot;,\r\n              &quot;uniqueId&quot;: &quot;Z&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Y&quot;,\r\n              &quot;uniqueId&quot;: &quot;Z&quot;\r\n            }\r\n          ],\r\n          &quot;name&quot;: &quot;X&quot;\r\n        }\r\n      ]\r\n    }\r\n",
                "title": "Getting only desired properties from nested array values with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503080453,
                "creation_date": 1503080453,
                "answer_id": 45762823,
                "question_id": 45758631,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If the goal is to remove certain properties, then one could do so using `walk/1`.  For example, to remove properties whose names start with &quot;prop&quot;:\r\n\r\n     walk(if type == &quot;object&quot; \r\n          then with_entries(select(.key|startswith(&quot;prop&quot;) | not)) \r\n          else . end)\r\n\r\nThe same approach would also be applicable if the focus is on retaining certain properties, e.g.:\r\n\r\n    walk(if type == &quot;object&quot; \r\n         then with_entries(select(.key == &quot;name&quot; or .key == &quot;uniqueId&quot; or .key == &quot;catalog&quot;))\r\n         else . end)\r\n\r\n",
                "title": "Getting only desired properties from nested array values with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503093502,
                "creation_date": 1503093502,
                "answer_id": 45765539,
                "question_id": 45758631,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could build up a file that contains paths into the json (expressed as arrays) that you want to keep.  Then filter out values that do not fit in those paths.\r\n\r\npaths.json:\r\n\r\n    [&quot;catalog&quot;,&quot;name&quot;]\r\n    [&quot;catalog&quot;,&quot;catalog&quot;,&quot;name&quot;]\r\n    [&quot;catalog&quot;,&quot;catalog&quot;,&quot;uniqueId&quot;]\r\n\r\nThen filter values based on their paths.  Using streams is a great way to go for this since it gives you access to these paths directly:\r\n\r\n    $ jq --slurpfile paths paths.json &#39;\r\n    def keep_path($path): any($paths[]; . == [$path[] | select(strings)]);\r\n    fromstream(tostream | select(length == 1 or keep_path(.[0])))\r\n    &#39; input.json",
                "title": "Getting only desired properties from nested array values with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1503093502,
        "creation_date": 1503065112,
        "last_edit_date": 1503074542,
        "question_id": 45758631,
        "body_markdown": "The structure I ultimately want would be:\r\n\r\n    {\r\n      &quot;catalog&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;X&quot;,\r\n          &quot;catalog&quot;: [\r\n            { &quot;name&quot;: &quot;Y&quot;, &quot;uniqueId&quot;: &quot;Z&quot; },\r\n            { &quot;name&quot;: &quot;Q&quot;, &quot;uniqueId&quot;: &quot;B&quot; }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nThis is what the existing structure looks like except there are _many_ other properties at each level (https://gist.github.com/ajcrites/e0e0ca4ca3a08ff2dc401ec872e6094c). I just want to filter those out and get a JSON format that looks specifically like this.\r\n\r\nI have started out with: `jq &#39;.catalog&#39;`, but this returns only the array. I still want the `catalog` property name there. I can do this with `jq &#39;{catalog: .catalog[]}`, but this prints out each catalog object individually which makes the whole output invalid JSON. I still want the properties to be in the array. Is there a way to filter specific property key-values within arrays using jq?",
        "link": "https://stackoverflow.com/questions/45758631/getting-only-desired-properties-from-nested-array-values-with-jq",
        "title": "Getting only desired properties from nested array values with jq"
    },
    {
        "tags": [
            "json",
            "unix",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1503092280,
                "creation_date": 1503092280,
                "answer_id": 45765358,
                "question_id": 45765147,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution:\r\n\r\n      .[]\r\n    | .Result = [\r\n          .elements[]\r\n        | .steps[]\r\n        | {stepName:.name, status:.result.status}\r\n      ]\r\n    | del(.elements)\r\n\r\nHere is a sample run assuming your data is in `input.json`:\r\n\r\n    $ jq &#39;.[] | .Result = [.elements[] | .steps[] | {stepName:.name, status:.result.status}] | del(.elements)&#39; input.json\r\n    {\r\n      &quot;name&quot;: &quot;Successful retrieval&quot;,\r\n      &quot;Result&quot;: [\r\n        {\r\n          &quot;stepName&quot;: &quot;as a customer&quot;,\r\n          &quot;status&quot;: &quot;passed&quot;\r\n        },\r\n        {\r\n          &quot;stepName&quot;: &quot;I hit API&quot;,\r\n          &quot;status&quot;: &quot;passed&quot;\r\n        },\r\n        {\r\n          &quot;stepName&quot;: &quot;API should respond&quot;,\r\n          &quot;status&quot;: &quot;passed&quot;\r\n        }\r\n      ]\r\n    }\r\n",
                "title": "Formatting json data using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1503248941,
                "creation_date": 1503248941,
                "answer_id": 45784769,
                "question_id": 45765147,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is just a minor variation on jq170727&#39;s answer.\r\n\r\nThe last step builds the object out of the parts you want rather than deleting the ones you don&#39;t want.\r\n\r\n    jq &#39;.[]\r\n    | .Result =\r\n      [  \r\n         .elements[]\r\n         | .steps[]\r\n         | { stepName:.name, status:.result.status }\r\n      ]\r\n    | { name, Result }&#39;",
                "title": "Formatting json data using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1503248941,
        "creation_date": 1503090919,
        "question_id": 45765147,
        "body_markdown": "I am trying to convert the json from the following format to a different format but I am getting am unable to generate the required format format:\r\n\r\n**Input Json:**\r\n\r\n    [&#160;&#160;\r\n    &#160;&#160;&#160;{&#160;&#160;\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&quot;name&quot;:&quot;Successful&#160;retrieval&quot;,\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&quot;elements&quot;:[&#160;&#160;\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;{&#160;&#160;\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;scenario&quot;:&quot;First&quot;,\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;steps&quot;:[&#160;&#160;\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;{&#160;&#160;\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;name&quot;:&quot;as&#160;a&#160;customer&quot;,\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;result&quot;:{&#160;&#160;\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;status&quot;:&quot;passed&quot;,\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;duration&quot;:29428\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;}\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;},\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;{&#160;&#160;\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;name&quot;:&quot;I&#160;hit&#160;API&quot;,\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;result&quot;:{&#160;&#160;\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;status&quot;:&quot;passed&quot;,\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;duration&quot;:210403731\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;}\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;},\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;{&#160;&#160;\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;name&quot;:&quot;API&#160;should&#160;respond&quot;,\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;result&quot;:{&#160;&#160;\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;status&quot;:&quot;passed&quot;,\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;duration&quot;:1246183\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;}\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;}\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;]\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;}\r\n    &#160;&#160;&#160;&#160;&#160;&#160;]\r\n    &#160;&#160;&#160;}\r\n    ]\r\n\r\n**Desired Format:**\r\n \r\n\r\n        {&#160;&#160;\r\n    &#160;&#160;&#160;&quot;name&quot;:&quot;Successful&#160;retrieval&quot;,\r\n    &#160;&#160;&#160;&quot;Result&quot;:[&#160;&#160;\r\n    &#160;&#160;&#160;&#160;&#160;&#160;{&#160;&#160;\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;stepName&quot;:&quot;as&#160;a&#160;customer&quot;,\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;status&quot;:&quot;passed&quot;\r\n    &#160;&#160;&#160;&#160;&#160;&#160;},\r\n    &#160;&#160;&#160;&#160;&#160;&#160;{&#160;&#160;\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;stepName&quot;:&quot;I&#160;hit&#160;API&quot;,\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;status&quot;:&quot;passed&quot;\r\n    &#160;&#160;&#160;&#160;&#160;&#160;},\r\n    &#160;&#160;&#160;&#160;&#160;&#160;{&#160;&#160;\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;stepName&quot;:&quot;API&#160;should&#160;respond&quot;,\r\n    &#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&#160;&quot;status&quot;:&quot;passed&quot;\r\n    &#160;&#160;&#160;&#160;&#160;&#160;}\r\n    &#160;&#160;&#160;]\r\n    }\r\n\r\n**JQ command used:**\r\n\r\n  \r\n\r\n      jq [&#39;.[] | { name: .name, steps: .elements[].steps[]} | \r\n    {name:.name, stepName:.steps.name, status:.steps.result.status}&#39;]\r\n\r\nWith the above command, I am getting the following format:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Successful retrieval&quot;,\r\n        &quot;stepName&quot;: &quot;as an  Synapse API customer&quot;,\r\n        &quot;status&quot;: &quot;passed&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Successful retrieval&quot;,\r\n        &quot;stepName&quot;: &quot;I hit API&quot;,\r\n        &quot;status&quot;: &quot;passed&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Successful retrieval&quot;,\r\n        &quot;stepName&quot;: &quot;API should respond&quot;,\r\n        &quot;status&quot;: &quot;passed&quot;\r\n      }\r\n    ]\r\n\r\nI tried using the `join`but it didn&#39;t work. Any pointers will be helpful.\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/45765147/formatting-json-data-using-jq",
        "title": "Formatting json data using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 112771,
                    "reputation": 45800,
                    "user_id": 297323,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/97e8a3c4945a8a898cbf216ce912fd46?s=256&d=identicon&r=PG",
                    "display_name": "Fredrik Pihl",
                    "link": "https://stackoverflow.com/users/297323/fredrik-pihl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1503250996,
                "post_id": 45784813,
                "comment_id": 78527660,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1503252477,
                "creation_date": 1503252477,
                "answer_id": 45785339,
                "question_id": 45784813,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You have three issues - two typos and one `jq` filter usage issue:\r\n\r\n- set `APPLICATION_ENVIRONMENT` to `development` instead of `developement`\r\n- use variable name consistently: if you define `appenv`, use `$appenv`, not `$env`\r\n- address with `.environments[$appenv]`\r\n\r\nWhen fixed, looks like this:\r\n\r\n    $ APPLICATION_ENVIRONMENT=&quot;development&quot;\r\n    $ jq --arg appenv &quot;$APPLICATION_ENVIRONMENT&quot; &#39;.environments[$appenv][]&#39; test-app-1.json\r\n    &quot;server1&quot;",
                "title": "Pass bash variable (string) as jq argument to walk JSON object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1503252477,
        "creation_date": 1503249267,
        "question_id": 45784813,
        "body_markdown": "This is seemingly a *very* basic question. I am new to JSON, so I am prepared for the incoming facepalm. \r\n\r\nI have the following JSON file (test-app-1.json):\r\n\r\n\r\n    &quot;application.name&quot;: &quot;test-app-1&quot;,\r\n    &quot;environments&quot;: {\r\n        &quot;development&quot;: [\r\n            &quot;server1&quot;\r\n        ],\r\n        &quot;stage&quot;: [\r\n            &quot;server2&quot;,\r\n            &quot;server3&quot;\r\n        ],\r\n        &quot;production&quot;: [\r\n            &quot;server4&quot;,\r\n            &quot;server5&quot;\r\n        ]\r\n    }\r\nThe intent is to use this as a configuration file and reference for input validation. \r\n\r\nI am using `bash 3.2` and will be using `jq 1.4` (*not* the latest) to read the JSON.\r\n\r\nThe problem:\r\nI need to return all values in the specified JSON array based on an argument. \r\n\r\nExample: (how the documentation and other resources show that it *should* work)\r\n\r\n`APPLICATION_ENVIRONMENT=&quot;developement&quot;`\r\n\r\n`jq --arg appenv &quot;$APPLICATION_ENVIRONMENT&quot; &#39;.environments.&quot;$env[]&quot;&#39; test-app-1.json`\r\n\r\nIf executed, this returns `null`. This should return `server1`.\r\n\r\nObviously, if I specify text explicitly matching the JSON arrays under environment, it works just fine: \r\n`jq &#39;environments.development[]&#39; test-app-1.json` returns: `server1`.\r\n\r\nLimitations: I am stuck to jq 1.4 for this project. I have tried the same actions in 1.5 on a different machine with the same `null` results. \r\n\r\nWhat am I doing wrong here? \r\n\r\njq documentation: https://stedolan.github.io/jq/manual/ \r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/45784813/pass-bash-variable-string-as-jq-argument-to-walk-json-object",
        "title": "Pass bash variable (string) as jq argument to walk JSON object"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503264244,
                "creation_date": 1503264244,
                "answer_id": 45786928,
                "question_id": 45786861,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "do you want like this : ?\r\n\r\n    jq -r &#39;.secondary_letters | map(.name)&#39; letters.json\r\n    ==&gt; [&quot;a&quot; , &quot;aa&quot;]\r\n\r\nIf you need more attributes, .i.e: id:\r\n\r\n    jq -r &#39;.secondary_letters | map(.name, .id)&#39; letters.json\r\n    ==&gt; [&quot;a&quot; , 1, &quot;aa&quot;, 2]\r\n\r\n",
                "title": "jq display nodes in one line"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1503272882,
                "creation_date": 1503272882,
                "answer_id": 45787776,
                "question_id": 45786861,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming the input has been corrected so it is valid JSON,\r\n\r\n    jq -r &#39;.secondary_letters | map(.name) | join(&quot;, &quot;)&#39;\r\n\r\nproduces\r\n\r\n    a, aa\r\n  \r\nThe same filter also satisfies the generality requirement.",
                "title": "jq display nodes in one line"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503302602,
                "creation_date": 1503302602,
                "answer_id": 45792033,
                "question_id": 45786861,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Simple ***jq*** approach:\r\n\r\n    jq -r &#39;[.secondary_letters[].name] | join(&quot;, &quot;)&#39; letters.json\r\nThe output:\r\n\r\n    a, aa",
                "title": "jq display nodes in one line"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1503302602,
        "creation_date": 1503263605,
        "question_id": 45786861,
        "body_markdown": "So I have this:\r\n\r\n    jq -r &#39;.letters[0].secondary_letters[0] | &quot;\\(.name)&quot;&#39; letters.json\r\n\r\nwhich outputs:\r\n\r\n    a\r\n    aa\r\n\r\nI&#39;d like them to be: a, aa\r\n\r\nThe json looks like:\r\n\r\n      &quot;secondary_letters&quot;: [\r\n        {\r\n          &quot;id&quot;: 1,\r\n          &quot;name&quot;: &quot;a&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;name&quot;: &quot;aa&quot;\r\n        }\r\n\r\nThere might be more so the jq command should be able to extract as many as sub nodes needed.\r\n\r\nCan it be done?\r\n",
        "link": "https://stackoverflow.com/questions/45786861/jq-display-nodes-in-one-line",
        "title": "jq display nodes in one line"
    },
    {
        "tags": [
            "amazon-ec2",
            "tags",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503354696,
                "creation_date": 1503354696,
                "answer_id": 45806414,
                "question_id": 45804706,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I believe I&#39;ve found a solution.  It may not be optimal, but I&#39;ve found a way to pipe-chain excludes of exact strings:\r\n\r\n    aws ec2 describe-instances --output json --query &#39;Reservations[].Instances[].{ID:InstanceId, EnvTag: Tags[?Key==`Environment`].Value, FinTag: Tags[?Key==`Finance`].Value}&#39; | jq &#39;.[]&#39; | jq &#39;select(.EnvTag[] != &quot;dev&quot;) | select (.EnvTag[] != &quot;stg&quot;) | select (.EnvTag[] != &quot;prod&quot;) | select (.EnvTag[] != &quot;test&quot;) | select (.EnvTag[] != &quot;ops&quot;) | .ID&#39;\r\n\r\nI verified this by changing an environment tag from &quot;ops&quot; to &quot;oops&quot;.\r\n\r\nUpon running this query, it returned the single instance with the oops tag.\r\n",
                "title": "Find ec2 instances with improper or missing tags"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1508975750,
                "last_edit_date": 1508975750,
                "creation_date": 1503372412,
                "answer_id": 45808441,
                "question_id": 45804706,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; I believe I&#39;ve found a solution. \r\n\r\nIt can be greatly simplified. First, in this case, there is no need to invoke jq twice. `jq &#39;.[]&#39; | jq ...` is equivalent to `jq &#39;.[] | ...&#39;`\r\n\r\nSecond, the long pipeline of &#39;select&#39; filters can be condensed, for example to:&lt;br/&gt;\r\n\r\n    select(.EnvTag[]\r\n      | (. != &quot;dev&quot; and . != &quot;stg&quot; and . != &quot;prod&quot; and . != &quot;test&quot; and . != &quot;ops&quot;))\r\n\r\nor, if your jq has `all/2`, even more concisely to:\r\n\r\n    select( . as $in | all( (&quot;dev&quot;, &quot;stg&quot;, &quot;prod&quot;, &quot;test&quot;, &quot;ops&quot;); . != $in.EnvTag[]) )\r\n\r\n",
                "title": "Find ec2 instances with improper or missing tags"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1508975750,
        "creation_date": 1503345718,
        "last_edit_date": 1503349313,
        "question_id": 45804706,
        "body_markdown": "I am trying to simply output a list of all instance IDs that do not follow a particular tagging convention.\r\n\r\n 1. Tag is missing (Tag Keys: Environment or Finance) \r\n 1. Environment Tag value is not one of (prod, stg, test, dev)\r\n 1. Finance Tag value is not one of (GroupA , GroupB)\r\n\r\n&lt;hr&gt;\r\nFor (1) I can use the following:\r\n\r\n    aws ec2 describe-instances --output json --query &#39;Reservations[*].Instances[?!not_null(Tags[?Key==`Environment`].Value)] | [].InstanceId&#39;\r\n    [\r\n        &quot;i-12345678901234567&quot;, \r\n        &quot;i-76543210987654321&quot;\r\n    ]\r\n\r\n&lt;hr&gt;\r\nBut I still need (2) and (3).  What if the tag exists but is empty, or has a typo in the value?\r\n\r\n&quot;ec2 --query&quot; functionality is limited and I&#39;ve yet to find a way for it to get me (2) or (3), especially when it comes to inverting results.\r\n\r\nI&#39;ve gone back and forth trying to \r\n\r\n- modify the output from the CLI to make it easier to parse in JQ\r\n\r\nVS\r\n\r\n- trying to wrangle the output in JQ \r\n\r\nFor (2) and (3).  Here&#39;s a pair of outputs from the CLI that I&#39;ve tried sending to JQ to parse with sample output for 2 instances:\r\n\r\n**CLI Sample Output [A]** Tag.Value and Tag.Key need to be paired when searching, and then negating/inverting a set of searches... \r\n\r\n    aws ec2 describe-instances --output json --query &#39;Reservations[].Instances[].{ID:InstanceId, Tag: Tags[]}&#39; | jq &#39;.[]&#39;\r\n    {\r\n      &quot;Tag&quot;: [\r\n        {\r\n          &quot;Value&quot;: &quot;GroupA&quot;,\r\n          &quot;Key&quot;: &quot;Finance&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;stg&quot;,\r\n          &quot;Key&quot;: &quot;Environment&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;true&quot;,\r\n          &quot;Key&quot;: &quot;Backup&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;Another Server&quot;,\r\n          &quot;Key&quot;: &quot;Name&quot;\r\n        }\r\n      ],\r\n      &quot;ID&quot;: &quot;i-87654321&quot;\r\n    }\r\n    {\r\n      &quot;Tag&quot;: [\r\n        {\r\n          &quot;Value&quot;: &quot;GroupB&quot;,\r\n          &quot;Key&quot;: &quot;Finance&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;Server 1&quot;,\r\n          &quot;Key&quot;: &quot;Name&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;true&quot;,\r\n          &quot;Key&quot;: &quot;Backup&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;stg&quot;,\r\n          &quot;Key&quot;: &quot;Environment&quot;\r\n        }\r\n      ],\r\n      &quot;ID&quot;: &quot;i-12345678&quot;\r\n    }\r\n\r\n**CLI Sample Output [B]** Tag value being inside an array has been enough to trigger syntax errors when attempting things like &quot;jq map&quot; or &quot;jq select&quot;\r\n\r\n    aws ec2 describe-instances --output json --query &#39;Reservations[].Instances[].{ID:InstanceId, EnvTag: Tags[?Key==`Environment`].Value, FinTag: Tags[?Key==`Finance`].Value}&#39; | jq &#39;.[]&#39;\r\n    {\r\n      &quot;EnvTag&quot;: [\r\n        &quot;stg&quot;\r\n      ],\r\n      &quot;ID&quot;: &quot;i-87654321&quot;,\r\n      &quot;FinTag&quot;: [\r\n        &quot;GroupA&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;EnvTag&quot;: [\r\n        &quot;stg&quot;\r\n      ],\r\n      &quot;ID&quot;: &quot;i-12345678&quot;,\r\n      &quot;FinTag&quot;: [\r\n        &quot;GroupB&quot;\r\n      ]\r\n    }\r\n\r\nI find most of the time, when I try to expand some solution from a simpler use case, I only ever end up with cryptic syntax errors due to some oddity in the structure of my incoming dataset.\r\n\r\n&lt;hr&gt;\r\n**Example Issue 1**\r\nBelow is an example of how the inverting / negating fails.  This is using CLI output B:\r\n\r\n    aws ec2 describe-instances --output json --query &#39;Reservations[].Instances[].{ID:InstanceId, EnvTag: Tags[?Key==`Environment`].Value, FinTag: Tags[?Key==`Finance`].Value}&#39; | jq &#39;.[]&#39; | jq &#39;select(.EnvTag[] | contains (&quot;prod&quot;, &quot;dev&quot;) | not)&#39;\r\n\r\nI would expect the above to return everything except prod and dev.  But it looks like the logic is inverted on each item as opposed to the set of contains:\r\n\r\n- &quot;!A + !B&quot; instead of &quot;!(A or B)&quot;\r\n\r\nThe resulting dataset returned is a list of everything, including dev and prod.\r\n\r\n**Example Issue 1.5**\r\nI can workaround the logic issue by chaining the contain excludes, but then I discover that &quot;contains&quot; won&#39;t work for me as it will pickup typos that still happen to contain the string in question:\r\n\r\n    aws ec2 describe-instances --output json --query &#39;Reservations[].Instances[].{ID:InstanceId, EnvTag: Tags[?Key==`Environment`].Value, FinTag: Tags[?Key==`Finance`].Value}&#39; | jq &#39;.[]&#39; | jq &#39;select(.EnvTag[] | contains (&quot;dev&quot;) | not) | select(.EnvTag[] | contains (&quot;stg&quot;) | not) | select(.EnvTag[] | contains (&quot;test&quot;) | not) | select(.EnvTag[] | contains (&quot;prod&quot;) | not) | select (.EnvTag[] | contains (&quot;foo&quot;) | not)&#39;\r\n\r\n- prod != production\r\n- &quot;prod&quot; contains(&quot;prod&quot;) = true\r\n- &quot;production&quot; contains (&quot;prod&quot;) = true &lt;-- bad :(\r\n",
        "link": "https://stackoverflow.com/questions/45804706/find-ec2-instances-with-improper-or-missing-tags",
        "title": "Find ec2 instances with improper or missing tags"
    },
    {
        "tags": [
            "curl",
            "elasticsearch",
            "kibana",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503855730,
                "creation_date": 1503855730,
                "answer_id": 45907672,
                "question_id": 45823120,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The thing about the `-S` option is that it only affects the output, it doesn&#39;t have any influence on the objects as they are being processed. Since the inner json string is not an object, jq cannot sort the keys in those objects within. If you wanted jq to sort them via the `-S` option, you would have to output it as objects first, then use another invocation to convert back to json.\r\n\r\n    $ jq -S &#39;._source.fields |= (fromjson | sort_by(.name))&#39; input.json | \\\r\n    jq &#39;._source.fields |= tojson&#39;\r\n\r\nThat however is far from ideal. Instead, you could take advantage of the fact that jq preserves insertion order of object keys by default. So you could define a function that would take an object and recreate it with sorted keys. Then apply it to objects you want sorted. Then apply this recursively on all objects in your tree.\r\n\r\n    def sort_object: (objects | . as $in | reduce keys[] as $k ({}; .[$k] = $in[$k])) // .;\r\n    def sort_object_recursive: walk((objects | sort_object) // .);\r\n    ._source.fields |= (fromjson | sort_by(.name)) | sort_object_recursive | ._source.fields |= tojson\r\n\r\nThis yields the following output:\r\n\r\n    {\r\n      &quot;_id&quot;: &quot;eslogs-*&quot;,\r\n      &quot;_index&quot;: &quot;.kibana&quot;,\r\n      &quot;_source&quot;: {\r\n        &quot;fields&quot;: &quot;[{\\&quot;aggregatable\\&quot;:false,\\&quot;analyzed\\&quot;:true,\\&quot;count\\&quot;:0,\\&quot;doc_values\\&quot;:false,\\&quot;indexed\\&quot;:true,\\&quot;name\\&quot;:\\&quot;source\\&quot;,\\&quot;scripted\\&quot;:false,\\&quot;searchable\\&quot;:true,\\&quot;type\\&quot;:\\&quot;string\\&quot;},{\\&quot;aggregatable\\&quot;:false,\\&quot;analyzed\\&quot;:false,\\&quot;count\\&quot;:0,\\&quot;doc_values\\&quot;:true,\\&quot;indexed\\&quot;:true,\\&quot;name\\&quot;:\\&quot;took_millis\\&quot;,\\&quot;scripted\\&quot;:false,\\&quot;searchable\\&quot;:false,\\&quot;type\\&quot;:\\&quot;number\\&quot;},{\\&quot;aggregatable\\&quot;:false,\\&quot;analyzed\\&quot;:false,\\&quot;count\\&quot;:0,\\&quot;doc_values\\&quot;:true,\\&quot;indexed\\&quot;:true,\\&quot;name\\&quot;:\\&quot;total_shards\\&quot;,\\&quot;scripted\\&quot;:false,\\&quot;searchable\\&quot;:false,\\&quot;type\\&quot;:\\&quot;number\\&quot;}]&quot;,\r\n        &quot;notExpandable&quot;: true,\r\n        &quot;timeFieldName&quot;: &quot;@timestamp&quot;,\r\n        &quot;title&quot;: &quot;eslogs-*&quot;\r\n      },\r\n      &quot;_type&quot;: &quot;index-pattern&quot;,\r\n      &quot;_version&quot;: 1,\r\n      &quot;found&quot;: true\r\n    }\r\n\r\nJust be sure to include the definition of [`walk/1`](https://github.com/stedolan/jq/blob/7b81a836c31500e685d043729259affa8b670a87/src/builtin.jq#L284) in your `~/.jq` file.\r\n",
                "title": "Kibana: exporting and sorting embedded JSON using curl and jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1503855730,
        "creation_date": 1503420497,
        "question_id": 45823120,
        "body_markdown": "Context: \r\n\r\nI use Kibana (v5.5.1) on Ubuntu Xenial (16.04). I want to manage changes to Kibana objects (adding / removing / updating dashboards, visualizations, searches, etc.) in Git. \r\n\r\n(Kibana&#39;s &quot;snapshot&quot; feature uses binary format, so it&#39;s not an option.)\r\n\r\nI want to export Kibana objects as JSON and add/update them in Git.\r\n\r\nI use `curl` and `jq`:\r\n\r\n    curl -s -XGET &quot;http://localhost:9200/.kibana/dashboard/Metricbeat-Docker&quot;| jq --sort-keys &#39;.&#39;\r\n\r\nwhich is ok: I get *diff-friendly* sorted JSON that I can store in Git and later import back to Elastic.\r\n\r\nHere&#39;s example output I get: \r\n\r\n    {\r\n      &quot;_id&quot;: &quot;eslogs-*&quot;,\r\n      &quot;_index&quot;: &quot;.kibana&quot;,\r\n      &quot;_source&quot;: {\r\n        &quot;fields&quot;: &quot;[{\\&quot;name\\&quot;:\\&quot;total_shards\\&quot;,\\&quot;type\\&quot;:\\&quot;number\\&quot;,\\&quot;count\\&quot;:0,\\&quot;scripted\\&quot;:false,\\&quot;indexed\\&quot;:true,\\&quot;analyzed\\&quot;:false,\\&quot;doc_values\\&quot;:true,\\&quot;searchable\\&quot;:false,\\&quot;aggregatable\\&quot;:false},{\\&quot;name\\&quot;:\\&quot;took_millis\\&quot;,\\&quot;type\\&quot;:\\&quot;number\\&quot;,\\&quot;count\\&quot;:0,\\&quot;scripted\\&quot;:false,\\&quot;indexed\\&quot;:true,\\&quot;analyzed\\&quot;:false,\\&quot;doc_values\\&quot;:true,\\&quot;searchable\\&quot;:false,\\&quot;aggregatable\\&quot;:false},{\\&quot;name\\&quot;:\\&quot;source\\&quot;,\\&quot;type\\&quot;:\\&quot;string\\&quot;,\\&quot;count\\&quot;:0,\\&quot;scripted\\&quot;:false,\\&quot;indexed\\&quot;:true,\\&quot;analyzed\\&quot;:true,\\&quot;doc_values\\&quot;:false,\\&quot;searchable\\&quot;:true,\\&quot;aggregatable\\&quot;:false}]&quot;,\r\n        &quot;notExpandable&quot;: true,\r\n        &quot;timeFieldName&quot;: &quot;@timestamp&quot;,\r\n        &quot;title&quot;: &quot;eslogs-*&quot;\r\n      },\r\n      &quot;_type&quot;: &quot;index-pattern&quot;,\r\n      &quot;_version&quot;: 1,\r\n      &quot;found&quot;: true\r\n    }\r\n\r\n\r\n\r\nHowever, since field ordering in JSON is random, on every export I get too many false diffs caused by the field ordering. In order to make diff easy, I must sort 2 other things:\r\n\r\n1. Sort the field ordering inside &quot;_source&quot; object.\r\n\r\n2. Sort **Embedded JSON text** inside &quot;_source.fields&quot; by &quot;name&quot; field.\r\n\r\nRegarding (2) I can use `jq` with `-r` option like this:\r\n\r\n\r\n    curl -s -XGET &quot;http://localhost:9200/.kibana/index-pattern/eslogs-*&quot; | jq  -r &#39;._source.fields&#39; | jq -c &#39;. |= sort_by(.name)&#39;\r\n\r\nwhich gives me a nice sorted JSON.\r\n\r\nI tried to get that sorted embedded JSON text into a shell variable and later to &quot;inject&quot; it to `jq` using `--arg`, but then I got &quot;Argument too long&quot; error. \r\n\r\nSo my question is:\r\n\r\nHow to combine all these requirements into a single command line script which do all the following:\r\n\r\n  1. Iterate over all Kibana objects \r\n  2. Sorts the field order in each JSON object\r\n  3. Sort the embedded JSON text inside &quot;_source.fields&quot;\r\n\r\nDo you have any idea which is simple enough, **readable** and elegant? \r\n\r\nThanks.",
        "link": "https://stackoverflow.com/questions/45823120/kibana-exporting-and-sorting-embedded-json-using-curl-and-jq",
        "title": "Kibana: exporting and sorting embedded JSON using curl and jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1503454049,
                "creation_date": 1503454049,
                "answer_id": 45829543,
                "question_id": 45827932,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This gets the desired output\r\n\r\n    jq &#39;[.[] | .[]]&#39;\r\n\r\nExplanation from the manual. When `.[]` is used on an array, it returns all of the elements of an array. When it is used on an object it will return all the values of the object.",
                "title": "How to convert json from one format to another using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1503454049,
        "creation_date": 1503440791,
        "question_id": 45827932,
        "body_markdown": "I would like to convert 500+ json files to csv format using the solution provided in https://stackoverflow.com/questions/32960857/how-to-convert-arbirtrary-simple-json-to-csv-using-jq but my json files are not in the same format as per the proposed solution.\r\n\r\nFollowing represents a sample json file:\r\n\r\n    [\r\n      {\r\n        &quot;jou_entry&quot;: {\r\n          &quot;id&quot;: 655002886,\r\n          &quot;units&quot;: 2\r\n        }\r\n      },\r\n      {\r\n        &quot;jou_entry&quot;: {\r\n          &quot;id&quot;: 655002823,\r\n          &quot;units&quot;: 4\r\n        }\r\n      },\r\n      {\r\n        &quot;jou_entry&quot;: {\r\n          &quot;id&quot;: 657553949,\r\n          &quot;units&quot;: 6\r\n        }\r\n      }\r\n    ]\r\n    \r\nWhere as the proposed solution requires the json in the following format:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: 655002886,\r\n        &quot;units&quot;: 2\r\n      },\r\n      {\r\n        &quot;id&quot;: 655002823,\r\n        &quot;units&quot;: 4\r\n      },\r\n      {\r\n        &quot;id&quot;: 657553949,\r\n        &quot;units&quot;: 6\r\n      }\r\n    ]\r\n\r\nI am able to convert the json from source format to required format using the following jq filter\r\n\r\n    jq -r &#39;[.[] | .&quot;jou_entry&quot;]&#39; \r\n\r\nBut I don&#39;t like the hard-coding of key &quot;jou_entry&quot; in the filter. As this will require individual key definition for so many files. I would like to have the conversion without the hard-coded value.\r\n\r\nHow can I do this? Please help",
        "link": "https://stackoverflow.com/questions/45827932/how-to-convert-json-from-one-format-to-another-using-jq",
        "title": "How to convert json from one format to another using jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503457416,
                "creation_date": 1503457416,
                "answer_id": 45829975,
                "question_id": 45829791,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can map to **array** and resign the `int` by operation, like:\r\n\r\n    jq --arg mod &quot;GOOD&quot; &#39;.[] | .int=.int + {stat: $mod}&#39; tmp.json\r\n    \r\n    {\r\n      &quot;_id&quot;: &quot;1234&quot;,\r\n      &quot;org&quot;: &quot;org1&quot;,\r\n      &quot;int&quot;: {\r\n        &quot;url&quot;: &quot;http://url.com.uk:1234&quot;,\r\n        &quot;stat&quot;: &quot;GOOD&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;_id&quot;: &quot;4321&quot;,\r\n      &quot;org&quot;: &quot;org2&quot;,\r\n      &quot;int&quot;: {\r\n        &quot;url&quot;: &quot;http://url.com.us:4321&quot;,\r\n        &quot;stat&quot;: &quot;GOOD&quot;\r\n      }\r\n    }\r\n\r\n   \r\n",
                "title": "jq - add new field with updating whole file"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1503464818,
                "last_edit_date": 1503464818,
                "creation_date": 1503464505,
                "answer_id": 45830971,
                "question_id": 45829791,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you put your data in `data.json` and the changes you want to make to\r\neach record into a separate `arg.json` argument file like\r\n\r\n    {\r\n        &quot;1234&quot;: { &quot;int&quot;: { &quot;stat&quot;: &quot;GOOD&quot; } },\r\n        &quot;4321&quot;: { &quot;int&quot;: { &quot;stat&quot;: &quot;BAD&quot;, &quot;xxx&quot;: &quot;yyy&quot; } }\r\n    }\r\n\r\nand run jq as\r\n\r\n    $ jq -M --argfile arg arg.json &#39;map(. + $arg[._id])&#39; data.json\r\n\r\nthen it will output the updated data, e.g.\r\n\r\n    [\r\n      {\r\n        &quot;_id&quot;: &quot;1234&quot;,\r\n        &quot;org&quot;: &quot;org1&quot;,\r\n        &quot;int&quot;: {\r\n          &quot;stat&quot;: &quot;GOOD&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;_id&quot;: &quot;4321&quot;,\r\n        &quot;org&quot;: &quot;org2&quot;,\r\n        &quot;int&quot;: {\r\n          &quot;stat&quot;: &quot;BAD&quot;,\r\n          &quot;xxx&quot;: &quot;yyy&quot;\r\n        }\r\n      }\r\n    ]\r\n    \r\nNote that the `+` replaces keys.  If you want to merge keys you can use `*` e.g.\r\n\r\n    $ jq -M --argfile arg arg.json &#39;map(. * $arg[._id])&#39; data.json \r\n\r\nwhich generates\r\n\r\n    [\r\n      {\r\n        &quot;_id&quot;: &quot;1234&quot;,\r\n        &quot;org&quot;: &quot;org1&quot;,\r\n        &quot;int&quot;: {\r\n          &quot;url&quot;: &quot;http://url.com.uk:1234&quot;,\r\n          &quot;stat&quot;: &quot;GOOD&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;_id&quot;: &quot;4321&quot;,\r\n        &quot;org&quot;: &quot;org2&quot;,\r\n        &quot;int&quot;: {\r\n          &quot;url&quot;: &quot;http://url.com.us:4321&quot;,\r\n          &quot;stat&quot;: &quot;BAD&quot;,\r\n          &quot;xxx&quot;: &quot;yyy&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\n\r\nIf you want to update the data in place you could use [sponge](https://linux.die.net/man/1/sponge)\r\nas described in the answer [Manipulate JSON with jq](https://stackoverflow.com/questions/41166330/manipulate-json-with-jq/41171245#41171245_)\r\ne.g.\r\n\r\n    $ jq -M --argfile arg arg.json &#39;map(. * $arg[._id])&#39; data.json | sponge data.json\r\n    \r\n",
                "title": "jq - add new field with updating whole file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1503464818,
        "creation_date": 1503456087,
        "last_edit_date": 1503460291,
        "question_id": 45829791,
        "body_markdown": "I have json file which is constructed in simmilar way:\r\n\r\n    [\r\n    {\r\n    &quot;_id&quot;:&quot;1234&quot;,\r\n    &quot;org&quot;:&quot;org1&quot;,\r\n    &quot;int&quot;:\r\n        {&quot;url&quot;:&quot;http://url.com.uk:1234&quot;}},\r\n    {\r\n    &quot;_id&quot;:&quot;4321&quot;,\r\n    &quot;org&quot;:&quot;org2&quot;,\r\n    &quot;int&quot;:\r\n        {&quot;url&quot;:&quot;http://url.com.us:4321&quot;}},\r\n    ...\r\n    ]\r\n\r\nNow im &quot;jumping&quot; from one entry to another and checking if under URL application is working properly. After check i want to add/update field &quot;status&quot;. But i can&#39;t update whole file, im just getting:\r\n\r\n    $ jq --arg mod &quot;GOOD&quot; &#39;.[0].int + {stat: $mod}&#39; tmp.json\r\n    {\r\n      &quot;url&quot;: &quot;http://url.com.uk:1234&quot;,\r\n      &quot;stat&quot;: &quot;GOOD&quot;\r\n    }\r\nHow can i with jq command get new updated **whole** file, not just only part of it? \r\n",
        "link": "https://stackoverflow.com/questions/45829791/jq-add-new-field-with-updating-whole-file",
        "title": "jq - add new field with updating whole file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1503529952,
                "creation_date": 1503529952,
                "answer_id": 45850614,
                "question_id": 45850452,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It&#39;s a little tricky, since you need to embed the input into the list bound to the `errands` key. Start by creating the sequence of `name`/`post_deploy` objects:\r\n\r\n    % jq &#39;.[] | {name: ., post_deploy: true}&#39; names.json\r\n    {\r\n      &quot;name&quot;: &quot;smoke-tests&quot;,\r\n      &quot;post_deploy&quot;: true\r\n    }\r\n    {\r\n      &quot;name&quot;: &quot;push-apps-manager&quot;,\r\n      &quot;post_deploy&quot;: true\r\n    }\r\n\r\nThen wrap that in the list in the outer object: \r\n\r\n    % jq &#39;{errands: [.[] | {name: ., post_deploy: true}]}&#39; names.json\r\n    {\r\n      &quot;errands&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;smoke-tests&quot;,\r\n          &quot;post_deploy&quot;: true\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;push-apps-manager&quot;,\r\n          &quot;post_deploy&quot;: true\r\n        }\r\n      ]\r\n    }\r\n\r\nYou can also use the `map` function (which I rarely remember how to use correctly, but it turns out is pretty simple here):\r\n\r\n    % jq &#39;{errands: map({name:., post_deploy: true})}&#39; names.json",
                "title": "Create one JSON from another, with extra data va JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1503536584,
                "creation_date": 1503536584,
                "answer_id": 45851396,
                "question_id": 45850452,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another approach.  If you are new to **jq** it may be easiest to work towards the goal in small steps.\r\n\r\n1) Start with the identity filter\r\n\r\n     .\r\n    \r\nwhich produces as expected\r\n     \r\n    [\r\n      &quot;smoke-tests&quot;,\r\n      &quot;push-apps-manager&quot;\r\n    ]\r\n    \r\n2) next add the outer object with the `&quot;errands&quot;` key:\r\n\r\n    { &quot;errands&quot;: . }\r\n\r\nwhich produces\r\n \r\n    {\r\n      &quot;errands&quot;: [\r\n        &quot;smoke-tests&quot;,\r\n        &quot;push-apps-manager&quot;\r\n      ]\r\n    }     \r\n\r\n3) next move the data into an array\r\n\r\n    { &quot;errands&quot;: [ . ] }\r\n\r\nwhich produces\r\n\r\n    {\r\n      &quot;errands&quot;: [\r\n        [\r\n          &quot;smoke-tests&quot;,\r\n          &quot;push-apps-manager&quot;\r\n        ]\r\n      ]\r\n    }\r\n    \r\n4) add the inner object with the `&quot;name&quot;` and `&quot;post_deploy&quot;` keys     \r\n\r\n    { &quot;errands&quot;: [ { &quot;name&quot;: ., &quot;post_deploy&quot;: true } ] }\r\n\r\nwhich produces\r\n\r\n    {\r\n      &quot;errands&quot;: [\r\n        {\r\n          &quot;name&quot;: [\r\n            &quot;smoke-tests&quot;,\r\n            &quot;push-apps-manager&quot;\r\n          ],\r\n          &quot;post_deploy&quot;: true\r\n        }\r\n      ]\r\n    }\r\n\r\n5) Now we&#39;re really close.  All we need to do is take advantage of **jq**&#39;s [Object Construction behavior when an expression produces multiple results](https://stedolan.github.io/jq/manual/#ObjectConstruction:{}) :\r\n\r\n    { &quot;errands&quot;: [ { &quot;name&quot;: .[], &quot;post_deploy&quot;: true } ] }\r\n\r\nwhich gives us the desired result\r\n\r\n    {\r\n      &quot;errands&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;smoke-tests&quot;,\r\n          &quot;post_deploy&quot;: true\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;push-apps-manager&quot;,\r\n          &quot;post_deploy&quot;: true\r\n        }\r\n      ]\r\n    }\r\n    \r\n",
                "title": "Create one JSON from another, with extra data va JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1503536584,
        "creation_date": 1503528612,
        "question_id": 45850452,
        "body_markdown": "I have this file:\r\n\r\n    [\r\n        &quot;smoke-tests&quot;,\r\n        &quot;push-apps-manager&quot;\r\n    ]\r\n\r\nI&#39;d like to get this output using JQ:\r\n\r\n    {\r\n      &quot;errands&quot;: [\r\n        {&quot;name&quot;: &quot;smoke-tests&quot;, &quot;post_deploy&quot;: true},\r\n        {&quot;name&quot;: &quot;push-apps-manager&quot;, &quot;post_deploy&quot;: true}\r\n      ]\r\n    }\r\n\r\nIt seems so simple, yet, I have so much difficulty here...",
        "link": "https://stackoverflow.com/questions/45850452/create-one-json-from-another-with-extra-data-va-jq",
        "title": "Create one JSON from another, with extra data va JQ"
    },
    {
        "tags": [
            "json",
            "regex",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1503945448,
                "last_edit_date": 1503945448,
                "creation_date": 1503943427,
                "answer_id": 45924920,
                "question_id": 45924263,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses [`with_entries`](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries) and [`match`](https://stedolan.github.io/jq/manual/#match(val),match(regex;flags)).\r\n\r\n    def condition:\r\n      .key|match(&quot;NodeLaunchConfig[a-zA-Z0-9_]+&quot;)\r\n    ;\r\n    {\r\n      Resources: .Resources | with_entries(select(condition))\r\n    }\r\n   \r\nIf you would rather not break out the condition into a separate function you can use\r\n\r\n    {\r\n      Resources: .Resources | with_entries(select(.key|match(&quot;NodeLaunchConfig[a-zA-Z0-9_]+&quot;)))\r\n    }\r\n\r\nDepending on your actual data this could be shorted a little with update assignment [`|=`](https://stedolan.github.io/jq/manual/#Update-assignment:|=) to just:\r\n\r\n    .Resources |= with_entries(select(.key|match(&quot;NodeLaunchConfig[a-zA-Z0-9_]+&quot;)))",
                "title": "How to select a json property using jq and regex?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1504027056,
        "creation_date": 1503940696,
        "last_edit_date": 1504027056,
        "question_id": 45924263,
        "body_markdown": "I have a `json` file like this one below:\r\n\r\n    {\r\n      &quot;Resources&quot;: {\r\n        &quot;NodeLaunchConfig123456789&quot;: {\r\n          ...\r\n        }\r\n      }\r\n    }\r\n\r\nHow can I select the property `NodeLaunchConfig123456789` using `jq` and a regex like `NodeLaunchConfig\\w+`?",
        "link": "https://stackoverflow.com/questions/45924263/how-to-select-a-json-property-using-jq-and-regex",
        "title": "How to select a json property using jq and regex?"
    },
    {
        "tags": [
            "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": 1504178988,
                "post_id": 45979477,
                "comment_id": 78919696,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1504176325,
                "creation_date": 1504176325,
                "answer_id": 45979559,
                "question_id": 45979477,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming the data is parsed and lives in `var data`:\r\n\r\n- first: `data.cruises[0].waypoint_cities[0]`\r\n- last: `data.cruises[0].waypoint_cities[data.cruises[0].waypoint_cities.length-1]`",
                "title": "Extract the first and the last value of a json array/object"
            },
            {
                "up_vote_count": 27,
                "is_accepted": false,
                "score": 27,
                "last_activity_date": 1504188083,
                "creation_date": 1504188083,
                "answer_id": 45983361,
                "question_id": 45979477,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "[0] returns the first element in an array; [-1] returns the last. (See the &quot;basic filters&quot; section of the manual.)\r\n\r\nFor the input given above\r\n\r\n    jq &#39;.[][][][0, -1]&#39;\r\n\r\nyields this output\r\n\r\n    &quot;Palma de Mallorca&quot;\r\n    &quot;Palma de Mallorca&quot;\r\n",
                "title": "Extract the first and the last value of a json array/object"
            },
            {
                "up_vote_count": 45,
                "is_accepted": true,
                "score": 45,
                "last_activity_date": 1504197145,
                "creation_date": 1504197145,
                "answer_id": 45986265,
                "question_id": 45979477,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using [first](https://stedolan.github.io/jq/manual/#first,last,nth(n)) and [last](https://stedolan.github.io/jq/manual/#first,last,nth(n))\r\n\r\n    .cruises[].waypoint_cities | first, last\r\n\r\nOutput\r\n\r\n    &quot;Palma de Mallorca&quot;\r\n    &quot;Palma de Mallorca&quot;",
                "title": "Extract the first and the last value of a json array/object"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 33,
        "last_activity_date": 1504197145,
        "creation_date": 1504176047,
        "question_id": 45979477,
        "body_markdown": "I use jq 1.5 in an windows 10 enviroment. I receive via api several information include different city arrays like that:\r\n\r\n  \r\n\r\n      {\r\n     \r\n      &quot;cruises&quot;: [\r\n        {\r\n         \r\n          &quot;waypoint_cities&quot;: [\r\n            &quot;Palma de Mallorca&quot;,\r\n            &quot;C&#225;diz&quot;,\r\n            &quot;Puerto del Rosario, Fuerteventura&quot;,\r\n            &quot;Arrecife, Lanzarote&quot;,\r\n            &quot;Arrecife, Lanzarote&quot;,\r\n            &quot;Agadir&quot;,\r\n            &quot;Gibraltar&quot;,\r\n            &quot;Barcelona&quot;,\r\n            &quot;Palma de Mallorca&quot;\r\n          ]}]}\r\n\r\nHow can i find the first and the last entry of those arrays with jq? I tried the function min/maxby but that function only delivers the entrys with the first and last in charakter of the Alphabet.\r\n\r\nregards\r\nTimo\r\n",
        "link": "https://stackoverflow.com/questions/45979477/extract-the-first-and-the-last-value-of-a-json-array-object",
        "title": "Extract the first and the last value of a json array/object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1504190740,
                "last_edit_date": 1504190740,
                "creation_date": 1504190094,
                "answer_id": 45984077,
                "question_id": 45982943,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`.services.service[]|[{name,timer:.timer[]}|[.name,.timer[]]]` will give you your expected output,\r\n\r\n`.services.service[]|{name,timer:.timer[]}|[.name,.timer[]]` (without array aggregation) will give you one result for each timer:\r\n\r\n    [&quot;Test Value&quot;,&quot;08/30/2017 16:33:35&quot;,&quot;625&quot;]\r\n    [&quot;Test Value&quot;,&quot;08/30/2017 16:22:38&quot;,&quot;240&quot;]\r\n    [&quot;Test Value 2&quot;,&quot;08/30/2017 16:07:38&quot;,&quot;432&quot;]\r\n    [&quot;Test Value 2&quot;,&quot;08/30/2017 15:59:07&quot;,&quot;1355&quot;]\r\n\r\nWhat you missed in your attempt is\r\n\r\n&gt; The expression exp as $x | ... means: for each value of expression exp, run the rest of the pipeline with the entire original input, and  with  $x  set  to that value. Thus as functions as something of a foreach loop.\r\n\r\nIf you really want to use variables you need to do it like this: `.services.service[]| .name as $name | .timer | map([ $name, .datetime, .value ])`",
                "title": "jq get each value in array with parent"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1504192366,
                "creation_date": 1504192366,
                "answer_id": 45984821,
                "question_id": 45982943,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I think it would be helpful to try and visualize it in terms of the levels your data is in, and where you want it to be in your result.  When flattening a hierarchy of data, I find it easier to think if it as taking values in one level, and combining it with the values from the next level.\r\n\r\nSo looking at the individual service objects, you want to take the name, and combine it with properties of its timer objects, and produce a results for each combination.  So start there:\r\n\r\n    [.name] + (properties of the timer objects)\r\n\r\nThen you need to generate the `properties of the timer objects`.\r\n\r\n    .timer[] | [.datetime, .value]\r\n\r\nYou can read this as: &quot;for each item in the `timer` array, create an array consisting of the `datetime` and `value` properties.&quot;\r\n\r\nOnce you get everything at the same level, you could rearrange the values if you wanted, but fortunately in our case, everything is where we want them.\r\n\r\nPut together, this expression produces individual arrays of the name, datetime, and values but you want to collect them in an array. So put them in.\r\n\r\n    [[.name] + (.timer[] | [.datetime, .value])]\r\n\r\nWhen you put it all together, you&#39;ll get your result.\r\n\r\n    .services.service[] | [[.name] + (.timer[] | [.datetime, .value])]",
                "title": "jq get each value in array with parent"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1504198073,
                "creation_date": 1504198073,
                "answer_id": 45986530,
                "question_id": 45982943,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another solution demonstrating array constructor variations.  Note the placement of the [ ] in each is slightly different. With your data, this filter\r\n\r\n     .services.service[] | {name} + .timer[]\r\n     \r\ngenerates a single stream of objects\r\n\r\n    {&quot;name&quot;:&quot;Test Value&quot;,&quot;datetime&quot;:&quot;08/30/2017 16:33:35&quot;,&quot;value&quot;:&quot;625&quot;}\r\n    {&quot;name&quot;:&quot;Test Value&quot;,&quot;datetime&quot;:&quot;08/30/2017 16:22:38&quot;,&quot;value&quot;:&quot;240&quot;}\r\n    {&quot;name&quot;:&quot;Test Value 2&quot;,&quot;datetime&quot;:&quot;08/30/2017 16:07:38&quot;,&quot;value&quot;:&quot;432&quot;}\r\n    {&quot;name&quot;:&quot;Test Value 2&quot;,&quot;datetime&quot;:&quot;08/30/2017 15:59:07&quot;,&quot;value&quot;:&quot;1355&quot;}\r\n\r\nthis filter\r\n\r\n     .services.service[] | [ {name} + .timer[] ]\r\n     \r\ngenerates arrays of objects for each service\r\n\r\n    [{&quot;name&quot;:&quot;Test Value&quot;,&quot;datetime&quot;:&quot;08/30/2017 16:33:35&quot;,&quot;value&quot;:&quot;625&quot;},{&quot;name&quot;:&quot;Test Value&quot;,&quot;datetime&quot;:&quot;08/30/2017 16:22:38&quot;,&quot;value&quot;:&quot;240&quot;}]\r\n    [{&quot;name&quot;:&quot;Test Value 2&quot;,&quot;datetime&quot;:&quot;08/30/2017 16:07:38&quot;,&quot;value&quot;:&quot;432&quot;},{&quot;name&quot;:&quot;Test Value 2&quot;,&quot;datetime&quot;:&quot;08/30/2017 15:59:07&quot;,&quot;value&quot;:&quot;1355&quot;}]\r\n\r\nthis filter\r\n\r\n     .services.service[] | {name} + .timer[] | [.[]]\r\n\r\ngenerates a stream of arrays\r\n\r\n    [&quot;Test Value&quot;,&quot;08/30/2017 16:33:35&quot;,&quot;625&quot;]\r\n    [&quot;Test Value&quot;,&quot;08/30/2017 16:22:38&quot;,&quot;240&quot;]\r\n    [&quot;Test Value 2&quot;,&quot;08/30/2017 16:07:38&quot;,&quot;432&quot;]\r\n    [&quot;Test Value 2&quot;,&quot;08/30/2017 15:59:07&quot;,&quot;1355&quot;]\r\n\r\nand this filter\r\n\r\n     .services.service[] | [ {name} + .timer[] | [.[]] ]\r\n     \r\ngenerates arrays of arrays for each service\r\n\r\n    [[&quot;Test Value&quot;,&quot;08/30/2017 16:33:35&quot;,&quot;625&quot;],[&quot;Test Value&quot;,&quot;08/30/2017 16:22:38&quot;,&quot;240&quot;]]\r\n    [[&quot;Test Value 2&quot;,&quot;08/30/2017 16:07:38&quot;,&quot;432&quot;],[&quot;Test Value 2&quot;,&quot;08/30/2017 15:59:07&quot;,&quot;1355&quot;]]",
                "title": "jq get each value in array with parent"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 10,
        "last_activity_date": 1504198073,
        "creation_date": 1504186872,
        "last_edit_date": 1504188885,
        "question_id": 45982943,
        "body_markdown": "I have json that looks like the below. I&#39;d like to get an output that contains one line for each timer record, but includes the name of the service.\r\n\r\n\r\n    {  \r\n       &quot;services&quot;:{  \r\n          &quot;service&quot;:[  \r\n             {  \r\n                &quot;name&quot;:&quot;Test Value&quot;,\r\n                &quot;timer&quot;:[  \r\n                   { &quot;datetime&quot;:&quot;08/30/2017 16:33:35&quot;, &quot;value&quot;:&quot;625&quot; },\r\n                   { &quot;datetime&quot;:&quot;08/30/2017 16:22:38&quot;, &quot;value&quot;:&quot;240&quot; }\r\n                ]\r\n             },\r\n             {\r\n                &quot;name&quot;:&quot;Test Value 2&quot;,\r\n                &quot;timer&quot;:[\r\n                   { &quot;datetime&quot;:&quot;08/30/2017 16:07:38&quot;, &quot;value&quot;:&quot;432&quot; },\r\n                   { &quot;datetime&quot;:&quot;08/30/2017 15:59:07&quot;, &quot;value&quot;:&quot;1355&quot; }\r\n                ]\r\n             }\r\n          ]\r\n       }\r\n    }\r\n\r\nI&#39;ve come up with `.services.service[].name as $name | .services.service[].timer | map([ $name, .datetime, .value ])`, which gets me \r\n\r\n    [[&quot;Test Value&quot;,&quot;08/30/2017 16:33:35&quot;,&quot;625&quot;],[&quot;Test Value&quot;,&quot;08/30/2017 16:22:38&quot;,&quot;240&quot;]]\r\n    [[&quot;Test Value&quot;,&quot;08/30/2017 16:07:38&quot;,&quot;432&quot;],[&quot;Test Value&quot;,&quot;08/30/2017 15:59:07&quot;,&quot;1355&quot;]]\r\n    [[&quot;Test Value 2&quot;,&quot;08/30/2017 16:33:35&quot;,&quot;625&quot;],[&quot;Test Value 2&quot;,&quot;08/30/2017 16:22:38&quot;,&quot;240&quot;]]\r\n    [[&quot;Test Value 2&quot;,&quot;08/30/2017 16:07:38&quot;,&quot;432&quot;],[&quot;Test Value 2&quot;,&quot;08/30/2017 15:59:07&quot;,&quot;1355&quot;]]\r\n\r\nThe output that I&#39;m expecting would be\r\n\r\n    [[&quot;Test Value&quot;,&quot;08/30/2017 16:33:35&quot;,&quot;625&quot;],[&quot;Test Value&quot;,&quot;08/30/2017 16:22:38&quot;,&quot;240&quot;]]\r\n    [[&quot;Test Value 2&quot;,&quot;08/30/2017 16:07:38&quot;,&quot;432&quot;],[&quot;Test Value 2&quot;,&quot;08/30/2017 15:59:07&quot;,&quot;1355&quot;]]\r\n\r\n\r\nBut notice that the values are duplicated for both services and sets of timers. What am I missing?\r\n",
        "link": "https://stackoverflow.com/questions/45982943/jq-get-each-value-in-array-with-parent",
        "title": "jq get each value in array with parent"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1504685836,
                "post_id": 46070012,
                "comment_id": 79100711,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 173557,
                    "reputation": 24077,
                    "user_id": 402322,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/GWEWt.gif?s=256",
                    "display_name": "ceving",
                    "link": "https://stackoverflow.com/users/402322/ceving"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1504696172,
                "post_id": 46070012,
                "comment_id": 79107899,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 76,
                "is_accepted": false,
                "score": 76,
                "last_activity_date": 1605688491,
                "last_edit_date": 1605688491,
                "creation_date": 1504686801,
                "answer_id": 46070413,
                "question_id": 46070012,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `select` filter of `jq`:\r\n\r\n    jq &#39;.zk_kafka | .[] | select(.InstanceType == &quot;t2.medium&quot;)&#39;\r\n\r\nUse the `--arg` option to pass an argument to the query to avoid injections.\r\n\r\n    jq --arg instance &quot;t2.medium&quot; &#39;.zk_kafka | .[] | select(.InstanceType == $instance)&#39;\r\n\r\n`jq` has a [manual][1], a [tutorial][2] and a [cookbook][3].\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/\r\n  [2]: https://stedolan.github.io/jq/tutorial/\r\n  [3]: https://github.com/stedolan/jq/wiki/Cookbook",
                "title": "How to filter an array of JSON objects with jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1653468346,
                "creation_date": 1653468346,
                "answer_id": 72374502,
                "question_id": 46070012,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Alternatively, you can also use `map()`:\r\n\r\n    jq &#39;.zk_kafka | map(select(.InstanceType == &quot;t2.medium&quot;))&#39; input.json",
                "title": "How to filter an array of JSON objects with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 47,
        "last_activity_date": 1653468346,
        "creation_date": 1504685534,
        "last_edit_date": 1504695745,
        "question_id": 46070012,
        "body_markdown": "I have the following JSON input:\r\n\r\n    {\r\n      &quot;zk_kafka&quot;: [\r\n        {\r\n          &quot;InstanceType&quot;: &quot;t2.medium&quot;,\r\n          &quot;zkMemory&quot;: &quot;16&quot;,\r\n          &quot;kafkaMemory&quot;: &quot;8&quot;\r\n        },\r\n        {\r\n          &quot;InstanceType&quot;: &quot;t2.small&quot;,\r\n          &quot;zkMemory&quot;: &quot;8&quot;,\r\n          &quot;kafkaMemory&quot;: &quot;4&quot;\r\n        }\r\n      ],\r\n      &quot;es_hdfs&quot;: [\r\n        {\r\n          &quot;InstanceType&quot;: &quot;t2.medium&quot;,\r\n          &quot;esMemory&quot;: &quot;16&quot;,\r\n          &quot;hdfsMemory&quot;: &quot;8&quot;\r\n        },\r\n        {\r\n          &quot;InstanceType&quot;: &quot;t2.small&quot;,\r\n          &quot;esMemory&quot;: &quot;8&quot;,\r\n          &quot;hdfsMemory&quot;: &quot;4&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nFirst I want to select an array by a property name. And then I want to select an object of the array by the value of the property `InstanceType`.\r\n\r\nExample for the property `zk_kafka` and the value `t2.medium`:\r\n\r\n    {\r\n      &quot;InstanceType&quot;: &quot;t2.medium&quot;,\r\n      &quot;zkMemory&quot;: &quot;16&quot;,\r\n      &quot;kafkaMemory&quot;: &quot;8&quot;\r\n    }\r\n\r\nI know how to select the array:\r\n\r\n    jq .zk_kafka\r\n\r\nBut I do not know how to filter the array of object by a property value.",
        "link": "https://stackoverflow.com/questions/46070012/how-to-filter-an-array-of-json-objects-with-jq",
        "title": "How to filter an array of JSON objects 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": 1,
                "creation_date": 1504705337,
                "post_id": 46076664,
                "comment_id": 79114843,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11705598,
                    "reputation": 1,
                    "user_id": 8569266,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6151a13498545a882a6e144a3cb29b28?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gryffus",
                    "link": "https://stackoverflow.com/users/8569266/gryffus"
                },
                "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": 1504708407,
                "post_id": 46076664,
                "comment_id": 79117174,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1504713507,
                "creation_date": 1504713507,
                "answer_id": 46079698,
                "question_id": 46076664,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "***jq*** solution:\r\n\r\nAssuming that the new values come as a string containing comma separated items. The variable `new_values` will contain those new values.\r\n \r\n\r\n    export new_values=&quot;736231,937213,297312,923723,913346,642354,844737,398301,943401,472312,483423,483324,432123,394610,473412,472311,956121,786052,879411,461223,123999,598111,865511,987917,576914,691044,765991,987152,979166,987111,283113,987999,112311,768123,687688,987123,212000,198623,897777,123111,387661,662111,190231,761900&quot;\r\n    \r\n    jq --arg new_vals &quot;$new_values&quot; &#39;.[] | if(.item.name == &quot;elementName&quot; and .operator == &quot;in&quot;)\r\n                       then .value |= ($new_vals | split(&quot;,&quot;)) else empty end&#39; input.json\r\n\r\nThe output:\r\n\r\n    {\r\n      &quot;item&quot;: {\r\n        &quot;name&quot;: &quot;elementName&quot;,\r\n        &quot;type&quot;: &quot;table&quot;,\r\n        &quot;displayName&quot;: &quot;Element name&quot;,\r\n        &quot;operators&quot;: [\r\n          &quot;in&quot;,\r\n          &quot;not in&quot;,\r\n          &quot;=&quot;,\r\n          &quot;&lt;&gt;&quot;,\r\n          &quot;like&quot;\r\n        ],\r\n        &quot;values&quot;: []\r\n      },\r\n      &quot;operator&quot;: &quot;in&quot;,\r\n      &quot;value&quot;: [\r\n        &quot;736231&quot;,\r\n        &quot;937213&quot;,\r\n        &quot;297312&quot;,\r\n        &quot;923723&quot;,\r\n        &quot;913346&quot;,\r\n        &quot;642354&quot;,\r\n        &quot;844737&quot;,\r\n        &quot;398301&quot;,\r\n        &quot;943401&quot;,\r\n        &quot;472312&quot;,\r\n        &quot;483423&quot;,\r\n        &quot;483324&quot;,\r\n        &quot;432123&quot;,\r\n        &quot;394610&quot;,\r\n        &quot;473412&quot;,\r\n        &quot;472311&quot;,\r\n        &quot;956121&quot;,\r\n        &quot;786052&quot;,\r\n        &quot;879411&quot;,\r\n        &quot;461223&quot;,\r\n        &quot;123999&quot;,\r\n        &quot;598111&quot;,\r\n        &quot;865511&quot;,\r\n        &quot;987917&quot;,\r\n        &quot;576914&quot;,\r\n        &quot;691044&quot;,\r\n        &quot;765991&quot;,\r\n        &quot;987152&quot;,\r\n        &quot;979166&quot;,\r\n        &quot;987111&quot;,\r\n        &quot;283113&quot;,\r\n        &quot;987999&quot;,\r\n        &quot;112311&quot;,\r\n        &quot;768123&quot;,\r\n        &quot;687688&quot;,\r\n        &quot;987123&quot;,\r\n        &quot;212000&quot;,\r\n        &quot;198623&quot;,\r\n        &quot;897777&quot;,\r\n        &quot;123111&quot;,\r\n        &quot;387661&quot;,\r\n        &quot;662111&quot;,\r\n        &quot;190231&quot;,\r\n        &quot;761900&quot;\r\n      ],\r\n      &quot;conjunction&quot;: &quot;or&quot;,\r\n      &quot;level&quot;: 2,\r\n      &quot;userFriendlyValue&quot;: [\r\n        &quot;NEHVN_3_NOIRSC3_1&quot;,\r\n        &quot;NGNHU_5_NGNHU_5_1&quot;,\r\n        &quot;NMVL381_NMDC381_1&quot;,\r\n        &quot;XGR_MA1_NMDC381_1&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;item&quot;: {\r\n        &quot;name&quot;: &quot;elementName&quot;,\r\n        &quot;type&quot;: &quot;table&quot;,\r\n        &quot;displayName&quot;: &quot;Element name&quot;,\r\n        &quot;operators&quot;: [\r\n          &quot;in&quot;,\r\n          &quot;not in&quot;,\r\n          &quot;=&quot;,\r\n          &quot;&lt;&gt;&quot;,\r\n          &quot;like&quot;\r\n        ],\r\n        &quot;values&quot;: []\r\n      },\r\n      &quot;operator&quot;: &quot;in&quot;,\r\n      &quot;value&quot;: [\r\n        &quot;736231&quot;,\r\n        &quot;937213&quot;,\r\n        &quot;297312&quot;,\r\n        &quot;923723&quot;,\r\n        &quot;913346&quot;,\r\n        &quot;642354&quot;,\r\n        &quot;844737&quot;,\r\n        &quot;398301&quot;,\r\n        &quot;943401&quot;,\r\n        &quot;472312&quot;,\r\n        &quot;483423&quot;,\r\n        &quot;483324&quot;,\r\n        &quot;432123&quot;,\r\n        &quot;394610&quot;,\r\n        &quot;473412&quot;,\r\n        &quot;472311&quot;,\r\n        &quot;956121&quot;,\r\n        &quot;786052&quot;,\r\n        &quot;879411&quot;,\r\n        &quot;461223&quot;,\r\n        &quot;123999&quot;,\r\n        &quot;598111&quot;,\r\n        &quot;865511&quot;,\r\n        &quot;987917&quot;,\r\n        &quot;576914&quot;,\r\n        &quot;691044&quot;,\r\n        &quot;765991&quot;,\r\n        &quot;987152&quot;,\r\n        &quot;979166&quot;,\r\n        &quot;987111&quot;,\r\n        &quot;283113&quot;,\r\n        &quot;987999&quot;,\r\n        &quot;112311&quot;,\r\n        &quot;768123&quot;,\r\n        &quot;687688&quot;,\r\n        &quot;987123&quot;,\r\n        &quot;212000&quot;,\r\n        &quot;198623&quot;,\r\n        &quot;897777&quot;,\r\n        &quot;123111&quot;,\r\n        &quot;387661&quot;,\r\n        &quot;662111&quot;,\r\n        &quot;190231&quot;,\r\n        &quot;761900&quot;\r\n      ],\r\n      &quot;conjunction&quot;: &quot;and&quot;,\r\n      &quot;level&quot;: 2,\r\n      &quot;userFriendlyValue&quot;: [\r\n        &quot;NBSL381_NBSL381_U&quot;,\r\n        &quot;NBSL381_NBSL381_V&quot;,\r\n        &quot;NBWK381_NBWK381_U&quot;,\r\n        &quot;NBWK381_NBWK381_W&quot;,\r\n        &quot;NBWK381_NBWK381_Y&quot;,\r\n        &quot;NCST381_NCST381_V&quot;,\r\n        &quot;NCST381_NCST381_X&quot;,\r\n        &quot;NCST381_NCST381_Z&quot;,\r\n        &quot;NDE1503_NDE1503_V&quot;,\r\n        &quot;NDIM381_NDIM381_V&quot;,\r\n        &quot;NDIM381_NDIM381_W&quot;,\r\n        &quot;NDIM381_NDIM381_X&quot;,\r\n        &quot;NDIM381_NDIM381_Y&quot;,\r\n        &quot;NDOD381_NDOD381_U&quot;,\r\n        &quot;NDOD381_NDOD381_W&quot;,\r\n        &quot;NDOD381_NDOD381_X&quot;,\r\n        &quot;NEHV381_NEHV381_W&quot;,\r\n        &quot;NEHV381_NEHV381_X&quot;,\r\n        &quot;NEHV381_NEHV381_Y&quot;,\r\n        &quot;NEHV381_NEHV381_Z&quot;,\r\n        &quot;NENS381_NENS381_T&quot;,\r\n        &quot;NENS381_NENS381_U&quot;,\r\n        &quot;NENS381_NENS381_W&quot;,\r\n        &quot;NHGL381_NHGL381_X&quot;,\r\n        &quot;NHGL381_NHGL381_Y&quot;,\r\n        &quot;NHGL381_NHGL381_Z&quot;,\r\n        &quot;NHSW222_NHSW222_X&quot;,\r\n        &quot;NHSW222_NHSW222_Y&quot;,\r\n        &quot;NHSW222_NHSW222_Z&quot;,\r\n        &quot;NKIJ381_NKIJ381_V&quot;,\r\n        &quot;NKIJ381_NKIJ381_Z&quot;,\r\n        &quot;NMBT381_NMBT381_U&quot;,\r\n        &quot;NMBT381_NMBT381_V&quot;,\r\n        &quot;NMBT381_NMBT381_W&quot;,\r\n        &quot;NMBT381_NMBT381_X&quot;,\r\n        &quot;NOZN381_NOZN381_W&quot;,\r\n        &quot;NOZN381_NOZN381_X&quot;,\r\n        &quot;NOZN381_NOZN381_Y&quot;,\r\n        &quot;NWL3801_NWL3801_X&quot;,\r\n        &quot;NWL3801_NWL3801_Y&quot;,\r\n        &quot;NWL3801_NWL3801_Z&quot;,\r\n        &quot;NWTR381_NWTR381_M&quot;,\r\n        &quot;NWTR381_NWTR381_N&quot;,\r\n        &quot;NWTR381_NWTR381_O&quot;\r\n      ]\r\n    }\r\n\r\n\r\n",
                "title": "Replace values in Json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1504717676,
                "creation_date": 1504717676,
                "answer_id": 46080855,
                "question_id": 46076664,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a general solution using [jq](https://stedolan.github.io/jq/) and the `--argfile` option.  First create a table of the replacements however you like.  e.g.\r\n\r\n    [\r\n      {\r\n        &quot;from&quot;: [&quot;NEHVN_3_NOIRSC3_1&quot;,&quot;NGNHU_5_NGNHU_5_1&quot;,&quot;NMVL381_NMDC381_1&quot;,&quot;XGR_MA1_NMDC381_1&quot;],\r\n        &quot;to&quot;:   [183213, 834924, 986312, 987312]\r\n      }\r\n    ]\r\n     \r\nIf this table is in the file `repl.json`, your data is in `data.json` and the following filter is in the file `filter.jq`\r\n\r\n      $replacements[] as $r\r\n    | map(if .value==$r.from then .value=$r.to else . end)\r\n\r\nthen the command\r\n\r\n    $ jq -M --argfile replacements repl.json -f filter.jq data.json\r\n\r\nwill produce the output with the substituted values.\r\n",
                "title": "Replace values in Json"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1504722644,
        "creation_date": 1504704746,
        "last_edit_date": 1504722644,
        "question_id": 46076664,
        "body_markdown": "I have the following JSON data:\r\n\r\n    [\r\n      {\r\n        &quot;item&quot;: {\r\n          &quot;name&quot;: &quot;tso&quot;,\r\n          &quot;type&quot;: &quot;table&quot;,\r\n          &quot;displayName&quot;: &quot;TSO&quot;,\r\n          &quot;operators&quot;: [\r\n            &quot;in&quot;,\r\n            &quot;not in&quot;,\r\n            &quot;=&quot;,\r\n            &quot;&lt;&gt;&quot;\r\n          ],\r\n          &quot;values&quot;: []\r\n        },\r\n        &quot;operator&quot;: &quot;in&quot;,\r\n        &quot;value&quot;: [\r\n          &quot;NL&quot;\r\n        ],\r\n        &quot;conjunction&quot;: &quot; &quot;,\r\n        &quot;level&quot;: 0,\r\n        &quot;userFriendlyValue&quot;: [\r\n          &quot;TENNET_NL&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;item&quot;: {\r\n          &quot;name&quot;: &quot;elementType&quot;,\r\n          &quot;type&quot;: &quot;select&quot;,\r\n          &quot;displayName&quot;: &quot;Element type&quot;,\r\n          &quot;operators&quot;: [\r\n            &quot;=&quot;,\r\n            &quot;&lt;&gt;&quot;\r\n          ],\r\n          &quot;values&quot;: [\r\n            &quot;line&quot;,\r\n            &quot;trafo&quot;\r\n          ]\r\n        },\r\n        &quot;operator&quot;: &quot;=&quot;,\r\n        &quot;value&quot;: &quot;line&quot;,\r\n        &quot;conjunction&quot;: &quot;and&quot;,\r\n        &quot;level&quot;: 1,\r\n        &quot;userFriendlyValue&quot;: null\r\n      },\r\n      {\r\n        &quot;item&quot;: {\r\n          &quot;name&quot;: &quot;optionalName&quot;,\r\n          &quot;type&quot;: &quot;table&quot;,\r\n          &quot;displayName&quot;: &quot;Element optional name&quot;,\r\n          &quot;operators&quot;: [\r\n            &quot;in&quot;,\r\n            &quot;not in&quot;,\r\n            &quot;=&quot;,\r\n            &quot;&lt;&gt;&quot;,\r\n            &quot;like&quot;\r\n          ],\r\n          &quot;values&quot;: []\r\n        },\r\n        &quot;operator&quot;: &quot;like&quot;,\r\n        &quot;value&quot;: &quot;*110*&quot;,\r\n        &quot;conjunction&quot;: &quot;and&quot;,\r\n        &quot;level&quot;: 2,\r\n        &quot;userFriendlyValue&quot;: null\r\n      },\r\n      {\r\n        &quot;item&quot;: {\r\n          &quot;name&quot;: &quot;optionalName&quot;,\r\n          &quot;type&quot;: &quot;table&quot;,\r\n          &quot;displayName&quot;: &quot;Element optional name&quot;,\r\n          &quot;operators&quot;: [\r\n            &quot;in&quot;,\r\n            &quot;not in&quot;,\r\n            &quot;=&quot;,\r\n            &quot;&lt;&gt;&quot;,\r\n            &quot;like&quot;\r\n          ],\r\n          &quot;values&quot;: []\r\n        },\r\n        &quot;operator&quot;: &quot;like&quot;,\r\n        &quot;value&quot;: &quot;*150*&quot;,\r\n        &quot;conjunction&quot;: &quot;or&quot;,\r\n        &quot;level&quot;: 2,\r\n        &quot;userFriendlyValue&quot;: null\r\n      },\r\n      {\r\n        &quot;item&quot;: {\r\n          &quot;name&quot;: &quot;optionalName&quot;,\r\n          &quot;type&quot;: &quot;table&quot;,\r\n          &quot;displayName&quot;: &quot;Element optional name&quot;,\r\n          &quot;operators&quot;: [\r\n            &quot;in&quot;,\r\n            &quot;not in&quot;,\r\n            &quot;=&quot;,\r\n            &quot;&lt;&gt;&quot;,\r\n            &quot;like&quot;\r\n          ],\r\n          &quot;values&quot;: []\r\n        },\r\n        &quot;operator&quot;: &quot;like&quot;,\r\n        &quot;value&quot;: &quot;KV_VS&quot;,\r\n        &quot;conjunction&quot;: &quot;or&quot;,\r\n        &quot;level&quot;: 2,\r\n        &quot;userFriendlyValue&quot;: null\r\n      },\r\n      {\r\n        &quot;item&quot;: {\r\n          &quot;name&quot;: &quot;elementName&quot;,\r\n          &quot;type&quot;: &quot;table&quot;,\r\n          &quot;displayName&quot;: &quot;Element name&quot;,\r\n          &quot;operators&quot;: [\r\n            &quot;in&quot;,\r\n            &quot;not in&quot;,\r\n            &quot;=&quot;,\r\n            &quot;&lt;&gt;&quot;,\r\n            &quot;like&quot;\r\n          ],\r\n          &quot;values&quot;: []\r\n        },\r\n        &quot;operator&quot;: &quot;like&quot;,\r\n        &quot;value&quot;: &quot;*15*&quot;,\r\n        &quot;conjunction&quot;: &quot;or&quot;,\r\n        &quot;level&quot;: 2,\r\n        &quot;userFriendlyValue&quot;: null\r\n      },\r\n      {\r\n        &quot;item&quot;: {\r\n          &quot;name&quot;: &quot;elementName&quot;,\r\n          &quot;type&quot;: &quot;table&quot;,\r\n          &quot;displayName&quot;: &quot;Element name&quot;,\r\n          &quot;operators&quot;: [\r\n            &quot;in&quot;,\r\n            &quot;not in&quot;,\r\n            &quot;=&quot;,\r\n            &quot;&lt;&gt;&quot;,\r\n            &quot;like&quot;\r\n          ],\r\n          &quot;values&quot;: []\r\n        },\r\n        &quot;operator&quot;: &quot;like&quot;,\r\n        &quot;value&quot;: &quot;*11*&quot;,\r\n        &quot;conjunction&quot;: &quot;or&quot;,\r\n        &quot;level&quot;: 2,\r\n        &quot;userFriendlyValue&quot;: null\r\n      },\r\n      {\r\n        &quot;item&quot;: {\r\n          &quot;name&quot;: &quot;elementName&quot;,\r\n          &quot;type&quot;: &quot;table&quot;,\r\n          &quot;displayName&quot;: &quot;Element name&quot;,\r\n          &quot;operators&quot;: [\r\n            &quot;in&quot;,\r\n            &quot;not in&quot;,\r\n            &quot;=&quot;,\r\n            &quot;&lt;&gt;&quot;,\r\n            &quot;like&quot;\r\n          ],\r\n          &quot;values&quot;: []\r\n        },\r\n        &quot;operator&quot;: &quot;in&quot;,\r\n        &quot;value&quot;: [\r\n          &quot;NEHVN_3_NOIRSC3_1&quot;,\r\n          &quot;NGNHU_5_NGNHU_5_1&quot;,\r\n          &quot;NMVL381_NMDC381_1&quot;,\r\n          &quot;XGR_MA1_NMDC381_1&quot;\r\n        ],\r\n        &quot;conjunction&quot;: &quot;or&quot;,\r\n        &quot;level&quot;: 2,\r\n        &quot;userFriendlyValue&quot;: [\r\n          &quot;NEHVN_3_NOIRSC3_1&quot;,\r\n          &quot;NGNHU_5_NGNHU_5_1&quot;,\r\n          &quot;NMVL381_NMDC381_1&quot;,\r\n          &quot;XGR_MA1_NMDC381_1&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;item&quot;: {\r\n          &quot;name&quot;: &quot;elementType&quot;,\r\n          &quot;type&quot;: &quot;select&quot;,\r\n          &quot;displayName&quot;: &quot;Element type&quot;,\r\n          &quot;operators&quot;: [\r\n            &quot;=&quot;,\r\n            &quot;&lt;&gt;&quot;\r\n          ],\r\n          &quot;values&quot;: [\r\n            &quot;line&quot;,\r\n            &quot;trafo&quot;\r\n          ]\r\n        },\r\n        &quot;operator&quot;: &quot;=&quot;,\r\n        &quot;value&quot;: &quot;trafo&quot;,\r\n        &quot;conjunction&quot;: &quot;or&quot;,\r\n        &quot;level&quot;: 1,\r\n        &quot;userFriendlyValue&quot;: null\r\n      },\r\n      {\r\n        &quot;item&quot;: {\r\n          &quot;name&quot;: &quot;elementName&quot;,\r\n          &quot;type&quot;: &quot;table&quot;,\r\n          &quot;displayName&quot;: &quot;Element name&quot;,\r\n          &quot;operators&quot;: [\r\n            &quot;in&quot;,\r\n            &quot;not in&quot;,\r\n            &quot;=&quot;,\r\n            &quot;&lt;&gt;&quot;,\r\n            &quot;like&quot;\r\n          ],\r\n          &quot;values&quot;: []\r\n        },\r\n        &quot;operator&quot;: &quot;in&quot;,\r\n        &quot;value&quot;: [\r\n          &quot;NBSL381_NBSL381_U&quot;,\r\n          &quot;NBSL381_NBSL381_V&quot;,\r\n          &quot;NBWK381_NBWK381_U&quot;,\r\n          &quot;NBWK381_NBWK381_W&quot;,\r\n          &quot;NBWK381_NBWK381_Y&quot;,\r\n          &quot;NCST381_NCST381_V&quot;,\r\n          &quot;NCST381_NCST381_X&quot;,\r\n          &quot;NCST381_NCST381_Z&quot;,\r\n          &quot;NDE1503_NDE1503_V&quot;,\r\n          &quot;NDIM381_NDIM381_V&quot;,\r\n          &quot;NDIM381_NDIM381_W&quot;,\r\n          &quot;NDIM381_NDIM381_X&quot;,\r\n          &quot;NDIM381_NDIM381_Y&quot;,\r\n          &quot;NDOD381_NDOD381_U&quot;,\r\n          &quot;NDOD381_NDOD381_W&quot;,\r\n          &quot;NDOD381_NDOD381_X&quot;,\r\n          &quot;NEHV381_NEHV381_W&quot;,\r\n          &quot;NEHV381_NEHV381_X&quot;,\r\n          &quot;NEHV381_NEHV381_Y&quot;,\r\n          &quot;NEHV381_NEHV381_Z&quot;,\r\n          &quot;NENS381_NENS381_T&quot;,\r\n          &quot;NENS381_NENS381_U&quot;,\r\n          &quot;NENS381_NENS381_W&quot;,\r\n          &quot;NHGL381_NHGL381_X&quot;,\r\n          &quot;NHGL381_NHGL381_Y&quot;,\r\n          &quot;NHGL381_NHGL381_Z&quot;,\r\n          &quot;NHSW222_NHSW222_X&quot;,\r\n          &quot;NHSW222_NHSW222_Y&quot;,\r\n          &quot;NHSW222_NHSW222_Z&quot;,\r\n          &quot;NKIJ381_NKIJ381_V&quot;,\r\n          &quot;NKIJ381_NKIJ381_Z&quot;,\r\n          &quot;NMBT381_NMBT381_U&quot;,\r\n          &quot;NMBT381_NMBT381_V&quot;,\r\n          &quot;NMBT381_NMBT381_W&quot;,\r\n          &quot;NMBT381_NMBT381_X&quot;,\r\n          &quot;NOZN381_NOZN381_W&quot;,\r\n          &quot;NOZN381_NOZN381_X&quot;,\r\n          &quot;NOZN381_NOZN381_Y&quot;,\r\n          &quot;NWL3801_NWL3801_X&quot;,\r\n          &quot;NWL3801_NWL3801_Y&quot;,\r\n          &quot;NWL3801_NWL3801_Z&quot;,\r\n          &quot;NWTR381_NWTR381_M&quot;,\r\n          &quot;NWTR381_NWTR381_N&quot;,\r\n          &quot;NWTR381_NWTR381_O&quot;\r\n        ],\r\n        &quot;conjunction&quot;: &quot;and&quot;,\r\n        &quot;level&quot;: 2,\r\n        &quot;userFriendlyValue&quot;: [\r\n          &quot;NBSL381_NBSL381_U&quot;,\r\n          &quot;NBSL381_NBSL381_V&quot;,\r\n          &quot;NBWK381_NBWK381_U&quot;,\r\n          &quot;NBWK381_NBWK381_W&quot;,\r\n          &quot;NBWK381_NBWK381_Y&quot;,\r\n          &quot;NCST381_NCST381_V&quot;,\r\n          &quot;NCST381_NCST381_X&quot;,\r\n          &quot;NCST381_NCST381_Z&quot;,\r\n          &quot;NDE1503_NDE1503_V&quot;,\r\n          &quot;NDIM381_NDIM381_V&quot;,\r\n          &quot;NDIM381_NDIM381_W&quot;,\r\n          &quot;NDIM381_NDIM381_X&quot;,\r\n          &quot;NDIM381_NDIM381_Y&quot;,\r\n          &quot;NDOD381_NDOD381_U&quot;,\r\n          &quot;NDOD381_NDOD381_W&quot;,\r\n          &quot;NDOD381_NDOD381_X&quot;,\r\n          &quot;NEHV381_NEHV381_W&quot;,\r\n          &quot;NEHV381_NEHV381_X&quot;,\r\n          &quot;NEHV381_NEHV381_Y&quot;,\r\n          &quot;NEHV381_NEHV381_Z&quot;,\r\n          &quot;NENS381_NENS381_T&quot;,\r\n          &quot;NENS381_NENS381_U&quot;,\r\n          &quot;NENS381_NENS381_W&quot;,\r\n          &quot;NHGL381_NHGL381_X&quot;,\r\n          &quot;NHGL381_NHGL381_Y&quot;,\r\n          &quot;NHGL381_NHGL381_Z&quot;,\r\n          &quot;NHSW222_NHSW222_X&quot;,\r\n          &quot;NHSW222_NHSW222_Y&quot;,\r\n          &quot;NHSW222_NHSW222_Z&quot;,\r\n          &quot;NKIJ381_NKIJ381_V&quot;,\r\n          &quot;NKIJ381_NKIJ381_Z&quot;,\r\n          &quot;NMBT381_NMBT381_U&quot;,\r\n          &quot;NMBT381_NMBT381_V&quot;,\r\n          &quot;NMBT381_NMBT381_W&quot;,\r\n          &quot;NMBT381_NMBT381_X&quot;,\r\n          &quot;NOZN381_NOZN381_W&quot;,\r\n          &quot;NOZN381_NOZN381_X&quot;,\r\n          &quot;NOZN381_NOZN381_Y&quot;,\r\n          &quot;NWL3801_NWL3801_X&quot;,\r\n          &quot;NWL3801_NWL3801_Y&quot;,\r\n          &quot;NWL3801_NWL3801_Z&quot;,\r\n          &quot;NWTR381_NWTR381_M&quot;,\r\n          &quot;NWTR381_NWTR381_N&quot;,\r\n          &quot;NWTR381_NWTR381_O&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nI would like to replace the contents of some of the &quot;value&quot; keys with data from a mysql query that takes the former value as argument.\r\n\r\nFor example, in the case of this object\r\n\r\n      {\r\n        &quot;item&quot;: {\r\n          &quot;name&quot;: &quot;elementName&quot;,\r\n          &quot;type&quot;: &quot;table&quot;,\r\n          &quot;displayName&quot;: &quot;Element name&quot;,\r\n          &quot;operators&quot;: [\r\n            &quot;in&quot;,\r\n            &quot;not in&quot;,\r\n            &quot;=&quot;,\r\n            &quot;&lt;&gt;&quot;,\r\n            &quot;like&quot;\r\n          ],\r\n          &quot;values&quot;: []\r\n        },\r\n        &quot;operator&quot;: &quot;in&quot;,\r\n        &quot;value&quot;: [\r\n          &quot;NEHVN_3_NOIRSC3_1&quot;,\r\n          &quot;NGNHU_5_NGNHU_5_1&quot;,\r\n          &quot;NMVL381_NMDC381_1&quot;,\r\n          &quot;XGR_MA1_NMDC381_1&quot;\r\n        ],\r\n        &quot;conjunction&quot;: &quot;or&quot;,\r\n        &quot;level&quot;: 2,\r\n        &quot;userFriendlyValue&quot;: [\r\n          &quot;NEHVN_3_NOIRSC3_1&quot;,\r\n          &quot;NGNHU_5_NGNHU_5_1&quot;,\r\n          &quot;NMVL381_NMDC381_1&quot;,\r\n          &quot;XGR_MA1_NMDC381_1&quot;\r\n        ]\r\n      },\r\n\r\nif the mysql query returned\r\n\r\n          183213,\r\n          834924,\r\n          986312,\r\n          987312\r\n\r\nthe object would become\r\n\r\n      {\r\n        &quot;item&quot;: {\r\n          &quot;name&quot;: &quot;elementName&quot;,\r\n          &quot;type&quot;: &quot;table&quot;,\r\n          &quot;displayName&quot;: &quot;Element name&quot;,\r\n          &quot;operators&quot;: [\r\n            &quot;in&quot;,\r\n            &quot;not in&quot;,\r\n            &quot;=&quot;,\r\n            &quot;&lt;&gt;&quot;,\r\n            &quot;like&quot;\r\n          ],\r\n          &quot;values&quot;: []\r\n        },\r\n        &quot;operator&quot;: &quot;in&quot;,\r\n        &quot;value&quot;: [\r\n          183213,\r\n          834924,\r\n          986312,\r\n          987312\r\n        ],\r\n        &quot;conjunction&quot;: &quot;or&quot;,\r\n        &quot;level&quot;: 2,\r\n        &quot;userFriendlyValue&quot;: [\r\n          &quot;NEHVN_3_NOIRSC3_1&quot;,\r\n          &quot;NGNHU_5_NGNHU_5_1&quot;,\r\n          &quot;NMVL381_NMDC381_1&quot;,\r\n          &quot;XGR_MA1_NMDC381_1&quot;\r\n        ]\r\n      },\r\n\r\nI was planning to loop over the first array with jq&#39;s &quot;.[0]&quot; &quot;.[1]&quot; and concatenate resulting json in the loop.\r\n\r\nIs there some more clever or generally better way? I can see jq has loops but I was not successful using them.\r\n",
        "link": "https://stackoverflow.com/questions/46076664/replace-values-in-json",
        "title": "Replace values in Json"
    },
    {
        "tags": [
            "json",
            "sed",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1504803956,
                "creation_date": 1504803956,
                "answer_id": 46101797,
                "question_id": 46100997,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`jq` is designed to work with json data. Your input is **not** pure json. If you can make certain assumptions about your input, then you can _probably_ process the json parts. Any deviation in any of the inputs will break things.\r\n\r\n1. **the pipe (`|`) is only used as a delimiter throughout the file, kind of like a &quot;pipe separated values&quot; file (a la csv but with no escape sequences)**  \r\n_jq can consume raw files as strings, if pipes are really only used as delimiters, we don&#39;t have to worry about parsing it_\r\n2. **data in the file does not span multiple rows and only occupies a single row**  \r\n_without parsing the data or assuming any patterns in the file, it will be impossible to know which lines belong to a single item and when a new one starts_\r\n3. **your json data will always be found in a fixed column of the psv row**  \r\n_again, it will be impossible to know where the request or response parts are in the row if it isn&#39;t in fixed places without further processing_\r\n\r\nIf these assumptions hold true, you could probably use something like this:\r\n\r\n    $ jq -R &#39;split(&quot;|&quot;) | {request:.[5]|fromjson,response:.[6]|fromjson}&#39; input.psv\r\n\r\nThis should give you objects with which you could access the request and response objects. Then you can operate on these.",
                "title": "jq remove text before and after json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1504806970,
                "last_edit_date": 1504806970,
                "creation_date": 1504806555,
                "answer_id": 46102393,
                "question_id": 46100997,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "While [Jeff&#39;s answer](https://stackoverflow.com/a/46101797/8379597) pretty much sums it up, here&#39;s a specific example assembled from the sample data fragments. If the file `data` contains\r\n\r\n    Sep  1 15:52:26 | IdentityValidationApi |  |  |  | {&quot;header&quot;:{&quot;tenantId&quot;:&quot;X03LHWE3&quot;}, &quot;serverTime&quot;:&quot;2017-09-01T19:52:24.641Z&quot;} | {&quot;responseHeader&quot;:{&quot;tenantID&quot;: &quot;...&quot;, &quot;fieldValue&quot;:&quot;Engineer&quot;}} | D2C CrossCore Request-Response | IdentityValidationApi.corp-dev.com | /api/Inquiry | 172.30.68.88 |  | True\r\n\r\nthen \r\n\r\n    $ jq -M -Rc &#39;./&quot;|&quot; | .[5] | fromjson&#39; data\r\n\r\nwill produce just the json fragment from column 5:\r\n\r\n    {&quot;header&quot;:{&quot;tenantId&quot;:&quot;X03LHWE3&quot;},&quot;serverTime&quot;:&quot;2017-09-01T19:52:24.641Z&quot;}\r\n\r\nThis filter\r\n\r\n    $ jq -M -Rc &#39;./&quot;|&quot; | (.[5]|fromjson) + (.[6]|fromjson)&#39; data\r\n\r\nwill combine the objects in columns 5 and 6 into one object:\r\n\r\n    {&quot;header&quot;:{&quot;tenantId&quot;:&quot;X03LHWE3&quot;},&quot;serverTime&quot;:&quot;2017-09-01T19:52:24.641Z&quot;,&quot;responseHeader&quot;:{&quot;tenantID&quot;:&quot;...&quot;,&quot;fieldValue&quot;:&quot;Engineer&quot;}}",
                "title": "jq remove text before and after json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1504806970,
        "creation_date": 1504800941,
        "question_id": 46100997,
        "body_markdown": "Ingesting another sourcetype that provides insane json output. It starts out like: \r\n \r\n    Sep  1 15:52:26 | IdentityValidationApi |  |  |  | {&quot;header&quot;:{&quot;tenantId&quot;:&quot;X03LHWE3&quot;,&quot;requestType&quot;:&quot;  ...\r\n\r\nand has a pipe in between the request and the response, but both are on the same line:\r\n\r\n    ...&quot;serverTime&quot;:&quot;2017-09-01T19:52:24.641Z&quot;}}} | {&quot;responseHeader&quot;:{&quot;tenantID&quot;:  \r\n\r\nand the json output ends with \r\n\r\n    ...,&quot;fieldValue&quot;:&quot;Engineer&quot;}]}}} | D2C CrossCore Request-Response | IdentityValidationApi.corp-dev.com | /api/Inquiry | 172.30.68.88 |  | True\r\n    \r\nI&#39;ve tried jq, using jq .header[], but it hates that | in the middle of the event. End goal is to ingest the entire event into Splunk without the beginning or end text outside the json. Can someone suggest any steps here?  Thank you.\r\n\r\nEdit: I can use sed to pull out the beginning of the line, but am unsure how to combine that with removing the text from the end. Can I do that?",
        "link": "https://stackoverflow.com/questions/46100997/jq-remove-text-before-and-after-json",
        "title": "jq remove text before and after json"
    },
    {
        "tags": [
            "arrays",
            "json",
            "csv",
            "unix",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1504880999,
                "creation_date": 1504880999,
                "answer_id": 46118824,
                "question_id": 46117049,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I would pass it to ***awk*** via pipeline:\r\n\r\n    jq -r &#39;[&quot;Name&quot;,&quot;Description&quot;,&quot;Result&quot;],(.hits.hits[]._source |\r\n           [.acb.item.name,.acb.item.description,.value])|@csv&#39; yourfile | \r\n           awk &#39;BEGIN{ FS=OFS=&quot;,&quot; }NR&gt;1{ $3=sprintf(&quot;%.2f&quot;,$3) }1&#39;\r\nThe output:\r\n\r\n    &quot;Name&quot;,&quot;Description&quot;,&quot;Result&quot;\r\n    &quot;Account Average Latency&quot;,&quot;Generate of last month&quot;,210.09\r\n    &quot;Profile Average Latency&quot;,&quot;Profile average latency of last month&quot;,370.21\r\n\r\n",
                "title": "How I can round digit on the last column to 2 decimal after a dot using JQ?"
            },
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 15,
                "last_activity_date": 1504888433,
                "last_edit_date": 1504888433,
                "creation_date": 1504884865,
                "answer_id": 46119984,
                "question_id": 46117049,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Depending on your build of jq, you may have access to some [cstdlib math functions](https://stedolan.github.io/jq/manual/#Math) (e.g., `sin` or `cos`). Since you&#39;re on *nix, you very likely do. In my particular build, I don&#39;t seem to have access to [`round`](https://linux.die.net/man/3/round) but perhaps you do.\r\n\r\n    def roundit: .*100.0|round/100.0;\r\n    [&quot;Name&quot;,&quot;Description&quot;,&quot;Result&quot;],\r\n    (.hits.hits[]._source | [.acb.item.name, .acb.item.description, (.value|roundit)])\r\n        | @csv\r\n\r\nFortunately, it could be implemented in terms of `floor` which I do have access to.\r\n\r\n    def roundit: .*100.0 + 0.5|floor/100.0;",
                "title": "How I can round digit on the last column to 2 decimal after a dot using JQ?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1504890893,
                "creation_date": 1504890893,
                "answer_id": 46121578,
                "question_id": 46117049,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is your current filter with minor reformatting:\r\n\r\n      [&quot;Name&quot;, &quot;Description&quot;, &quot;Result&quot;]\r\n    , (   .hits.hits[]._source\r\n        | [.acb.item.name, .acb.item.description, .value]\r\n      )\r\n    | @csv\r\n \r\nHere is a filter which rounds the value column.  Note we do this after the `@csv` so that we have full control over the string\r\n\r\n    def round:                                                # e.g.\r\n        (split(&quot;.&quot;) + [&quot;0&quot;])[:2]                              # [&quot;210&quot;,&quot;08691986891395&quot;]\r\n      | &quot;\\(.[1])000&quot;[:3] as $x | [.[0], $x[:2], $x[2:3]]      # [&quot;210&quot;,&quot;08&quot;,&quot;6&quot;]\r\n      | map(tonumber)                                         # [210,8,6]\r\n      | if .[2] &gt;  4 then .[2] = 0 | .[1] += 1 else . end     # [210,9,0]\r\n      | if .[1] &gt; 99 then .[1] = 0 | .[0] += 1 else . end     # [210,9,0]\r\n      | [&quot;\\(.[0])&quot;, &quot;00\\(.[1])&quot;[-2:]]                         # [&quot;210&quot;,&quot;09&quot;]\r\n      | join(&quot;.&quot;)                                             # 210.09\r\n    ;\r\n\r\n      (   [&quot;Name&quot;, &quot;Description&quot;, &quot;Result&quot;] | @csv )\r\n    , (   .hits.hits[]._source\r\n        | [.acb.item.name, .acb.item.description, .value]\r\n        | @csv\r\n\t    | split(&quot;,&quot;) | .[-1] |= round | join(&quot;,&quot;)\r\n      )\r\n\r\nIf this filter is in `filter.jq` and the sample data is in `data.json` then the command\r\n\r\n    $ jq -Mr -f filter.jq data.json\r\n\r\nproduces\r\n\r\n    &quot;Name&quot;,&quot;Description&quot;,&quot;Result&quot;\r\n    &quot;Account Average Latency&quot;,&quot;Generate of last month&quot;,210.09\r\n    &quot;Profile Average Latency&quot;,&quot;Profile average latency of last month&quot;,370.21",
                "title": "How I can round digit on the last column to 2 decimal after a dot using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 13,
        "last_activity_date": 1504890893,
        "creation_date": 1504875223,
        "last_edit_date": 1504884001,
        "question_id": 46117049,
        "body_markdown": "How I round digit on the last column to 2 decimal places?\r\n\r\nI have json:\r\n\r\n    {\r\n      &quot;took&quot;: 1,\r\n      &quot;timed_out&quot;: false,\r\n      &quot;_shards&quot;: {\r\n        &quot;total&quot;: 9,\r\n        &quot;successful&quot;: 9,\r\n        &quot;failed&quot;: 0\r\n      },\r\n      &quot;hits&quot;: {\r\n        &quot;total&quot;: 2,\r\n        &quot;max_score&quot;: 2.575364,\r\n        &quot;hits&quot;: [\r\n          {\r\n            &quot;_index&quot;: &quot;my-2017-08&quot;,\r\n            &quot;_type&quot;: &quot;log&quot;,\r\n            &quot;_id&quot;: &quot;AV5V8l0oDDWj-VP3YnCw&quot;,\r\n            &quot;_score&quot;: 2.575364,\r\n            &quot;_source&quot;: {\r\n              &quot;acb&quot;: {\r\n                &quot;version&quot;: 1,\r\n                &quot;id&quot;: &quot;7&quot;,\r\n                &quot;owner&quot;: &quot;pc&quot;,\r\n                &quot;item&quot;: {\r\n                  &quot;name&quot;: &quot;Account Average Latency&quot;,\r\n                  &quot;short_name&quot;: &quot;Generate&quot;,\r\n                  &quot;description&quot;: &quot;Generate of last month&quot;\r\n                },\r\n                &quot;service&quot;: &quot;gsm&quot;\r\n              },\r\n              &quot;@timestamp&quot;: &quot;2017-07-31T22:00:00.000Z&quot;,\r\n              &quot;value&quot;: 210.08691986891395\r\n            }\r\n          },\r\n          {\r\n            &quot;_index&quot;: &quot;my-2017-08&quot;,\r\n            &quot;_type&quot;: &quot;log&quot;,\r\n            &quot;_id&quot;: &quot;AV5V8lbE28ShqBNuBl60&quot;,\r\n            &quot;_score&quot;: 2.575364,\r\n            &quot;_source&quot;: {\r\n              &quot;acb&quot;: {\r\n                &quot;version&quot;: 1,\r\n                &quot;id&quot;: &quot;5&quot;,\r\n                &quot;owner&quot;: &quot;pc&quot;,\r\n                &quot;item&quot;: {\r\n                  &quot;name&quot;: &quot;Profile Average Latency&quot;,\r\n                  &quot;short_name&quot;: &quot;Profile&quot;,\r\n                  &quot;description&quot;: &quot;Profile average latency of last month&quot;\r\n                },\r\n                &quot;service&quot;: &quot;gsm&quot;\r\n              },\r\n              &quot;@timestamp&quot;: &quot;2017-07-31T22:00:00.000Z&quot;,\r\n              &quot;value&quot;: 370.20963260148716\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nI use JQ to get csv data:\r\n\r\n    [&quot;Name&quot;,&quot;Description&quot;,&quot;Result&quot;],(.hits.hits[]._source | [.acb.item.name,.acb.item.description,.value])|@csv\r\n\r\nI see result:\r\n\r\n    &quot;Name&quot;,&quot;Description&quot;,&quot;Result&quot;\r\n    &quot;Account Average Latency&quot;,&quot;Generate of last month&quot;,210.08691986891395\r\n    &quot;Profile Average Latency&quot;,&quot;Profile average latency of last month&quot;,370.20963260148716\r\n\r\nI have *210.08691986891395* and *370.20963260148716* but I want **210.09** and **370.21**\r\n",
        "link": "https://stackoverflow.com/questions/46117049/how-i-can-round-digit-on-the-last-column-to-2-decimal-after-a-dot-using-jq",
        "title": "How I can round digit on the last column to 2 decimal after a dot using JQ?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5147209,
                    "reputation": 4656,
                    "user_id": 4122849,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/yDoo4.jpg?s=256",
                    "display_name": "Pat Myron",
                    "link": "https://stackoverflow.com/users/4122849/pat-myron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1750128429,
                "post_id": 46131727,
                "comment_id": 140519008,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 90,
                "is_accepted": true,
                "score": 90,
                "last_activity_date": 1689900486,
                "last_edit_date": 1689900486,
                "creation_date": 1504969205,
                "answer_id": 46131963,
                "question_id": 46131727,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The easiest way in your example is to use [String Interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-\\\\\\(foo\\)) along with the `-r` option. e.g.\r\n\r\n    echo &#39;{ &quot;fmep&quot;: { &quot;foo&quot;: 112, &quot;bar&quot;: 234324, &quot;cat&quot;: 21343423 } }&#39; | \\\r\n    jq -r &#39;.fmep| &quot;\\(.foo) \\(.bar)&quot;&#39;\r\n\r\nproduces\r\n\r\n    112 234324\r\n\r\nYou may also want to consider putting the values in an array and using [@tsv](https://jqlang.github.io/jq/manual/#Builtinoperatorsandfunctions:~:text=escaped%20by%20repetition.-,%40tsv,-%3A) e.g.\r\n\r\n    echo &#39;{ &quot;fmep&quot;: { &quot;foo&quot;: 112, &quot;bar&quot;: 234324, &quot;cat&quot;: 21343423 } }&#39; | \\\r\n    jq -r &#39;.fmep | [.foo, .bar] | @tsv&#39;\r\n\r\nwhich produces tab-separated\r\n\r\n    112\t234324\r\n",
                "title": "Printing multiple values on the same line"
            },
            {
                "up_vote_count": 18,
                "is_accepted": false,
                "score": 18,
                "last_activity_date": 1523582328,
                "creation_date": 1523582328,
                "answer_id": 49807940,
                "question_id": 46131727,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is the syntax using joined output (`-j`):\r\n\r\n    jq -j &#39;.fmep | .foo, &quot; &quot;, .bar, &quot;\\n&quot;&#39; payload.json",
                "title": "Printing multiple values on the same line"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1634494612,
                "creation_date": 1634494612,
                "answer_id": 69607324,
                "question_id": 46131727,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s say our JSON (*example.json*) looks like this:\r\n    {\r\n       &quot;hello&quot;:&quot;world&quot;,\r\n       &quot;foo&quot;:&quot;bar&quot;\r\n    }\r\n\r\nIn order to join a few fields into the same line you can:\r\n\r\n    $ jq -j &#39;.hello,.foo&#39; example.json\r\nThis will result in \r\n\r\n    worldbar\r\n\r\nWant to add a delimiter? let&#39;s say a space\r\n\r\n    $ jq -j &#39;.hello,&quot; &quot;,.foo&#39; example.json\r\nThis will result in\r\n\r\n    world bar\r\n\r\n*Just make sure you are using jq version 1.5 or higher",
                "title": "Printing multiple values on the same line"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 55,
        "last_activity_date": 1750128339,
        "creation_date": 1504967483,
        "last_edit_date": 1750128339,
        "question_id": 46131727,
        "body_markdown": "I&#39;m trying to parse a JSON document and print a couple of values on the same line. Is there a way to take this document:\r\n\r\n    {\r\n      &quot;fmep&quot;: {\r\n        &quot;foo&quot;: 112,\r\n        &quot;bar&quot;: 234324,\r\n        &quot;cat&quot;: 21343423\r\n      }\r\n    }\r\n\r\nAnd print:\r\n\r\n    112 234324\r\n\r\nI get the values I want but they are printed on separate lines:\r\n\r\n    $ echo &#39;{ &quot;fmep&quot;: { &quot;foo&quot;: 112, &quot;bar&quot;: 234324, &quot;cat&quot;: 21343423 } }&#39; | jq &#39;.fmep|.foo,.bar&#39;\r\n    \r\n    112  \r\n    234324\r\n\r\n",
        "link": "https://stackoverflow.com/questions/46131727/printing-multiple-values-on-the-same-line",
        "title": "Printing multiple values on the same line"
    },
    {
        "tags": [
            "performance",
            "amazon-web-services",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1505027745,
                "last_edit_date": 1505027745,
                "creation_date": 1505026672,
                "answer_id": 46138103,
                "question_id": 46137642,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a more efficient approach.  With the `-r` option, the following filter\r\n\r\n        .SecurityGroups[]\r\n      | .GroupId as $gid\r\n      | .GroupName as $gname\r\n      | (.IpPermissions[], .IpPermissionsEgress[]?)\r\n      | .FromPort as $from\r\n      | .ToPort as $to\r\n      | .IpProtocol as $pro\r\n      | .IpRanges[]\r\n      | &quot;\\($gid)|\\($gname)|\\($from)|\\($to)|\\($pro)|\\(.CidrIp)&quot;\r\n\r\nwith the sample data produces \r\n\r\n    sg-xxxxxx|database|22|22|tcp|10.200.0.0/16\r\n    sg-xxxxxx|database|22|22|tcp|10.200.30.79/32\r\n    sg-xxxxxx|database|22|22|tcp|10.200.42.0/24\r\n    sg-xxxxxx|database|5555|5555|tcp|10.200.0.0/16\r\n    sg-xxxxxx|database|5555|5555|tcp|10.200.0.155/32\r\n    sg-xxxxxx|database|4506|4506|tcp|10.200.0.0/16\r\n\r\nNote that this includes `.IpPermissionsEgress[]?` because although it&#39;s absent from your sample data and unused in the second part of your script it is nevertheless present in the first part of your sample script so I think you may have intended to include it.",
                "title": "How to improve performance on a slow jq script?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1505027745,
        "creation_date": 1505022134,
        "question_id": 46137642,
        "body_markdown": "I have a JSON doc that looks like:\r\n\r\n    {\r\n        &quot;SecurityGroups&quot;: [\r\n            {\r\n                &quot;GroupName&quot;: &quot;database&quot;,\r\n                &quot;GroupId&quot;: &quot;sg-xxxxxx&quot;,\r\n                &quot;VpcId&quot;: &quot;vpc-yyyyyyy&quot;,\r\n                &quot;IpPermissions&quot;: [\r\n                    {\r\n                        &quot;FromPort&quot;: 22,\r\n                        &quot;ToPort&quot;: 22,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;10.200.0.0/16&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;10.200.30.79/32&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;10.200.42.0/24&quot;\r\n                            }\r\n                        ],\r\n                        &quot;UserIdGroupPairs&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;FromPort&quot;: 5555,\r\n                        &quot;ToPort&quot;: 5555,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;10.200.0.0/16&quot;\r\n                            },\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;10.200.0.155/32&quot;\r\n                            }\r\n                        ],\r\n                        &quot;UserIdGroupPairs&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;FromPort&quot;: 4506,\r\n                        &quot;ToPort&quot;: 4506,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;10.200.0.0/16&quot;\r\n                            }\r\n                        ],\r\n                        &quot;UserIdGroupPairs&quot;: []\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\r\nThe output I need to generate is as follow:\r\n\r\n    sg-xxxxxx|database|22|22|tcp|10.200.0.0/16\r\n    sg-xxxxxx|database|22|22|tcp|10.200.30.79/32\r\n    sg-xxxxxx|database|22|22|tcp|10.200.42.0/24\r\n    sg-xxxxxx|database|5555|5555|tcp|10.200.0.0/16\r\n    sg-xxxxxx|database|5555|5555|tcp|10.200.0.155/32\r\n    sg-xxxxxx|database|4506|4506|tcp|10.200.0.0/16\r\n\r\nI&#39;m able to achieve that by using using jq first to generate a list of GroupId&#39;s and then loop through the list to filter data into jq twice.  Here&#39;s how I did it:\r\n\r\n    cat json.in | jq -r &#39;.SecurityGroups[]|&quot;\\(.GroupId) \\(.GroupName)&quot;&#39; | while read groupid groupname\r\n    do\r\n            cat json.in | jq &quot;.SecurityGroups[]|{GroupId,IpPermissions,IpPermissionsEgress}|select(.GroupId == \\&quot;$groupid\\&quot;)&quot; | jq -r &#39;.IpPermissions[]|&quot;\\(.FromPort)|\\(.ToPort)|\\(.IpProtocol)|\\(.IpRanges[].CidrIp)&quot;&#39; | sed &quot;s/^/$groupid|$groupname|/&quot;\r\n    done\r\n\r\nMy solution is slow and I would like to improve on it, Any pointers?",
        "link": "https://stackoverflow.com/questions/46137642/how-to-improve-performance-on-a-slow-jq-script",
        "title": "How to improve performance on a slow jq script?"
    },
    {
        "tags": [
            "drupal",
            "drupal-8",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1505145827,
                "creation_date": 1505145827,
                "answer_id": 46159886,
                "question_id": 46159110,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution.  If the following filter is in `filter.jq`\r\n\r\n      .services\r\n    | keys[] as $k\r\n    | .[$k]\r\n    | select(.tags[]?.name == $name)\r\n    | $k\r\n\r\nand the sample data is in `data.json` then the command\r\n\r\n    $ jq -Mr --arg name &#39;access_check&#39; -f filter.jq data.json\r\n\r\nproduces\r\n\r\n    access_check.settings_tray.block.settings_tray_form",
                "title": "Getting an object key based on subarray value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1505319898,
                "last_edit_date": 1505319898,
                "creation_date": 1505176274,
                "answer_id": 46166184,
                "question_id": 46159110,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "So if I understand your inputs and outputs, you want a service name, if it contains a given tag name.\r\n\r\nI would write it like so.\r\n\r\n    $ jq --arg name &quot;access_check&quot; &#39;\r\n    .services | to_entries[] | select(any(.value.tags[].name; . == $name)).key\r\n    &#39; input.json\r\n\r\nYou were close with your attempts, but there were some syntax issues:\r\n\r\n1. `.value.tags.[].name`  \r\nBy having the dot before the `[]`, the syntax is now invalid. It should have been `.value.tags[].name`.\r\n2. `.value.tags|.name`  \r\n`tags` is an array, it may not have a property called `name`.",
                "title": "Getting an object key based on subarray value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1505319898,
        "creation_date": 1505143216,
        "last_edit_date": 1505147113,
        "question_id": 46159110,
        "body_markdown": "I have a JSON defining some services:\r\n\r\n    {\r\n      &quot;services&quot;: {\r\n        &quot;main_content_renderer.off_canvas&quot;: {\r\n          &quot;class&quot;: &quot;Drupal\\\\settings_tray\\\\Render\\\\MainContent\\\\OffCanvasRenderer&quot;,\r\n          &quot;arguments&quot;: [\r\n            &quot;@title_resolver&quot;,\r\n            &quot;@renderer&quot;\r\n          ],\r\n          &quot;tags&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;render.main_content_renderer&quot;,\r\n              &quot;format&quot;: &quot;drupal_dialog.off_canvas&quot;\r\n            }\r\n          ]\r\n        },\r\n        &quot;access_check.settings_tray.block.settings_tray_form&quot;: {\r\n          &quot;class&quot;: &quot;Drupal\\\\settings_tray\\\\Access\\\\BlockPluginHasSettingsTrayFormAccessCheck&quot;,\r\n          &quot;tags&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;access_check&quot;,\r\n              &quot;applies_to&quot;: &quot;_access_block_plugin_has_settings_tray_form&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\nI would like to write a `jq` program which returns `access_check.settings_tray.block.settings_tray_form` for the input `access_check`.\r\n\r\nI tried various things  but I either get `jq: error (at &lt;stdin&gt;:20): Cannot index array with string &quot;name&quot;` or just a syntax error.\r\n\r\nExamples:\r\n\r\n`jq &#39;.services| to_entries|map(select(.value.tags.[].name == &quot;access_check&quot;)))&#39;`\r\n\r\nThis leads to a syntax error: `jq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:`\r\n\r\nOr `jq &#39;.services| to_entries|map(select(.value.tags|.name == &quot;paramconverter&quot;))&#39;` results in\r\n\r\n`jq: error (at &lt;stdin&gt;:20): Cannot index array with string &quot;name&quot;`\r\n\r\nEdit: while the example doesn&#39;t show there can be multiple tags.",
        "link": "https://stackoverflow.com/questions/46159110/getting-an-object-key-based-on-subarray-value",
        "title": "Getting an object key based on subarray value"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 447475,
                    "reputation": 1,
                    "user_id": 841108,
                    "user_type": "registered",
                    "accept_rate": 61,
                    "profile_image": "https://i.sstatic.net/Fm52y.png?s=256",
                    "display_name": "Basile Starynkevitch",
                    "link": "https://stackoverflow.com/users/841108/basile-starynkevitch"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1505197169,
                "post_id": 46169164,
                "comment_id": 79300327,
                "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": 1505198515,
                "post_id": 46169164,
                "comment_id": 79301056,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5665565,
                    "reputation": 2687,
                    "user_id": 4481829,
                    "user_type": "registered",
                    "accept_rate": 55,
                    "profile_image": "https://i.sstatic.net/OQpdM.jpg?s=256",
                    "display_name": "Bhavik Joshi",
                    "link": "https://stackoverflow.com/users/4481829/bhavik-joshi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1505198949,
                "post_id": 46169164,
                "comment_id": 79301329,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1505219219,
                "last_edit_date": 1505219219,
                "creation_date": 1505198453,
                "answer_id": 46169591,
                "question_id": 46169164,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution to the original problem.  If the following filter is in `filter.jq`\r\n\r\n      .scaleApp\r\n    | {imageName, volumesFrom}\r\n    | .imageName |= .[8:]\r\n    | .volumesFrom[] |= .[8:]\r\n\r\nand the following (original) sample data \r\n\r\n    {\r\n      &quot;appId&quot;: &quot;server1&quot;,\r\n      &quot;userName&quot;: &quot;bhavik&quot;,\r\n      &quot;scaleApp&quot;: {\r\n        &quot;imageName&quot;: &quot;${DATA}/build-server:159&quot;,\r\n        &quot;internalPath&quot;: &quot;/&quot;,\r\n        &quot;volumesFrom&quot;: [\r\n          &quot;${DATA}/buildtype-mock:218&quot;,\r\n          &quot;${DATA}/buildtype-se:540-1.0.5-V30.1-GA&quot;,\r\n          &quot;${DATA}/buildtype-nodejs:42&quot;,\r\n          &quot;${DATA}/buildtype-flogo:682&quot;\r\n        ]\r\n      }\r\n    }\r\n\r\nis in `data.json` then the command\r\n\r\n    $ jq -M -f filter.jq data.json\r\n\r\nproduces\r\n\r\n    {\r\n      &quot;imageName&quot;: &quot;build-server:159&quot;,\r\n      &quot;volumesFrom&quot;: [\r\n        &quot;buildtype-mock:218&quot;,\r\n        &quot;buildtype-se:540-1.0.5-V30.1-GA&quot;,\r\n        &quot;buildtype-nodejs:42&quot;,\r\n        &quot;buildtype-flogo:682&quot;\r\n      ]\r\n    }\r\n\r\n____\r\n\r\nHere is a solution to the revised problem. Assuming the following sample data is in `data.json`\r\n\r\n    [\r\n      {\r\n        &quot;appId&quot;: &quot;server1&quot;,\r\n        &quot;userName&quot;: &quot;bhavik&quot;,\r\n        &quot;scaleApp&quot;: {\r\n          &quot;imageName&quot;: &quot;${DATA}/build-server:1&quot;,\r\n          &quot;internalPath&quot;: &quot;/&quot;,\r\n          &quot;volumesFrom&quot;: [\r\n            &quot;${DATA}/buildtype-mock:219&quot;,\r\n            &quot;${DATA}/buildtype-se:543-1.0.5-V30.2-GA&quot;\r\n          ]\r\n        }\r\n      },\r\n      {\r\n        &quot;appId&quot;: &quot;server2&quot;,\r\n        &quot;userName&quot;: &quot;rajiv&quot;,\r\n        &quot;scaleApp&quot;: {\r\n          &quot;imageName&quot;: &quot;${DATA}/build-server:159&quot;,\r\n          &quot;internalPath&quot;: &quot;/&quot;,\r\n          &quot;volumesFrom&quot;: [\r\n            &quot;${DATA}/buildtype-mock:218&quot;,\r\n            &quot;${DATA}/buildtype-se:540-1.0.5-V30.1-GA&quot;,\r\n            &quot;${DATA}/buildtype-nodejs:42&quot;,\r\n            &quot;${DATA}/buildtype-flogo:682&quot;\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n\r\nthis `filter.jq`\r\n\r\n    map(      \r\n      .scaleApp\r\n    | {imageName, volumesFrom}\r\n    | .imageName |= .[8:]\r\n    | .volumesFrom[] |= .[8:]\r\n    )\r\n\r\nproduces\r\n\r\n    [\r\n      {\r\n        &quot;imageName&quot;: &quot;build-server:1&quot;,\r\n        &quot;volumesFrom&quot;: [\r\n          &quot;buildtype-mock:219&quot;,\r\n          &quot;buildtype-se:543-1.0.5-V30.2-GA&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;imageName&quot;: &quot;build-server:159&quot;,\r\n        &quot;volumesFrom&quot;: [\r\n          &quot;buildtype-mock:218&quot;,\r\n          &quot;buildtype-se:540-1.0.5-V30.1-GA&quot;,\r\n          &quot;buildtype-nodejs:42&quot;,\r\n          &quot;buildtype-flogo:682&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nwhich is a little more then what you asked for so this `filter.jq`\r\n\r\n    map(      \r\n       select(.appId == &quot;server2&quot;)\r\n    |  .scaleApp\r\n    | {imageName, volumesFrom}\r\n    | .imageName |= .[8:]\r\n    | .volumesFrom[] |= .[8:]\r\n    )[]\r\n\r\nproduces only\r\n\r\n    {\r\n      &quot;imageName&quot;: &quot;build-server:159&quot;,\r\n      &quot;volumesFrom&quot;: [\r\n        &quot;buildtype-mock:218&quot;,\r\n        &quot;buildtype-se:540-1.0.5-V30.1-GA&quot;,\r\n        &quot;buildtype-nodejs:42&quot;,\r\n        &quot;buildtype-flogo:682&quot;\r\n      ]\r\n    }\r\n\r\nfor `.appId == &quot;server2&quot;`\r\n",
                "title": "How to reformat and transform the output of jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1505219219,
        "creation_date": 1505196913,
        "last_edit_date": 1505208154,
        "question_id": 46169164,
        "body_markdown": "I have a json string as below:\r\n\r\n    \t[{\r\n\t\t\t&quot;appId&quot;: &quot;server1&quot;,\r\n\t\t\t&quot;userName&quot;: &quot;bhavik&quot;,\r\n\t\t\t&quot;scaleApp&quot;: {\r\n\t\t\t\t&quot;imageName&quot;: &quot;${DATA}/build-server:1&quot;,\r\n\t\t\t\t&quot;internalPath&quot;: &quot;/&quot;,\r\n\t\t\t\t&quot;volumesFrom&quot;: [\r\n\t\t\t\t\t&quot;${DATA}/buildtype-mock:219&quot;,\r\n\t\t\t\t\t&quot;${DATA}/buildtype-se:543-1.0.5-V30.2-GA&quot;\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;appId&quot;: &quot;server2&quot;,\r\n\t\t\t&quot;userName&quot;: &quot;rajiv&quot;,\r\n\t\t\t&quot;scaleApp&quot;: {\r\n\t\t\t\t&quot;imageName&quot;: &quot;${DATA}/build-server:159&quot;,\r\n\t\t\t\t&quot;internalPath&quot;: &quot;/&quot;,\r\n\t\t\t\t&quot;volumesFrom&quot;: [\r\n\t\t\t\t\t&quot;${DATA}/buildtype-mock:218&quot;,\r\n\t\t\t\t\t&quot;${DATA}/buildtype-se:540-1.0.5-V30.1-GA&quot;,\r\n\t\t\t\t\t&quot;${DATA}/buildtype-nodejs:42&quot;,\r\n\t\t\t\t\t&quot;${DATA}/buildtype-flogo:682&quot;\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t}\r\n\t]\r\nI need output as below:\r\n\r\n    {\r\n    &quot;imageName&quot; : &quot;build-server:159&quot;,\r\n    &quot;volumesFrom&quot; : [\r\n            &quot;buildtype-mock:218&quot;,\r\n            &quot;buildtype-se:540-1.0.5-V30.1-GA&quot;,\r\n            &quot;buildtype-nodejs:42&quot;,\r\n            &quot;buildtype-flogo:682&quot;\r\n          ]\r\n    }\r\n\r\nI am trying to achieve it with jq. I am using the following command:\r\n\r\n    jq &#39;.[] | { imageName: .scaleApp.imageName,volumesFrom: .scaleApp.volumesFrom } &#39; data.json\r\n\r\nfollowing is the output:\r\n\r\n    {\r\n      &quot;imageName&quot;: &quot;${DATA}/build-server:159&quot;,\r\n      &quot;volumesFrom&quot;: [\r\n            &quot;${DATA}/buildtype-mock:218&quot;,\r\n            &quot;${DATA}/buildtype-se:540-1.0.5-V30.1-GA&quot;,\r\n            &quot;${DATA}/buildtype-nodejs:42&quot;,\r\n            &quot;${DATA}/buildtype-flogo:682&quot;\r\n          ]\r\n    }\r\n\r\nI am not getting the proper format what I want, could anyone please help me out.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/46169164/how-to-reformat-and-transform-the-output-of-jq",
        "title": "How to reformat and transform the output of jq?"
    },
    {
        "tags": [
            "bash",
            "batch-file",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1505198122,
                "creation_date": 1505198122,
                "answer_id": 46169489,
                "question_id": 46169239,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a demonstration of a solution that uses [sponge](https://stackoverflow.com/questions/21867969/overwrite-contents-of-a-file-alternative-to/21868000#21868000)\r\n\r\n    bash-3.2$ cat data.json\r\n    {\r\n      &quot;name&quot;: &quot;app&quot;,\r\n      &quot;value&quot;: &quot;one&quot;\r\n    }\r\n\r\n    bash-3.2$ jq -M &#39;.value=&quot;two&quot;&#39; &lt; data.json | sponge data.json \r\n\r\n    bash-3.2$ cat data.json \r\n    {\r\n      &quot;name&quot;: &quot;app&quot;,\r\n      &quot;value&quot;: &quot;two&quot;\r\n    }\r\n    ",
                "title": "How to set a property of a json file and replace in one command using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1526576261,
        "creation_date": 1505197216,
        "last_edit_date": 1505198614,
        "question_id": 46169239,
        "body_markdown": "[How do I update a single value in a json document using jq?][1] Doesn&#39;t have the answer for this question. \r\n\r\n 1. Read json file.  \r\n 2. Update the value.  \r\n 3. Replace the file.\r\n\r\nExpecting **one inline command** using [jq][2]\r\n\r\nAssume I have following json file.\r\n\r\n    {\r\n      &quot;name&quot;: &quot;app&quot;,\r\n      &quot;value&quot;: &quot;one&quot;,\r\n      ... \r\n    }\r\n\r\nI want to update the value field to &quot;two&quot;. So resulting json file should look like\r\n\r\n    {\r\n      &quot;name&quot;: &quot;app&quot;,\r\n      &quot;value&quot;: &quot;two&quot;,\r\n      ... \r\n    }\r\n\r\n\r\nWhat is the simplest bash command and windows bat command for this. \r\n\r\n  [1]: https://stackoverflow.com/questions/31034746/how-do-i-update-a-single-value-in-a-json-document-using-jq\r\n  [2]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/46169239/how-to-set-a-property-of-a-json-file-and-replace-in-one-command-using-jq",
        "title": "How to set a property of a json file and replace in one command using jq"
    },
    {
        "tags": [
            "shell",
            "amazon-web-services",
            "foreach",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7128986,
                    "reputation": 1,
                    "user_id": 5450951,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/28c456e85edba0332573de5f11494474?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Thiago",
                    "link": "https://stackoverflow.com/users/5450951/thiago"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1505222895,
                "post_id": 46177546,
                "comment_id": 79317785,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1505227651,
                "last_edit_date": 1505227651,
                "creation_date": 1505225404,
                "answer_id": 46178675,
                "question_id": 46177546,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "[tag:jq] has a [`@sh` directive](https://stedolan.github.io/jq/manual/#Formatstringsandescaping) to output values properly quoted for the shell:\r\n\r\n    aws ec2 describe-tags --filters &quot;Name=resource-id,Values=$INSTANCE_ID&quot; \\\r\n    | jq -r &#39;.Tags[] | @sh &quot;aws ec2 create-tags --resources XXXXX --tags Key=\\(.Key),Value=\\(.Value)&quot;&#39; \r\n\r\nGiven your input, this outputs\r\n\r\n    aws ec2 create-tags --resources XXXXX --tags Key=&#39;A-KEY&#39;,Value=&#39;A-VALUE&#39;\r\n    aws ec2 create-tags --resources XXXXX --tags Key=&#39;B-KEY&#39;,Value=&#39;B-VALUE&#39;\r\n    aws ec2 create-tags --resources XXXXX --tags Key=&#39;C-KEY&#39;,Value=&#39;C-VALUE&#39;\r\n    aws ec2 create-tags --resources XXXXX --tags Key=&#39;D-KEY&#39;,Value=&#39;D-VALUE&#39;\r\n    aws ec2 create-tags --resources XXXXX --tags Key=&#39;E-KEY&#39;,Value=&#39;E-VALUE&#39;\r\n    aws ec2 create-tags --resources XXXXX --tags Key=&#39;G-KEY&#39;,Value=&#39;F-VALUE&#39;\r\n\r\nTo execute those as commands pipe into `sh`:\r\n\r\n    aws ec2 describe-tags ... | jq -r ... | sh \r\n\r\n---\r\njq is quite an adventure. You need to add a &quot;select&quot; filter to remove keys that start with &quot;aws:&quot;\r\n\r\n    jq -r &#39;\r\n        .Tags[] | \r\n        select(.Key | test(&quot;^aws:&quot;) | not) |\r\n        @sh &quot;aws ... --tags Key=\\(.Key),Value=\\(.Value)&quot;\r\n    &#39;\r\n\r\n",
                "title": "jq key, value for each shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1505227651,
        "creation_date": 1505222324,
        "last_edit_date": 1505222716,
        "question_id": 46177546,
        "body_markdown": "I&#39;m trying to use every Key,Value of an output and pipe it to another command.\r\nHere is what I&#39;m trying to use:\r\n\r\n    INSTANCE_ID=$(curl http://169.254.169.254/latest/meta-data/instance-id)\r\n    aws ec2 describe-tags --filters &quot;Name=resource-id,Values=$INSTANCE_ID&quot;\r\n\r\nWith the above command, I have the following output:\r\n\r\n    {\r\n    &quot;Tags&quot;: [\r\n        {\r\n            &quot;ResourceType&quot;: &quot;instance&quot;,\r\n            &quot;ResourceId&quot;: &quot;i-0342a609edf80001a&quot;,\r\n            &quot;Value&quot;: &quot;A-VALUE&quot;,\r\n            &quot;Key&quot;: &quot;A-KEY&quot;\r\n        },\r\n        {\r\n            &quot;ResourceType&quot;: &quot;instance&quot;,\r\n            &quot;ResourceId&quot;: &quot;i-0342a609edf80001a&quot;,\r\n            &quot;Value&quot;: &quot;B-VALUE&quot;,\r\n            &quot;Key&quot;: &quot;B-KEY&quot;\r\n        },\r\n        {\r\n            &quot;ResourceType&quot;: &quot;instance&quot;,\r\n            &quot;ResourceId&quot;: &quot;i-0342a609edf80001a&quot;,\r\n            &quot;Value&quot;: &quot;C-VALUE&quot;,\r\n            &quot;Key&quot;: &quot;C-KEY&quot;\r\n        },\r\n        {\r\n            &quot;ResourceType&quot;: &quot;instance&quot;,\r\n            &quot;ResourceId&quot;: &quot;i-0342a609edf80001a&quot;,\r\n            &quot;Value&quot;: &quot;D-VALUE&quot;,\r\n            &quot;Key&quot;: &quot;D-KEY&quot;\r\n        },\r\n        {\r\n            &quot;ResourceType&quot;: &quot;instance&quot;,\r\n            &quot;ResourceId&quot;: &quot;i-0342a609edf80001a&quot;,\r\n            &quot;Value&quot;: &quot;E-VALUE&quot;,\r\n            &quot;Key&quot;: &quot;E-KEY&quot;\r\n        },\r\n        {\r\n            &quot;ResourceType&quot;: &quot;instance&quot;,\r\n            &quot;ResourceId&quot;: &quot;i-0342a609edf80001a&quot;,\r\n            &quot;Value&quot;: &quot;F-VALUE&quot;,\r\n            &quot;Key&quot;: &quot;G-KEY&quot;\r\n        },\r\n        {\r\n\r\nNow I want to pipe each Key,Value to the following command:\r\n\r\n    aws ec2 create-tags --resources XXXXX --tags Key=H-KEY,Value=H-VALUE\r\n\r\nWhere the quantity and values of Key,Value are variable. So I believe I need a &quot;for each&quot;.\r\n\r\nMay you help me?\r\n\r\nIt&#39;s like: For each Key,Value, do:\r\n\r\n    aws ec2 create-tags --resources XXXXX --tags Key=A-KEY,Value=A-VALUE\r\n    aws ec2 create-tags --resources XXXXX --tags Key=B-KEY,Value=B-VALUE\r\n    aws ec2 create-tags --resources XXXXX --tags Key=C-KEY,Value=C-VALUE\r\n    aws ec2 create-tags --resources XXXXX --tags Key=N...-KEY,Value=N...-VALUE",
        "link": "https://stackoverflow.com/questions/46177546/jq-key-value-for-each-shell-script",
        "title": "jq key, value for each shell script"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1505237825,
                "last_edit_date": 1505237825,
                "creation_date": 1505235935,
                "answer_id": 46182013,
                "question_id": 46181542,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This would be easier to answer if you provided more sample data but\r\nworking backwards from your commands (with some reformatting)\r\n    \r\n    $ jq &#39;\r\n          .modules[].resources[]\r\n        | select(.type == &quot;openstack_compute_instance_v2&quot; and .primary.attributes.name == &quot;jumpbox&quot;)\r\n        | .primary.id\r\n    &#39; terraform.tfstate\r\n    &quot;5edfe2bf-94df-49d5-8118-3e91fb52946b&quot;\r\n\r\n    $ jq &#39;\r\n          .modules[].resources[]\r\n        | select(.type ==&quot;openstack_compute_floatingip_associate_v2&quot; and .primary.attributes.instance_id == &quot;5edfe2bf-94df-49d5-8118-3e91fb52946b&quot;)\r\n        | .primary.attributes.floating_ip\r\n    &#39; terraform.tfstate\r\n    &quot;10.120.241.21&quot;\r\n\r\nwe can infer you have data which looks like\r\n\r\n    {\r\n      &quot;modules&quot;: [\r\n        {\r\n          &quot;resources&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;openstack_compute_instance_v2&quot;,\r\n              &quot;primary&quot;: {\r\n                &quot;id&quot;: &quot;5edfe2bf-94df-49d5-8118-3e91fb52946b&quot;,\r\n                &quot;attributes&quot;: {\r\n                  &quot;name&quot;: &quot;jumpbox&quot;\r\n                }\r\n              }\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;openstack_compute_floatingip_associate_v2&quot;,\r\n              &quot;primary&quot;: {\r\n                &quot;attributes&quot;: {\r\n                  &quot;instance_id&quot;: &quot;5edfe2bf-94df-49d5-8118-3e91fb52946b&quot;,\r\n                  &quot;floating_ip&quot;: &quot;10.120.241.21&quot;\r\n                }\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nThe following filter demonstrates a solution using [functions](https://stedolan.github.io/jq/manual/#DefiningFunctions), [variables](https://stedolan.github.io/jq/manual/#Variable/SymbolicBindingOperator:...as$identifier|...) and [parenthesis ()](https://stedolan.github.io/jq/manual/#Parenthesis):\r\n \r\n\r\n    def get_primary_id($name):\r\n        select(.type == &quot;openstack_compute_instance_v2&quot;\r\n           and .primary.attributes.name == $name)\r\n      | .primary.id\r\n    ;\r\n    def get_floating_ip($id):\r\n        select(.type ==&quot;openstack_compute_floatingip_associate_v2&quot;\r\n           and .primary.attributes.instance_id == $id)\r\n      | .primary.attributes.floating_ip\r\n    ;\r\n      .modules[]\r\n    | ( .resources[] | get_primary_id(&quot;jumpbox&quot;) ) as $id\r\n    | ( .resources[] | get_floating_ip($id)      ) as $fip\r\n    | ($id, $fip)\r\n\r\nif this filter is in `filter.jq` and `data.json` contains the sample data above\r\nthen\r\n\r\n    $ jq -M -f filter.jq data.json\r\n\r\nproduces the output:\r\n\r\n    &quot;5edfe2bf-94df-49d5-8118-3e91fb52946b&quot;\r\n    &quot;10.120.241.21&quot;\r\n\r\n",
                "title": "jq: search by value from another array element"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1505464648,
        "creation_date": 1505233983,
        "last_edit_date": 1505464648,
        "question_id": 46181542,
        "body_markdown": "I have an array of objects of various types which reference one another with UUIDs (a terraform.tfstate file). I&#39;d like to select one value from one such object based on the appearance of a different value in another object, where the two objects are related by one of those UUIDs.\r\n\r\nBy way of example, I can do this:\r\n\r\n    $ jq &#39;.modules[].resources[]\r\n    | select(.type == &quot;openstack_compute_instance_v2&quot; and \r\n             .primary.attributes.name == &quot;jumpbox&quot;).primary.id&#39; terraform.tfstate\r\n    &quot;5edfe2bf-94df-49d5-8118-3e91fb52946b&quot;\r\n    $ jq &#39;.modules[].resources[] \r\n    | select(.type ==&quot;openstack_compute_floatingip_associate_v2&quot; and \r\n             .primary.attributes.instance_id == &quot;5edfe2bf-94df-49d5-8118-3e91fb52946b&quot;).primary.attributes.floating_ip&#39; terraform.tfstate\r\n    &quot;10.120.241.21&quot;\r\n\r\nGiving me the external floating IP of the &#39;jumpbox&#39; VM based on its name.\r\n\r\nI&#39;d like to make that all one jq call. Is that possible?",
        "link": "https://stackoverflow.com/questions/46181542/jq-search-by-value-from-another-array-element",
        "title": "jq: search by value from another array element"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1505238094,
                "creation_date": 1505238094,
                "answer_id": 46182537,
                "question_id": 46182398,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You are pretty close.  Try this\r\n\r\n    map(select(.key == &quot;value1&quot;)) | length\r\n\r\nor the equivalent\r\n\r\n    [ .[] | select(.key == &quot;value1&quot;) ] | length\r\n",
                "title": "jq get number of jsons in an array containing a specific value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1505436086,
                "last_edit_date": 1505436086,
                "creation_date": 1505435669,
                "answer_id": 46230019,
                "question_id": 46182398,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "An efficient and convenient way to count is to use &#39;count&#39; as defined below:\r\n\r\n    def count(s; cond): reduce s as $x (0; if ($x|cond) then .+1 else . end);\r\n    count(.[]; .key == &quot;value1&quot;)",
                "title": "jq get number of jsons in an array containing a specific value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1505436086,
        "creation_date": 1505237582,
        "question_id": 46182398,
        "body_markdown": "I&#39;ve got an array of multiple JSON. I would like to get the number of of JSON which contain a specific value. \r\n\r\nExample:\r\n \r\n    [\r\n     {\r\n      &quot;key&quot;: &quot;value1&quot;,\r\n      &quot;2ndKey&quot;:&quot;2ndValue1&quot;\r\n     },\r\n     {\r\n      &quot;key&quot;: &quot;value2&quot;,\r\n      &quot;2ndKey&quot;:&quot;2ndValue2&quot;\r\n     },\r\n     {\r\n      &quot;key&quot;: &quot;value1&quot;,\r\n      &quot;2ndKey&quot;:&quot;2ndValue3&quot;\r\n     }\r\n    ]\r\n\r\nSo in case I&#39;m looking for value1 in key, the result should be 2. \r\n\r\nI would like to get an solution using jq. I had already some tries, however they did not fully work. The best one yet was the following: \r\n\r\n    cat /tmp/tmp.txt | jq &#39; select(.[].key == &quot;value1&quot; ) | length &#39; \r\n\r\nI get the correct results but it is shown multiple times.\r\n\r\nCan anybody help me to further improve my code. Thanks in advance! \r\n",
        "link": "https://stackoverflow.com/questions/46182398/jq-get-number-of-jsons-in-an-array-containing-a-specific-value",
        "title": "jq get number of jsons in an array containing a specific value"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1505276604,
                "post_id": 46187807,
                "comment_id": 79339960,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1505271404,
                "last_edit_date": 1505271404,
                "creation_date": 1505269861,
                "answer_id": 46187922,
                "question_id": 46187807,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can loop over the key/value pairs and use `declare` to create variable names dynamically.\r\n\r\n    while read -r name value; do\r\n        declare &quot;$name=$value&quot;\r\n    done &lt; &lt;(jq -r &#39;to_entries[] | &quot;\\(.key) \\(.value)&quot;&#39; arguments.json)",
                "title": "Is there a way to read all key-value pairs in the JSON file and then initialize all variables accordingly in shell?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1505271404,
        "creation_date": 1505268966,
        "question_id": 46187807,
        "body_markdown": "Given a JSON file, `arguments.json`:\r\n\r\n    {&quot;dagger&quot;: true, &quot;version&quot;: false, &quot;nether_strike&quot;: true, \r\n     &quot;greater_bash&quot;: &quot;5&quot;, &quot;FILE&quot;: &quot;ancientscroll.txt&quot;, \r\n     &quot;empower_haste&quot;: &quot;1&quot;, &quot;help&quot;: false}\r\n\r\nI can read using `jq` in shell and initialize the variables individually:\r\n\r\n    dagger=$(cat arguments.json | jq &#39;.[&quot;dagger&quot;]&#39;)\r\n    greater_bash =$(cat arguments.json | jq &#39;.[&quot;greater_bash&quot;]&#39;)    \r\n\r\n    echo $dagger\r\n    echo $greater_bash\r\n\r\n**Is there a way to read all key-value pairs in the JSON file and then initialize all variables accordingly in shell?**\r\n   \r\n\r\n    \r\n    ",
        "link": "https://stackoverflow.com/questions/46187807/is-there-a-way-to-read-all-key-value-pairs-in-the-json-file-and-then-initialize",
        "title": "Is there a way to read all key-value pairs in the JSON file and then initialize all variables accordingly in shell?"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 464329,
                    "reputation": 758,
                    "user_id": 867757,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3f7af14a86e0e72a3c4b12ac4cd8fe7c?s=256&d=identicon&r=PG",
                    "display_name": "jeberle",
                    "link": "https://stackoverflow.com/users/867757/jeberle"
                },
                "edited": false,
                "score": 9,
                "creation_date": 1505272375,
                "post_id": 46188224,
                "comment_id": 79339023,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1505275856,
                "post_id": 46188224,
                "comment_id": 79339748,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 302279,
                    "reputation": 123025,
                    "user_id": 610569,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/0e9087f2672b0e4f28d91266acf9ce57?s=256&d=identicon&r=PG",
                    "display_name": "alvas",
                    "link": "https://stackoverflow.com/users/610569/alvas"
                },
                "reply_to_user": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1505293417,
                "post_id": 46188224,
                "comment_id": 79348622,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1505293810,
                "post_id": 46188224,
                "comment_id": 79348926,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 3,
        "last_activity_date": 1505272141,
        "creation_date": 1505272141,
        "question_id": 46188224,
        "body_markdown": "Given a JSON file, `arguments.json`:\r\n\r\n    {&quot;dagger&quot;: true, &quot;version&quot;: false, &quot;nether_strike&quot;: true, \r\n     &quot;greater_bash&quot;: &quot;5&quot;, &quot;FILE&quot;: &quot;ancientscroll.txt&quot;, \r\n     &quot;empower_haste&quot;: &quot;1&quot;, &quot;help&quot;: false}\r\n\r\nWhen calling reading the variables as such:\r\n\r\n    #!/bin/bash\r\n    dagger=$(cat arguments.json | jq &#39;.[&quot;dagger&quot;]&#39;)\r\n    greater_bash =$(cat arguments.json | jq &#39;.[&quot;greater_bash&quot;]&#39;)    \r\n    \r\n    echo $dagger\r\n    echo $greater_bash\r\n\r\n[out]:\r\n\r\n    true\r\n    &quot;5&quot;\r\n\r\nThe variable contains the quotation marks `&quot;&quot;`.\r\n\r\n**How to remove the quotes when reading a variable in jq?** \r\n\r\n\r\n---- \r\n\r\nI could use `sed` to strip the quotes as such:\r\n\r\n    greater_bash =$(cat arguments.json | jq &#39;.[&quot;greater_bash&quot;]&#39; | sed -e &#39;s/^&quot;//&#39; -e &#39;s/&quot;$//&#39;)\r\n    echo $greater_bash\r\n\r\n\r\n[out]:\r\n\r\n    5\r\n\r\n**But is there a way to just strip the quotes when reading from `jq`?**",
        "link": "https://stackoverflow.com/questions/46188224/how-to-remove-the-quotes-when-reading-a-variable-in-jq-in-shell",
        "title": "How to remove the quotes when reading a variable in jq in shell?"
    },
    {
        "tags": [
            "json",
            "firefox",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1586029382,
                "last_edit_date": 1586029382,
                "creation_date": 1505335929,
                "answer_id": 46206648,
                "question_id": 46206367,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution using [tostream](https://stedolan.github.io/jq/manual/#tostream):    \r\n\r\n        tostream                       # read [[path],value] and [[path]] stream\r\n      | select(length==2) as [$p,$v]   # put [path] in $p and value in $v\r\n      | select($p[-1] == &quot;uri&quot;)        # keep paths ending in &quot;uri&quot;\r\n      | $v                             # emit value\r\n\r\nIf the above filter is in `filter.jq` and `data.json` contains the following sample bookmark data:\r\n\r\n    {\r\n      &quot;guid&quot;: &quot;root________&quot;,\r\n      &quot;title&quot;: &quot;&quot;,\r\n      &quot;index&quot;: 0,\r\n      &quot;dateAdded&quot;: 1000000000000000,\r\n      &quot;lastModified&quot;: 1000000000000000,\r\n      &quot;id&quot;: 1,\r\n      &quot;type&quot;: &quot;text/x-moz-place-container&quot;,\r\n      &quot;root&quot;: &quot;placesRoot&quot;,\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;guid&quot;: &quot;menu________&quot;,\r\n          &quot;title&quot;: &quot;Bookmarks Menu&quot;,\r\n          &quot;index&quot;: 0,\r\n          &quot;dateAdded&quot;: 1000000000000000,\r\n          &quot;lastModified&quot;: 1000000000000000,\r\n          &quot;id&quot;: 2,\r\n          &quot;type&quot;: &quot;text/x-moz-place-container&quot;,\r\n          &quot;root&quot;: &quot;bookmarksMenuFolder&quot;,\r\n          &quot;children&quot;: [\r\n            {\r\n              &quot;guid&quot;: &quot;ygE5SOG8IWid&quot;,\r\n              &quot;title&quot;: &quot;Stack Overflow&quot;,\r\n              &quot;index&quot;: 0,\r\n              &quot;dateAdded&quot;: 1000000000000000,\r\n              &quot;lastModified&quot;: 1000000000000000,\r\n              &quot;id&quot;: 3,\r\n              &quot;iconuri&quot;: &quot;https://cdn.sstatic.net/Sites/stackoverflow/img/favicon.ico?v=4f32ecc8f43d&quot;,\r\n              &quot;annos&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;bookmarkProperties/description&quot;,\r\n                  &quot;flags&quot;: 0,\r\n                  &quot;expires&quot;: 4,\r\n                  &quot;value&quot;: &quot;Stack Overflow is the largest, most trusted online community for developers to learn, share​ ​their programming ​knowledge, and build their careers.&quot;\r\n                }\r\n              ],\r\n              &quot;type&quot;: &quot;text/x-moz-place&quot;,\r\n              &quot;uri&quot;: &quot;https://stackoverflow.com/&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n     \r\nThen the command\r\n\r\n    $ jq -Mr -f filter.jq data.json\r\n\r\nproduces\r\n\r\n    https://stackoverflow.com/\r\n    ",
                "title": "How to parse Firefox manual JSON bookmarks backup using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1586029382,
        "creation_date": 1505334753,
        "question_id": 46206367,
        "body_markdown": "I&#39;ve created my own JSON bookmark backup according to this page : \r\n[http://kb.mozillazine.org/Backing_up_and_restoring_bookmarks_-_Firefox#Creating_bookmark_backups][1]\r\n\r\nI won&#39;t post my JSON bookmark backup file here (it&#39;s too big), you can create your own file and have a look at the entire file.\r\n\r\nThen for testing I just tried to get the uri of all bookmarks (later I will extract other datas too) but this didn&#39;t work\r\n\r\n    jq -r &#39;.[] | .uri&#39; bookmarks-2017-09-13.json \r\n    jq: error (at bookmarks-2017-09-13.json:1): Cannot index string with string &quot;uri&quot;\r\n\r\n    jq -r &#39;.uri&#39; bookmarks-2017-09-13.json \r\n    null\r\n\r\nVersion of Firefox : Firefox 55.0.2 (64 bits) with Ubuntu 16.04 LTS\r\n\r\nVersion of jq : jq-1.5-1-a5b5cbe\r\n\r\nRegards\r\n\r\n\r\n  [1]: http://kb.mozillazine.org/Backing_up_and_restoring_bookmarks_-_Firefox#Creating_bookmark_backups",
        "link": "https://stackoverflow.com/questions/46206367/how-to-parse-firefox-manual-json-bookmarks-backup-using-jq",
        "title": "How to parse Firefox manual JSON bookmarks backup using jq?"
    },
    {
        "tags": [
            "json",
            "edit",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2589204,
                    "reputation": 3696,
                    "user_id": 2244262,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/b3ad659289193a70a3eed1c45159ce79?s=256&d=identicon&r=PG",
                    "display_name": "Stalinko",
                    "link": "https://stackoverflow.com/users/2244262/stalinko"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1505384161,
                "post_id": 46216346,
                "comment_id": 79395410,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2595479,
                    "reputation": 432,
                    "user_id": 2249284,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/112f12fbec3402bbb4dea3aed8d0dd83?s=256&d=identicon&r=PG",
                    "display_name": "ITL",
                    "link": "https://stackoverflow.com/users/2249284/itl"
                },
                "reply_to_user": {
                    "account_id": 2589204,
                    "reputation": 3696,
                    "user_id": 2244262,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/b3ad659289193a70a3eed1c45159ce79?s=256&d=identicon&r=PG",
                    "display_name": "Stalinko",
                    "link": "https://stackoverflow.com/users/2244262/stalinko"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1505384352,
                "post_id": 46216346,
                "comment_id": 79395514,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1505387071,
                "creation_date": 1505387071,
                "answer_id": 46217413,
                "question_id": 46216346,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**jq** solution:\r\n\r\n    jq --slurpfile repl repl.json &#39;.manipulate=[.manipulate[] \r\n         | if .type==&quot;replace&quot; then .=$repl[0] else . end]&#39; config.json\r\n\r\n- `repl.json` - json file containing replacement JSON data\r\n\r\n- `--slurpfile repl repl.json` - reads all the JSON texts in the named file and binds an array of the parsed JSON values to the given global variable\r\n\r\nThe output:\r\n\r\n    {\r\n      &quot;keep&quot;: &quot;whatever type of value&quot;,\r\n      &quot;manipulate&quot;: [\r\n        {\r\n          &quot;foo&quot;: &quot;bar&quot;,\r\n          &quot;cat&quot;: {\r\n            &quot;color&quot;: &quot;grey&quot;\r\n          },\r\n          &quot;type&quot;: &quot;keep&quot;,\r\n          &quot;detail&quot;: &quot;keep whole array element&quot;\r\n        },\r\n        {\r\n          &quot;stuff&quot;: &quot;i want that&quot;,\r\n          &quot;fancy&quot;: &quot;very&quot;,\r\n          &quot;type&quot;: &quot;new&quot;\r\n        },\r\n        {\r\n          &quot;foz&quot;: &quot;baz&quot;,\r\n          &quot;dog&quot;: {\r\n            &quot;color&quot;: &quot;brown&quot;\r\n          },\r\n          &quot;type&quot;: &quot;keep&quot;,\r\n          &quot;detail&quot;: &quot;keep whole array element&quot;\r\n        }\r\n      ],\r\n      &quot;also_keep&quot;: &quot;whatever type of value&quot;\r\n    }\r\n\r\n",
                "title": "Replace array element within JSON hash with content from other file"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1505423287,
                "creation_date": 1505423287,
                "answer_id": 46228246,
                "question_id": 46216346,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq --slurpfile repl repl.json &#39;.manipulate |= \r\n      map(if .type==&quot;replace&quot; then $repl[0] else . end)&#39; config.json",
                "title": "Replace array element within JSON hash with content from other file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1505923016,
        "creation_date": 1505383899,
        "last_edit_date": 1505923016,
        "question_id": 46216346,
        "body_markdown": "I have got a configuration with content to be exchanged with snippets from separate file. How would I neatly achieve this?\r\n\r\nConfig file might look like:\r\n\r\n    # config file\r\n\t{\r\n\t\t&quot;keep&quot;: &quot;whatever type of value&quot;,\r\n\t\t&quot;manipulate&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;foo&quot;: &quot;bar&quot;,\r\n\t\t\t\t&quot;cat&quot;: {\r\n\t\t\t\t\t&quot;color&quot;: &quot;grey&quot;\r\n\t\t\t\t},\r\n\t\t\t\t&quot;type&quot;: &quot;keep&quot;,\r\n\t\t\t\t&quot;detail&quot;: &quot;keep whole array element&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;stuff&quot;: &quot;obsolete&quot;,\r\n\t\t\t\t&quot;more_stuff&quot;: &quot;obsolete&quot;,\r\n\t\t\t\t&quot;type&quot;: &quot;replace&quot;,\r\n\t\t\t\t&quot;detail&quot;: &quot;replace whole array element with content from separate file&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;foz&quot;: &quot;baz&quot;,\r\n\t\t\t\t&quot;dog&quot;: {\r\n\t\t\t\t\t&quot;color&quot;: &quot;brown&quot;\r\n\t\t\t\t},\r\n\t\t\t\t&quot;type&quot;: &quot;keep&quot;,\r\n\t\t\t\t&quot;detail&quot;: &quot;keep whole array element&quot;\r\n\t\t\t},\r\n\r\n\t\t],\r\n\t\t&quot;also_keep&quot;: &quot;whatever type of value&quot;\r\n\t}\r\n\r\nThe content (coming **from separate file**) to be inserted as a replacement of _obsolete_ array element:\r\n\r\n    # replacement\r\n\t{\r\n\t\t&quot;stuff&quot;: &quot;i want that&quot;,\r\n\t\t&quot;fancy&quot;: &quot;very&quot;,\r\n\t\t&quot;type&quot;: &quot;new&quot;\r\n\t}\r\n\r\nThe desired result should look like:\r\n\r\n    # result\r\n\t{\r\n\t\t&quot;keep&quot;: &quot;whatever kind of value&quot;,\r\n\t\t&quot;manipulate&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;foo&quot;: &quot;bar&quot;,\r\n\t\t\t\t&quot;cat&quot;: {\r\n\t\t\t\t\t&quot;color&quot;: &quot;grey&quot;\r\n\t\t\t\t},\r\n\t\t\t\t&quot;type&quot;: &quot;keep&quot;,\r\n\t\t\t\t&quot;detail&quot;: &quot;keep whole array element&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;stuff&quot;: &quot;i want that&quot;,\r\n\t\t\t\t&quot;fancy&quot;: &quot;very&quot;,\r\n\t\t\t\t&quot;type&quot;: &quot;new&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;foz&quot;: &quot;baz&quot;,\r\n\t\t\t\t&quot;dog&quot;: {\r\n\t\t\t\t\t&quot;color&quot;: &quot;brown&quot;\r\n\t\t\t\t},\r\n\t\t\t\t&quot;type&quot;: &quot;keep&quot;,\r\n\t\t\t\t&quot;detail&quot;: &quot;keep whole array element&quot;\r\n\t\t\t},\r\n\r\n\t\t],\r\n\t\t&quot;also_keep&quot;: &quot;whatever kind of value&quot;,\r\n\t}\r\n\r\nRequirements:\r\n\r\n - Content replacement needs to be done based on `type` key&#39;s value.\r\n - Preferably use `jq` and common bash/linux tools.\r\n - Array element ordering should stay same",
        "link": "https://stackoverflow.com/questions/46216346/replace-array-element-within-json-hash-with-content-from-other-file",
        "title": "Replace array element within JSON hash with content from other file"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2387472,
                    "reputation": 74949,
                    "user_id": 2088135,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://i.sstatic.net/YB10Q.jpg?s=256",
                    "display_name": "Tom Fenech",
                    "link": "https://stackoverflow.com/users/2088135/tom-fenech"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1505422892,
                "post_id": 46227984,
                "comment_id": 79420210,
                "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": 1505424139,
                "post_id": 46227984,
                "comment_id": 79420715,
                "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": 1505520631,
                "post_id": 46227984,
                "comment_id": 79461993,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1505422502,
                "creation_date": 1505422502,
                "answer_id": 46228077,
                "question_id": 46227984,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just correct your approach to the following:\r\n\r\n    echo &quot;$pollresp&quot; | jq &#39;.ImportImageTasks[] | select(.ImportTaskId==&quot;import-ami-123456&quot;) | .ImportTaskId,.Status,.StatusMessage&#39;\r\n\r\nThe output:\r\n\r\n    &quot;import-ami-123456&quot;\r\n    &quot;deleted&quot;\r\n    &quot;User initiated task cancelation&quot;\r\n\r\n",
                "title": "keep spaces when printing using printf"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1505424858,
                "last_edit_date": 1505424858,
                "creation_date": 1505423222,
                "answer_id": 46228233,
                "question_id": 46227984,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Bash by default splits arguments on spaces, so the output of your echo is being split on spaces. \r\n\r\n    jq &#39;.ImportImageTasks[] | select(.ImportTaskId==&quot;import-ami-123456&quot;) | .ImportTaskId,.Status,.StatusMessage&#39; &lt;&lt;&lt; &quot;$pollresp&quot;\r\n\r\nWill output:\r\n\r\n    &quot;import-ami-123456&quot;\r\n    &quot;deleted&quot;\r\n    &quot;User initiated task cancelation&quot;",
                "title": "keep spaces when printing using printf"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1505424781,
                "last_edit_date": 1505424781,
                "creation_date": 1505424402,
                "answer_id": 46228487,
                "question_id": 46227984,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Written for clarity and readability, this might look like:\r\n\r\n    #!/usr/bin/env bash\r\n\r\n    jq_script=&#39;\r\n    .ImportImageTasks[]\r\n    | select(.ImportTaskId==&quot;import-ami-123456&quot;)\r\n    | [.ImportTaskId, .Status, .StatusMessage]\r\n    | @tsv\r\n    &#39;\r\n    \r\n    while IFS=$&#39;\\t&#39; read -r importTaskId status statusMessage; do\r\n      printf &#39;%s\\n&#39; &quot;$importTaskId&quot; &quot;$status&quot; &quot;$statusMessage&quot;\r\n    done &lt; &lt;(jq -r &quot;$jq_script&quot; &lt;&lt;&lt;&quot;$pollresp&quot;)\r\n\r\nNote the `@tsv` on the end of the `jq` pipeline -- that generates tab-separated output, which the `while IFS=$&#39;\\t&#39; read -r var1 var2 var3` loop -- as described in [BashFAQ #1](http://mywiki.wooledge.org/BashFAQ/001) -- iterates over.\r\n\r\n&lt;sub&gt;&lt;i&gt;(If doing this in a security-sensitive context, I would suggest amending your `jq` expressions to strip tabs and newlines from content fields -- or, if those are legitimate data, [switching to NUL delimiters](https://github.com/stedolan/jq/issues/1271) and stripping those).&lt;/i&gt;&lt;/sub&gt;",
                "title": "keep spaces when printing using printf"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1505425242,
                "last_edit_date": 1505425242,
                "creation_date": 1505424538,
                "answer_id": 46228519,
                "question_id": 46227984,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The issue is not with `jq`, it&#39;s with the way you&#39;re using the bash subshell.  Here is a script that demonstrates the difference.\r\n\r\n    #!/bin/bash\r\n    pollresp=&#39;{\r\n        &quot;ImportImageTasks&quot;: [\r\n            {\r\n                &quot;Description&quot;: &quot;SP&quot;,\r\n                &quot;ImportTaskId&quot;: &quot;import-ami-123456&quot;,\r\n                &quot;Status&quot;: &quot;deleted&quot;,\r\n                &quot;StatusMessage&quot;: &quot;User initiated task cancelation&quot;\r\n            }\r\n        ]\r\n    }&#39;\r\n    \r\n    filter=&#39;\r\n        .ImportImageTasks[] \r\n      | select(.ImportTaskId==&quot;import-ami-123456&quot;) \r\n      | .ImportTaskId,.Status,.StatusMessage\r\n    &#39;\r\n    \r\n    \r\n    echo _________________________ with printf &quot;%s\\n%s\\n%s&quot; unquoted subshell\r\n    printf &quot;%s\\n%s\\n%s&quot; $(echo ${pollresp} | jq &quot;$filter&quot;)\r\n    \r\n    echo\r\n    echo _________________________ with printf &quot;%s\\n&quot; quoted subshell\r\n    printf &quot;%s\\n&quot; &quot;$(echo ${pollresp} | jq &quot;$filter&quot;)&quot;\r\n    \r\n    echo _________________________ with no subshell\r\n    jq &quot;$filter&quot; &lt;&lt;&lt; &quot;$pollresp&quot;\r\n    \r\n    echo _________________________ with while/read\r\n    while read -r ImportTaskId\r\n          read -r Status\r\n          read -r StatusMessage\r\n    do\r\n        printf &quot;%s\\n%s\\n%s\\n&quot; &quot;$ImportTaskId&quot; &quot;$Status&quot; &quot;$StatusMessage&quot;\r\n    done &lt; &lt;(jq &quot;$filter&quot; &lt;&lt;&lt; &quot;$pollresp&quot;)\r\n    echo _________________________ \r\n\r\n\r\nHere is the output demonstrating the difference.  I would recommend the while/read approach if you want to further format or process the result from jq in bash.\r\n\r\n    _________________________ with printf %s\\n%s\\n%s unquoted subshell\r\n    &quot;import-ami-123456&quot;\r\n    &quot;deleted&quot;\r\n    &quot;Userinitiated\r\n    task\r\n    cancelation&quot;\r\n    _________________________ with printf %s\\n quoted subshell\r\n    &quot;import-ami-123456&quot;\r\n    &quot;deleted&quot;\r\n    &quot;User initiated task cancelation&quot;\r\n    _________________________ with no subshell\r\n    &quot;import-ami-123456&quot;\r\n    &quot;deleted&quot;\r\n    &quot;User initiated task cancelation&quot;\r\n    _________________________ with while/read\r\n    &quot;import-ami-123456&quot;\r\n    &quot;deleted&quot;\r\n    &quot;User initiated task cancelation&quot;\r\n    _________________________\r\n",
                "title": "keep spaces when printing using printf"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": -1,
        "last_activity_date": 1505425242,
        "creation_date": 1505422047,
        "question_id": 46227984,
        "body_markdown": "This is how my input looks like:\r\n\r\n    pollresp={\r\n        &quot;ImportImageTasks&quot;: [\r\n            {\r\n                &quot;Description&quot;: &quot;SP&quot;,\r\n                &quot;ImportTaskId&quot;: &quot;import-ami-123456&quot;,\r\n                &quot;Status&quot;: &quot;deleted&quot;,\r\n                &quot;StatusMessage&quot;: &quot;User initiated task cancelation&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nUsing jq, I am filtering the object based on ImportTaskId and printing Status and StatusMessage.\r\n\r\nThis is how my filter expression looks like:\r\n\r\n    printf &quot;%s\\n%s\\n%s&quot; $(echo ${pollresp} |  jq &#39;.ImportImageTasks[] | select(.ImportTaskId==&quot;import-ami-123456&quot;) | .ImportTaskId,.Status,.StatusMessage&#39;)\r\n\r\nOutput comes as:\r\n\r\n    &quot;import-ami-123456&quot;\r\n    &quot;deleted&quot;\r\n    &quot;Userinitiated\r\n    task\r\n    cancelation&quot;\r\n\r\nStatusMessage has spaces. I am trying to preserve the spaces and get the output as:\r\n\r\n    &quot;import-ami-123456&quot;\r\n    &quot;deleted&quot;\r\n    &quot;User initiated task cancelation&quot;\r\n\r\nHow do I do it?",
        "link": "https://stackoverflow.com/questions/46227984/keep-spaces-when-printing-using-printf",
        "title": "keep spaces when printing using printf"
    },
    {
        "tags": [
            "json",
            "bash",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1505428025,
                "post_id": 46229097,
                "comment_id": 79422110,
                "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": 1505428087,
                "post_id": 46229097,
                "comment_id": 79422134,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1505428469,
                "creation_date": 1505428469,
                "answer_id": 46229168,
                "question_id": 46229097,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`to_entries` has nothing whatsoever to do with exposing JQ results to bash. Rather, it takes each entry in a JSON object and emits a `{&quot;key&quot;: key, &quot;value&quot;: value}` pair.\r\n\r\nThat *can* be useful, if you want to identify and extract arbitrary keys. For example:\r\n\r\n    #!/usr/bin/env bash\r\n\r\n    jq_script=&#39;\r\n    .profile.download.entries[]\r\n    | select(.store == &quot;A&quot;)\r\n    | to_entries[]\r\n    | select(.key != &quot;store&quot;)\r\n    | select(.key != &quot;type&quot;)\r\n    | [.key, .value]\r\n    | @tsv\r\n    &#39;\r\n    \r\n    declare -A array=( )\r\n    while IFS=$&#39;\\t&#39; read -r key value; do\r\n      array[$key]=$value\r\n    done &lt; &lt;(jq -r &quot;$jq_script&quot;)\r\n\r\n    # print array output\r\n    declare -p array\r\n\r\n...will, when given your input on stdin, emit (albeit on a single line, without the whitespace changes):\r\n\r\n    declare -A array=([ENTRY_A]=&quot;testserver1_place_com&quot;\r\n                      [ENTRY_B]=&quot;testserver2_anotherplace_com&quot; )\r\n\r\n...which I *assume*, for lack of any better description in the question, is what you actually want.",
                "title": "Convert a nested JSON of objects into array into a bash array using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1505430863,
                "creation_date": 1505430863,
                "answer_id": 46229483,
                "question_id": 46229097,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a slightly different approach (with some cleaned-up data) which captures the output from `jq` into separate column arrays.\r\n\r\n    #!/bin/bash\r\n    data=&#39;{\r\n      &quot;profile&quot;: {\r\n        &quot;name&quot;: &quot;TesterRun1&quot;,\r\n        &quot;download&quot;: {\r\n          &quot;entries&quot;: [\r\n            {\r\n              &quot;entry&quot;: &quot;testserver1_place_com&quot;,\r\n              &quot;store&quot;: &quot;A&quot;,\r\n              &quot;type&quot;: &quot;direct&quot;\r\n            },\r\n            {\r\n              &quot;entry&quot;: &quot;testserver2_anotherplace_com&quot;,\r\n              &quot;store&quot;: &quot;B&quot;,\r\n              &quot;type&quot;: &quot;bypass&quot;\r\n            },\r\n            {\r\n              &quot;entry&quot;: &quot;testserver2_anotherplace_com&quot;,\r\n              &quot;store&quot;: &quot;A&quot;,\r\n              &quot;type&quot;: &quot;bypass&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }&#39;\r\n    filter=&#39;\r\n            .profile.download.entries[]\r\n          | select(.store == &quot;A&quot;)\r\n          | .entry, .store, .type\r\n    &#39;      \r\n    declare -a ENTRY\r\n    declare -a STORE\r\n    declare -a TYPE\r\n    i=0\r\n    while read -r entry; read -r store; read -r type; do\r\n        ENTRY[$i]=&quot;$entry&quot;\r\n        STORE[$i]=&quot;$store&quot;\r\n        TYPE[$i]=&quot;$type&quot;\r\n        i=$((i + 1))\r\n    done &lt; &lt;(jq -Mr &quot;$filter&quot; &lt;&lt;&lt; &quot;$data&quot;)\r\n    declare -p ENTRY STORE TYPE\r\n\r\nOutput\r\n\r\n    declare -a ENTRY=&#39;([0]=&quot;testserver1_place_com&quot; [1]=&quot;testserver2_anotherplace_com&quot;)&#39;\r\n    declare -a STORE=&#39;([0]=&quot;A&quot; [1]=&quot;A&quot;)&#39;\r\n    declare -a TYPE=&#39;([0]=&quot;direct&quot; [1]=&quot;bypass&quot;)&#39;\r\n\r\n",
                "title": "Convert a nested JSON of objects into array into a bash array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1505430863,
        "creation_date": 1505427939,
        "question_id": 46229097,
        "body_markdown": "I am doing something fundamentally wrong but just can&#39;t see what, could some kind person point out my fault with jq or JSON here?\r\n\r\nI have the the following child objects contained within an array “`entries`”\r\n\r\n    {\r\n    \t&quot;profile&quot;: {\r\n    \t\t&quot;name&quot;: &quot;TesterRun1&quot;,\r\n    \t\t&quot;download&quot;: {\r\n    \t\t\t&quot;entries&quot;: [{\r\n    \t\t\t\t\t&quot;ENTRY_A&quot;: &quot;testserver1_place_com&quot;,\r\n    \t\t\t\t\t&quot;store&quot;: &quot;A&quot;,\r\n    \t\t\t\t\t&quot;type&quot;: &quot;direct&quot;\r\n    \t\t\t\t},\r\n    \t\t\t\t{\r\n    \t\t\t\t\t&quot;ENTRY_B&quot;: &quot;testserver2_anotherplace_com&quot;,\r\n    \t\t\t\t\t&quot;store&quot;: &quot;B&quot;,\r\n    \t\t\t\t\t&quot;type&quot;: &quot;bypass&quot;\r\n    \t\t\t\t},\r\n    \t\t\t\t{\r\n    \t\t\t\t\t&quot;ENTRY_B&quot;: &quot;testserver2_anotherplace_com&quot;,\r\n    \t\t\t\t\t&quot;store&quot;: &quot;A&quot;,\r\n    \t\t\t\t\t&quot;type&quot;: &quot;bypass&quot;\r\n    \t\t\t\t}\r\n    \t\t\t]\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\nI wish to convert these to an array accessible by bash via the jq function “`to_entries`” using the below query but so far nothing! \r\n\r\n    jq &#39;to_entries|.[]|.profile.download.entries|select(.store==&quot;A&quot;)|.[]&#39;\r\n\r\nYou can see here that nothing is returned on JQ Play - [enter link description here][1]\r\n    \r\nPlease help save my sanity, what am I doing wrong\r\n\r\n\r\n  [1]: https://jqplay.org/s/KqWlUhmbls",
        "link": "https://stackoverflow.com/questions/46229097/convert-a-nested-json-of-objects-into-array-into-a-bash-array-using-jq",
        "title": "Convert a nested JSON of objects into array into a bash array using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1505484833,
                "last_edit_date": 1505484833,
                "creation_date": 1505484226,
                "answer_id": 46241485,
                "question_id": 46241435,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You still need to get to that point; you haven&#39;t done the `jq` equivalent of `cd` or anything. You need to flatten the array returned by `episodes[1:]` by adding another set of brackets. Also, you skipped the resolution level (`&quot;720p&quot;`).  Putting that all together, this should work. It will output one duration value per line, unquoted:\r\n\r\n    jq -r &#39;.episodes[1:][].media[&quot;720p&quot;].duration&#39;\r\n\r\nNote that you can&#39;t use the dot syntax on `720p` (*`media.720p.duration`) because that key starts with a digit.\r\n\r\nNote that your JSON snippet is technically invalid; strict JSON doesn&#39;t allow commas at the end of a list. I corrected that and wrapped a structure it to match your query:\r\n\r\n    {\r\n      &quot;episodes&quot;: [\r\n        {},\r\n        {\r\n          &quot;uniqueHash&quot;: &quot;a2dc48cd0f9&quot;,\r\n          &quot;startOffset&quot;: &quot;{0}&quot;,\r\n          &quot;media&quot;: {\r\n            &quot;720p&quot;: {\r\n              &quot;extension&quot;: &quot;mp4&quot;,\r\n              &quot;filesize&quot;: &quot;1702&quot;,\r\n              &quot;duration&quot;: &quot;00:51:55&quot;\r\n            }\r\n          }\r\n        },\r\n        {\r\n          &quot;uniqueHash&quot;: &quot;a2d0f9&quot;,\r\n          &quot;startOffset&quot;: &quot;{0}&quot;,\r\n          &quot;media&quot;: {\r\n            &quot;720p&quot;: {\r\n              &quot;extension&quot;: &quot;mp4&quot;,\r\n              &quot;filesize&quot;: &quot;12602&quot;,\r\n              &quot;duration&quot;: &quot;00:51:55&quot;\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nRunning `jq -r &#39;.episodes[1:][]|.media[&quot;720p&quot;].duration&#39;` on the above yields this output:\r\n\r\n    00:51:55\r\n    00:51:55",
                "title": "How to search in json with jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1505487710,
                "last_edit_date": 1505487710,
                "creation_date": 1505484392,
                "answer_id": 46241544,
                "question_id": 46241435,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use `map()`:\r\n\r\n    $ cat test.json | jq -r &#39;.episodes[1:] | map(.media[&quot;720p&quot;].duration)&#39;\r\n    [\r\n      &quot;00:51:55&quot;,\r\n      &quot;00:51:55&quot;\r\n    ]\r\n\r\nBecause `.episodes[1:]` gives you a list, you need to iter over it. [`map(&lt;selector&gt;)`](https://stedolan.github.io/jq/manual/#map(x),map_values(x)) is what you want here.\r\n\r\nAlternatively, you could flatten the list using [`.[]`](https://stedolan.github.io/jq/manual/#Array/ObjectValueIterator:.[]):\r\n\r\n    $ cat test.json | jq -r &quot;.episodes[1:] | .[] | .media[\\&quot;720p\\&quot;].duration&quot; \r\n    00:51:55\r\n    00:51:55\r\n\r\n---\r\n\r\nThe above solutions assume you always have `720p`. This might not always be the case, so you can use [`to_entries`](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries) to get all resolutions:\r\n\r\n    $ cat test.json | jq -r &quot;.episodes[1:] | map(.media|to_entries[]|.value.duration)&quot;\r\n    [\r\n      &quot;00:51:55&quot;,\r\n      &quot;00:51:55&quot;\r\n    ]",
                "title": "How to search in json with jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1505485784,
                "creation_date": 1505485784,
                "answer_id": 46241994,
                "question_id": 46241435,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you just want to pull any `duration` value in your json tree, you could just recurse and try to pull the `duration` discarding null results.\r\n\r\n    .. | objects.duration? // empty\r\n\r\nTo be more explicit and only pull `duration` values, you could analyze the paths to the values and select the `duration` values only.\r\n\r\n    getpath(leaf_paths | select(.[-1] == &quot;duration&quot;))\r\n",
                "title": "How to search in json with jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1505488651,
                "creation_date": 1505488651,
                "answer_id": 46242801,
                "question_id": 46241435,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a variation using [tostream](https://stedolan.github.io/jq/manual/#tostream).  If the (slightly corrected) sample data is in `data.json` then the command\r\n\r\n    $ jq -Mr &#39; \r\n        tostream                        # generate [[path],value] pairs from input\r\n      | select(length==2) as [$p,$v]    # assign [path] to $p and value to $v\r\n      | select($p[-1]==&quot;duration&quot;)      # keep paths ending in &quot;duration&quot;\r\n      | $v                              # emit value\r\n    &#39; data.json\r\n\r\nproduces\r\n\r\n    00:51:55\r\n    00:51:55\r\n\r\nThis should work on the original JSON data as well as the `.media.duration` sample data subtree.",
                "title": "How to search in json with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 3,
        "last_activity_date": 1505488651,
        "creation_date": 1505484055,
        "last_edit_date": 1505484761,
        "question_id": 46241435,
        "body_markdown": "How can I output just the `duration` values from below?\r\n\r\nIf I search for `jq -r &quot;.media.duration&quot;` then I get `nil`.\r\n\r\n    $ cat test.json | jq -r &quot;.episodes[1:]&quot; \r\n    [\r\n      {\r\n        &quot;uniqueHash&quot;: &quot;a2dc48cd0f9&quot;,\r\n        &quot;startOffset&quot;: &quot;{0}&quot;,\r\n        &quot;media&quot;: {\r\n          &quot;720p&quot;: {\r\n            &quot;extension&quot;: &quot;mp4&quot;,\r\n            &quot;filesize&quot;: &quot;1702&quot;,\r\n            &quot;duration&quot;: &quot;00:51:55&quot;,\r\n          },\r\n        }\r\n      },\r\n      {\r\n        &quot;uniqueHash&quot;: &quot;a2d0f9&quot;,\r\n        &quot;startOffset&quot;: &quot;{0}&quot;,\r\n        &quot;media&quot;: {\r\n          &quot;720p&quot;: {\r\n            &quot;extension&quot;: &quot;mp4&quot;,\r\n            &quot;filesize&quot;: &quot;12602&quot;,\r\n            &quot;duration&quot;: &quot;00:51:55&quot;,\r\n          },\r\n        }\r\n      },\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/46241435/how-to-search-in-json-with-jq",
        "title": "How to search in json with jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1505518327,
                "creation_date": 1505518327,
                "answer_id": 46248654,
                "question_id": 46248576,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "do you need to use `|=`?  If not could you use ordinary assignment?  e.g.\r\n\r\n    jq -Mnc &#39;\r\n          {&quot;x&quot;: {&quot;y&quot;: 5}} | if .x.y != null then .x.y = 123 else . end\r\n        , {&quot;x&quot;: {&quot;z&quot;: 9}} | if .x.y != null then .x.y = 123 else . end\r\n    &#39;\r\n    \r\noutput\r\n\r\n    {&quot;x&quot;:{&quot;y&quot;:123}}\r\n    {&quot;x&quot;:{&quot;z&quot;:9}}    ",
                "title": "jq: how to only update data if existing?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1505551048,
                "creation_date": 1505551048,
                "answer_id": 46251906,
                "question_id": 46248576,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With built-in `has()` function:\r\n\r\n    jq -nc &#39;{&quot;x&quot;:{&quot;y&quot;: 5}} | if (.x | has(&quot;y&quot;)) then .x.y=123 else empty end&#39;\r\nThe output:\r\n\r\n    {&quot;x&quot;:{&quot;y&quot;:123}}\r\n\r\n",
                "title": "jq: how to only update data if existing?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1505552909,
                "creation_date": 1505552909,
                "answer_id": 46252163,
                "question_id": 46248576,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using streams could actually handle this quite nicely. A stream for an object will yield paths and values to actual existing values in your input. So search for the pairs that contain your path and update the value while rebuilding the stream.\r\n\r\n    $ jq --argjson path &#39;[&quot;x&quot;,&quot;y&quot;]&#39; --argjson new &#39;123&#39; &#39;\r\n    fromstream(tostream|select(length == 2 and .[0] == $path)[1] = $new)\r\n    &#39; input.json",
                "title": "jq: how to only update data if existing?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1505870603,
                "creation_date": 1505870603,
                "answer_id": 46311862,
                "question_id": 46248576,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Both the following produce the desired results (whether using 1.5 or later), but there are important differences in the semantics (having to do with the difference between `{&quot;x&quot;: null}` and `{}`):\r\n\r\n    if has(&quot;x&quot;) and (.x | has(&quot;y&quot;)) then .x.y = 123 else . end\r\n&lt;br/&gt;\r\n\r\n    if .x.y? then .x.y = 123 else . end",
                "title": "jq: how to only update data if existing?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1505870603,
        "creation_date": 1505517653,
        "question_id": 46248576,
        "body_markdown": "With dev version of jq, this could be done with `jq &#39;.x.y |= if . then 123 else empty end&#39;`. (Because bug [#13134][1] is solved.)\r\n\r\nHow can I do this in jq 1.5?\r\n\r\nexample:  \r\nin `{&quot;x&quot;: {&quot;y&quot;: 5}}`, y should be changed to 123,  \r\nbut in `{&quot;x&quot;: {&quot;z&quot;: 9}}`, nothing should change.\r\n\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/1314",
        "link": "https://stackoverflow.com/questions/46248576/jq-how-to-only-update-data-if-existing",
        "title": "jq: how to only update data if existing?"
    },
    {
        "tags": [
            "json",
            "object",
            "merge",
            "grouping",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1505572832,
                "creation_date": 1505572832,
                "answer_id": 46255055,
                "question_id": 46254655,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If the sample data is in `data.json`, the command \r\n\r\n    $ jq -Mr &#39;[ group_by(.name)[] | add | tojson ] | join(&quot;,\\n&quot;)&#39; data.json\r\n\r\nwill produce the output\r\n\r\n    {&quot;name&quot;: &quot;alice&quot;, &quot;ipaddress&quot;: &quot;10.10.10.222&quot;, &quot;version&quot;: &quot;6.7&quot;},\r\n    {&quot;name&quot;: &quot;bob&quot;, &quot;ipaddress&quot;: &quot;10.20.20.77&quot;, &quot;version&quot;: &quot;5.2.2&quot;}\r\n\r\n\r\nHowever if what is actually desired is a single array of objects then the command\r\n\r\n    $ jq -M &#39;[group_by(.name)[] | add]&#39; data.json\r\n\r\nproduces\r\n\r\n    [\r\n      {\r\n        &quot;ipaddress&quot;: &quot;10.10.10.222&quot;,\r\n        &quot;name&quot;: &quot;alice&quot;,\r\n        &quot;version&quot;: &quot;6.7&quot;\r\n      },\r\n      {\r\n        &quot;ipaddress&quot;: &quot;10.20.20.77&quot;,\r\n        &quot;name&quot;: &quot;bob&quot;,\r\n        &quot;version&quot;: &quot;5.2.2&quot;\r\n      }\r\n    ]\r\n",
                "title": "How to merge json objects by grouping on key with jq"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1505646030,
                "last_edit_date": 1505646030,
                "creation_date": 1505573675,
                "answer_id": 46255183,
                "question_id": 46254655,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq -c &#39;group_by(.name)[]|add&#39; input.json\r\n\r\nproduces a stream of the JSON objects (i.e. without intervening commas).\r\n\r\nBetter yet would be to avoid `group_by/1` altogether as it involves a sort:\r\n\r\n    def add_by(f):\r\n      reduce .[] as $x ({}; ($x|f) as $f | .[$f] += [$x])\r\n      | [.[] | add];\r\n    \r\n    add_by(.name)\r\n\r\n",
                "title": "How to merge json objects by grouping on key with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1575808895,
        "creation_date": 1505570114,
        "last_edit_date": 1575808895,
        "question_id": 46254655,
        "body_markdown": "I have a JSON list which I want to merge on command line . \r\n\r\n#### Input: \r\n\r\n    [\r\n     {\r\n       &quot;ipaddress&quot;: &quot;10.10.10.222&quot;,\r\n       &quot;name&quot;: &quot;alice&quot;\r\n     },\r\n     {\r\n       &quot;ipaddress&quot;: &quot;10.20.20.77&quot;,\r\n       &quot;name&quot;: &quot;bob&quot;\r\n     },\r\n     {\r\n       &quot;version&quot;: &quot;6.7&quot;,\r\n       &quot;name&quot;: &quot;alice&quot;\r\n     },\r\n     {\r\n       &quot;version&quot;: &quot;5.2.2&quot;,\r\n       &quot;name&quot;: &quot;bob&quot;\r\n     }\r\n    ]\r\n\r\n\r\nExpected Output:\r\n  \r\n    {&quot;name&quot;: &quot;alice&quot;, &quot;ipaddress&quot;: &quot;10.10.10.222&quot;, &quot;version&quot;: &quot;6.7&quot;},\r\n    {&quot;name&quot;: &quot;bob&quot;, &quot;ipaddress&quot;: &quot;10.20.20.77&quot;, &quot;version&quot;: &quot;5.2.2&quot;}\r\n\r\ncan you help me? Thank you.\r\nbernd\r\n",
        "link": "https://stackoverflow.com/questions/46254655/how-to-merge-json-objects-by-grouping-on-key-with-jq",
        "title": "How to merge json objects by grouping on key with jq"
    },
    {
        "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": 1505593119,
                "post_id": 46257850,
                "comment_id": 79479690,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2496029,
                    "reputation": 319,
                    "user_id": 2528481,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/9e6f88950bcae75679e302a52c5d9795?s=256&d=identicon&r=PG",
                    "display_name": "PanwarS87",
                    "link": "https://stackoverflow.com/users/2528481/panwars87"
                },
                "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": 1505594079,
                "post_id": 46257850,
                "comment_id": 79479948,
                "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": 1505595044,
                "post_id": 46257850,
                "comment_id": 79480215,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1505595999,
                "post_id": 46257850,
                "comment_id": 79480440,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1505594769,
                "creation_date": 1505594769,
                "answer_id": 46258294,
                "question_id": 46257850,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I assume you mean you want to store them as *shell* variables. With bash you can write:\r\n\r\n    while read -r user query; do \r\n        echo &quot;user-&gt;$user&quot;\r\n        echo &quot;query-&gt;$query&quot;\r\n    done &lt; &lt;( jq -r &#39;.[] | &quot;\\(.user) \\(.userQuery)&quot;&#39; &lt;&lt;&lt; &quot;$jstring&quot; )\r\n\r\n&lt;!-- --&gt;\r\n\r\n    user-&gt;abc\r\n    query-&gt;select name from abc;\r\n    user-&gt;xyz\r\n    query-&gt;select name from xyz;\r\n    user-&gt;ppp\r\n    query-&gt;select name from ppp;\r\n\r\n\r\n\r\nThe secret sauce is in the formulation of the string inside jq that refers to the object properties with `\\(.user)`\r\n\r\nI&#39;m assuming that the user name does not contain spaces. Otherwise we have to use a different separator in that string, and use `IFS` with the shell read command.",
                "title": "Parsing multiple json values in linux jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1505595887,
                "creation_date": 1505595887,
                "answer_id": 46258413,
                "question_id": 46257850,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**jq** + **bash** solution:\r\n\r\n    #!/bin/bash\r\n    jstring=&#39;[{&quot;userQuery&quot;:&quot;select name from abc;&quot;,&quot;user&quot;:&quot;abc&quot;},{&quot;userQuery&quot;:&quot;select name from xyz;&quot;,&quot;user&quot;:&quot;xyz&quot;},{&quot;userQuery&quot;:&quot;select name from ppp;&quot;,&quot;user&quot;:&quot;ppp&quot;}]&#39;\r\n    \r\n    while IFS=$&#39;\\t&#39; read -r user query; do\r\n        msg=&quot;User: ${user} is running : ${query}&quot;\r\n        mail -s &quot;User query&quot; &quot;youremail@gmail.com&quot; &lt;&lt;&lt; &quot;$msg&quot;\r\n    done &lt; &lt;(jq &#39;.[] | [.user,.userQuery] | @tsv&#39; &lt;&lt;&lt; &quot;$jstring&quot;)\r\n\r\n",
                "title": "Parsing multiple json values in linux jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1505599482,
        "creation_date": 1505591263,
        "question_id": 46257850,
        "body_markdown": "I have json string like this:\r\n\r\n    jstring=&#39;[{&quot;userQuery&quot;:&quot;select name from abc;&quot;,&quot;user&quot;:&quot;abc&quot;},{&quot;userQuery&quot;:&quot;select name from xyz;&quot;,&quot;user&quot;:&quot;xyz&quot;},{&quot;userQuery&quot;:&quot;select name from ppp;&quot;,&quot;user&quot;:&quot;ppp&quot;}]&#39;\r\n\r\nI wrote a simple for loop using jq to extract values but not getting the desired result.\r\n\r\n    for i in `echo $jstring | jq &#39;.[] | [.user, .userQuery]&#39;`; do echo ${i}; done\r\n\r\nWith the help of this line : `echo $jstring | jq &#39;.[] | [.user, .userQuery]&#39;`. I am able to extract below info: \r\n\r\n    [ &quot;abc&quot;, &quot;select name from abc;&quot;][ &quot;xyz&quot;, &quot;select name from xyz;&quot;][ &quot;ppp&quot;, &quot;select name from ppp;&quot;]\r\n\r\nNow, I want two variable &quot;user&quot; &amp; &quot;query&quot; for each array and store that info. &lt;br /&gt;\r\nEg: For [ &quot;abc&quot;, &quot;select name from abc;&quot;] -- user: abc, query: &quot;select name from abc&quot; and store them.\r\n\r\nI am not sure how to iterate over json using jq and get individual values and store them.",
        "link": "https://stackoverflow.com/questions/46257850/parsing-multiple-json-values-in-linux-jq",
        "title": "Parsing multiple json values in linux jq"
    },
    {
        "tags": [
            "json",
            "select",
            "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": 1505745643,
                "post_id": 46281030,
                "comment_id": 79527037,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1505746867,
                "creation_date": 1505746867,
                "answer_id": 46282507,
                "question_id": 46281030,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**jq** solution:\r\n\r\n    jq &#39;[.items[] | if (.spec | has(&quot;taints&quot;) | not) \r\n        or (.spec.taints[] | select(.effect!=&quot;NoSchedule&quot;)) then . else empty end]&#39; your.json\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;apiVersion&quot;: &quot;v1&quot;,\r\n        &quot;kind&quot;: &quot;Node&quot;,\r\n        &quot;metadata&quot;: {\r\n          &quot;annotations&quot;: {\r\n            &quot;node.alpha.kubernetes.io/ttl&quot;: &quot;0&quot;,\r\n            &quot;volumes.kubernetes.io/controller-managed-attach-detach&quot;: &quot;true&quot;\r\n          },\r\n          &quot;creationTimestamp&quot;: &quot;2017-09-14T12:05:42Z&quot;,\r\n          &quot;labels&quot;: {\r\n            &quot;beta.kubernetes.io/arch&quot;: &quot;amd64&quot;,\r\n            &quot;beta.kubernetes.io/os&quot;: &quot;linux&quot;,\r\n            &quot;kubernetes.io/hostname&quot;: &quot;msl-kub02.int.na.myapp.com&quot;\r\n          },\r\n          &quot;name&quot;: &quot;msl-kub02.int.na.myapp.com&quot;,\r\n          &quot;namespace&quot;: &quot;&quot;,\r\n          &quot;resourceVersion&quot;: &quot;123156&quot;,\r\n          &quot;selfLink&quot;: &quot;/api/v1/nodes/msl-kub02.int.na.myapp.com&quot;,\r\n          &quot;uid&quot;: &quot;084f439e-9945-11e7-bf0b-fa163e6604fc&quot;\r\n        },\r\n        &quot;spec&quot;: {\r\n          &quot;externalID&quot;: &quot;msl-kub02.int.na.myapp.com&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\n",
                "title": "Use jq to select objects not containing nested objects"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1505746999,
                "creation_date": 1505746999,
                "answer_id": 46282553,
                "question_id": 46281030,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could use `?` to ignore any errors if a given property or array doesn&#39;t exist. So with that in mind, go through the items where none of them contain a taint effect of `&quot;NoSchedule&quot;`.\r\n\r\n    .items[] | select(all(.spec.taints[]?; .effect != &quot;NoSchedule&quot;))",
                "title": "Use jq to select objects not containing nested objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1505747248,
                "creation_date": 1505747248,
                "answer_id": 46282651,
                "question_id": 46281030,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a filter which should work. \r\n\r\n       .items[]\r\n     | select(.spec.taints | (.==null) or (any(.effect==&quot;NoSchedule&quot;)|not))",
                "title": "Use jq to select objects not containing nested objects"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1505749881,
        "creation_date": 1505742736,
        "last_edit_date": 1505749881,
        "question_id": 46281030,
        "body_markdown": "I have following JSON:\r\n      \r\n    {\r\n    &quot;apiVersion&quot;: &quot;v1&quot;,\r\n    &quot;items&quot;: [\r\n        {\r\n            &quot;apiVersion&quot;: &quot;v1&quot;,\r\n            &quot;kind&quot;: &quot;Node&quot;,\r\n            &quot;metadata&quot;: {\r\n                &quot;annotations&quot;: {\r\n                    &quot;node.alpha.kubernetes.io/ttl&quot;: &quot;0&quot;,\r\n                    &quot;volumes.kubernetes.io/controller-managed-attach-detach&quot;: &quot;true&quot;\r\n                },\r\n                &quot;creationTimestamp&quot;: &quot;2017-09-14T11:53:07Z&quot;,\r\n                &quot;labels&quot;: {\r\n                    &quot;beta.kubernetes.io/arch&quot;: &quot;amd64&quot;,\r\n                    &quot;beta.kubernetes.io/os&quot;: &quot;linux&quot;,\r\n                    &quot;kubernetes.io/hostname&quot;: &quot;msl-kub01.int.na.myapp.com&quot;,\r\n                    &quot;node-role.kubernetes.io/master&quot;: &quot;&quot;\r\n                },\r\n                &quot;name&quot;: &quot;msl-kub01.int.na.myapp.com&quot;,\r\n                &quot;namespace&quot;: &quot;&quot;,\r\n                &quot;resourceVersion&quot;: &quot;123154&quot;,\r\n                &quot;selfLink&quot;: &quot;/api/v1/nodes/msl-kub01.int.na.myapp.com&quot;,\r\n                &quot;uid&quot;: &quot;45e3b430-9943-11e7-bf0b-fa163e6604fc&quot;\r\n            },\r\n            &quot;spec&quot;: {\r\n                &quot;externalID&quot;: &quot;msl-kub01.int.na.myapp.com&quot;,\r\n                &quot;taints&quot;: [\r\n                    {\r\n                        &quot;effect&quot;: &quot;NoSchedule&quot;,\r\n                        &quot;key&quot;: &quot;node-role.kubernetes.io/master&quot;,\r\n                        &quot;timeAdded&quot;: null\r\n                    }\r\n                ]\r\n            }\r\n        },    \r\n        {\r\n            &quot;apiVersion&quot;: &quot;v1&quot;,\r\n            &quot;kind&quot;: &quot;Node&quot;,\r\n            &quot;metadata&quot;: {\r\n                &quot;annotations&quot;: {\r\n                    &quot;node.alpha.kubernetes.io/ttl&quot;: &quot;0&quot;,\r\n                    &quot;volumes.kubernetes.io/controller-managed-attach-detach&quot;: &quot;true&quot;\r\n                },\r\n                &quot;creationTimestamp&quot;: &quot;2017-09-14T12:05:42Z&quot;,\r\n                &quot;labels&quot;: {\r\n                    &quot;beta.kubernetes.io/arch&quot;: &quot;amd64&quot;,\r\n                    &quot;beta.kubernetes.io/os&quot;: &quot;linux&quot;,\r\n                    &quot;kubernetes.io/hostname&quot;: &quot;msl-kub02.int.na.myapp.com&quot;\r\n                },\r\n                &quot;name&quot;: &quot;msl-kub02.int.na.myapp.com&quot;,\r\n                &quot;namespace&quot;: &quot;&quot;,\r\n                &quot;resourceVersion&quot;: &quot;123156&quot;,\r\n                &quot;selfLink&quot;: &quot;/api/v1/nodes/msl-kub02.int.na.myapp.com&quot;,\r\n                &quot;uid&quot;: &quot;084f439e-9945-11e7-bf0b-fa163e6604fc&quot;\r\n            },\r\n            &quot;spec&quot;: {\r\n                &quot;externalID&quot;: &quot;msl-kub02.int.na.myapp.com&quot;\r\n            }\r\n        }\r\n    ],\r\n    &quot;kind&quot;: &quot;List&quot;,\r\n    &quot;metadata&quot;: {\r\n        &quot;resourceVersion&quot;: &quot;&quot;,\r\n        &quot;selfLink&quot;: &quot;&quot;\r\n    }}\r\n\r\nI need to select all entries of &quot;items&quot; list which do not have &quot;spec.taints[].effect == &quot;NoSchedule&quot;.\r\n\r\nThe thing is that presence of taints list and effect key is not mandatory in source JSON so I cannot do:\r\n\r\n    select (.spec.taints[].effect != &quot;NoSchedule&quot;)\r\n\r\nI was hoping to use something like:\r\n\r\n    select (has(&quot;.spec.taints[].effect&quot;) | not)\r\n\r\nBut it is not allowed.\r\n\r\nThx for tips.",
        "link": "https://stackoverflow.com/questions/46281030/use-jq-to-select-objects-not-containing-nested-objects",
        "title": "Use jq to select objects not containing nested objects"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1505809368,
                "last_edit_date": 1505809368,
                "creation_date": 1505751740,
                "answer_id": 46284053,
                "question_id": 46282648,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which converts arrays to objects down to the level of services, merges with `*` and converts back to the array form.  If `file1` and `file2` contain the sample data then this command:\r\n\r\n    $ jq -Mn --argfile file1 file1 --argfile file2 file2 &#39;\r\n       def merge:                         # merge function\r\n           ($file1, $file2)               # process $file1 then $file2\r\n         | .account as $a                 # save .account in $a\r\n         | .regions[]                     # for each element of .regions\r\n         | .region as $r                  # save .region in $r\r\n         | .services[] as $s              # save each element of .services in $s\r\n         | {($a): {($r): $s}}             # generate object for each account,region,service\r\n       # | debug                          # uncomment debug here to see stream                                   \r\n       ;\r\n         reduce merge as $x ({}; . * $x)  # use &#39;*&#39; to recombine all the objects from merge\r\n\r\n       # | debug                          # uncomment debug here to see combined object\r\n\r\n       | keys[] as $a                     # for each key (account) of combined object\r\n       | {account:$a, regions:[           #  construct object with {account, regions array}\r\n            .[$a]                         #   for each account\r\n          | keys[] as $r                  #    for each key (region) of account object\r\n          | {region:$r, services:[        #     constuct object with {region, services array}\r\n               .[$r]                      #      for each region\r\n             | keys[] as $s               #       for each service\r\n             | {($s): .[$s]}              #         generate service object\r\n            ]}                            #      add service objects to service array\r\n          ]}&#39;                             #   add region object ot regions array\r\n\r\nproduces\r\n\r\n    {\r\n      &quot;account&quot;: &quot;123456789012&quot;,\r\n      &quot;regions&quot;: [\r\n        {\r\n          &quot;region&quot;: &quot;one&quot;,\r\n          &quot;services&quot;: [\r\n            {\r\n              &quot;group_policies&quot;: [\r\n                {\r\n                  &quot;GroupName&quot;: &quot;foo&quot;,\r\n                  &quot;PolicyNames&quot;: [\r\n                    &quot;all_foo&quot;,\r\n                    &quot;all_bar&quot;\r\n                  ]\r\n                },\r\n                {\r\n                  &quot;GroupName&quot;: &quot;bar&quot;,\r\n                  &quot;PolicyNames&quot;: [\r\n                    &quot;all_bar&quot;\r\n                  ]\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;groups&quot;: [\r\n                {\r\n                  &quot;GroupId&quot;: &quot;123456&quot;,\r\n                  &quot;GroupName&quot;: &quot;foo&quot;\r\n                },\r\n                {\r\n                  &quot;GroupId&quot;: &quot;234567&quot;,\r\n                  &quot;GroupName&quot;: &quot;bar&quot;\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n___\r\n\r\n## extended explaination\r\n\r\nAssembling this step by step provides a better picture of how this works.\r\nStart with just this filter\r\n\r\n       def merge:                         # merge function\r\n           ($file1, $file2)               # process $file1 then $file2\r\n         | .account as $a                 # save .account in $a\r\n         | $a\r\n       ;\r\n       merge\r\n\r\nsince there are two objects (one from file1 and one from file2) this outputs\r\nthe `.account` from each:\r\n\r\n    &quot;123456789012&quot;\r\n    &quot;123456789012&quot;\r\n\r\nNote that `.account as $a`  does not change the current value of `.`.\r\nVariables allow us to &quot;drill down&quot; into subobjects without losing higher\r\nlevel context.  Consider this filter:\r\n\r\n       def merge:                         # merge function\r\n           ($file1, $file2)               # process $file1 then $file2\r\n         | .account as $a                 # save .account in $a\r\n         | .regions[]                     # for each element of .regions\r\n         | .region as $r                  # save .region in $r\r\n         | [$a, $r]\r\n       ;\r\n       merge\r\n\r\nwhich outputs (account, region) pairs:\r\n\r\n    [&quot;123456789012&quot;,&quot;one&quot;]\r\n    [&quot;123456789012&quot;,&quot;one&quot;]\r\n\r\nNow we can keep drilling down into services:\r\n\r\n       def merge:                         # merge function\r\n           ($file1, $file2)               # process $file1 then $file2\r\n         | .account as $a                 # save .account in $a\r\n         | .regions[]                     # for each element of .regions\r\n         | .region as $r                  # save .region in $r\r\n         | .services[]\r\n         | [$a, $r, .]\r\n       ;\r\n       merge\r\n\r\nThe third element of the array (`.`) at that point refers to each\r\nsuccessive service in the `.services` array, so this filter generates\r\n\r\n    [&quot;123456789012&quot;,&quot;one&quot;,{&quot;groups&quot;:[{&quot;GroupId&quot;:&quot;123456&quot;,&quot;GroupName&quot;:&quot;foo&quot;},\r\n                                     {&quot;GroupId&quot;:&quot;234567&quot;,&quot;GroupName&quot;:&quot;bar&quot;}]}]\r\n    [&quot;123456789012&quot;,&quot;one&quot;,{&quot;group_policies&quot;:[{&quot;GroupName&quot;:&quot;foo&quot;,&quot;PolicyNames&quot;:[&quot;all_foo&quot;,&quot;all_bar&quot;]},\r\n                                             {&quot;GroupName&quot;:&quot;bar&quot;,&quot;PolicyNames&quot;:[&quot;all_bar&quot;]}]}]\r\n\r\nThis (complete) merge function:\r\n\r\n       def merge:                         # merge function\r\n           ($file1, $file2)               # process $file1 then $file2\r\n         | .account as $a                 # save .account in $a\r\n         | .regions[]                     # for each element of .regions\r\n         | .region as $r                  # save .region in $r\r\n         | .services[] as $s              # save each element of .services in $s\r\n         | {($a): {($r): $s}}             # generate object for each account,region,service\r\n       ;\r\n       merge\r\n\r\nproduces the stream\r\n\r\n    {&quot;123456789012&quot;:{&quot;one&quot;:{&quot;groups&quot;:[{&quot;GroupId&quot;:&quot;123456&quot;,&quot;GroupName&quot;:&quot;foo&quot;},\r\n                                      {&quot;GroupId&quot;:&quot;234567&quot;,&quot;GroupName&quot;:&quot;bar&quot;}]}}}\r\n    {&quot;123456789012&quot;:{&quot;one&quot;:{&quot;group_policies&quot;:[{&quot;GroupName&quot;:&quot;foo&quot;,&quot;PolicyNames&quot;:[&quot;all_foo&quot;,&quot;all_bar&quot;]},\r\n                                              {&quot;GroupName&quot;:&quot;bar&quot;,&quot;PolicyNames&quot;:[&quot;all_bar&quot;]}]}}}\r\n\r\nThe important thing to observe is that these are objects which can easily be merged with `*`\r\nby a reduce step:\r\n\r\n       def merge:                         # merge function\r\n           ($file1, $file2)               # process $file1 then $file2\r\n         | .account as $a                 # save .account in $a\r\n         | .regions[]                     # for each element of .regions\r\n         | .region as $r                  # save .region in $r\r\n         | .services[] as $s              # save each element of .services in $s\r\n         | {($a): {($r): $s}}             # generate object for each account,region,service\r\n       ;\r\n       reduce merge as $x ({}; . * $x)    # use &#39;*&#39; to recombine all the objects from merge\r\n\r\nreduce initializes its local state (`.`) to `{}` and then\r\ncomputes a new state for each result from the merge function\r\nby evaluating `. * $x`, recursively combining the objects merge\r\nbuilt from $file1 and $file:\r\n\r\n    {&quot;123456789012&quot;:{&quot;one&quot;:{&quot;groups&quot;:[{&quot;GroupId&quot;:&quot;123456&quot;,&quot;GroupName&quot;:&quot;foo&quot;},\r\n                                      {&quot;GroupId&quot;:&quot;234567&quot;,&quot;GroupName&quot;:&quot;bar&quot;}],\r\n                            &quot;group_policies&quot;:[{&quot;GroupName&quot;:&quot;foo&quot;,&quot;PolicyNames&quot;:[&quot;all_foo&quot;,&quot;all_bar&quot;]},\r\n                                              {&quot;GroupName&quot;:&quot;bar&quot;,&quot;PolicyNames&quot;:[&quot;all_bar&quot;]}]}}}\r\n\r\nNote that `*` stopped merging at the array objects in the &#39;groups&#39; and &#39;group_policies&#39; keys.\r\nHad we wanted to continue merging we could create more objects in the merge function.  e.g.\r\nconsider this extension:\r\n\r\n       def merge:                         # merge function\r\n           ($file1, $file2)               # process $file1 then $file2\r\n         | .account as $a                 # save .account in $a\r\n         | .regions[]                     # for each element of .regions\r\n         | .region as $r                  # save .region in $r\r\n         | .services[] as $s              # save each element of .services in $s\r\n         | (\r\n             $s.groups[]? as $g\r\n           | {($a): {($r): {groups: {($g.GroupId): $g}}}}\r\n           ), (\r\n             $s.group_policies[]? as $p\r\n           | {($a): {($r): {group_policies: {($p.GroupName): $p}}}}\r\n           )\r\n       ;\r\n       merge\r\n\r\nThis merge goes deeper then the previous one, producing\r\n\r\n    {&quot;123456789012&quot;:{&quot;one&quot;:{&quot;groups&quot;:{&quot;123456&quot;:{&quot;GroupId&quot;:&quot;123456&quot;,&quot;GroupName&quot;:&quot;foo&quot;}}}}}\r\n    {&quot;123456789012&quot;:{&quot;one&quot;:{&quot;groups&quot;:{&quot;234567&quot;:{&quot;GroupId&quot;:&quot;234567&quot;,&quot;GroupName&quot;:&quot;bar&quot;}}}}}\r\n    {&quot;123456789012&quot;:{&quot;one&quot;:{&quot;group_policies&quot;:{&quot;foo&quot;:{&quot;GroupName&quot;:&quot;foo&quot;,&quot;PolicyNames&quot;:[&quot;all_foo&quot;,&quot;all_bar&quot;]}}}}}\r\n    {&quot;123456789012&quot;:{&quot;one&quot;:{&quot;group_policies&quot;:{&quot;bar&quot;:{&quot;GroupName&quot;:&quot;bar&quot;,&quot;PolicyNames&quot;:[&quot;all_bar&quot;]}}}}}\r\n\r\nWhat is important here is that the &quot;groups&quot; and &quot;group_policies&quot; keys contain objects\r\nwhich means in this filter\r\n\r\n       def merge:                         # merge function\r\n           ($file1, $file2)               # process $file1 then $file2\r\n         | .account as $a                 # save .account in $a\r\n         | .regions[]                     # for each element of .regions\r\n         | .region as $r                  # save .region in $r\r\n         | .services[] as $s              # save each element of .services in $s\r\n         | (\r\n             $s.groups[]? as $g\r\n           | {($a): {($r): {groups: {($g.GroupId): $g}}}}\r\n           ), (\r\n             $s.group_policies[]? as $p\r\n           | {($a): {($r): {group_policies: {($p.GroupName): $p}}}}\r\n           )\r\n       ;\r\n       reduce merge as $x ({}; . * $x)\r\n\r\nthe reduce `*` will merge groups and group policies instead of overwriting them, generating:\r\n\r\n    {&quot;123456789012&quot;:{&quot;one&quot;:{&quot;groups&quot;:{&quot;123456&quot;:{&quot;GroupId&quot;:&quot;123456&quot;,&quot;GroupName&quot;:&quot;foo&quot;},\r\n                                      &quot;234567&quot;:{&quot;GroupId&quot;:&quot;234567&quot;,&quot;GroupName&quot;:&quot;bar&quot;}},\r\n                            &quot;group_policies&quot;:{&quot;foo&quot;:{&quot;GroupName&quot;:&quot;foo&quot;,&quot;PolicyNames&quot;:[&quot;all_foo&quot;,&quot;all_bar&quot;]},\r\n                                              &quot;bar&quot;:{&quot;GroupName&quot;:&quot;bar&quot;,&quot;PolicyNames&quot;:[&quot;all_bar&quot;]}}}}}\r\n\r\nPutting this back into the original form will require a little more work, but not much:\r\n\r\n       def merge:                         # merge function\r\n           ($file1, $file2)               # process $file1 then $file2\r\n         | .account as $a                 # save .account in $a\r\n         | .regions[]                     # for each element of .regions\r\n         | .region as $r                  # save .region in $r\r\n         | .services[] as $s              # save each element of .services in $s\r\n         | (\r\n             $s.groups[]? as $g\r\n           | {($a): {($r): {groups: {($g.GroupId): $g}}}}\r\n           ), (\r\n             $s.group_policies[]? as $p\r\n           | {($a): {($r): {group_policies: {($p.GroupName): $p}}}}\r\n           )\r\n       ;\r\n       reduce merge as $x ({}; . * $x)\r\n\r\n       | keys[] as $a                     # for each key (account) of combined object\r\n       | {account:$a, regions:[           #  construct object with {account, regions array}\r\n            .[$a]                         #   for each account\r\n          | keys[] as $r                  #    for each key (region) of account object\r\n          | {region:$r, services:[        #     constuct object with {region, services array}\r\n               .[$r]                      #      for each region\r\n             |   {groups:         [.groups[]]}          # add groups to service\r\n               , {group_policies: [.group_policies[]]}  # add group_policies to service\r\n            ]}\r\n          ]}\r\n\r\nNow with this version suppose our file2 contains a group as well as group_policies. e.g\r\n\r\n    {\r\n      &quot;account&quot;: &quot;123456789012&quot;,\r\n      &quot;regions&quot;: [\r\n        {\r\n          &quot;region&quot;: &quot;one&quot;,\r\n          &quot;services&quot;: [\r\n            {\r\n              &quot;groups&quot;: [\r\n                {\r\n                  &quot;GroupId&quot;: &quot;999&quot;,\r\n                  &quot;GroupName&quot;: &quot;baz&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n             &quot;group_policies&quot;: [\r\n                {\r\n                  &quot;GroupName&quot;: &quot;foo&quot;,\r\n                  &quot;PolicyNames&quot;: [\r\n                    &quot;all_foo&quot;,\r\n                    &quot;all_bar&quot;                \r\n                  ]\r\n                },\r\n                {\r\n                  &quot;GroupName&quot;: &quot;bar&quot;,\r\n                  &quot;PolicyNames&quot;: [\r\n                    &quot;all_bar&quot;\r\n                  ]\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nWhere the first version of this solution produced\r\n\r\n    {\r\n      &quot;account&quot;: &quot;123456789012&quot;,\r\n      &quot;regions&quot;: [\r\n        {\r\n          &quot;region&quot;: &quot;one&quot;,\r\n          &quot;services&quot;: [\r\n            {\r\n              &quot;group_policies&quot;: [\r\n                {\r\n                  &quot;GroupName&quot;: &quot;foo&quot;,\r\n                  &quot;PolicyNames&quot;: [\r\n                    &quot;all_foo&quot;,\r\n                    &quot;all_bar&quot;\r\n                  ]\r\n                },\r\n                {\r\n                  &quot;GroupName&quot;: &quot;bar&quot;,\r\n                  &quot;PolicyNames&quot;: [\r\n                    &quot;all_bar&quot;\r\n                  ]\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;groups&quot;: [\r\n                {\r\n                  &quot;GroupId&quot;: &quot;999&quot;,\r\n                  &quot;GroupName&quot;: &quot;baz&quot;\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nThis revised version produces\r\n\r\n    {\r\n      &quot;account&quot;: &quot;123456789012&quot;,\r\n      &quot;regions&quot;: [\r\n        {\r\n          &quot;region&quot;: &quot;one&quot;,\r\n          &quot;services&quot;: [\r\n            {\r\n              &quot;groups&quot;: [\r\n                {\r\n                  &quot;GroupId&quot;: &quot;123456&quot;,\r\n                  &quot;GroupName&quot;: &quot;foo&quot;\r\n                },\r\n                {\r\n                  &quot;GroupId&quot;: &quot;234567&quot;,\r\n                  &quot;GroupName&quot;: &quot;bar&quot;\r\n                },\r\n                {\r\n                  &quot;GroupId&quot;: &quot;999&quot;,\r\n                  &quot;GroupName&quot;: &quot;baz&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;group_policies&quot;: [\r\n                {\r\n                  &quot;GroupName&quot;: &quot;foo&quot;,\r\n                  &quot;PolicyNames&quot;: [\r\n                    &quot;all_foo&quot;,\r\n                    &quot;all_bar&quot;\r\n                  ]\r\n                },\r\n                {\r\n                  &quot;GroupName&quot;: &quot;bar&quot;,\r\n                  &quot;PolicyNames&quot;: [\r\n                    &quot;all_bar&quot;\r\n                  ]\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "How to merge identically structured, nested json files using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1519217221,
                "creation_date": 1519217221,
                "answer_id": 48906335,
                "question_id": 46282648,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "combining `jq add` and jq gives us:\r\n\r\n` jq &#39;.hits.hits&#39; logs.*.json | jq -s add `\r\n\r\nthat will merge all the hits.hits array in all the logs.*.json files into one big array.",
                "title": "How to merge identically structured, nested json files using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1519217221,
        "creation_date": 1505747233,
        "question_id": 46282648,
        "body_markdown": "I need to merge an array in a series of identically structured, nested JSON files that share the same higher level keys. \r\n\r\nThe goal is to create a merged file while retaining all of the existing, higher level keys and values. \r\n\r\n**File 1:** \r\n\r\n    {\r\n      &quot;account&quot;: &quot;123456789012&quot;,\r\n      &quot;regions&quot;: [\r\n        {\r\n          &quot;region&quot;: &quot;one&quot;,\r\n          &quot;services&quot;: [\r\n            {\r\n              &quot;groups&quot;: [\r\n                {\r\n                  &quot;GroupId&quot;: &quot;123456&quot;,\r\n                  &quot;GroupName&quot;: &quot;foo&quot;\r\n                },\r\n                {\r\n                  &quot;GroupId&quot;: &quot;234567&quot;,\r\n                  &quot;GroupName&quot;: &quot;bar&quot;\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n**File 2:**\r\n\r\n    {\r\n      &quot;account&quot;: &quot;123456789012&quot;,\r\n      &quot;regions&quot;: [\r\n        {\r\n          &quot;region&quot;: &quot;one&quot;,\r\n          &quot;services&quot;: [\r\n            {\r\n              &quot;group_policies&quot;: [\r\n                {\r\n                  &quot;GroupName&quot;: &quot;foo&quot;,\r\n                  &quot;PolicyNames&quot;: [\r\n                    &quot;all_foo&quot;,\r\n                    &quot;all_bar&quot;                \r\n                  ]\r\n                },\r\n                {\r\n                  &quot;GroupName&quot;: &quot;bar&quot;,\r\n                  &quot;PolicyNames&quot;: [\r\n                    &quot;all_bar&quot;\r\n                  ]\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n**Expected result:**\r\n\r\n    {\r\n      &quot;account&quot;: &quot;123456789012&quot;,\r\n      &quot;regions&quot;: [\r\n        {\r\n          &quot;region&quot;: &quot;one&quot;,\r\n          &quot;services&quot;: [\r\n            {\r\n              &quot;groups&quot;: [\r\n                {\r\n                  &quot;GroupId&quot;: &quot;123456&quot;,\r\n                  &quot;GroupName&quot;: &quot;foo&quot;\r\n                },\r\n                {\r\n                  &quot;GroupId&quot;: &quot;234567&quot;,\r\n                  &quot;GroupName&quot;: &quot;bar&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;group_policies&quot;: [\r\n               {\r\n                  &quot;GroupName&quot;: &quot;foo&quot;,\r\n                  &quot;PolicyNames&quot;: [\r\n                    &quot;all_foo&quot;,\r\n                    &quot;all_bar&quot;                \r\n                  ]\r\n                },\r\n                {\r\n                  &quot;GroupName&quot;: &quot;bar&quot;,\r\n                  &quot;PolicyNames&quot;: [\r\n                    &quot;all_bar&quot;\r\n                  ]\r\n                }\r\n               ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nI have tried the following based on answers to other questions of this type with no success: \r\n\r\n    jq -s &#39;.[0] * .[1]&#39; test1.json test2.json\r\n\r\n    jq -s add test1.json test2.json\r\n\r\n    jq -n &#39;[inputs[]]&#39; test{1,2}.json\r\n\r\nThe following successfully merges the array but lacks the higher level keys and values in the results.\r\n\r\n    jq -s &#39;.[0].regions[0].services[0] * .[1].regions[0].services[0]&#39; test1.json test2.json\r\n\r\nI am assuming there is a simple jq solution to this that is escaping my searches. If not, any combination of jq and bash will work for a solution. \r\n\r\n",
        "link": "https://stackoverflow.com/questions/46282648/how-to-merge-identically-structured-nested-json-files-using-jq",
        "title": "How to merge identically structured, nested json files using jq"
    },
    {
        "tags": [
            "time",
            "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": 1505754654,
                "post_id": 46282902,
                "comment_id": 79532567,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1549645,
                    "reputation": 1247,
                    "user_id": 1442357,
                    "user_type": "registered",
                    "accept_rate": 33,
                    "profile_image": "https://www.gravatar.com/avatar/b154102bc17c24fa430c84370903c4d8?s=256&d=identicon&r=PG",
                    "display_name": "wjtk",
                    "link": "https://stackoverflow.com/users/1442357/wjtk"
                },
                "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": 1505768070,
                "post_id": 46282902,
                "comment_id": 79539224,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1505754943,
                "creation_date": 1505754943,
                "answer_id": 46284891,
                "question_id": 46282902,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which does the calculations directly.\r\n\r\n     def roundto(n):   (./n|floor)*n ;\r\n     def timefmt(ms):\r\n       def calcsecs:                             .s_to_m = (.seconds | roundto(60)) | .secs = .seconds - .s_to_m ;\r\n       def calcmins:     .minutes = .s_to_m/60 | .m_to_h = (.minutes | roundto(60)) | .mins = .minutes - .m_to_h ;\r\n       def calchrs:      .hours   = .m_to_h/60 | .h_to_d = (.hours   | roundto(24)) | .hrs  = .hours   - .h_to_d ;\r\n       def calcdays:     .days    = .h_to_d/24 ;\r\n       def fmtelt(e;u):  if e&gt;0 then &quot; \\(e)\\(u)&quot; else &quot;&quot; end ;\r\n       def fmt:\r\n           .s = &quot; \\(.secs)s&quot;\r\n         | .m = fmtelt(.mins; &quot;m&quot;)\r\n         | .h = fmtelt(.hrs; &quot;h&quot;)\r\n         | .d = fmtelt(.days; &quot;d&quot;)\r\n         | &quot;\\(.d)\\(.h)\\(.m)\\(.s)&quot;[1:]\r\n       ;\r\n       {seconds: (ms/1000)|floor} | calcsecs | calcmins | calchrs | calcdays | fmt\r\n    ;     \r\n    timefmt($ms)\r\n\r\nIf this filter is in `filter.jq` then\r\n\r\n    $ jq -Mnr --argjson ms 1505752580000 -f filter.jq\r\n\r\noutputs\r\n\r\n    17427d 16h 36m 20s\r\n\r\nfor smaller intervals only the relevent fields are shown. e.g.\r\n\r\n    $ jq -Mnr --argjson ms 1505750 -f filter.jq\r\n\r\noutputs\r\n\r\n    25m 5s\r\n",
                "title": "format time period with jq console tool"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1505849327,
                "creation_date": 1505849327,
                "answer_id": 46308382,
                "question_id": 46282902,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a concise but straightforward implementation of a function for converting milliseconds to a condensed &quot;d h m s&quot; string, with no rounding. It would be trivial to modify this to include the millisecond remainder as well.\r\n\r\n    # input: milliseconds\r\n    # output: ignore millisecond remainder\r\n    def formattime:\r\n      def f(u): if .&gt;0 then &quot; \\(.)&quot; + u else &quot;&quot; end ;\r\n      # emit a stream of the remainders\r\n      def s: foreach (1000,60,60,24,1) as $i ([.,0];\r\n        .[0] as $n\r\n        | ($n/$i | floor) as $m\r\n        | [$m, $n - ($m*$i)];\r\n        if $i == 1 then .[0] else .[1] end);\r\n\r\n     [s] as [$ms, $s, $m, $h, $d]\r\n      | {s : &quot; \\($s)s&quot;,\r\n         m : ($m|f(&quot;m&quot;)),\r\n         h : ($h|f(&quot;h&quot;)),\r\n         d : ($d|f(&quot;d&quot;)) }\r\n      | &quot;\\(.d)\\(.h)\\(.m)\\(.s)&quot;[1:]\r\n    ;\r\n    formattime\r\n\r\n**Example:**\r\n\r\n    $ jq -r -f formattime.jq\r\n    1505752580000 \r\n    17427d 16h 36m 20s\r\n    6006\r\n    6s\r\n    1\r\n    0s\r\n",
                "title": "format time period with jq console tool"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1505921893,
        "creation_date": 1505747983,
        "last_edit_date": 1505921893,
        "question_id": 46282902,
        "body_markdown": "I have time in milliseconds and I want to format it to time period. For example like this(not necessary exactly like this): 1d 23h 15m 13s.\r\nHow can it be done with jq? ",
        "link": "https://stackoverflow.com/questions/46282902/format-time-period-with-jq-console-tool",
        "title": "format time period with jq console tool"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1505764640,
                "creation_date": 1505764640,
                "answer_id": 46287235,
                "question_id": 46286977,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses [reduce](https://stedolan.github.io/jq/manual/#Reduce) to compute the totals, generate objects in the specified format and add them to the original input array:\r\n\r\n     . + [\r\n         reduce .[] as $r ({}; .[$r[&quot;ID&quot;]] += $r[&quot;VALUE&quot;])\r\n       | keys[] as $id\r\n       | {ID:$id, VALUE:.[$id], TYPE:&quot;total&quot;}\r\n     ]\r\n\r\nNote that the value this computes with the sample data for C is `33.5` which I believe is correct.",
                "title": "jq: Add values of a specific key for all objects with same ID"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1505774985,
                "last_edit_date": 1505774985,
                "creation_date": 1505771329,
                "answer_id": 46288686,
                "question_id": 46286977,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can group them up by the `ID`, then aggregate them into the new objects.  Then combine that with the existing array of items.\r\n\r\n    [.[], (group_by(.ID)[] | { ID: .[0].ID, VALUE: map(.VALUE)|add, TYPE: &quot;total&quot; })]",
                "title": "jq: Add values of a specific key for all objects with same ID"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1509910359,
        "creation_date": 1505763547,
        "last_edit_date": 1509910359,
        "question_id": 46286977,
        "body_markdown": "I have a JSON array that contains a lot of objects and it looks like this:\r\n\r\n    [\r\n    {&quot;ID&quot;:&quot;A&quot;,&quot;VALUE&quot;:12,&quot;TYPE&quot;:&quot;single&quot;},\r\n    {&quot;ID&quot;:&quot;A&quot;,&quot;VALUE&quot;:17,&quot;TYPE&quot;:&quot;single&quot;},\r\n    {&quot;ID&quot;:&quot;A&quot;,&quot;VALUE&quot;:-7,&quot;TYPE&quot;:&quot;single&quot;},\r\n    \r\n    {&quot;ID&quot;:&quot;B&quot;,&quot;VALUE&quot;:35,&quot;TYPE&quot;:&quot;single&quot;},\r\n    {&quot;ID&quot;:&quot;B&quot;,&quot;VALUE&quot;:10,&quot;TYPE&quot;:&quot;single&quot;},\r\n    {&quot;ID&quot;:&quot;B&quot;,&quot;VALUE&quot;:15,&quot;TYPE&quot;:&quot;single&quot;},\r\n    \r\n    {&quot;ID&quot;:&quot;C&quot;,&quot;VALUE&quot;:0,&quot;TYPE&quot;:&quot;single&quot;},\r\n    {&quot;ID&quot;:&quot;C&quot;,&quot;VALUE&quot;:13,&quot;TYPE&quot;:&quot;single&quot;},\r\n    {&quot;ID&quot;:&quot;C&quot;,&quot;VALUE&quot;:20.5,&quot;TYPE&quot;:&quot;single&quot;}\r\n    ]\r\nNow I would like to add all values for every ID and create new objects with the results like this:\r\n\r\n    {&quot;ID&quot;:&quot;A&quot;,&quot;VALUE&quot;:22,&quot;TYPE&quot;:&quot;total&quot;},\r\n    {&quot;ID&quot;:&quot;B&quot;,&quot;VALUE&quot;:60,&quot;TYPE&quot;:&quot;total&quot;},\r\n    {&quot;ID&quot;:&quot;C&quot;,&quot;VALUE&quot;:23.5,&quot;TYPE&quot;:&quot;total&quot;}\r\n\r\nAdditionally, the resulting objects should be added to the initial array.\r\n\r\nI am pretty new to jq so I did some research. Indeed I know how to get the totals for an ID:\r\n\r\n    [.[] | select(.&quot;ID&quot;==&quot;A&quot;).VALUE]|add\r\n\r\n    -&gt; 22\r\nand how to create new objects:\r\n\r\n    .[] | {ID: .ID, VALUE: .VALUE, TYPE: &quot;total&quot;}\r\n\r\nBut how do I get the format I want from here? With a loop? \r\n\r\nThanks!\r\n",
        "link": "https://stackoverflow.com/questions/46286977/jq-add-values-of-a-specific-key-for-all-objects-with-same-id",
        "title": "jq: Add values of a specific key for all objects with same ID"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1505833597,
                "post_id": 46303200,
                "comment_id": 79570135,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8282671,
                    "reputation": 107,
                    "user_id": 6226819,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://lh5.googleusercontent.com/-lgiXlXHTtaI/AAAAAAAAAAI/AAAAAAAAADk/B-HhBlWHheg/s256-rj/photo.jpg",
                    "display_name": "Bishop Minter",
                    "link": "https://stackoverflow.com/users/6226819/bishop-minter"
                },
                "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": 1,
                "creation_date": 1505834904,
                "post_id": 46303200,
                "comment_id": 79570969,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1505841628,
                "post_id": 46303200,
                "comment_id": 79574624,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8282671,
                    "reputation": 107,
                    "user_id": 6226819,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://lh5.googleusercontent.com/-lgiXlXHTtaI/AAAAAAAAAAI/AAAAAAAAADk/B-HhBlWHheg/s256-rj/photo.jpg",
                    "display_name": "Bishop Minter",
                    "link": "https://stackoverflow.com/users/6226819/bishop-minter"
                },
                "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": 1505847770,
                "post_id": 46303200,
                "comment_id": 79577831,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1505849201,
                "last_edit_date": 1505849201,
                "creation_date": 1505837992,
                "answer_id": 46305351,
                "question_id": 46303200,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The array of objects with non-uniform keys is making things a little tricky here.  Once you&#39;ve gotten past `.files` you need to start using [Array Iteration `[]`](https://stedolan.github.io/jq/manual/#.[]?) to access those elements and then use object operations like [`keys`](https://stedolan.github.io/jq/manual/#keys,keys_unsorted) to go deeper.  \r\n\r\nHere is a function which may help in this situation.  It scans `.files` for an object with a key matching the specified key and then returns the corresponding value:\r\n\r\n    def getfile($k): .files[] | select(keys[] | .==$k) | .[$k];\r\n\r\nIf `jqtest` contains the sample data the command\r\n\r\n    $ jq -M &#39;\r\n    def getfile($k): .files[] | select(keys[] | .==$k) | .[$k];\r\n    getfile(&quot;BLOCK1&quot;).SUBBLOCK1.akey1\r\n    &#39; jqtest\r\n\r\nReturns\r\n\r\n    &quot;avalue1&quot;\r\n\r\nAnother approach is to use a function to convert `.files[]` into a more useful form.  e.g.\r\n\r\n    $ jq -M &#39;\r\n    def files: reduce .files[] as $f ({}; ($f|keys[0]) as $k | .[$k] = $f[$k]) ;\r\n    files \r\n    &#39; jqtest\r\n\r\nthis returns a more uniform structure without arrays\r\n\r\n    {\r\n      &quot;BLOCK1&quot;: {\r\n        &quot;SUBBLOCK1&quot;: {\r\n          &quot;akey1&quot;: &quot;avalue1&quot;,\r\n          &quot;bkey1&quot;: &quot;bvalue1&quot;,\r\n          &quot;ckey1&quot;: &quot;cvalue1&quot;\r\n        },\r\n        &quot;dkey1&quot;: &quot;dvalue1&quot;,\r\n        &quot;key&quot;: &quot;evalue1&quot;\r\n      },\r\n      &quot;BLOCK-2&quot;: ...\r\n\r\n\r\nso with it you can write\r\n\r\n    files.BLOCK1.SUBBLOCK1\r\n    \r\nto obtain \r\n\r\n    {\r\n      &quot;akey1&quot;: &quot;avalue1&quot;,\r\n      &quot;bkey1&quot;: &quot;bvalue1&quot;,\r\n      &quot;ckey1&quot;: &quot;cvalue1&quot;\r\n    }\r\n\r\nNote that jq will re-evaluate the `files` function with each use so the following form may be more practical:\r\n\r\n      files as $files\r\n    | $files.BLOCK1.SUBBLOCK1\r\n    \r\nIf you find this representation useful you may want to skip the function and instead just start your filter with\r\n\r\n    .files = reduce .files[] as $f ({}; ($f|keys[0]) as $k | .[$k] = $f[$k])\r\n\r\ne.g.\r\n\r\n    $ jq -M &#39;\r\n    .files = reduce .files[] as $f ({}; ($f|keys[0]) as $k | .[$k] = $f[$k])\r\n    # more stuff goes here\r\n    &#39; jqtest\r\n\r\nwhich converts your input to\r\n\r\n    {\r\n      &quot;files&quot;: {\r\n        &quot;BLOCK1&quot;: {\r\n          &quot;SUBBLOCK1&quot;: {\r\n            &quot;akey1&quot;: &quot;avalue1&quot;,\r\n            &quot;bkey1&quot;: &quot;bvalue1&quot;,\r\n            &quot;ckey1&quot;: &quot;cvalue1&quot;\r\n          },\r\n          &quot;dkey1&quot;: &quot;dvalue1&quot;,\r\n          &quot;key&quot;: &quot;evalue1&quot;\r\n        },\r\n        &quot;BLOCK-2&quot;: {\r\n          &quot;SUBBLOCK2&quot;: {\r\n            &quot;akey2&quot;: &quot;avalue2&quot;,\r\n            &quot;bkey2&quot;: &quot;bvalue2&quot;\r\n          },\r\n          &quot;ckey2&quot;: &quot;cvalue2&quot;,\r\n          &quot;key&quot;: &quot;dvalue2&quot;\r\n        },\r\n        &quot;BLOCK-A&quot;: {\r\n          &quot;SUBBLOCK2&quot;: {\r\n            &quot;akey2&quot;: &quot;avalue2&quot;,\r\n            &quot;bkey2&quot;: &quot;bvalue2&quot;\r\n          },\r\n          &quot;ckey2&quot;: &quot;cvalue2&quot;,\r\n          &quot;key&quot;: &quot;dvalue2&quot;\r\n        }\r\n      },\r\n      &quot;NOBLOCK&quot;: &quot;value&quot;,\r\n      &quot;key&quot;: &quot;NOBLOCKvalue&quot;\r\n    }\r\n\r\nmaking whatever else you need to do after that easier",
                "title": "Can&#39;t get jq to recognize an array within a json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1505849201,
        "creation_date": 1505831641,
        "last_edit_date": 1505833532,
        "question_id": 46303200,
        "body_markdown": "I have a json file that I use for work that I need to parse that is in the following format:\r\n\r\n    (^)#(^)#(^)#(^)bminter@ubuntu:~$ cat jqtest\r\n    {\r\n       &quot;files&quot;:[\r\n          {\r\n             &quot;BLOCK1&quot;:{\r\n                &quot;SUBBLOCK1&quot;:{\r\n                   &quot;akey1&quot;:&quot;avalue1&quot;,\r\n                   &quot;bkey1&quot;:&quot;bvalue1&quot;,\r\n                   &quot;ckey1&quot;:&quot;cvalue1&quot;\r\n                },\r\n                &quot;dkey1&quot;:&quot;dvalue1&quot;,\r\n                &quot;key&quot;:&quot;evalue1&quot;\r\n             }\r\n          },\r\n          {\r\n             &quot;BLOCK-2&quot;:{\r\n                &quot;SUBBLOCK2&quot;:{\r\n                   &quot;akey2&quot;:&quot;avalue2&quot;,\r\n                   &quot;bkey2&quot;:&quot;bvalue2&quot;\r\n                },\r\n                &quot;ckey2&quot;:&quot;cvalue2&quot;,\r\n                &quot;key&quot;:&quot;dvalue2&quot;\r\n             }\r\n          },\r\n          {\r\n             &quot;BLOCK-A&quot;:{\r\n                &quot;SUBBLOCK2&quot;:{\r\n                   &quot;akey2&quot;:&quot;avalue2&quot;,\r\n                   &quot;bkey2&quot;:&quot;bvalue2&quot;\r\n                },\r\n                &quot;ckey2&quot;:&quot;cvalue2&quot;,\r\n                &quot;key&quot;:&quot;dvalue2&quot;\r\n             }\r\n          }],\r\n       &quot;NOBLOCK&quot;:&quot;value&quot;,\r\n       &quot;key&quot;:&quot;NOBLOCKvalue&quot;\r\n    }\r\n\r\nSo it&#39;s an array nested within a json file.  `jq .[] jqtest` gives me everything in the file.  Even the data outside the array.  Except, outside the array, I&#39;m only given the values not the keys:\r\n\r\n    (^)#(^)#(^)#(^)bminter@ubuntu:~$ jq .[] jqtest\r\n    [\r\n      {\r\n        &quot;BLOCK1&quot;: {\r\n          &quot;SUBBLOCK1&quot;: {\r\n            &quot;akey1&quot;: &quot;avalue1&quot;,\r\n            &quot;bkey1&quot;: &quot;bvalue1&quot;,\r\n            &quot;ckey1&quot;: &quot;cvalue1&quot;\r\n          },\r\n          &quot;dkey1&quot;: &quot;dvalue1&quot;,\r\n          &quot;key&quot;: &quot;evalue1&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;BLOCK-2&quot;: {\r\n          &quot;SUBBLOCK2&quot;: {\r\n            &quot;akey2&quot;: &quot;avalue2&quot;,\r\n            &quot;bkey2&quot;: &quot;bvalue2&quot;\r\n          },\r\n          &quot;ckey2&quot;: &quot;cvalue2&quot;,\r\n          &quot;key&quot;: &quot;dvalue2&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;BLOCK-A&quot;: {\r\n          &quot;SUBBLOCK2&quot;: {\r\n            &quot;akey2&quot;: &quot;avalue2&quot;,\r\n            &quot;bkey2&quot;: &quot;bvalue2&quot;\r\n          },\r\n          &quot;ckey2&quot;: &quot;cvalue2&quot;,\r\n          &quot;key&quot;: &quot;dvalue2&quot;\r\n        }\r\n      }\r\n    ]\r\n    &quot;value&quot;\r\n    &quot;NOBLOCKvalue&quot;\r\n    (^)#(^)#(^)#(^)bminter@ubuntu:~$ \r\n\r\nBeyond that I can&#39;t access any block inside the array:\r\n\r\n    (^)#(^)#(^)#(^)bminter@ubuntu:~$ jq &#39;.[].BLOCK1&#39; jqtest\r\n    jq: error (at jqtest:36): Cannot index array with string &quot;BLOCK1&quot;\r\n    (^)#(^)#(^)#(^)bminter@ubuntu:~$ jq &#39;.[].BLOCK-2&#39; jqtest\r\n    jq: error (at jqtest:36): Cannot index array with string &quot;BLOCK&quot;\r\n    (^)#(^)#(^)#(^)bminter@ubuntu:~$ jq &#39;.[].BLOCK-A&#39; jqtest\r\n    jq: error: A/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .[].BLOCK-A          \r\n    jq: 1 compile error\r\n    (^)#(^)#(^)#(^)bminter@ubuntu:~$ \r\n\r\nHow do I access the array?",
        "link": "https://stackoverflow.com/questions/46303200/cant-get-jq-to-recognize-an-array-within-a-json-file",
        "title": "Can&#39;t get jq to recognize an array within a json file"
    },
    {
        "tags": [
            "xor",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1505855268,
                "last_edit_date": 1505855268,
                "creation_date": 1505850256,
                "answer_id": 46308629,
                "question_id": 46308139,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "How about this: if `data.json` contains your sample data the command\r\n\r\n    $ jq -Mc &#39;\r\n      def xor($a;$b): $a != $b ;\r\n      map(select(.letters|xor(contains([&quot;a&quot;]);contains([&quot;b&quot;]))))\r\n    &#39; data.json\r\n\r\nproduces\r\n\r\n    [{&quot;letters&quot;:[&quot;a&quot;,&quot;c&quot;]},{&quot;letters&quot;:[&quot;b&quot;,&quot;c&quot;]}]\r\n\r\nNote that the `xor` used above works here but isn&#39;t safe to use with non-boolean parameters.  A more robust version is:\r\n\r\n    def xor($a;$b): ($a|not) != ($b|not) ;\r\n\r\n",
                "title": "exclusive or (xor) operator?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1505853600,
                "last_edit_date": 1505853600,
                "creation_date": 1505852324,
                "answer_id": 46309117,
                "question_id": 46308139,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If there are no duplicates in `.letters`, here is another way which takes advantage of a little-known use of array indexing: \r\n\r\n    $ jq -Mc &#39;map(select(.letters|.[[&quot;a&quot;]]+.[[&quot;b&quot;]]|length==1))&#39; data.json\r\n\r\nproduces\r\n\r\n    [{&quot;letters&quot;:[&quot;a&quot;,&quot;c&quot;]},{&quot;letters&quot;:[&quot;b&quot;,&quot;c&quot;]}]\r\n\r\nThis works because if `$x` is an array `$x[ [&quot;a&quot;] ]` returns the indices of `&quot;a&quot;` within `$x`. e.g.\r\n\r\n    $ jq -Mnc &#39;[&quot;a&quot;,&quot;c&quot;][[&quot;a&quot;]]&#39;\r\n    [0]\r\n    $ jq -Mnc &#39;[&quot;a&quot;,&quot;c&quot;][[&quot;b&quot;]]&#39;\r\n    []\r\n    $ jq -Mnc &#39;[&quot;a&quot;,&quot;c&quot;,&quot;a&quot;,&quot;b&quot;][[&quot;a&quot;]]&#39;\r\n    [0,2]\r\n\r\nSee also jq [indices](https://stedolan.github.io/jq/manual/#indices(s)) builtin (which uses it in its [implementation](https://github.com/stedolan/jq/blob/master/src/builtin.jq#L28))\r\n\r\nThis may be too tricky to recommend using in the general case compared to a more obvious approach and if `.letters` contains duplicates then the simplistic `length==1` check won&#39;t work.",
                "title": "exclusive or (xor) operator?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1505875640,
                "last_edit_date": 1505875640,
                "creation_date": 1505853016,
                "answer_id": 46309298,
                "question_id": 46308139,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`xor` can easily be defined:\r\n\r\n    def xor($a;$b): ($a or $b) and (($a and $b)|not);\r\n\r\n`contains` is tricky (it is probably better not to use it unless you have studied its subtleties). In general, it would be better to use `index`: \r\n\r\n    .letters | select( xor( index(&quot;a&quot;); index(&quot;b&quot;) ))\r\n\r\nFor efficiency, it would be even better to use `IN` if your jq has it:\r\n\r\n    .letters as $a | select( xor( &quot;a&quot; | IN($a[]); &quot;b&quot; | IN($a[]) ))\r\n\r\n",
                "title": "exclusive or (xor) operator?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1505932690,
        "creation_date": 1505848332,
        "last_edit_date": 1505932690,
        "question_id": 46308139,
        "body_markdown": "Does jq have an exclusive or (AKA xor) operator?  I&#39;m having trouble finding it in its documentation.\r\n\r\n(I&#39;ve had trouble finding other topics in the docs that I later found worked in jq and are documented. I probably didn&#39;t find them at first because I&#39;d used poor search terms.)\r\n\r\nI wanted jq to return all top-level objects from the input that have array properties containing one of two specific values, but not both values.\r\n\r\nFor example, given the input:\r\n\r\n    [\r\n      {&quot;letters&quot;: [&quot;a&quot;, &quot;c&quot;]},\r\n      {&quot;letters&quot;: [&quot;a&quot;, &quot;b&quot;, &quot;c&quot;]},\r\n      {&quot;letters&quot;: [&quot;b&quot;, &quot;c&quot;]}\r\n    ]\r\n\r\nI want only the objects whose `&quot;letters&quot;` property contains either `&quot;a&quot;` or `&quot;b&quot;`, but not both.\r\n\r\nI ended up using the long-winded filter:\r\n\r\n    map(select(.letters//[]|((contains([&quot;a&quot;]) or contains([&quot;b&quot;])) and (contains([&quot;a&quot;, &quot;b&quot;])|not))))\r\n\r\nWhich gave the correct output:\r\n\r\n    [{&quot;letters&quot;:[&quot;a&quot;,&quot;c&quot;]},{&quot;letters&quot;:[&quot;b&quot;,&quot;c&quot;]}]\r\n\r\nBut that&#39;s long, tedious, and a maintenance headache.  Is there a simpler way to do accomplish this?\r\n\r\nA &quot;jq play&quot; snippet for this code: https://jqplay.org/s/mwBhsYud2F\r\n\r\nPS: Even if there isn&#39;t any better solution than the one I&#39;ve found, I&#39;ll be happy to receive constructive criticism about improving it.",
        "link": "https://stackoverflow.com/questions/46308139/exclusive-or-xor-operator",
        "title": "exclusive or (xor) operator?"
    },
    {
        "tags": [
            "jq",
            "backreference"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1505915474,
                "creation_date": 1505915474,
                "answer_id": 46323948,
                "question_id": 46323036,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a demonstration using a named capture `?&lt;a&gt;` with [sub](https://stedolan.github.io/jq/manual/#RegularexpressionsPCRE) and [gsub](https://stedolan.github.io/jq/manual/#RegularexpressionsPCRE):\r\n\r\n    $ jq -Mn &#39;\r\n      &quot;\\n*blah\\n**tim\\nbob was here\\n*item1\\n**item2\\n&quot;\r\n    |    sub(&quot;(?&lt;a&gt;\\n\\\\*[A-Za-z0-9]*\\n)&quot;;&quot;\\n\\(.a)&quot;;&quot;g&quot;)\r\n      , gsub(&quot;(?&lt;a&gt;\\n\\\\*[A-Za-z0-9]*\\n)&quot;;&quot;\\n\\(.a)&quot;)\r\n    &#39;\r\n\r\noutput\r\n\r\n    &quot;\\n\\n*blah\\n**tim\\nbob was here\\n\\n*item1\\n**item2\\n&quot;\r\n    &quot;\\n\\n*blah\\n**tim\\nbob was here\\n\\n*item1\\n**item2\\n&quot;",
                "title": "Backreferences in jq like sed or vi?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1505915474,
        "creation_date": 1505913167,
        "question_id": 46323036,
        "body_markdown": "I have the following string in my input to `jq`:\r\n\r\n`&quot;\\n*blah\\n**tim\\nbob was here\\n*item1\\n**item2\\n&quot;`\r\n\r\nAnd I&#39;m able to match the first `\\n*` with the following:\r\n\r\n`[match(&quot;(\\n\\\\*[A-Za-z0-9]*\\n)&quot;;&quot;g&quot;)]`\r\n\r\nWhich gives me the following matches:\r\n\r\n\r\n    [\r\n      {\r\n        &quot;offset&quot;: 0,\r\n        &quot;length&quot;: 7,\r\n        &quot;string&quot;: &quot;\\n*blah\\n&quot;,\r\n        &quot;captures&quot;: [\r\n          {\r\n            &quot;offset&quot;: 0,\r\n            &quot;length&quot;: 7,\r\n            &quot;string&quot;: &quot;\\n*blah\\n&quot;,\r\n            &quot;name&quot;: null\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;offset&quot;: 25,\r\n        &quot;length&quot;: 8,\r\n        &quot;string&quot;: &quot;\\n*item1\\n&quot;,\r\n        &quot;captures&quot;: [\r\n          {\r\n            &quot;offset&quot;: 25,\r\n            &quot;length&quot;: 8,\r\n            &quot;string&quot;: &quot;\\n*item1\\n&quot;,\r\n            &quot;name&quot;: null\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nMy goal however, is to search for these and add an extra `\\n` to the start of the matched `\\n*` lines.  \r\n\r\nI don&#39;t appear to be able to do backreferences using gsub, so is there a similar functionality to what can be done in `sed` and `vi` using backreference matches in `jq`?",
        "link": "https://stackoverflow.com/questions/46323036/backreferences-in-jq-like-sed-or-vi",
        "title": "Backreferences in jq like sed or vi?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1194068,
                    "reputation": 694,
                    "user_id": 1208392,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/4aa9ca107e36760640c0dff769dd5eae?s=256&d=identicon&r=PG",
                    "display_name": "nbren12",
                    "link": "https://stackoverflow.com/users/1208392/nbren12"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1505979463,
                "post_id": 46337867,
                "comment_id": 79635800,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1505980285,
                "creation_date": 1505980285,
                "answer_id": 46338340,
                "question_id": 46337867,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use `cat ab.json|jq &#39;[{&quot;a&quot;: .a, &quot;b&quot;: .b[]}]&#39;` to get the answer.",
                "title": "Assigning parent keys in innermost object using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1506180489,
                "last_edit_date": 1506180489,
                "creation_date": 1505980454,
                "answer_id": 46338393,
                "question_id": 46337867,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If minimizing keystrokes is the goal, then consider:\r\n\r\n    jq &#39;.+{b:.b[]}&#39; &lt;&lt;&lt; &quot;$j&quot;\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: 1\r\n    }\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: 2\r\n    }\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: 3\r\n    }\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: 4\r\n    }\r\n\r\nUsing `.` here ensures that all keys other than &quot;b&quot; will be preserved. By contrast, if one wants to ignore all the keys other than &quot;a&quot; and &quot;b&quot;, then one could use the jq filter:\r\n\r\n     {a,b:.b[]}\r\n\r\nTo turn the stream into an array, just wrap the expression in square brackets: [ ... ]",
                "title": "Assigning parent keys in innermost object using JQ"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1505983607,
                "last_edit_date": 1505983607,
                "creation_date": 1505981177,
                "answer_id": 46338648,
                "question_id": 46337867,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution:\r\n\r\n    $ jq -Mc &#39;[.b=.b[]]&#39; data.json\r\n\r\nIf `data.json` contains the sample data the output is\r\n\r\n    [{&quot;a&quot;:1,&quot;b&quot;:1},{&quot;a&quot;:1,&quot;b&quot;:2},{&quot;a&quot;:1,&quot;b&quot;:3},{&quot;a&quot;:1,&quot;b&quot;:4}]\r\n",
                "title": "Assigning parent keys in innermost object using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1506180489,
        "creation_date": 1505978743,
        "last_edit_date": 1506091837,
        "question_id": 46337867,
        "body_markdown": "I would like to turn this:\r\n\r\n\r\n    {\r\n        &quot;a&quot;: 1,\r\n        &quot;b&quot;: [1,2,3,4]\r\n    }\r\n\r\ninto this\r\n\r\n    [\r\n    {&quot;a&quot;: 1, &quot;b&quot;: 1},\r\n    {&quot;a&quot;: 1, &quot;b&quot;: 2},\r\n    ...\r\n    ]\r\n\r\nThis is sort of like python&#39;s `zip` but with unequally shaped objects.\r\n\r\nThanks!\r\n",
        "link": "https://stackoverflow.com/questions/46337867/assigning-parent-keys-in-innermost-object-using-jq",
        "title": "Assigning parent keys in innermost object using JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9670665,
                    "reputation": 2142,
                    "user_id": 7175708,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://i.sstatic.net/Jpjl6QC2.png?s=256",
                    "display_name": "Lechucico",
                    "link": "https://stackoverflow.com/users/7175708/lechucico"
                },
                "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": 1506015387,
                "post_id": 46342327,
                "comment_id": 79660303,
                "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": 1506015434,
                "post_id": 46342327,
                "comment_id": 79660331,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 9670665,
                    "reputation": 2142,
                    "user_id": 7175708,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://i.sstatic.net/Jpjl6QC2.png?s=256",
                    "display_name": "Lechucico",
                    "link": "https://stackoverflow.com/users/7175708/lechucico"
                },
                "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": 1506015761,
                "post_id": 46342327,
                "comment_id": 79660519,
                "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": 1506016472,
                "post_id": 46342327,
                "comment_id": 79660881,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1506013118,
                "creation_date": 1506013118,
                "answer_id": 46349400,
                "question_id": 46342327,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; Is that possible?\r\n\r\nYes, there are many ways to achieve both tasks.  You will probably find it easiest to keep track of the three files separately within the jq program.  This too can be done in several ways, but I&#39;d suggest starting with the &#39;--argfile NAME FILENAME&#39; option, one triple for each file.\r\n\r\nIt&#39;s not immediately clear to me what you mean by ascertaining which &quot;customers&quot; are missing, but let me offer this hopefully helpful hint:\r\n\r\nIf A and B are two JSON arrays, then the expression (A - B) will emit an array containing the items in A that are not in B.\r\n\r\n",
                "title": "jq: Comparing three files to find missing identifiers in any"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1506017348,
                "last_edit_date": 1506017348,
                "creation_date": 1506014615,
                "answer_id": 46349801,
                "question_id": 46342327,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "EDIT:  This answer was written before [Lechucico](https://stackoverflow.com/users/7175708/lechucico) simplified the sample data and clarified the relationships between the objects.  The following may only be of cursory interest since [Charles](https://stackoverflow.com/users/14122/charles-duffy) has provided a good solution to the revised problem.\r\n\r\n___\r\n\r\nYou need to understand your data before you can make progress on this.  You could start with a report,   \r\n\r\n\r\n      &quot;__________________________________________________  mongo.json&quot;\r\n    , ($mongo[] | {client_id, name})\r\n\r\n    , &quot;__________________________________________________  elastic.json&quot;\r\n    , ($elastic[] | {alias, index})\r\n\r\n    , &quot;__________________________________________________  stripe.json&quot;\r\n    , ($stripe.data[] | {id, object})\r\n    \r\n    \r\nIf the above filter is in `filter.jq` then the command\r\n\r\n    jq -Mnc \\\r\n      --argfile mongo mongo.json \\\r\n      --argfile elastic elastic.json \\\r\n      --argfile stripe stripe.json \\\r\n      -f filter.jq\r\n \r\nproduces\r\n\r\n    __________________________________________________  mongo.json\r\n    {&quot;client_id&quot;:&quot;TEST&quot;,&quot;name&quot;:&quot;Windows Client&quot;}\r\n    {&quot;client_id&quot;:&quot;TEST2&quot;,&quot;name&quot;:&quot;Linux Client&quot;}\r\n    __________________________________________________  elastic.json\r\n    {&quot;alias&quot;:&quot;living&quot;,&quot;index&quot;:&quot;living_v1&quot;}\r\n    {&quot;alias&quot;:&quot;reindex&quot;,&quot;index&quot;:&quot;living_v1&quot;}\r\n    __________________________________________________  stripe.json\r\n    {&quot;id&quot;:&quot;cus_BRKuwUx0TS1LPL&quot;,&quot;object&quot;:&quot;customer&quot;}\r\n\r\nIt&#39;s pretty clear that these are different types of objects so there may not be an obvious one-to-one relationship between them but if you investigate your actual data and workflow you may be able to discover a more meaningful link.",
                "title": "jq: Comparing three files to find missing identifiers in any"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1506017057,
                "last_edit_date": 1506017057,
                "creation_date": 1506016345,
                "answer_id": 46350303,
                "question_id": 46342327,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq -n \\\r\n      --slurpfile mongo mongo.json \\\r\n      --slurpfile elastic elastic.json \\\r\n      --slurpfile stripe stripe.json \\\r\n    &#39;\r\n      [$mongo[][].client_id] as $mongo_ids\r\n    | [$elastic[][].alias] as $elastic_ids\r\n    | [$stripe[].data[].id] as $stripe_ids\r\n    | (($mongo_ids + $elastic_ids + $stripe_ids) | unique) as $all_ids\r\n    | {&quot;missing_from_stripe&quot;:  ($all_ids - $stripe_ids),\r\n       &quot;missing_from_elastic&quot;: ($all_ids - $elastic_ids),\r\n       &quot;missing_from_mongo&quot;:   ($all_ids - $mongo_ids)}\r\n    | [to_entries[] | select(.value|length &gt; 0)] | from_entries\r\n    &#39;\r\n\r\n...correctly emits:\r\n\r\n    {\r\n      &quot;missing_from_stripe&quot;: [\r\n        &quot;test2@test2.com&quot;\r\n      ]\r\n    }\r\n\r\n",
                "title": "jq: Comparing three files to find missing identifiers in any"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1506017348,
        "creation_date": 1505992008,
        "last_edit_date": 1506016731,
        "question_id": 46342327,
        "body_markdown": "I have 3 different files. `mongo.json`, `elastic.json`, `stripe.json`.\r\n\r\nEach one has an array of clients and I want to compare the lenght of those arrays to check if they have the same amount of customers for preventing errors. Here&#39;s an example of each file:\r\n\r\n`Mongo.json`\r\n\r\n    [{\r\n        &quot;_id&quot;: {\r\n                &quot;$oid&quot;: &quot;59c3942baeef22b03fa573d2&quot;\r\n        },\r\n        &quot;client_id&quot;: &quot;test@test.com&quot;,\r\n        &quot;name&quot;: &quot;Windows Client&quot;\r\n    },{\r\n        &quot;_id&quot;: {\r\n                &quot;$oid&quot;: &quot;59c3942baeef22b03fa573d2&quot;\r\n        },\r\n        &quot;client_id&quot;: &quot;test2@test2.com&quot;,\r\n        &quot;name&quot;: &quot;Linux Client&quot;\r\n    }]\r\n\r\n`elastic.json`\r\n\r\n    [\r\n        {\r\n            &quot;alias&quot; : &quot;test@test.com&quot;,\r\n            &quot;index&quot; : &quot;index1&quot;,\r\n            &quot;filter&quot; : &quot;-&quot;\r\n        },\r\n        {\r\n            &quot;alias&quot; : &quot;test2@test2.com&quot;,\r\n            &quot;index&quot; : &quot;index2&quot;,\r\n            &quot;filter&quot; : &quot;-&quot;\r\n        }\r\n    ]\r\n\r\n`stripe.json`\r\n\r\n    {\r\n    &quot;object&quot;: &quot;list&quot;,\r\n    &quot;data&quot;: [\r\n      {\r\n          &quot;id&quot;: &quot;test@test.com&quot;,\r\n          &quot;object&quot;: &quot;customer&quot;,\r\n          &quot;account_balance&quot;: 0,\r\n          &quot;created&quot;: 1505990903\r\n      }\r\n    ]\r\n    }\r\n    \r\n\r\nWith the following command I obtain the lenght of each array, but I don&#39;t know how to compare these lengts for check if they are the same or not:\r\n\r\n    jq &#39;. | length&#39; mongo.json elastic.json stripe.json\r\n\r\nresult:\r\n\r\n    2\r\n    2\r\n    1\r\n\r\nHow I can compare these results? I would like the following output:\r\n\r\nIn case they have the same length:\r\n\r\n    Everyting is OK.\r\n\r\nIn contrary case:\r\n\r\n    Missing customer test2@test2.com\r\n\r\nThe customer ID: **is the email**.\r\n\r\nHow I can do that?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/46342327/jq-comparing-three-files-to-find-missing-identifiers-in-any",
        "title": "jq: Comparing three files to find missing identifiers in any"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1506011447,
                "creation_date": 1506011447,
                "answer_id": 46348933,
                "question_id": 46344646,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming the following jq program is in a file, say program.jq, then the invocation:\r\n\r\n    jq --argfile ratio ratio.json --argfile constants constants.json  -f program.jq data.json\r\n\r\nproduces the desired result, at least if jq 1.5 or later is used:\r\n\r\n    # r should be an array of ratios\r\n    # input is assumed to be an object with .time_CET\r\n    def getRatio(r):\r\n      if .time_CET==&quot;00:00:00&quot; then r[0]\r\n      elif  .time_CET==&quot;00:15:00&quot; then r[1]\r\n      elif  .time_CET==&quot;00:30:00&quot; then r[2]\r\n      else r[3]\r\n      end\r\n      ;\r\n    \r\n    def todict: reduce .[] as $o ({}; . + ($o | { (.ID): .CONST }));\r\n    \r\n    def extend(r):\r\n      ($constants|todict)[.ID]  as $c\r\n      | .VAL = getRatio(r) * $c\r\n      ;\r\n    \r\n    ($ratio[0] | .RATIO) as $RATIO\r\n    | map(extend($RATIO))\r\n\r\n\r\n\r\n",
                "title": "jq: Multiply values from array with constants and add result to objects with matching id in another file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1506012632,
                "creation_date": 1506012632,
                "answer_id": 46349260,
                "question_id": 46344646,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution:\r\n\r\n    # recent versions of jq include this in builtin.jq.\r\n    # we redefine it here in case it&#39;s not present\r\n    def INDEX(stream; idx_expr):\r\n      reduce stream as $row (\r\n        {}\r\n      ; .[$row|idx_expr|if type != &quot;string&quot; then tojson else . end] |= $row\r\n      )\r\n    ;\r\n\r\n    # make an array of all the times that appear in time_CET\r\n    def datatimes:\r\n       [$data[].time_CET] | unique[]\r\n    ;\r\n\r\n    # make an object mapping time_CET to ratios\r\n    def time_to_ratio:\r\n        reduce datatimes as $i (\r\n          {}\r\n        ; .[$i] = $ratio[0].RATIO[length]\r\n        )\r\n    ;\r\n\r\n    # main procedure here\r\n\r\n      INDEX($constants[];.ID) as $ctable\r\n    | time_to_ratio as $rtable\r\n    | $data\r\n    | map(.VAL = $ctable[.ID].CONST * $rtable[.time_CET])\r\n\r\nif this filter is in `filter.jq` and the other data is in the `constants.json`, `ratio.json` and `data.json` files respectively then the command\r\n\r\n    jq -Mnc \\\r\n       --argfile constants constants.json \\\r\n       --argfile data data.json \\\r\n       --argfile ratio ratio.json \\\r\n       -f filter.jq\r\n\r\nproduces\r\n\r\n    [\r\n      {\r\n        &quot;ID&quot;: &quot;aaa&quot;,\r\n        &quot;time_CET&quot;: &quot;00:00:00&quot;,\r\n        &quot;VAL&quot;: 125\r\n      },\r\n      {\r\n        &quot;ID&quot;: &quot;aaa&quot;,\r\n        &quot;time_CET&quot;: &quot;00:15:00&quot;,\r\n        &quot;VAL&quot;: 175\r\n      },\r\n      {\r\n        &quot;ID&quot;: &quot;aaa&quot;,\r\n        &quot;time_CET&quot;: &quot;00:30:00&quot;,\r\n        &quot;VAL&quot;: 200\r\n      },\r\n      {\r\n        &quot;ID&quot;: &quot;aaa&quot;,\r\n        &quot;time_CET&quot;: &quot;00:45:00&quot;,\r\n        &quot;VAL&quot;: 225\r\n      },\r\n      {\r\n        &quot;ID&quot;: &quot;bbb&quot;,\r\n        &quot;time_CET&quot;: &quot;00:00:00&quot;,\r\n        &quot;VAL&quot;: 175\r\n      },\r\n      {\r\n        &quot;ID&quot;: &quot;bbb&quot;,\r\n        &quot;time_CET&quot;: &quot;00:15:00&quot;,\r\n        &quot;VAL&quot;: 244.99999999999997\r\n      },\r\n      {\r\n        &quot;ID&quot;: &quot;bbb&quot;,\r\n        &quot;time_CET&quot;: &quot;00:30:00&quot;,\r\n        &quot;VAL&quot;: 280\r\n      },\r\n      {\r\n        &quot;ID&quot;: &quot;bbb&quot;,\r\n        &quot;time_CET&quot;: &quot;00:45:00&quot;,\r\n        &quot;VAL&quot;: 315\r\n      },\r\n      {\r\n        &quot;ID&quot;: &quot;ccc&quot;,\r\n        &quot;time_CET&quot;: &quot;00:00:00&quot;,\r\n        &quot;VAL&quot;: 100\r\n      },\r\n      {\r\n        &quot;ID&quot;: &quot;ccc&quot;,\r\n        &quot;time_CET&quot;: &quot;00:15:00&quot;,\r\n        &quot;VAL&quot;: 140\r\n      },\r\n      {\r\n        &quot;ID&quot;: &quot;ccc&quot;,\r\n        &quot;time_CET&quot;: &quot;00:30:00&quot;,\r\n        &quot;VAL&quot;: 160\r\n      },\r\n      {\r\n        &quot;ID&quot;: &quot;ccc&quot;,\r\n        &quot;time_CET&quot;: &quot;00:45:00&quot;,\r\n        &quot;VAL&quot;: 180\r\n      },\r\n      {\r\n        &quot;ID&quot;: &quot;ddd&quot;,\r\n        &quot;time_CET&quot;: &quot;00:00:00&quot;,\r\n        &quot;VAL&quot;: 95\r\n      },\r\n      {\r\n        &quot;ID&quot;: &quot;ddd&quot;,\r\n        &quot;time_CET&quot;: &quot;00:15:00&quot;,\r\n        &quot;VAL&quot;: 133\r\n      },\r\n      {\r\n        &quot;ID&quot;: &quot;ddd&quot;,\r\n        &quot;time_CET&quot;: &quot;00:30:00&quot;,\r\n        &quot;VAL&quot;: 152\r\n      },\r\n      {\r\n        &quot;ID&quot;: &quot;ddd&quot;,\r\n        &quot;time_CET&quot;: &quot;00:45:00&quot;,\r\n        &quot;VAL&quot;: 171\r\n      }\r\n    ]\r\n",
                "title": "jq: Multiply values from array with constants and add result to objects with matching id in another file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1506104581,
        "creation_date": 1505998878,
        "last_edit_date": 1506104581,
        "question_id": 46344646,
        "body_markdown": "So there are three .json files in my directory. I have created the first file dynamically (Using linux bash and jq) which contains one object including the array &quot;RATIO&quot;:\r\n\r\n - ratio.json:\r\n\r\n        [\r\n         {...,&quot;RATIO&quot;:[0.5,0.7,0.8,0.9], ....}\r\n        ]\r\n\r\nIn the second file I have stored the constants (this is just hardcoded so the constants could also be moved into the code directly, if that&#39;s easier):\r\n\r\n - constants.json:\r\n\r\n        [\r\n         {&quot;ID&quot;:&quot;aaa&quot;,&quot;CONST&quot;:250},\r\n         {&quot;ID&quot;:&quot;bbb&quot;,&quot;CONST&quot;:350},\r\n         {&quot;ID&quot;:&quot;ccc&quot;,&quot;CONST&quot;:200},\r\n         {&quot;ID&quot;:&quot;ddd&quot;,&quot;CONST&quot;:190}\r\n        ]\r\n\r\nThe third file is where &quot;the magic&quot; should happen:\r\n\r\n - data.json:\r\n\r\n        [\r\n         {&quot;ID&quot;:&quot;aaa&quot;,&quot;time_CET&quot;:&quot;00:00:00&quot;},\r\n         {&quot;ID&quot;:&quot;aaa&quot;,&quot;time_CET&quot;:&quot;00:15:00&quot;},\r\n         {&quot;ID&quot;:&quot;aaa&quot;,&quot;time_CET&quot;:&quot;00:30:00&quot;},\r\n         {&quot;ID&quot;:&quot;aaa&quot;,&quot;time_CET&quot;:&quot;00:45:00&quot;},\r\n    \r\n         {&quot;ID&quot;:&quot;bbb&quot;,&quot;time_CET&quot;:&quot;00:00:00&quot;},\r\n         {&quot;ID&quot;:&quot;bbb&quot;,&quot;time_CET&quot;:&quot;00:15:00&quot;},\r\n         {&quot;ID&quot;:&quot;bbb&quot;,&quot;time_CET&quot;:&quot;00:30:00&quot;},\r\n         {&quot;ID&quot;:&quot;bbb&quot;,&quot;time_CET&quot;:&quot;00:45:00&quot;},\r\n    \r\n         {&quot;ID&quot;:&quot;ccc&quot;,&quot;time_CET&quot;:&quot;00:00:00&quot;},\r\n         {&quot;ID&quot;:&quot;ccc&quot;,&quot;time_CET&quot;:&quot;00:15:00&quot;},\r\n         {&quot;ID&quot;:&quot;ccc&quot;,&quot;time_CET&quot;:&quot;00:30:00&quot;},\r\n         {&quot;ID&quot;:&quot;ccc&quot;,&quot;time_CET&quot;:&quot;00:45:00&quot;},\r\n    \r\n         {&quot;ID&quot;:&quot;ddd&quot;,&quot;time_CET&quot;:&quot;00:00:00&quot;},\r\n         {&quot;ID&quot;:&quot;ddd&quot;,&quot;time_CET&quot;:&quot;00:15:00&quot;},\r\n         {&quot;ID&quot;:&quot;ddd&quot;,&quot;time_CET&quot;:&quot;00:30:00&quot;},\r\n         {&quot;ID&quot;:&quot;ddd&quot;,&quot;time_CET&quot;:&quot;00:45:00&quot;}\r\n        ]\r\nAll objects in this array should be extended by the element &quot;VAL&quot; which is calculated by multiplying RATIO with CONST. So in my case RATIO[0] (that&#39;s 0.5) is used for every object with time_CET = &quot;00:00:00&quot;. RATIO[1] is used for time_CET=00:15:00 and so on. The array in data.json is already sorted as you can see (00:00:00 always first for every ID), that&#39;s why I think the trick with the array index should work.\r\nSo in the end, the data.json file should look like this (on the right is the calculation logic for VAL):\r\n - data.json:\r\n\r\n  \r\n\r\n        [     \r\n    \r\n          {&quot;ID&quot;:&quot;aaa&quot;,&quot;time_CET&quot;:&quot;00:00:00&quot;, &quot;VAL&quot;: 125}, -&gt;0.5*250\r\n          {&quot;ID&quot;:&quot;aaa&quot;,&quot;time_CET&quot;:&quot;00:15:00&quot;, &quot;VAL&quot;: 175}, -&gt;0.7*250\r\n          {&quot;ID&quot;:&quot;aaa&quot;,&quot;time_CET&quot;:&quot;00:30:00&quot;, &quot;VAL&quot;: 200}, -&gt;0.8*250\r\n          {&quot;ID&quot;:&quot;aaa&quot;,&quot;time_CET&quot;:&quot;00:45:00&quot;, &quot;VAL&quot;: 225}, -&gt;0.9*250\r\n    \r\n          {&quot;ID&quot;:&quot;bbb&quot;,&quot;time_CET&quot;:&quot;00:00:00&quot;, &quot;VAL&quot;: 175}, -&gt;0.5*350\r\n          {&quot;ID&quot;:&quot;bbb&quot;,&quot;time_CET&quot;:&quot;00:15:00&quot;, &quot;VAL&quot;: 245}, -&gt;0.7*350\r\n          {&quot;ID&quot;:&quot;bbb&quot;,&quot;time_CET&quot;:&quot;00:30:00&quot;, &quot;VAL&quot;: 280}, -&gt;0.8*350\r\n          {&quot;ID&quot;:&quot;bbb&quot;,&quot;time_CET&quot;:&quot;00:45:00&quot;, &quot;VAL&quot;: 315}, -&gt;0.9*350\r\n    \r\n          {&quot;ID&quot;:&quot;ccc&quot;,&quot;time_CET&quot;:&quot;00:00:00&quot;, &quot;VAL&quot;: 100}, -&gt;0.5*200\r\n          {&quot;ID&quot;:&quot;ccc&quot;,&quot;time_CET&quot;:&quot;00:15:00&quot;, &quot;VAL&quot;: 140}, -&gt;0.7*200\r\n          {&quot;ID&quot;:&quot;ccc&quot;,&quot;time_CET&quot;:&quot;00:30:00&quot;, &quot;VAL&quot;: 160}, -&gt;0.8*200\r\n          {&quot;ID&quot;:&quot;ccc&quot;,&quot;time_CET&quot;:&quot;00:45:00&quot;, &quot;VAL&quot;: 180}, -&gt;0.9*200\r\n    \r\n          {&quot;ID&quot;:&quot;ddd&quot;,&quot;time_CET&quot;:&quot;00:00:00&quot;, &quot;VAL&quot;: 95}, -&gt;0.5*190\r\n          {&quot;ID&quot;:&quot;ddd&quot;,&quot;time_CET&quot;:&quot;00:15:00&quot;, &quot;VAL&quot;: 133}, -&gt;0.7*190\r\n          {&quot;ID&quot;:&quot;ddd&quot;,&quot;time_CET&quot;:&quot;00:30:00&quot;, &quot;VAL&quot;: 152}, -&gt;0.8*190\r\n          {&quot;ID&quot;:&quot;ddd&quot;,&quot;time_CET&quot;:&quot;00:45:00&quot;, &quot;VAL&quot;: 171}, -&gt;0.9*190\r\n        ]\r\n\r\nSo I am not sure if that is even possible. Perhaps I have to reshape the ratio array to objects? (objects with &quot;time_cet&quot; key and not an array of values). \r\n\r\nAnyway, what is the best way to accomplish this with jq (and maybe linux bash)?  Thank you!\r\n\r\nUPDATE: Both solutions work now, thank you very much. \r\nThis is maybe another topic but I would like to add an error handler to catch exceptions especially for the RATIO array. \r\nIt may happen that this Array\r\n\r\n 1.Does not contain a value at the specified index/not definded\r\n\r\n 2.Value that is not an integer\r\n\r\nIn any case I would like to set a default value for VAL. The error message should be logged in another file, if that is possible.. (can I use the current date here? -&gt; maybe send to STDERR?) Thx.",
        "link": "https://stackoverflow.com/questions/46344646/jq-multiply-values-from-array-with-constants-and-add-result-to-objects-with-mat",
        "title": "jq: Multiply values from array with constants and add result to objects with matching id in another file"
    },
    {
        "tags": [
            "json",
            "stream",
            "edit",
            "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": 1506006396,
                "post_id": 46346394,
                "comment_id": 79654976,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1506008920,
                "post_id": 46346394,
                "comment_id": 79656664,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 9754,
                    "reputation": 26532,
                    "user_id": 18149,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/f5e10278b9b6a518d5835f658704d85f?s=256&d=identicon&r=PG",
                    "display_name": "leeand00",
                    "link": "https://stackoverflow.com/users/18149/leeand00"
                },
                "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": 1506083433,
                "post_id": 46346394,
                "comment_id": 79688986,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1506009246,
                "creation_date": 1506009246,
                "answer_id": 46348336,
                "question_id": 46346394,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Yes, but to do so efficiently you&#39;d effectively need jq 1.5 or higher:\r\n\r\n    foreach inputs as $line (0; \r\n      if $line == &quot;*bob&quot; then . + 1 else . end;\r\n      if . == 1 then &quot;&quot; else empty end,\r\n        $line)\r\n\r\nDon&#39;t forget to use the -n command-line option!",
                "title": "Add an empty line prior to another matched line in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1506016882,
                "last_edit_date": 1506016882,
                "creation_date": 1506016018,
                "answer_id": 46350212,
                "question_id": 46346394,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another solution which uses the [`-s`](https://stedolan.github.io/jq/manual/#Invokingjq) (slurp) option\r\n\r\n    .[: .[[&quot;*bob&quot;]][0]] + [&quot;\\n&quot;] + .[.[[&quot;*bob&quot;]][0]:] | .[]        \r\n\r\nthat&#39;s a little unreadable but we can make it better with a few functions:\r\n\r\n      def firstbob:  .[[&quot;*bob&quot;]][0] ;\r\n      def beforebob: .[: firstbob ] ;\r\n      def afterbob:  .[ firstbob :] ;\r\n\r\n        beforebob + [&quot;\\n&quot;] + afterbob\r\n      | .[]\r\n\r\nif the above filter is in `filter.jq` and the sample data is in `data` then\r\n\r\n    $ jq -Ms -f filter.jq data\r\n\r\nproduces\r\n\r\n    &quot;```&quot;\r\n    &quot;include &lt;stdio.h&gt;&quot;\r\n    &quot;...&quot;\r\n    &quot;```&quot;\r\n    &quot;&#39;&#39;some example&#39;&#39;&quot;\r\n    &quot;\\n&quot;\r\n    &quot;*bob&quot;\r\n    &quot;**bob&quot;\r\n    &quot;*bob&quot;\r\n\r\nOne issue with this approach is that `beforebob` and `afterbob` won&#39;t quite work as you probably want if `&quot;*bob&quot;` is not in the input.  The easiest way to address that is with an if guard:\r\n\r\n        if firstbob then beforebob + [&quot;\\n&quot;] + afterbob else . end\r\n      | .[]\r\n\r\nwith that the input will be unaltered if `&quot;*bob&quot;` is not present.",
                "title": "Add an empty line prior to another matched line in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1506419787,
        "creation_date": 1506003563,
        "last_edit_date": 1506419787,
        "question_id": 46346394,
        "body_markdown": "Say I have a raw input like the following:\r\n\r\n    &quot;```&quot;\r\n    &quot;include &lt;stdio.h&gt;&quot;\r\n    &quot;...&quot;\r\n    &quot;```&quot;\r\n    &quot;&#39;&#39;some example&#39;&#39;&quot;\r\n    &quot;*bob&quot;\r\n    &quot;**bob&quot;\r\n    &quot;*bob&quot;\r\n\r\nAnd I&#39;d like to add a blank line right before the &quot;*bob&quot;:\r\n\r\n    &quot;```&quot;\r\n    &quot;include &lt;stdio.h&gt;&quot;\r\n    &quot;...&quot;\r\n    &quot;```&quot;\r\n    &quot;&#39;&#39;some example&#39;&#39;&quot;\r\n    &quot;&quot;\r\n    &quot;*bob&quot;\r\n    &quot;**bob&quot;\r\n    &quot;*bob&quot;\r\n\r\nCan this be done with jq?",
        "link": "https://stackoverflow.com/questions/46346394/add-an-empty-line-prior-to-another-matched-line-in-jq",
        "title": "Add an empty line prior to another matched line in jq?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "scripting",
            "filtering",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1506012252,
                "last_edit_date": 1506012252,
                "creation_date": 1506011939,
                "answer_id": 46349068,
                "question_id": 46348981,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You are looking for [`select()`][1]:\r\n\r\n    jq -r &#39;.files[]|select(.[&quot;BLOCK-A&quot;])|.[&quot;BLOCK-A&quot;].SUBBLOCKA.bkeyA&#39;\r\n\r\nor [`map()`][2]:\r\n\r\n    jq -r &#39;.files|map(.[&quot;BLOCK-A&quot;]//empty)[].SUBBLOCKA.bkeyA&#39;\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#select(boolean_expression)\r\n  [2]: https://stedolan.github.io/jq/manual/#map(x),map_values(x)",
                "title": "How do I use jq to single out a specific element in a json array whose order keeps changing?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1506012964,
                "creation_date": 1506012964,
                "answer_id": 46349340,
                "question_id": 46348981,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The alternative approach with `has()` function:\r\n\r\n    jq -r &#39;.files[] | if (has(&quot;BLOCK-A&quot;)) then .[&quot;BLOCK-A&quot;].SUBBLOCKA.bkeyA else empty end&#39; jqtest\r\n    bvalueA",
                "title": "How do I use jq to single out a specific element in a json array whose order keeps changing?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1506029888,
                "last_edit_date": 1506029888,
                "creation_date": 1506013326,
                "answer_id": 46349457,
                "question_id": 46348981,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is an solution based on [my previous answer](https://stackoverflow.com/a/46305351/8379597) to your earlier question:\r\n\r\n    $ jq -M &#39;\r\n\r\n    def getfile($k): .files[] | select(keys[] == $k) | .[$k];\r\n\r\n    getfile(&quot;BLOCK-A&quot;).SUBBLOCKA.bkeyA\r\n\r\n    &#39; jqtest\r\n\r\nWith the sample data provided the output is:\r\n\r\n    &quot;bvalueA&quot;\r\n",
                "title": "How do I use jq to single out a specific element in a json array whose order keeps changing?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1506248185,
                "last_edit_date": 1506248185,
                "creation_date": 1506028460,
                "answer_id": 46353261,
                "question_id": 46348981,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This might be the least-keystrokes solution:\r\n\r\n     .files[].&quot;BLOCK-A&quot;//empty|.SUBBLOCKA.bkeyA\r\n\r\nIf there is a possibility that there is more than one &quot;BLOCK-A&quot; element, and if you want to ensure that all but the first will be ignored when that is the case, then you could wrap the above in a call to `first/1`, assuming your version of jq has it:  first( ... )\r\n\r\nUsing `first` in this manner also yields a more efficient solution.\r\n",
                "title": "How do I use jq to single out a specific element in a json array whose order keeps changing?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1506248185,
        "creation_date": 1506011616,
        "last_edit_date": 1506151218,
        "question_id": 46348981,
        "body_markdown": "I have a file with the following format:\r\n\r\n{\r\n\r\n       &quot;files&quot;:[\r\n          {\r\n             &quot;BLOCK1&quot;:{\r\n                &quot;SUBBLOCK1&quot;:{\r\n                   &quot;akey1&quot;:&quot;avalue1&quot;,\r\n                   &quot;bkey1&quot;:&quot;bvalue1&quot;,\r\n                   &quot;ckey1&quot;:&quot;cvalue1&quot;\r\n                },\r\n                &quot;dkey1&quot;:&quot;dvalue1&quot;,\r\n                &quot;key&quot;:&quot;evalue1&quot;\r\n             }\r\n          },\r\n          {\r\n             &quot;BLOCK-2&quot;:{\r\n                &quot;SUBBLOCK2&quot;:{\r\n                   &quot;akey2&quot;:&quot;avalue2&quot;,\r\n                   &quot;bkey2&quot;:&quot;bvalue2&quot;\r\n                },\r\n                &quot;ckey2&quot;:&quot;cvalue2&quot;,\r\n                &quot;key&quot;:&quot;dvalue2&quot;\r\n             }\r\n          },\r\n          {\r\n             &quot;BLOCK-A&quot;:{\r\n                &quot;SUBBLOCKA&quot;:{\r\n                   &quot;akeyA&quot;:&quot;avalueA&quot;,\r\n                   &quot;bkeyA&quot;:&quot;bvalueA&quot;\r\n                },\r\n                &quot;ckeyA&quot;:&quot;cvalueA&quot;,\r\n                &quot;key&quot;:&quot;dvalueA&quot;\r\n             }\r\n          }],\r\n       &quot;NOBLOCK&quot;:&quot;value&quot;,\r\n       &quot;key&quot;:&quot;NOBLOCKvalue&quot;\r\n    }\r\n\r\nI&#39;m using the following the jq statement to isolate &quot;bvalueA&quot;:\r\n\r\n    value=$(jq -r &#39;.files | .[2] | .[&quot;BLOCK-A&quot;].SUBBLOCKA.bkeyA&#39; jqtest)\r\n\r\nWhich works just fine.  But the file changes order every night.  So BLOCK-A might be element 0 one night, 1 the next, so on and so forth.  How can I modify jq to always drill down to BLOCK-A no matter which element in the array it is?",
        "link": "https://stackoverflow.com/questions/46348981/how-do-i-use-jq-to-single-out-a-specific-element-in-a-json-array-whose-order-kee",
        "title": "How do I use jq to single out a specific element in a json array whose order keeps changing?"
    },
    {
        "tags": [
            "json",
            "object",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1506111046,
                "creation_date": 1506111046,
                "answer_id": 46372530,
                "question_id": 46372378,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With `reduce()` function:\r\n\r\n    jq &#39;reduce .[] as $k ({}; .[$k]=true)&#39; file\r\nThe output:\r\n\r\n    {\r\n      &quot;smoke-tests&quot;: true,\r\n      &quot;other-tests&quot;: true\r\n    }\r\n\r\n",
                "title": "add values to array of keys with JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1506111482,
                "creation_date": 1506111482,
                "answer_id": 46372617,
                "question_id": 46372378,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    $ s=&#39;[&quot;smoke-tests&quot;, &quot;other-tests&quot;]&#39;\r\n    $ jq &#39;[.[] | {(.): true}] | add&#39; &lt;&lt;&lt;&quot;$s&quot;\r\n    {\r\n      &quot;smoke-tests&quot;: true,\r\n      &quot;other-tests&quot;: true\r\n    }\r\n\r\nBreaking down how that works: `.[] | {(.): true}` converts each item into a dictionary mapping the value (as a key) to `true`. Surrounding that in `[ ]` means we generate a list of such objects; sending that to `add` combines them into a single object.",
                "title": "add values to array of keys with JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1506112293,
                "creation_date": 1506112293,
                "answer_id": 46372785,
                "question_id": 46372378,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you like the efficiency of `reduce` but don&#39;t want to use `reduce` explicitly:\r\n\r\n    . as $in | {} | .[$in[]] = true",
                "title": "add values to array of keys with JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1506116209,
                "creation_date": 1506116209,
                "answer_id": 46373560,
                "question_id": 46372378,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using add.  It&#39;s close to [Charles](https://stackoverflow.com/users/14122/charles-duffy)&#39;s solution but uses the behavior of [Object construction](https://stedolan.github.io/jq/manual/#ObjectConstruction:{}) to implicitly return multiple objects when used with an expression which returns multiple results.\r\n\r\n     [{(.[]):true}]|add",
                "title": "add values to array of keys with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1506151871,
        "creation_date": 1506110375,
        "last_edit_date": 1506151871,
        "question_id": 46372378,
        "body_markdown": "I have a simple JSON array:\r\n\r\n    [\r\n    &quot;smoke-tests&quot;,\r\n    &quot;other-tests&quot;\r\n    ]\r\n\r\nI&#39;d like to convert to a simple JSON:\r\n\r\n    {&quot;smoke-tests&quot;: true,\r\n     &quot;other-tests&quot;: true\r\n    }\r\n\r\nI&#39;ve tried several jq examples, but none seem to do what I want.\r\n\r\n`jq &#39;.[] | walk(.key = true)&#39;` produces a compile error.",
        "link": "https://stackoverflow.com/questions/46372378/add-values-to-array-of-keys-with-jq",
        "title": "add values to array of keys with JQ"
    },
    {
        "tags": [
            "json",
            "unique",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 19,
                "is_accepted": true,
                "score": 19,
                "last_activity_date": 1506313845,
                "creation_date": 1506313845,
                "answer_id": 46397650,
                "question_id": 46397592,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is an example which eliminates all but one of the `.Result` objects using `unique_by(.name)`\r\n\r\n    $ jq -M &#39;.Result |= unique_by(.name)&#39; data.json\r\n    {\r\n      &quot;Result&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;validation-of-art&quot;,\r\n          &quot;id&quot;: &quot;12&quot;,\r\n          &quot;status&quot;: &quot;passed&quot;,\r\n          &quot;duration&quot;: 4740302\r\n        }\r\n      ]\r\n    }\r\n\r\nIf this isn&#39;t quite what you want you can generalize this easily.  E.g. to keep one object for each unique `{name,id}` you could use\r\n    \r\n    $ jq -M &#39;.Result |= unique_by({name, id})&#39; data.json\r\n    {\r\n      &quot;Result&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;validation-of-art&quot;,\r\n          &quot;id&quot;: &quot;12&quot;,\r\n          &quot;status&quot;: &quot;passed&quot;,\r\n          &quot;duration&quot;: 4740302\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;validation-of-art&quot;,\r\n          &quot;id&quot;: &quot;13&quot;,\r\n          &quot;status&quot;: &quot;passed&quot;,\r\n          &quot;duration&quot;: 272320\r\n        }\r\n      ]\r\n    }\r\n",
                "title": "JQ - removing duplicates using unique_by"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 10,
        "last_activity_date": 1506324425,
        "creation_date": 1506313384,
        "last_edit_date": 1506324425,
        "question_id": 46397592,
        "body_markdown": "I am trying to remove the duplicates from the following json by `id`\r\nHere is the json:\r\n\r\n    {\r\n      &quot;Result&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;validation-of-art&quot;,\r\n          &quot;id&quot;: &quot;12&quot;,\r\n          &quot;status&quot;: &quot;passed&quot;,\r\n          &quot;duration&quot;: 4740302\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;validation-of-art&quot;,\r\n          &quot;id&quot;: &quot;12&quot;,\r\n          &quot;status&quot;: &quot;passed&quot;,\r\n          &quot;duration&quot;: 272320\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;validation-of-art&quot;,\r\n          &quot;id&quot;: &quot;13&quot;,\r\n          &quot;status&quot;: &quot;passed&quot;,\r\n          &quot;duration&quot;: 272320\r\n        }\r\n      ]\r\n    }\r\nHere is what i have tried with:\r\n\r\n    jq -r &#39;unique_by(.Result.name)&#39;\r\nand also with `jq &#39;unique_by(.Result[].name)&#39;`\r\n\r\nI am getting an error - `Cannot index array with string &quot;Result&quot;`\r\nAny help would be appreciated.",
        "link": "https://stackoverflow.com/questions/46397592/jq-removing-duplicates-using-unique-by",
        "title": "JQ - removing duplicates using unique_by"
    },
    {
        "tags": [
            "json",
            "text",
            "jq",
            "dynamically-generated"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1506418404,
                "creation_date": 1506418404,
                "answer_id": 46422779,
                "question_id": 46422124,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq -r &#39;.[] | &quot;mongo_customers,customer=\\(.client_id)&quot;&#39; mongo.json\r\n\r\nThere are many other possibilities. If you want to be absolutely sure the result will be valid CSV, then you might want to use the `@csv` filter.",
                "title": "JQ: Generate txt file with json information"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1506419533,
        "creation_date": 1506416654,
        "last_edit_date": 1506419533,
        "question_id": 46422124,
        "body_markdown": "I have the following Json:\r\n\r\n    [{\r\n        &quot;_id&quot;: {\r\n                &quot;$oid&quot;: &quot;59c3942baeef22b03fa573d2&quot;\r\n        },\r\n        &quot;client_id&quot;: &quot;test@test.com&quot;,\r\n        &quot;name&quot;: &quot;Windows Client&quot;\r\n    },\r\n    {\r\n        &quot;_id&quot;: {\r\n                &quot;$oid&quot;: &quot;59c3942baeef22b03fa573d2&quot;\r\n        },\r\n        &quot;client_id&quot;: &quot;test2@test2.com&quot;,\r\n        &quot;name&quot;: &quot;Linux Client&quot;\r\n    }]\r\n\r\nI would like to output the following:\r\n\r\n    mongo_customers,customer=test@test.com\r\n    mongo_customers,customer=test2@test.com\r\n\r\nI&#39;ve tryed the following but it doesn&#39;t work:\r\n\r\n    jq -n -R \\\r\n      --slurpfile mongo mongo.json \\\r\n    &#39;\r\n      $mongo[][].client_id] as $mongo_ids\r\n      &quot;mongo_customers,customer=&quot;($mongo_ids)\r\n    &#39;\r\n\r\nHow I can do that?",
        "link": "https://stackoverflow.com/questions/46422124/jq-generate-txt-file-with-json-information",
        "title": "JQ: Generate txt file with json information"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1506427422,
                "last_edit_date": 1506427422,
                "creation_date": 1506427102,
                "answer_id": 46425899,
                "question_id": 46425650,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since you already use [string interpolation][1] for that specific field, simply include the character you need (slash `/`) inside the string, like this:\r\n\r\n    curl ... | jq -c &#39;... [.version,.driver,.miner,&quot;\\(.gpus)/\\(.miner_instance)&quot;] ...&#39;\r\n\r\nIn your case (the complete line):\r\n\r\n    curl -s http://cd0a4a.ethosdistro.com/?json=yes | jq -c &#39;.rigs|.&quot;0d6b27&quot;,.&quot;50dc35&quot;|[.version,.driver,.miner,&quot;\\(.gpus)/\\(.miner_instance)&quot;]|@csv&#39; | sed &#39;s/\\\\//g;s/\\&quot;//g&#39; | gawk &#39;BEGIN{print  &quot;version&quot; &quot;,&quot; &quot;GPU_driver&quot; &quot;,&quot; &quot;miner&quot; &quot;,&quot; &quot;gpu&quot;} {print $0}&#39; | csvlook -I\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Stringinterpolation-%5C(foo)",
                "title": "jq print character inside output"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1506444081,
                "creation_date": 1506444081,
                "answer_id": 46431775,
                "question_id": 46425650,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here are some suggestions for simplification:\r\n\r\n - use the `--raw-output` option to `jq` to remove extraneous back-slashes\r\n - there is no need to remove the quotes, `csvlook` does it for you\r\n - no need for awk to add a title line, use a sub-shell\r\n - no need to specify rigs implicitly, use `.[]`\r\n\r\nHere is an example:\r\n\r\n    (\r\n      echo version,GPU_driver,miner,gpu\r\n      curl -s &#39;http://cd0a4a.ethosdistro.com/?json=yes&#39; |\r\n      jq -r &#39;\r\n        .rigs | .[] |\r\n        [ .version, .driver , .miner  , &quot;\\(.gpus)/\\(.miner_instance)&quot; ] |\r\n        @csv\r\n      &#39;\r\n    ) |\r\n    csvlook\r\n\r\nOutput:\r\n\r\n    |----------+------------+----------+------|\r\n    |  version | GPU_driver | miner    | gpu  |\r\n    |----------+------------+----------+------|\r\n    |  1.2.3   | nvidia     | ethminer | 2/2  |\r\n    |  1.2.4   | amdgpu     | ethminer | 1/1  |\r\n    |----------+------------+----------+------|",
                "title": "jq print character inside output"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1506446612,
                "creation_date": 1506446612,
                "answer_id": 46432449,
                "question_id": 46425650,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You&#39;re doing a lot of unnecessary calls just to process the data. Your commands could be drastically simplified.\r\n\r\n* You don&#39;t need to explicitly key into the `.rigs` object to get their values, you could just access them using `[]`.\r\n* You don&#39;t need the sed call to strip the quotes, just use the raw output `-r`.\r\n* You don&#39;t need the awk call to add the header, you could just output an additional row from jq.\r\n\r\nSo your command turns into this instead:\r\n\r\n&lt;!-- --&gt;\r\n\r\n    $ curl -s http://cd0a4a.ethosdistro.com/?json=yes \\\r\n    | jq -r &#39;[&quot;version&quot;, &quot;GPU_driver&quot;, &quot;miner&quot;, &quot;gpu&quot;],\r\n             (.rigs[] | [.version, .driver, .miner, &quot;\\(.gpus)/\\(.miner_instance)&quot;])\r\n                 | @csv&#39; \\\r\n    | csvlook -I",
                "title": "jq print character inside output"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1506446612,
        "creation_date": 1506426314,
        "last_edit_date": 1506445687,
        "question_id": 46425650,
        "body_markdown": "I want print `&quot;/&quot;` separator inside output title.\r\n\r\n    curl  -s http://cd0a4a.ethosdistro.com/?json=yes \\\r\n        | jq -c &#39;.rigs|.&quot;0d6b27&quot;,.&quot;50dc35&quot;|[.version,.driver,.miner,&quot;\\(.gpus)\\(.miner_instance)&quot;]|@csv&#39; \\\r\n        | sed &#39;s/\\\\//g;s/\\&quot;//g&#39; \\\r\n        | gawk &#39;BEGIN{print  &quot;version&quot; &quot;,&quot; &quot;GPU_driver&quot; &quot;,&quot; &quot;miner&quot; &quot;,&quot; &quot;gpu&quot;} {print $0}&#39; \\\r\n        | csvlook -I\r\n\r\n-----\r\nThe output is like this :\r\n\r\n    | version | GPU_driver | miner    | gpu |\r\n    | ------- | ---------- | -------- | --- |\r\n    | 1.2.3   | nvidia     | ethminer | 22  |\r\n    | 1.2.4   | amdgpu     | ethminer | 11  |\r\n\r\n-----\r\nBut I want separator in between the numbers inside gpu title like this :\r\n\r\n    | version | GPU_driver | miner    | gpu  |\r\n    | ------- | ---------- | -------- | ---- |\r\n    | 1.2.3   | nvidia     | ethminer | 2/2  |\r\n    | 1.2.4   | amdgpu     | ethminer | 1/1  |\r\n\r\n",
        "link": "https://stackoverflow.com/questions/46425650/jq-print-character-inside-output",
        "title": "jq print character inside output"
    }
]