[
    {
        "tags": [
            "bash",
            "awk",
            "sed",
            "grep",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5203734,
                    "reputation": 37594,
                    "user_id": 4162356,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/dGhuV.png?s=256",
                    "display_name": "James Brown",
                    "link": "https://stackoverflow.com/users/4162356/james-brown"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1489144510,
                "post_id": 42716872,
                "comment_id": 72554030,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2360730,
                    "reputation": 2259,
                    "user_id": 2067461,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df409614bad27b9c27031a6c4ee30e84?s=256&d=identicon&r=PG",
                    "display_name": "sameerkn",
                    "link": "https://stackoverflow.com/users/2067461/sameerkn"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1489145329,
                "post_id": 42716872,
                "comment_id": 72554499,
                "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": 1489147095,
                "post_id": 42716872,
                "comment_id": 72555581,
                "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": 1489162984,
                "post_id": 42716872,
                "comment_id": 72565933,
                "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": 1489163069,
                "post_id": 42716872,
                "comment_id": 72565983,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1489146689,
                "creation_date": 1489146689,
                "answer_id": 42717766,
                "question_id": 42716872,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; to print every instance-name that does not contain **key-one** ... the\r\n&gt; command would return **instance-name-5**\r\n\r\nUse the following `awk` approach *piping* with `uniq` command:\r\n\r\n    awk &#39;{gsub(/&quot;/, &quot;&quot;, $0); if($2 == &quot;key-one&quot;) {a[$1]++} if ($2 != &quot;key-one&quot; &amp;&amp; !a[$1]){ print $1 }} &#39;  testfile | uniq\r\n\r\nThe output:\r\n\r\n    instance-name-5\r\n\r\n\r\n----------\r\n`gsub(/&quot;/, &quot;&quot;, $0)` - will replace trailing double quotes\r\n\r\n`if($2 == &quot;key-one&quot;) {a[$1]++}` - captures all &quot;instance names&quot; which marked with `key-one`\r\n\r\n`($2 != &quot;key-one&quot; &amp;&amp; !a[$1]){ print $1 }` - prints all &quot;instance names&quot; which are not in the list of ignored(`key-one`) &quot;instance names&quot;\r\n\r\n`uniq` - omit repeated lines",
                "title": "How to filter duplicates with jq/awk/grep/sed?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1489166463,
                "last_edit_date": 1489166463,
                "creation_date": 1489150017,
                "answer_id": 42718804,
                "question_id": 42716872,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using [tag:awk]\r\n\r\n**Input**\r\n\r\n    $ cat file\r\n    &quot;instance-name-1 key-one&quot;\r\n    &quot;instance-name-1 instance-template&quot;\r\n    &quot;instance-name-1 created-by&quot;\r\n    &quot;instance-name-2 key-one&quot;\r\n    &quot;instance-name-2 instance-template&quot;\r\n    &quot;instance-name-2 created-by&quot;\r\n    &quot;instance-name-3 key-one&quot;\r\n    &quot;instance-name-3 key-one&quot;\r\n    &quot;instance-name-3 instance-template&quot;\r\n    &quot;instance-name-3 created-by&quot;\r\n    &quot;instance-name-4 key-one&quot;\r\n    &quot;instance-name-4 instance-template&quot;\r\n    &quot;instance-name-4 created-by&quot;\r\n    &quot;instance-name-5 key-two&quot;\r\n    &quot;instance-name-5 instance-template&quot;\r\n    &quot;instance-name-5 created-by&quot;\r\n\r\nIn current context both will work\r\n\r\n**Output**\r\n\r\n    $ awk -F&#39;[&quot; ]&#39; &#39;/key-one/{a[$2]}!($2 in a){ print $2; a[$2] }&#39; file\r\n    instance-name-5\r\n\r\n**OR**\r\n\r\n    $ awk -F&#39;[&quot; ]&#39; &#39;/key-one/{a[$2]}!($2 in a) &amp;&amp; !seen[$2]++{ print $2}&#39; file\r\n    instance-name-5\r\n\r\n\r\n**Explanation**\r\n\r\n    awk -F&#39;[&quot; ]&#39; &#39;                     # call awk and set field sep as quote and space\r\n             /key-one/{                # if key-one found in current row/line/record\r\n                       a[$2]           # register instance name in array a\r\n             }\r\n             !($2 in a){               # if instance name does not exists in array a then\r\n                       print $2;       # print instance name\r\n                       a[$2]           # register instance name so that\r\n                                       # you will print only once ( to avoid duplicate )\r\n             }\r\n          &#39;  file\r\n\r\n**For**\r\n\r\n    awk -F&#39;[&quot; ]&#39; &#39;/key-one/{a[$2]}!($2 in a) &amp;&amp; !seen[$2]++{ print $2}&#39; file\r\n\r\n&gt; `!($2 in a) &amp;&amp; !seen[$2]++ {print $2}`\r\n\r\n instance name (`$2` as index) does not exists in array `a`, meaning instance name does not contain `key-one` and `!seen[$2]++` second field (as index), that is instance name not printed before then print second field(`$2`).\r\n",
                "title": "How to filter duplicates with jq/awk/grep/sed?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1489164256,
                "last_edit_date": 1489164256,
                "creation_date": 1489162785,
                "answer_id": 42723054,
                "question_id": 42716872,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I tend to tackle this sort of thing with `grep` and chained simple commands just because I can find these text manipulations in old shell scripts and understand and reuse them quickly.  It&#39;s also clear what your intermediate data is, so that you can change the behavior to suit your needs easily.\r\n\r\nYou can do this with `grep`, `cut -f1` to get the first column (with `-d&#39; &#39;` to use spaces as a column delimiter), and `sort -u` or `uniq` to do uniquing.\r\n\r\n**All in one, you can do this:**\r\n\r\n`grep key-one yourfile.txt | cut -d&#39; &#39; -f1 | sort -u | grep -vf- yourfile.txt | cut -d&#39; &#39; -f1 | uniq | sed &#39;s/&quot;//g&#39;` \r\n\r\nto get:\r\n\r\n     instance-name-5\r\n\r\n**Explanations:**\r\n\r\nGet the instances that have `key-one`:\r\n\r\n`grep key-one yourfile.txt | cut -d&#39; &#39; -f1 | sort -u &gt; delete_these.txt`\r\n\r\nThis creates delete_these.txt:\r\n\r\n    &quot;instance-name-1\r\n    &quot;instance-name-2\r\n    &quot;instance-name-3\r\n    &quot;instance-name-4\r\n\r\nThen use the above as a pattern file for `grep`:\r\n\r\n`grep -v -f delete_these.txt yourfile.txt`:\r\n\r\n    &quot;instance-name-5 key-two&quot;\r\n    &quot;instance-name-5 instance-template&quot;\r\n    &quot;instance-name-5 created-by&quot;\r\n\r\nAnd if you want to just cut that down to names again:\r\n\r\n`grep -v -f delete_these.txt yourfile.txt | cut -d&#39; &#39; -f1 | sort -u`:\r\n\r\n    &quot;instance-name-5\r\n\r\nYou can also use `sed &#39;s/&quot;//g&#39;` to remove quotes at any point.  `grep -f-` reads patterns from stdin.",
                "title": "How to filter duplicates with jq/awk/grep/sed?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1489179869,
                "last_edit_date": 1489179869,
                "creation_date": 1489176446,
                "answer_id": 42726868,
                "question_id": 42716872,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since you are using jq, it would make sense to apply the filter using jq.  jq 1.5 supports regular expressions, so you could for example include something like: `..... | select(.key | test(&quot;key-one&quot;) | not)`\r\n\r\nIf your jq does not include regex support, then consider upgrading, or using `index` or perhaps `contains` (but check the documentation for how to use these appropriately with your version of jq).\r\n",
                "title": "How to filter duplicates with jq/awk/grep/sed?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1489179869,
        "creation_date": 1489143949,
        "question_id": 42716872,
        "body_markdown": "I have the following which has been piped from jq, I need to print every instance-name that does not contain key-one. For example the command would return instance-name-5 if applied to the below. Should I apply another jq filter or just use grep/awk?\r\n\r\n    &quot;instance-name-1 key-one&quot;\r\n    &quot;instance-name-1 instance-template&quot;\r\n    &quot;instance-name-1 created-by&quot;\r\n    &quot;instance-name-2 key-one&quot;\r\n    &quot;instance-name-2 instance-template&quot;\r\n    &quot;instance-name-2 created-by&quot;\r\n    &quot;instance-name-3 key-one&quot;\r\n    &quot;instance-name-3 key-one&quot;\r\n    &quot;instance-name-3 instance-template&quot;\r\n    &quot;instance-name-3 created-by&quot;\r\n    &quot;instance-name-4 key-one&quot;\r\n    &quot;instance-name-4 instance-template&quot;\r\n    &quot;instance-name-4 created-by&quot;\r\n    &quot;instance-name-5 key-two&quot;\r\n    &quot;instance-name-5 instance-template&quot;\r\n    &quot;instance-name-5 created-by&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/42716872/how-to-filter-duplicates-with-jq-awk-grep-sed",
        "title": "How to filter duplicates with jq/awk/grep/sed?"
    },
    {
        "tags": [
            "pipeline",
            "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": 1489149248,
                "post_id": 42717586,
                "comment_id": 72556800,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 270035,
                    "reputation": 8656,
                    "user_id": 559742,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/bdc0803d3578379d994aa10fcbf4c15f?s=256&d=identicon&r=PG",
                    "display_name": "Roger",
                    "link": "https://stackoverflow.com/users/559742/roger"
                },
                "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": 1489151285,
                "post_id": 42717586,
                "comment_id": 72558069,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1491991400,
                "creation_date": 1491991400,
                "answer_id": 43366394,
                "question_id": 42717586,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`jq -c &#39;.[]\r\n| {a: .children[1].text, f: .children[0].text}\r\n| select(.a != null)\r\n| select(.f != null)\r\n| [.a, [.f,(.f | length)]]&#39;`",
                "title": "JQ | concatenate commands"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1492020199,
        "creation_date": 1489146158,
        "last_edit_date": 1492020199,
        "question_id": 42717586,
        "body_markdown": "Is there a way I can concatenate these js&#39;s command in just one jq command?\r\n\r\n\tjq &#39;map({a: .children[1].text, f: .children[0].text})&#39; | \\\r\n\tjq &#39;map(select(.a != null))&#39; | \\\r\n\tjq &#39;map(select(.f != null))&#39; | \\\r\n\tjq &#39;map([.a, [.f,(.f | length)]])&#39; | \\\r\n\tjq -c &#39;.[]&#39;\r\n\r\nThanks a lot.",
        "link": "https://stackoverflow.com/questions/42717586/jq-concatenate-commands",
        "title": "JQ | concatenate commands"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq",
            "dereference"
        ],
        "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": 1489152556,
                "post_id": 42719319,
                "comment_id": 72558906,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5248540,
                    "reputation": 2234,
                    "user_id": 4193473,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/369d81383d53787f8bc51e7b2112eb34?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "hgl",
                    "link": "https://stackoverflow.com/users/4193473/hgl"
                },
                "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": 1489152837,
                "post_id": 42719319,
                "comment_id": 72559094,
                "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": 1489155305,
                "post_id": 42719319,
                "comment_id": 72560745,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5248540,
                    "reputation": 2234,
                    "user_id": 4193473,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/369d81383d53787f8bc51e7b2112eb34?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "hgl",
                    "link": "https://stackoverflow.com/users/4193473/hgl"
                },
                "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": 1489156927,
                "post_id": 42719319,
                "comment_id": 72561865,
                "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": 1489160637,
                "post_id": 42719319,
                "comment_id": 72564408,
                "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": 1489162317,
                "post_id": 42719319,
                "comment_id": 72565524,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1489159654,
                "last_edit_date": 1495541372,
                "creation_date": 1489156717,
                "answer_id": 42720952,
                "question_id": 42719319,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. Network access has been proposed for jq but rejected, because of some combination of security, complexity, portabilty, and bloatware concerns.\r\n\r\n2. Shelling out has likewise been proposed but still seems some way off.\r\n\r\n3. It would be quite easy to achieve what \r\nI understand to be the goal here, using jq and curl in conjuction with a scripting language such as bash. One way would be to serialize the JSON, and then &quot;edit&quot; the serialized JSON using curl, before deserializing it. For serialization/deserialization functions in jq, see e.g. https://stackoverflow.com/questions/42553309/how-to-flatten-json-using-jq-and-bash-into-bash-associative-array-where-key-sele/42557971\r\n\r\n4. If all strings that are valid URLs are to be replaced, then identifying them could in principle be done before or after serialization. If only a subset of such strings are to be dereferenced, then the choice might depend on the specific requirements.",
                "title": "How to merge a remote json referenced by a url string into the current json"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1489160233,
                "creation_date": 1489160233,
                "answer_id": 42722216,
                "question_id": 42719319,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "XPath/XQuery has network access functions, since the W3C loves URI-references. If you are open to other tools, you could try my [XPath/XQuery/JSONiq interpreter](http://www.videlibri.de/xidel.html):\r\n\r\n    xidel master.json -e &#39;[$json()()!{.:json($json()(.))}]&#39;\r\n\r\nSyntax:\r\n\r\n1. `$json` is the input data\r\n\r\n2. `json()` is a function to retrieve JSON\r\n\r\n3. `()` are array values or object keys\r\n\r\n4. `!` maps a sequence of values, whereby `.` is a single value",
                "title": "How to merge a remote json referenced by a url string into the current json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1489254956,
                "last_edit_date": 1489254956,
                "creation_date": 1489161354,
                "answer_id": 42722554,
                "question_id": 42719319,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First, our test framework:\r\n\r\n    curl() {\r\n      case $1 in\r\n        http://example.com/remote1.json) echo &quot;[1]&quot; ;;\r\n        http://example.com/remote2.json) echo &quot;[2]&quot; ;;\r\n        *) echo &quot;IMABUG&quot; ;;\r\n      esac\r\n    }\r\n    input_json=&#39;[\r\n      {&quot;json1&quot;: &quot;http://example.com/remote1.json&quot;},\r\n      {&quot;json2&quot;: &quot;http://example.com/remote2.json&quot;}\r\n    ]&#39;\r\n\r\nThen, our actual code:\r\n\r\n    # defines the &quot;walk&quot; function, which is not yet included in a released version of jq\r\n    # ...in the future, this will not be necessary.\r\n    walk_fn=&#39;\r\n    def walk(f):\r\n      . as $in\r\n      | if type == &quot;object&quot; then\r\n          reduce keys[] as $key\r\n            ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n      elif type == &quot;array&quot; then map( walk(f) ) | f\r\n      else f\r\n      end;\r\n    &#39;\r\n\r\n    get_url_keys() {\r\n      jq -r &quot;$walk_fn\r\n        walk(\r\n          if type == \\&quot;object\\&quot; then\r\n            to_entries\r\n          else . end\r\n        )\r\n        | flatten\r\n        | .[]\r\n        | select(.value | test(\\&quot;://\\&quot;))\r\n        | [.key, .value]\r\n        | @tsv&quot;\r\n    }\r\n\r\n    operations=( )\r\n    options=( )\r\n    i=0\r\n    while IFS=$&#39;\\t&#39; read -r key url; do\r\n      options+=( --arg &quot;key$i&quot; &quot;$key&quot; --argjson &quot;value$i&quot; &quot;$(curl &quot;$url&quot;)&quot; )\r\n      operations+=(\r\n        &quot; walk(\r\n            if type == \\&quot;object\\&quot; then\r\n              if .[\\$key$i] then .[\\$key$i]=\\$value$i else . end\r\n            else . end\r\n          ) &quot;\r\n      )\r\n      (( ++i ))\r\n    done &lt; &lt;(get_url_keys &lt;&lt;&lt;&quot;$input_json&quot;)\r\n\r\n    IFS=&#39;|&#39; # separate operations with a | character\r\n    jq -c &quot;${options[@]}&quot; &quot;${walk_fn} ${operations[*]}&quot; &lt;&lt;&lt;&quot;$input_json&quot;\r\n\r\nOutput is properly:\r\n\r\n    [{&quot;json1&quot;:[1]},{&quot;json2&quot;:[2]}]",
                "title": "How to merge a remote json referenced by a url string into the current json"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1489304260,
        "creation_date": 1489151744,
        "last_edit_date": 1489304260,
        "question_id": 42719319,
        "body_markdown": "Given\r\n\r\n    [\r\n      {&quot;json1&quot;: &quot;http://example.com/remote1.json&quot;},\r\n      {&quot;json2&quot;: &quot;http://example.com/remote2.json&quot;}\r\n    ]\r\n\r\nwith `remote1.json` and `remote2.json` containing `[1]` and `[2]` respectively\r\n\r\nHow to turn it into\r\n\r\n    [{&quot;json1&quot;: [1], &quot;json2&quot;: [2]}]\r\n\r\nusing jq? I think other CLI tools like bash and curl are needed. But I have no idea how to merge the responses back.",
        "link": "https://stackoverflow.com/questions/42719319/how-to-merge-a-remote-json-referenced-by-a-url-string-into-the-current-json",
        "title": "How to merge a remote json referenced by a url string into the current json"
    },
    {
        "tags": [
            "json",
            "pretty-print",
            "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": 3,
                "creation_date": 1489192443,
                "post_id": 42729731,
                "comment_id": 72579317,
                "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": 1489250456,
                "post_id": 42729731,
                "comment_id": 72593504,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1489299719,
                "last_edit_date": 1489299719,
                "creation_date": 1489202256,
                "answer_id": 42730947,
                "question_id": 42729731,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A constrained-width JSON pretty-printer could be written in jq itself.\r\nHere is a pretty-printer which illustrates how this could be done, though in its present incarnation, it is of limited usefulness.\r\n\r\nppArray(indent; incr; width) will emit a stream of JSON strings that\r\ntogether are equivalent to the `tostring` value of the input. For\r\nrobustness, it will always act as a pretty-printer, even if the\r\nwidth restriction is violated.\r\n\r\nIf the input is an array, and if none of its elements (or recursively\r\ntheir elements) contains any large objects or long strings, then assuming the values of the parameters are reasonably chosen and that nesting is not too deep relative to these parameters,\r\neach emitted string should be no longer than &quot;width&quot;.\r\n\r\n    # indent is the initial indentation level;\r\n    # incr is the number of spaces to add for one additional indentation level;\r\n    # width is the target maximum width.\r\n    #\r\n    def ppArray(indent; incr; width):\r\n      # The inner function produces an array of unindented strings.\r\n      def ppArray_(incr_; width_):\r\n        tostring as $tostring\r\n        | if $tostring|length &lt;= (width_ - incr_) then [$tostring]\r\n          else reduce .[] as $i\r\n            ([];  \r\n             ($i|tostring) as $is\r\n              | if length == 0 then [ $is ]\r\n                else .[-1] as $s\r\n                | ($s|length) as $n\r\n                | ($is|length) as $isl\r\n                | if $n + $isl &lt;= (width_ - incr_)\r\n      \t         then .[-1] = ($s + &quot;, &quot; + $is)\r\n                  elif ($i|type) == &quot;array&quot;\r\n    \t         then (.[-1]+=&quot;,&quot;) + [ $i | ppArray(0; incr_; width_ - incr_) ]\r\n                  else  (.[-1]+=&quot;,&quot;) + [ $is ]\r\n                  end \r\n                end )\r\n          end;\r\n    \r\n        (&quot; &quot; * indent) as $indentation\r\n        | if type == &quot;array&quot; \r\n          then ppArray_(incr; width - indent)\r\n               | $indentation + &quot;[&quot;,\r\n               (.[] | ($indentation + &quot;  &quot; + . )),\r\n               $indentation + &quot;]&quot;\r\n        else $indentation + tostring\r\n        end\r\n    ;\r\n\r\n## Example:\r\n\r\n    [range(0;16)]\r\n    |\r\n    (ppArray(0; 2; 10)),\r\n    &quot;::&quot;,\r\n    ([{a:1}, {b:2}, {c:3}]  | ppArray(0; 2; 10)),\r\n    &quot;::&quot;,\r\n    (.[2]=[range(0;10)]) | ppArray(0; 2; 10)\r\n\r\n## Invocation: \r\n\r\n    jq -nrf pp.jq\r\n\r\n## Output:\r\n\r\n    [\r\n      0, 1, 2, 3,\r\n      4, 5, 6, 7,\r\n      8, 9, 10,\r\n      11, 12, 13,\r\n      14, 15\r\n    ]\r\n    ::\r\n    [\r\n      {&quot;a&quot;:1},\r\n      {&quot;b&quot;:2},\r\n      {&quot;c&quot;:3}\r\n    ]\r\n    ::\r\n    [\r\n      0, 1,\r\n      [\r\n        0, 1, 2,\r\n        3, 4, 5,\r\n        6, 7, 8,\r\n        9\r\n      ], 3, 4, 5,\r\n      6, 7, 8, 9,\r\n      10, 11, 12,\r\n      13, 14, 15\r\n    ]\r\n\r\n",
                "title": "Use jq to Format Certain Fields as Compact?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 9,
        "last_activity_date": 1489430188,
        "creation_date": 1489190667,
        "last_edit_date": 1489430188,
        "question_id": 42729731,
        "body_markdown": "# Is jq the best choice for pretty-printing arbitrary JSON?\r\n\r\n`cat my.json | jq .` pretty-prints the given JSON, but expands every field on a separate line.\r\n\r\nBut what if some of the fields are repetitive, such as a list of points? How can fields that match a pattern be formatted on a single line with `--compact-output`?\r\n\r\nFor example, format &quot;coords&quot; and &quot;list&quot; fields below on a single line:\r\n\r\n     [\r\n       { \r\n          &quot;field1&quot;: {\r\n            &quot;a&quot;: &quot;&quot;,\r\n            &quot;b&quot;: &quot;&quot;\r\n            &quot;list&quot;: [{ &quot;name&quot;: &quot;x&quot;, &quot;score&quot;: 1, &quot;rect&quot;: { &quot;x&quot;: 156, &quot;y&quot;: 245, &quot;w&quot;: 35, &quot;h&quot;: 45 }, ... ]\r\n          },\r\n          &quot;field2&quot;: 2,\r\n          &quot;coords&quot;: [{ &quot;x&quot;: 100, &quot;y&quot;: 400 },{ &quot;x&quot;: 100, &quot;y&quot;: 0 }]\r\n        },\r\n        ....\r\n     ]\r\n\r\nThe fields formatted with `--compact-output` can wrap (no need to break these long lines).\r\n\r\n",
        "link": "https://stackoverflow.com/questions/42729731/use-jq-to-format-certain-fields-as-compact",
        "title": "Use jq to Format Certain Fields as Compact?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1489326889,
                "post_id": 42746828,
                "comment_id": 72613162,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3220207,
                    "reputation": 1045,
                    "user_id": 2717853,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/757558928/picture?type=large",
                    "display_name": "Gavriel Fishel",
                    "link": "https://stackoverflow.com/users/2717853/gavriel-fishel"
                },
                "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": 1489329884,
                "post_id": 42746828,
                "comment_id": 72614116,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 141,
                "is_accepted": true,
                "score": 141,
                "last_activity_date": 1489324795,
                "creation_date": 1489324795,
                "answer_id": 42747910,
                "question_id": 42746828,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use `not` to reverse the logic\r\n\r\n    (.imageTags[] | contains(\\&quot;latest\\&quot;) | not)\r\n\r\nAlso, I&#39;d imagine you can simplify your pipeline into a single `jq` call.\r\n\r\n",
                "title": "jq: how to query for array values that don&#39;t contain text &quot;foo&quot;?"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1610386417,
                "last_edit_date": 1610386417,
                "creation_date": 1610384610,
                "answer_id": 65671353,
                "question_id": 42746828,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In this case `contains()` doesn&#39;t work properly, is better use the `not` of `index()` function\r\n\r\n    select(.imageTags | index(&quot;latest&quot;) | not)",
                "title": "jq: how to query for array values that don&#39;t contain text &quot;foo&quot;?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1610398307,
                "creation_date": 1610398307,
                "answer_id": 65674351,
                "question_id": 42746828,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This `.[] | .[]` can be shorten to `.[][]` e.g.,\r\n\r\n```lang-shell\r\n$ jq --null-input &#39;[[1,2],[3,4]] | .[] | .[]&#39;\r\n1\r\n2\r\n3\r\n4\r\n$ jq --null-input &#39;[[1,2],[3,4]] | .[][]&#39;\r\n1\r\n2\r\n3\r\n4\r\n```\r\n\r\nTo check whether a string does not contain another string, you can combine `contains` and `not` e.g.,\r\n\r\n```lang-shell\r\n$ jq --null-input &#39;&quot;foobar&quot; | contains(&quot;foo&quot;) | not&#39;\r\nfalse\r\n$ jq --null-input &#39;&quot;barbaz&quot; | contains(&quot;foo&quot;) | not&#39;\r\ntrue\r\n```\r\n\r\nYou can do something similar with an array of strings with either `any` or `all` e.g.,\r\n\r\n```lang-shell\r\n$ jq --null-input &#39;[&quot;foobar&quot;,&quot;barbaz&quot;] | any(.[]; contains(&quot;foo&quot;))&#39;\r\ntrue\r\n$ jq --null-input &#39;[&quot;foobar&quot;,&quot;barbaz&quot;] | any(.[]; contains(&quot;qux&quot;))&#39;\r\nfalse\r\n$ jq --null-input &#39;[&quot;foobar&quot;,&quot;barbaz&quot;] | all(.[]; contains(&quot;ba&quot;))&#39;\r\ntrue\r\n$ jq --null-input &#39;[&quot;foobar&quot;,&quot;barbaz&quot;] | all(.[]; contains(&quot;qux&quot;))&#39;\r\nfalse\r\n```\r\n\r\nSay you had file.json:\r\n\r\n```json\r\n[ [[&quot;foo&quot;, &quot;foo&quot;],[&quot;foo&quot;, &quot;bat&quot;]]\r\n, [[&quot;foo&quot;, &quot;bar&quot;],[&quot;foo&quot;, &quot;bat&quot;]]\r\n, [[&quot;foo&quot;, &quot;baz&quot;],[&quot;foo&quot;, &quot;bat&quot;]]\r\n]\r\n```\r\n\r\nAnd you only want to keep the nested arrays that don&#39;t have any strings with `&quot;ba&quot;`:\r\n\r\n```lang-shell\r\n$ jq --compact-output &#39;.[][] | select(all(.[]; contains(&quot;bat&quot;) | not))&#39; file.json\r\n[&quot;foo&quot;,&quot;foo&quot;]\r\n[&quot;foo&quot;,&quot;bar&quot;]\r\n[&quot;foo&quot;,&quot;baz&quot;]\r\n```",
                "title": "jq: how to query for array values that don&#39;t contain text &quot;foo&quot;?"
            },
            {
                "up_vote_count": 11,
                "is_accepted": false,
                "score": 11,
                "last_activity_date": 1704344079,
                "last_edit_date": 1704344079,
                "creation_date": 1613771008,
                "answer_id": 66285379,
                "question_id": 42746828,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "# Use `| not`\r\n\r\nA useful example, in particular for mac `brew` users:\r\n\r\n### List all bottled formulae \r\nby querying the JSON and parsing the output\r\n\r\n    brew info --json=v1 --installed | jq -r &#39;map(\r\n        select(.installed[].poured_from_bottle)|.name) | unique | .[]&#39; | tr &#39;\\n&#39; &#39; &#39;\r\n\r\n\r\n### List all non-bottled formulae \r\nby querying the JSON and parsing the output and using `| not`\r\n\r\n    brew info --json=v1 --installed | jq -r &#39;map(                                                                                                                          \r\n      select(.installed[].poured_from_bottle | not) | .name) | unique | .[]&#39;\r\n\r\n",
                "title": "jq: how to query for array values that don&#39;t contain text &quot;foo&quot;?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 92,
        "last_activity_date": 1704380965,
        "creation_date": 1489318002,
        "last_edit_date": 1704380965,
        "question_id": 42746828,
        "body_markdown": "I have an aws query where I want to filter all the `imageTags` that **don&#39;t** end with *latest*.\r\n\r\nI tried this, but it filters things containing *latest*, where I want to filter things **not** containing *latest* (or **not** ending with *latest*):\r\n\r\n    aws ecr describe-images --repository-name &lt;repo&gt; --output json \\\r\n      | jq &#39;.[]&#39; \\\r\n      | jq &#39;.[]&#39; \\\r\n      | jq &quot;select ((.imagePushedAt &lt; 14893094695) and (.imageTags[] | contains(\\&quot;latest\\&quot;)))&quot;",
        "link": "https://stackoverflow.com/questions/42746828/jq-how-to-query-for-array-values-that-dont-contain-text-foo",
        "title": "jq: how to query for array values that don&#39;t contain text &quot;foo&quot;?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1489338786,
                "last_edit_date": 1489338786,
                "creation_date": 1489337882,
                "answer_id": 42750304,
                "question_id": 42750089,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following will extract all key names from `.authenticationDatabase.JQ_Newb.profiles` :\r\n\r\n    jq -r &#39;.authenticationDatabase.JQ_Newb.profiles | to_entries[] | .key&#39; data.json\r\n\r\nIn case you have multiple keys in `.authenticationDatabase.JQ_Newb.profiles`, it will give :\r\n\r\n    12345678901234567890123456789012\r\n    12345678901234567890123456789013\r\n\r\nTo get the values under all keys in `.authenticationDatabase.JQ_Newb.profiles` : \r\n\r\n    jq -r &#39;.authenticationDatabase.JQ_Newb.profiles | to_entries[] | .value &#39; data.json",
                "title": "Cant manage to extract a field using JQ in a json file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1489343713,
                "creation_date": 1489343713,
                "answer_id": 42751460,
                "question_id": 42750089,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I had answered you but you were no longer in the channel - it&#39;s not very active as you may have noticed ;_;\r\n\r\nYou&#39;ve already been given a working solution but here was my answer using `keys`\r\n\r\n    user@host $ jq -r &#39;.authenticationDatabase.JQ_Newb.profiles | keys&#39; jqnewb.json \r\n    [\r\n      &quot;12345678901234567890123456789012&quot;\r\n    ]\r\n    user@host $ jq -r &#39;.authenticationDatabase.JQ_Newb.profiles | keys[]&#39; jqnewb.json \r\n    12345678901234567890123456789012",
                "title": "Cant manage to extract a field using JQ in a json file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1489343713,
        "creation_date": 1489336894,
        "last_edit_date": 1489337418,
        "question_id": 42750089,
        "body_markdown": "I&#39;ve been searching for a solution on this forever but still haven&#39;t managed to do it.\r\n\r\nI&#39;m trying to get the long number field (see below) and ommit everything else but fail to do so.\r\n\r\n\r\nThis is the JSON file contents:\r\n\r\n    {\r\n        &quot;jsonProfile&quot;: {\r\n            &quot;version&quot;: &quot;1.0&quot;,\r\n            &quot;format&quot;: 1\r\n        },\r\n        &quot;authenticationDatabase&quot;: {\r\n            &quot;JQ_Newb&quot;: {\r\n                &quot;username&quot;: &quot;JQ_Newb&quot;,\r\n                &quot;profiles&quot;: {\r\n                    &quot;12345678901234567890123456789012&quot;: {\r\n                        &quot;displayName&quot;: &quot;JQ_Newb&quot;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\nThis is my filter:\r\n\r\n    .authenticationDatabase|.[]|.profiles\r\n\r\n\r\nAnd this is the result:\r\n\r\n    {\r\n      &quot;12345678901234567890123456789012&quot;: {\r\n        &quot;displayName&quot;: &quot;JQ_Newb&quot;\r\n      }\r\n    }\r\n\r\nThanks for helping, Stackoverflow people!",
        "link": "https://stackoverflow.com/questions/42750089/cant-manage-to-extract-a-field-using-jq-in-a-json-file",
        "title": "Cant manage to extract a field using JQ in a json file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1489409262,
                "creation_date": 1489409262,
                "answer_id": 42764017,
                "question_id": 42762941,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Something like this will work, where you extract an array of key-value pairs and pipe to `from_entries`:\r\n\r\n    % jq &#39;[to_entries[] | {&quot;key&quot;: .key, &quot;value&quot;: .value.serials}] | from_entries&#39; 42762941.json\r\n    {\r\n      &quot;prodid_876006&quot;: [\r\n        &quot;028915&quot;\r\n      ],\r\n      &quot;prodid_980&quot;: [\r\n        &quot;192147&quot;,\r\n        &quot;1632589&quot;\r\n      ]\r\n    }\r\n\r\n",
                "title": "jq create a new json by transforming an existing one"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666130567,
                "creation_date": 1666130567,
                "answer_id": 74117922,
                "question_id": 42762941,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For question #1, simply replace the value by the serials property:\r\n\r\n```\r\nwith_entries(.value|=.serials)\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;prodid_876006&quot;: [\r\n    &quot;028915&quot;\r\n  ],\r\n  &quot;prodid_980&quot;: [\r\n    &quot;192147&quot;,\r\n    &quot;1632589&quot;\r\n  ]\r\n}\r\n```\r\n\r\nFor your second question, see [this answer](https://stackoverflow.com/a/74117849/112968) to an almost identical question. You can combine the solution from the linked answer with the solution for question #1:\r\n\r\n```\r\nwith_entries(.value|=.serials)\r\n| with_entries({key:.value[], value:[.key]})\r\n```\r\n\r\nor do it in a single step:\r\n\r\n```\r\nwith_entries({key:.value.serials[], value:[.key]})\r\n```\r\n\r\nIn both cases, the output will be:\r\n\r\n```json\r\n{\r\n  &quot;028915&quot;: [\r\n    &quot;prodid_876006&quot;\r\n  ],\r\n  &quot;192147&quot;: [\r\n    &quot;prodid_980&quot;\r\n  ],\r\n  &quot;1632589&quot;: [\r\n    &quot;prodid_980&quot;\r\n  ]\r\n}\r\n```",
                "title": "jq create a new json by transforming an existing one"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1666130567,
        "creation_date": 1489405796,
        "last_edit_date": 1489414323,
        "question_id": 42762941,
        "body_markdown": "        {\r\n    \t&quot;prodid_876006&quot;: {\r\n    \t\t&quot;serid&quot;: [{\r\n    \t\t\t&quot;seridone&quot;: &quot;3265874&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;seridtwo&quot;: &quot;21458915&quot;\r\n    \t\t}],\r\n    \t\t&quot;serials&quot;: [&quot;028915&quot;]\r\n    \t},\r\n    \t&quot;prodid_980&quot;: {\r\n    \t\t&quot;serid&quot;: [{\r\n    \t\t\t&quot;seridone&quot;: &quot;32743214&quot;\r\n    \t\t}, {\r\n    \t\t\t&quot;seridtwo&quot;: &quot;5469872&quot;\r\n    \t\t}],\r\n    \t\t&quot;serials&quot;: [&quot;192147&quot;,&quot;1632589&quot;]\r\n    \t}\r\n    }\r\n\r\ndesired output:\r\nfor each json object, extract the prodid_ info, and the serials array, and make a new json file, with the following format: \r\n\r\n    {    \r\n    &quot;prodid_876006&quot; : [&quot;028915&quot;],\r\n    &quot;prodid_980&quot; : [&quot;192147&quot;,&quot;1632589&quot;]\r\n    }\r\n\r\nwhat would be the jq command for this?\r\n\r\n    keys ,.[].serials\r\n\r\ngives me the following:\r\n\r\n    [\r\n      &quot;prodid_876006&quot;,\r\n      &quot;prodid_980&quot;\r\n    ]\r\n    [\r\n      &quot;028915&quot;\r\n    ]\r\n    [\r\n      &quot;192147&quot;,\r\n      &quot;1632589&quot;\r\n    ]\r\n\r\nupdated question:\r\n\r\nhow could i also get in another json the following output? (here the key is each element of the serials array, and the value is the key of the first sample json):\r\n\r\n    {    \r\n    &quot;028915&quot; : [&quot;prodid_876006&quot;],\r\n    &quot;192147&quot; : [&quot;prodid_980&quot;],\r\n    &quot;1632589&quot; : [&quot;prodid_980&quot;]\r\n    }",
        "link": "https://stackoverflow.com/questions/42762941/jq-create-a-new-json-by-transforming-an-existing-one",
        "title": "jq create a new json by transforming an existing one"
    },
    {
        "tags": [
            "json",
            "python-3.x",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 29240,
                    "reputation": 142526,
                    "user_id": 78845,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/7jZ4g.png?s=256",
                    "display_name": "johnsyweb",
                    "link": "https://stackoverflow.com/users/78845/johnsyweb"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1489441842,
                "post_id": 42766399,
                "comment_id": 72663512,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666130275,
                "post_id": 42766399,
                "comment_id": 130861962,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1489429035,
                "creation_date": 1489429035,
                "answer_id": 42770688,
                "question_id": 42766399,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following solution uses `reduce` within `reduce` and so might look a bit tricky, so it might help to think of &quot;reduce&quot; as a kind of &quot;do loop&quot;, as suggested by the indentation:\r\n\r\n    reduce to_entries[] as $kv ({};\r\n      reduce $kv.value.serials[] as $s (.;\r\n        . + {($s): (.[$s] + [$kv|.key]) } ) )\r\n",
                "title": "transform a json file, into a new json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502871686,
                "creation_date": 1502871686,
                "answer_id": 45708546,
                "question_id": 42766399,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **to_entries**, **reduce** and **add**\r\n\r\n        [ to_entries[]\r\n          | .key as $k\r\n          | reduce .value.serials[] as $v ({}; .[$v] += [$k])\r\n        ] | add",
                "title": "transform a json file, into a new json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1502901939,
                "creation_date": 1502901939,
                "answer_id": 45719001,
                "question_id": 42766399,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To start, a more succinct way to get the first result in your question is to use `map_values`. You&#39;re changing all the values in your object map to the contents of the `serials` value. Which can be expressed simply as:\r\n\r\n    map_values(.serials)\r\n\r\nFrom there, it&#39;s just a matter of pivoting the data.\r\n\r\n    map_values(.serials) | reduce to_entries[] as $e ({};\r\n        .[$e.value[]] += [$e.key]\r\n    )",
                "title": "transform a json file, into a new json"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1535298723,
        "creation_date": 1489416083,
        "last_edit_date": 1535298723,
        "question_id": 42766399,
        "body_markdown": "    {\r\n        &quot;prodid_876006&quot;: {\r\n            &quot;serid&quot;: [{\r\n                &quot;seridone&quot;: &quot;3265874&quot;\r\n            }, {\r\n                &quot;seridtwo&quot;: &quot;21458915&quot;\r\n            }],\r\n            &quot;serials&quot;: [&quot;028915&quot;]\r\n        },\r\n        &quot;prodid_980&quot;: {\r\n            &quot;serid&quot;: [{\r\n                &quot;seridone&quot;: &quot;32743214&quot;\r\n            }, {\r\n                &quot;seridtwo&quot;: &quot;5469872&quot;\r\n            }],\r\n            &quot;serials&quot;: [&quot;192147&quot;,&quot;1632589&quot;]\r\n        }\r\n    }\r\n\r\n    % jq &#39;[to_entries[] | {&quot;key&quot;: .key, &quot;value&quot;: .value.serials}] | from_entries&#39; some.json \r\ngives:\r\n\r\n    {\r\n      &quot;prodid_876006&quot;: [\r\n        &quot;028915&quot;\r\n      ],\r\n      &quot;prodid_980&quot;: [\r\n        &quot;192147&quot;,\r\n        &quot;1632589&quot;\r\n      ]\r\n    }\r\n\r\nhow could i get the following output? (here the key is each element of the serials array, and the value is the key of the sample json):\r\n\r\n    {    \r\n    &quot;028915&quot; : [&quot;prodid_876006&quot;],\r\n    &quot;192147&quot; : [&quot;prodid_980&quot;],\r\n    &quot;1632589&quot; : [&quot;prodid_980&quot;]\r\n    }",
        "link": "https://stackoverflow.com/questions/42766399/transform-a-json-file-into-a-new-json",
        "title": "transform a json file, into a new json"
    },
    {
        "tags": [
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1489428038,
                "creation_date": 1489428038,
                "answer_id": 42770403,
                "question_id": 42768870,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If your jq has `first/1`:\r\n\r\n    first(.accounts[] | .username)\r\n\r\nOtherwise you might like to consider:\r\n\r\n    [.accounts[] | .username][0]",
                "title": "Multiple fields but only extract the first key&#39;s value?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1489446284,
        "creation_date": 1489423015,
        "last_edit_date": 1489446284,
        "question_id": 42768870,
        "body_markdown": "The title could&#39;ve been done better, but sometimes my english vocabulary is as lacking as my JSON skills (despite jqplay.org being a useful resource) :(\r\n\r\n\r\nAnywho; I&#39;m trying to extract the first **username** value under the `&quot;accounts&quot;` field. The problem is, there are multiple entries (&quot;someone&quot; and &quot;someoneelse&quot;) and i only need the first key&#39;s value in the list (&quot;JQ_Newb&quot; or &quot;GOD&quot;, depending on how the JSON is parsed).\r\n\r\n**The JSON&#39;s contents are as followed:**\r\n\r\n    {\r\n      &quot;accounts&quot;: {\r\n        &quot;someone&quot;: {\r\n          &quot;username&quot;: &quot;JQ_Newb&quot;,\r\n          &quot;info&quot;: &quot;stackoverflow&quot;\r\n        },\r\n        &quot;someoneelse&quot;: {\r\n          &quot;username&quot;: &quot;GOD&quot;,\r\n          &quot;info&quot;: &quot;heaven&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI&#39;ve been fiddling around with `to_entries[]` and `select()` (with and without values between [] and () ), but all that i&#39;m getting is:\r\n\r\n    {\r\n      &quot;key&quot;: &quot;extra&quot;,\r\n      &quot;value&quot;: &quot;stackoverflow&quot;\r\n    }\r\n    {\r\n      &quot;key&quot;: &quot;extra&quot;,\r\n      &quot;value&quot;: &quot;heaven&quot;\r\n    }\r\n\r\n\r\n\r\n    \r\nand:\r\n\r\n    &quot;JQ_Newb&quot;\r\n    &quot;GOD&quot;\r\n\r\nusing `.accounts[].username`\r\n\r\n\r\n**TL;DR**\r\n\r\n    .accounts[]|to_entries[0]|select(i_dont_know_what_i&#39;m_doing)\r\n\r\nIf a solution is already on Stackoverflow, i&#39;m sorry i couldn&#39;t find it.\r\nI&#39;ve tried my best to solve this problem, myself.\r\n\r\n\r\n\r\nThanks,\r\n\r\n**copyitright**",
        "link": "https://stackoverflow.com/questions/42768870/multiple-fields-but-only-extract-the-first-keys-value",
        "title": "Multiple fields but only extract the first key&#39;s value?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2045726,
                    "reputation": 1600,
                    "user_id": 1825844,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a2e35e7a0b7e05f52976210665ee58ac?s=256&d=identicon&r=PG",
                    "display_name": "gvmani",
                    "link": "https://stackoverflow.com/users/1825844/gvmani"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1489428058,
                "post_id": 42769054,
                "comment_id": 72656329,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1666130285,
                "post_id": 42769054,
                "comment_id": 130861964,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503035733,
                "creation_date": 1503035733,
                "answer_id": 45749434,
                "question_id": 42769054,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another solution which uses **add**\r\n\r\n    . as $d | [ keys[] | {($d[.][]): [.]} ] | add\r\n\r\nor equivalently \r\n   \r\n    . as $d | keys | map( {($d[.][]):[.]} ) | add",
                "title": "use jq to reshape a json file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1666130083,
                "creation_date": 1666130083,
                "answer_id": 74117849,
                "question_id": 42769054,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A very concise solution using [`with_entries`](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries), swapping keys and values:\r\n\r\n```\r\nwith_entries({key:.value[], value:[.key]})\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;serial-8915&quot;: [\r\n    &quot;id-952&quot;\r\n  ],\r\n  &quot;serial-5747&quot;: [\r\n    &quot;id-546&quot;\r\n  ],\r\n  &quot;serial-8735&quot;: [\r\n    &quot;id-546&quot;\r\n  ]\r\n}\r\n```",
                "title": "use jq to reshape a json file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1666130083,
        "creation_date": 1489423564,
        "question_id": 42769054,
        "body_markdown": "i need to transform the following\r\n\r\ninput:   \r\n \r\n\r\n    {\r\n          &quot;id-952&quot;: [\r\n            &quot;serial-8915&quot;\r\n          ],\r\n          &quot;id-546&quot;: [\r\n            &quot;serial-5747&quot;,\r\n            &quot;serial-8735&quot;\r\n          ]\r\n\r\nDesired output:\r\n\r\n    {\r\n    &quot;serial-8915&quot;: [&quot;id-952&quot;],\r\n    &quot;serial-5747&quot;: [&quot;id-546&quot;],\r\n    serial-8735&quot;: [&quot;id-546&quot;]\r\n    }\r\n\r\nmy try, on jqplay:\r\n\r\n    keys, .[]\r\n\r\noutput:\r\n\r\n    [\r\n      &quot;id-546&quot;,\r\n      &quot;id-952&quot;\r\n    ]\r\n    [\r\n      &quot;serial-8915&quot;\r\n    ]\r\n    [\r\n      &quot;serial-5747&quot;,\r\n      &quot;serial-8735&quot;\r\n    ]\r\n\r\nwhat jq command is the appropriate one?",
        "link": "https://stackoverflow.com/questions/42769054/use-jq-to-reshape-a-json-file",
        "title": "use jq to reshape a json file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3555697,
                    "reputation": 2210,
                    "user_id": 2969535,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/70Hqi.jpg?s=256",
                    "display_name": "Olaia",
                    "link": "https://stackoverflow.com/users/2969535/olaia"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1489498666,
                "post_id": 42785677,
                "comment_id": 72689178,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user7708373"
                },
                "reply_to_user": {
                    "account_id": 3555697,
                    "reputation": 2210,
                    "user_id": 2969535,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/70Hqi.jpg?s=256",
                    "display_name": "Olaia",
                    "link": "https://stackoverflow.com/users/2969535/olaia"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1489499353,
                "post_id": 42785677,
                "comment_id": 72689721,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1489563566,
                "last_edit_date": 1489563566,
                "creation_date": 1489561529,
                "answer_id": 42803125,
                "question_id": 42785677,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The .... in the given expected output introduces several uncertainties beyond those in the problem statement itself, but the following program does produce results that are consistent with the expected output as shown.\r\n\r\nThe key to the solution given here is the helper function for combining a stream of JSON objects:\r\n \r\n    # Combine a stream of JSON objects into a single object\r\n    # by converting the value v to [v] at each\r\n    # key, and then appending the arrays at each key.\r\n    def combine(s):\r\n      reduce s as $o ({};\r\n        reduce ($o|keys[]) as $k (.; .[$k] += [$o[$k]]  ) );\r\n \r\nThe problem as I understand it can now be solved using `to_entries/0` three times; if you&#39;re not familiar with that filter, the following might seem fairly incomprehensible:\r\n  \r\n    combine( to_entries[]\r\n       | .key as $k\r\n       | .value\r\n       | to_entries[]\r\n       | select( .key | startswith(&quot;logfile_&quot;))\r\n       | .key as $innerkey\r\n       | .value[]\r\n       | to_entries[]\r\n       | { (.value): { ($k): $innerkey }}\r\n     ) | map_values(add)\r\n\r\nThe output with the given input is:\r\n\r\n    {\r\n      &quot;desiredvalueone&quot;: {\r\n        &quot;name_A&quot;: &quot;logfile_one&quot;\r\n      },\r\n      &quot;desiredvaluetwo&quot;: {\r\n        &quot;name_A&quot;: &quot;logfile_one&quot;,\r\n        &quot;name_B&quot;: &quot;logfile_two&quot;\r\n      },\r\n      &quot;desiredvaluethirtyfour&quot;: {\r\n        &quot;name_B&quot;: &quot;logfile_two&quot;\r\n      }\r\n    }\r\n\r\n",
                "title": "jq to manipulate a json file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503034292,
                "creation_date": 1503034292,
                "answer_id": 45749139,
                "question_id": 42785677,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which only assumes the input has the following structure\r\n\r\n    { \r\n      &quot;k&quot;: {\r\n         &quot;k2&quot;: [{\r\n            &quot;k3&quot;: &quot;v&quot;\r\n\r\nIt works by generating a temporary array of objects of the format\r\n\r\n    {&quot;v&quot;:&quot;desiredvalueone&quot;,&quot;k&quot;:&quot;name_A&quot;,&quot;k2&quot;:&quot;logfile_one&quot;}\r\n\r\nthen grouping by `.v` and combining groups and wrapping values \r\nin an array as requested.\r\n\r\n    [\r\n      . as $d\r\n    | [\r\n          keys[] as $k                           # e.g &quot;name_A&quot;...\r\n        | ($d[$k] | keys[]\r\n           | select($d[$k][.][0]|type==&quot;object&quot;)\r\n           ) as $k2                              # k2:  &quot;logfile_one&quot;\r\n        | $d[$k][$k2][] as $v                    # v:  {&quot;issue_desc&quot;:&quot;desiredvalueone&quot;},\r\n        | ($v|keys[]) as $k3                     # k3: &quot;issue_desc&quot;\r\n        | {v:$v[$k3], k:$k, k2:$k2}              # {&quot;v&quot;:&quot;desiredvalueone&quot;,&quot;k&quot;:&quot;name_A&quot;,&quot;k2&quot;:&quot;logfile_one&quot;}\r\n      ]\r\n    | group_by(.v)[]\r\n    | reduce .[] as $t (\r\n        {}\r\n      ; .[$t.v] += {($t.k): $t.k2}\r\n      )\r\n    ]\r\n    | add\r\n    | map_values([.])\r\n\r\nThe final output is\r\n\r\n    {\r\n      &quot;desiredvalueone&quot;: [\r\n        {\r\n          &quot;name_A&quot;: &quot;logfile_one&quot;\r\n        }\r\n      ],\r\n      &quot;desiredvaluethirtyfour&quot;: [\r\n        {\r\n          &quot;name_B&quot;: &quot;logfile_two&quot;\r\n        }\r\n      ],\r\n      &quot;desiredvaluetwo&quot;: [\r\n        {\r\n          &quot;name_A&quot;: &quot;logfile_one&quot;,\r\n          &quot;name_B&quot;: &quot;logfile_two&quot;\r\n        }\r\n      ]\r\n    }",
                "title": "jq to manipulate a json file"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1503034292,
        "creation_date": 1489493490,
        "last_edit_date": 1489681490,
        "question_id": 42785677,
        "body_markdown": "Having as input below sample json:  \r\n \r\n\t{\r\n\t    &quot;name_A&quot;: {\r\n\t        &quot;logfile_one&quot;: [{\r\n\t            &quot;issue_desc&quot;: &quot;desiredvalueone&quot;\r\n\t        }, {\r\n\t            &quot;issuetime&quot;: &quot;desiredvaluetwo&quot;\r\n\t        }],\r\n\t        &quot;output&quot;: [&quot;46312&quot;]\r\n\t    },\r\n\t    &quot;name_B&quot;: {\r\n\t        &quot;logfile_two&quot;: [{\r\n\t            &quot;issue_desc&quot;: &quot;desiredvaluethirtyfour&quot;\r\n\t        }, {\r\n\t            &quot;issuetime&quot;: &quot;desiredvaluetwo&quot;\r\n\t        }],\r\n\t        &quot;output&quot;: [&quot;1&quot;, &quot;2&quot;]\r\n\t    }\r\n\t}\r\n\r\nWe would like the following output:\r\n    \r\n\t{\r\n\t    &quot;desiredvalueone&quot;: [{\r\n\t        &quot;name_A&quot;: &quot;logfile_one&quot;\r\n\t    }],\r\n\t    &quot;desiredvaluetwo&quot;: [{\r\n\t        &quot;name_A&quot;: &quot;logfile_one&quot;,\r\n\t        &quot;name_B&quot;: &quot;logfile_two&quot;\r\n\t    }],\r\n\t    ...\r\n\t}\r\n\r\nusing t`o_entries[] | .key` for instance, we manage to get &quot;`name_A`&quot;\r\n&quot;`name_B`&quot;, but very far from what we try to achieve. Or with \r\n\r\n    [to_entries[] | {&quot;key&quot;: .key, &quot;value&quot;: .value[]}] | from_entries\r\n\r\noutput was\r\n\r\n    {\r\n      &quot;name_A&quot;: [\r\n        &quot;46312&quot;\r\n      ],\r\n      &quot;name_B&quot;: [\r\n        &quot;1&quot;,\r\n        &quot;2&quot;\r\n      ]\r\n    }",
        "link": "https://stackoverflow.com/questions/42785677/jq-to-manipulate-a-json-file",
        "title": "jq to manipulate a json file"
    },
    {
        "tags": [
            "json",
            "go",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 232938,
                    "reputation": 1329,
                    "user_id": 498109,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/100036fbeed75b1abf5bf0161d1fb560?s=256&d=identicon&r=PG",
                    "display_name": "Vadyus",
                    "link": "https://stackoverflow.com/users/498109/vadyus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1489500145,
                "post_id": 42788045,
                "comment_id": 72690335,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3357898,
                    "reputation": 1051,
                    "user_id": 2820419,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://graph.facebook.com/100000721485668/picture?type=large",
                    "display_name": "Sid Shukla",
                    "link": "https://stackoverflow.com/users/2820419/sid-shukla"
                },
                "reply_to_user": {
                    "account_id": 232938,
                    "reputation": 1329,
                    "user_id": 498109,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/100036fbeed75b1abf5bf0161d1fb560?s=256&d=identicon&r=PG",
                    "display_name": "Vadyus",
                    "link": "https://stackoverflow.com/users/498109/vadyus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1489500705,
                "post_id": 42788045,
                "comment_id": 72690797,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1886487,
                    "reputation": 421260,
                    "user_id": 1705598,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/aTFoe.jpg?s=256",
                    "display_name": "icza",
                    "link": "https://stackoverflow.com/users/1705598/icza"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1489501375,
                "post_id": 42788045,
                "comment_id": 72691367,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1489501715,
                "last_edit_date": 1489501715,
                "creation_date": 1489500502,
                "answer_id": 42788236,
                "question_id": 42788045,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The [`encoding/json`][1] package supports pretty output out-of-the-box. You may use [`json.MarshalIndent()`][2]. Or if you&#39;re using [`json.Encoder`][3], then call its [`Encoder.SetIndent()`][4] (new since [Go 1.7][5]) method prior to calling [`Encoder.Encode()`][6].\r\n\r\nExamples:\r\n\r\n\tm := map[string]interface{}{&quot;id&quot;: &quot;uuid1&quot;, &quot;name&quot;: &quot;John Smith&quot;}\r\n\r\n\tdata, err := json.MarshalIndent(m, &quot;&quot;, &quot;  &quot;)\r\n\tif err != nil {\r\n\t\tpanic(err)\r\n\t}\r\n\tfmt.Println(string(data))\r\n\r\n\tenc := json.NewEncoder(os.Stdout)\r\n\tenc.SetIndent(&quot;&quot;, &quot;  &quot;)\r\n\tif err := enc.Encode(m); err != nil {\r\n\t\tpanic(err)\r\n\t}\r\n\r\nOutput (try it on the [Go Playground][7]):\r\n\r\n    {\r\n      &quot;id&quot;: &quot;uuid1&quot;,\r\n      &quot;name&quot;: &quot;John Smith&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;uuid1&quot;,\r\n      &quot;name&quot;: &quot;John Smith&quot;\r\n    }\r\n\r\nIf you just want to format a &quot;ready&quot; JSON text, you may use the [`json.Indent()`][8] function:\r\n\r\n\tsrc := `{&quot;id&quot;:&quot;uuid1&quot;,&quot;name&quot;:&quot;John Smith&quot;}`\r\n\r\n\tdst := &amp;bytes.Buffer{}\r\n\tif err := json.Indent(dst, []byte(src), &quot;&quot;, &quot;  &quot;); err != nil {\r\n\t\tpanic(err)\r\n\t}\r\n\tfmt.Println(dst.String())\r\n\r\nOutput (try it on the [Go Playground][9]):\r\n\r\n    {\r\n      &quot;id&quot;: &quot;uuid1&quot;,\r\n      &quot;name&quot;: &quot;John Smith&quot;\r\n    }\r\n\r\nThe 2 `string` parameters to these `indent` functions are:\r\n\r\n    prefix, indent string\r\n\r\nExplanation is in the docs:\r\n\r\n&gt; Each element in a JSON object or array begins on a new, indented line beginning with prefix followed by one or more copies of indent according to the indentation nesting.\r\n\r\nSo each newline will be started with `prefix`, which will be followed by 0 or more copies of `indent`, depending on the nesting level.\r\n\r\nIt becomes clear and obvious if you specify values for them like this:\r\n\r\n    json.Indent(dst, []byte(src), &quot;+&quot;, &quot;-&quot;)\r\n\r\nTesting it with embedded objects:\r\n\r\n\tsrc := `{&quot;id&quot;:&quot;uuid1&quot;,&quot;name&quot;:&quot;John Smith&quot;,&quot;embedded:&quot;:{&quot;fieldx&quot;:&quot;y&quot;}}`\r\n\r\n\tdst := &amp;bytes.Buffer{}\r\n\tif err := json.Indent(dst, []byte(src), &quot;+&quot;, &quot;-&quot;); err != nil {\r\n\t\tpanic(err)\r\n\t}\r\n\tfmt.Println(dst.String())\r\n\r\nOutput (try it on the [Go Playground][10]):\r\n\r\n    {\r\n    +-&quot;id&quot;: &quot;uuid1&quot;,\r\n    +-&quot;name&quot;: &quot;John Smith&quot;,\r\n    +-&quot;embedded:&quot;: {\r\n    +--&quot;fieldx&quot;: &quot;y&quot;\r\n    +-}\r\n    +}\r\n\r\n\r\n  [1]: https://golang.org/pkg/encoding/json/\r\n  [2]: https://golang.org/pkg/encoding/json/#MarshalIndent\r\n  [3]: https://golang.org/pkg/encoding/json/#Encoder\r\n  [4]: https://golang.org/pkg/encoding/json/#Encoder.SetIndent\r\n  [5]: https://golang.org/doc/go1.7#encoding_json\r\n  [6]: https://golang.org/pkg/encoding/json/#Encoder.Encode\r\n  [7]: https://play.golang.org/p/WjLLth_BWk\r\n  [8]: https://golang.org/pkg/encoding/json/#Indent\r\n  [9]: https://play.golang.org/p/wYMWmXPMSX\r\n  [10]: https://play.golang.org/p/s4rpASv0AO",
                "title": "Is there a jq wrapper for golang that can produce human readable JSON output?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1556401469,
        "creation_date": 1489500012,
        "question_id": 42788045,
        "body_markdown": "I&#39;m writing a go program (let&#39;s call it foo) that outputs JSON on the Standard Out. \r\n\r\n    $ ./foo\r\n    {&quot;id&quot;:&quot;uuid1&quot;,&quot;name&quot;:&quot;John Smith&quot;}{&quot;id&quot;:&quot;uuid2&quot;,&quot;name&quot;:&quot;Jane Smith&quot;}\r\n\r\nIn order to make the output human readable, I have to pipe it into jq like:\r\n\r\n    $ ./foo | jq .\r\n\r\n    {\r\n    &quot;id&quot;:&quot;uuid1&quot;,\r\n    &quot;name&quot;: &quot;John Smith&quot;\r\n    }\r\n    {\r\n    &quot;id&quot;:&quot;uuid2&quot;\r\n    &quot;name&quot;: &quot;Jane Smith&quot;\r\n    }\r\n\r\nIs there a way to achieve the same result using a jq wrapper that is open sourced? I tried finding some but they are usually wrapping the functionality for filtering JSON input not prettifying JSON output.",
        "link": "https://stackoverflow.com/questions/42788045/is-there-a-jq-wrapper-for-golang-that-can-produce-human-readable-json-output",
        "title": "Is there a jq wrapper for golang that can produce human readable JSON output?"
    },
    {
        "tags": [
            "json",
            "date",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1489604064,
                "last_edit_date": 1489604064,
                "creation_date": 1489588400,
                "answer_id": 42812743,
                "question_id": 42812689,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This worked for me:\r\n\r\n    jq &#39;if .Start &gt;= &quot;2017-03&quot; then . else empty end&#39;",
                "title": "JSON and jq specifying date ranges"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1489604064,
        "creation_date": 1489588266,
        "question_id": 42812689,
        "body_markdown": "Can any please suggest the best way of returning all results which match a certain date.\r\n\r\nInput\r\n\r\n    {\r\n      &quot;Status&quot;: &quot;Down&quot;,\r\n      &quot;StatusID&quot;: &quot;72875529&quot;,\r\n      &quot;Start&quot;: &quot;2017-03-01 04:26:07&quot;,\r\n      &quot;End&quot;: &quot;2017-03-01 04:36:40&quot;,\r\n      &quot;Additional&quot;: &quot;Unexpected StatusCode Detected - StatusCode: undefined&quot;,\r\n      &quot;Period&quot;: &quot;10 Minutes &quot;\r\n    }\r\n    {\r\n      &quot;Status&quot;: &quot;Down&quot;,\r\n      &quot;StatusID&quot;: &quot;72785390&quot;,\r\n      &quot;Start&quot;: &quot;2017-02-28 16:24:26&quot;,\r\n      &quot;End&quot;: &quot;2017-02-28 16:26:01&quot;,\r\n      &quot;Period&quot;: &quot;1 Minutes &quot;\r\n    }\r\n\r\nI am trying to return the object which for example started in March. I have tried using &quot;match&quot; but it only returns matched string and &quot;contain&quot; only returns boolean values.\r\n\r\nI have through about using an if statement however not sure how to specify a partial match as I did not see ~= in the docs as I would need to do something like ~= &quot;2017-03&quot;",
        "link": "https://stackoverflow.com/questions/42812689/json-and-jq-specifying-date-ranges",
        "title": "JSON and jq specifying date ranges"
    },
    {
        "tags": [
            "geojson",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1489591369,
                "creation_date": 1489591369,
                "answer_id": 42813951,
                "question_id": 42813005,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. Many would suggest writing &quot;jq ... FILE&quot; instead of &#39;cat FILE | jq ...&#39;\r\n\r\n2. You don&#39;t need the initial &#39;. |&#39;\r\n\r\n3. Here is a variant of your jq filter that produces the results shown below:\r\n\r\n&amp;nbsp;\r\n\r\n    {\r\n        type: .type,\r\n        features: [\r\n            .features[] | {\r\n                type: .type,\r\n                properties: {\r\n                    display_name: .properties.facility,\r\n                    id: .id\r\n                },\r\n                geometry: {\r\n           \t        type: (if .geometry.type == &quot;Path&quot; then &quot;LineString&quot;\r\n    \t\t               else .geometry.type\r\n                           end)\r\n                }\r\n            }\r\n        ]\r\n    }\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n      &quot;features&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;display_name&quot;: &quot;hallway&quot;,\r\n            &quot;id&quot;: 16683828\r\n          },\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;LineString&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n\r\n",
                "title": "Conditionals inside a larger jq expression to transform input into valid geojson"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1489591369,
        "creation_date": 1489589073,
        "last_edit_date": 1489590770,
        "question_id": 42813005,
        "body_markdown": "I have a JSON input that is nearly-but-not-quite correct geojson, and I&#39;m attempting to use jq to transform it into a correct format. My input is using a custom geometry type of &quot;Path&quot; on some items, and inside the coordinates of these items it&#39;s storing some extra data (line curve data for rendering to SVG). I don&#39;t want to drop this data, so my goal has been to change all geometry items of type &quot;Path&quot; into a &quot;LineString&quot;, and strip out the extra coordinates in these items into a &quot;properties&quot; object (on the geometry item) to preserve the data.\r\n\r\nHere&#39;s a small example of the input:\r\n\r\n    {\r\n      &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n      &quot;features&quot;: [\r\n        {\r\n          &quot;id&quot;: 16683828,\r\n          &quot;properties&quot;: {\r\n            &quot;facility&quot;: &quot;hallway&quot;\r\n          },\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;Path&quot;,\r\n            &quot;coordinates&quot;: [\r\n              [\r\n                0,\r\n                379.64,\r\n                289.412\r\n              ],\r\n              [\r\n                3,\r\n                379.629,\r\n                289.768,\r\n                379.346,\r\n                290.059,\r\n                378.986,\r\n                290.066\r\n              ],\r\n              [\r\n                1,\r\n                373.156,\r\n                290.066\r\n              ],\r\n              [\r\n                1,\r\n                373.156,\r\n                298.5\r\n              ],\r\n              [\r\n                1,\r\n                373.156,\r\n                299.469\r\n              ],\r\n              [\r\n                4\r\n              ]\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nHere&#39;s roughly what I&#39;d like to transform this into:\r\n\r\n    {\r\n      &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n      &quot;features&quot;: [\r\n        {\r\n          &quot;properties&quot;: {\r\n            &quot;facility&quot;: &quot;hallway&quot;,\r\n            &quot;id&quot;: 16683828\r\n          },\r\n          &quot;type&quot;: &quot;Feature&quot;,\r\n          &quot;geometry&quot;: {\r\n            &quot;type&quot;: &quot;LineString&quot;,\r\n            &quot;properties&quot;: {\r\n              &quot;curves&quot;: [\r\n                {\r\n                  &quot;coordinate_position&quot;: 1,\r\n                  &quot;control_points&quot;: [379.629, 289.768, 379.346, 290.059]\r\n                }\r\n              ]\r\n            },\r\n            &quot;coordinates&quot;: [\r\n              [\r\n                379.64,\r\n                289.412\r\n              ],\r\n              [\r\n                378.986,\r\n                290.066\r\n              ],\r\n              [\r\n                373.156,\r\n                290.066\r\n              ],\r\n              [\r\n                373.156,\r\n                298.5\r\n              ],\r\n              [\r\n                373.156,\r\n                299.469\r\n              ]\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nThe part that&#39;s tripping me up is using conditionals inside of a larger jq formatting expression. For each feature, I&#39;m trying to check if geometry.type == &quot;Path&quot;, and if so, strip the first item from each coordinate (I don&#39;t need it), and then move all but the last two items from the coordinate into a object in a properties.curves array, noting the position within the &quot;coordinates&quot; array, and the extra data. If the geometry.type != &quot;Path&quot;, I just want to copy the geometry item to my output.\r\n\r\nHere&#39;s the script I have so far, including the incorrect conditional logic beginning at `geometry: {`:\r\n\r\n    cat input.json | jq &#39;. | \r\n    {\r\n        type: .type,\r\n        features: [\r\n            .features[] | {\r\n                type: .type,\r\n                properties: {\r\n                    display_name: .properties.display_name,\r\n                    id: .id\r\n                }\r\n                geometry: {\r\n                    if .geometry.type == &quot;Path&quot; then\r\n                        type: &quot;LineString&quot;\r\n                    else\r\n                        type: .geometry.type\r\n                    end\r\n                }\r\n            }\r\n        ]\r\n    }&#39;\r\n\r\nOf course what&#39;s not working here is the conditional directly inside an object. My best guess is that I need to use more jq pipes but I just haven&#39;t been able to figure out how to wrangle it into the correct format.",
        "link": "https://stackoverflow.com/questions/42813005/conditionals-inside-a-larger-jq-expression-to-transform-input-into-valid-geojson",
        "title": "Conditionals inside a larger jq expression to transform input into valid geojson"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1489603896,
                "last_edit_date": 1489603896,
                "creation_date": 1489603078,
                "answer_id": 42818094,
                "question_id": 42817889,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The idea of using `argjson` is right, but the syntax is as below on `jq-1.5`\r\n\r\n    jq --argjson obj &#39;{ &quot;ParameterKey&quot;: &quot;Foo3&quot;, &quot;ParameterValue&quot;: &quot;Bar3&quot; }&#39; &#39;. + [$obj]&#39; &lt; json \r\n    [\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;Foo1&quot;,\r\n        &quot;ParameterValue&quot;: &quot;Bar1&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;Foo2&quot;,\r\n        &quot;ParameterValue&quot;: &quot;Bar2&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;Foo3&quot;,\r\n        &quot;ParameterValue&quot;: &quot;Bar3&quot;\r\n      }\r\n    ]\r\n\r\nCheck the [jq-documentation](https://stedolan.github.io/jq/manual/) for more information about the `+` and `+=` operators.\r\n\r\nAm not aware of ways to do this in `jq` itself, but you can use a neat `bash` trick to do this,\r\n\r\n    jq --argjson obj &#39;{ &quot;ParameterKey&quot;: &quot;Foo3&quot;, &quot;ParameterValue&quot;: &quot;Bar3&quot; }&#39; &#39;. + [$obj]&#39; &lt; json &gt; temp &amp;&amp; mv temp json",
                "title": "Append new keypair to JSON file with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1489700716,
                "last_edit_date": 1489700716,
                "creation_date": 1489684457,
                "answer_id": 42840657,
                "question_id": 42817889,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you have one file with a JSON array (say parameters.json), and one or more additional files (say file*.json) with JSON entities that you want to append to the array in the first file, and if you want to overwrite the first file, here&#39;s a rather sly solution, which however requires jq 1.5 or later:\r\n\r\n    $ jq &#39;reduce inputs as $in (.; . + [$in])&#39; parameters.json file*.json |\r\n        sponge parameters.json\r\n\r\nNote that using this approach, each top-level JSON entity in each of the auxiliary files will be appended to the array separately.\r\n\r\nWhat makes this a bit crafty is that `inputs` is being used here without the -n option. \r\n\r\nSince you mentioned `bash`, please note that if any of the &quot;file*.json&quot; sources is a process, you could use `&lt;( ... )` rather than specifying a filename, e.g.:\r\n\r\n    $ jq &#39;reduce inputs as $in (.; . + [$in])&#39; parameters.json &lt;(curl -Ss ...) |\r\n        sponge parameters.json\r\n\r\n\r\nIf you don&#39;t have `sponge`, then you can use the idiom:\r\n\r\n    jq ..... &gt; OUT &amp;&amp; mv IN OUT\r\n",
                "title": "Append new keypair to JSON file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1582004226,
        "creation_date": 1489602514,
        "question_id": 42817889,
        "body_markdown": "I&#39;ve read almost every question I can find on SO with the same general premise and I&#39;ve gotten close three different times, but I just can&#39;t make this work.\r\n\r\nGiven a JSON file called `parameters.json` with keypairs like so; (shortened for sharing purposes)\r\n\r\n    [\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;Foo1&quot;,\r\n        &quot;ParameterValue&quot;: &quot;Bar1&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;Foo2&quot;,  \r\n        &quot;ParameterValue&quot;: &quot;Bar2&quot;\r\n      }\r\n    ]\r\n\r\nI want to add another keypair, say\r\n\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;Foo3&quot;,\r\n        &quot;ParameterValue&quot;: &quot;Bar3&quot;\r\n      }\r\n\r\nSo I end up with a file like\r\n\r\n    [\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;Foo1&quot;,\r\n        &quot;ParameterValue&quot;: &quot;Bar1&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;Foo2&quot;,  \r\n        &quot;ParameterValue&quot;: &quot;Bar2&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;Foo3&quot;,\r\n        &quot;ParameterValue&quot;: &quot;Bar3&quot;\r\n      }\r\n    ]\r\n\r\n#Use Case &amp; Attempts#\r\n\r\nI&#39;m writing a bash script that copies and updates parameter files for AWS - this is where the keypairs come in. We have a new keypair that needs to be added to any existing files when they&#39;re copied. I can get the if/then done fine, it&#39;s physically adding the new keypair that is stumping me. \r\n\r\nWith a ton of googling I ended up with this clunky workaround, which I don&#39;t really understand and, while it generates the keypair just fine, doesn&#39;t add it back into parameters.json\r\n\r\n    item=&#39;{&quot;ParameterKey&quot;: &quot;RTSMSnapshotID&quot;}&#39;\r\n\r\n    jq --argjson item &quot;$item&quot; &#39;$item + {&quot;ParameterValue&quot;: &quot;&quot;}&#39; parameters.json\r\n\r\nI get the keypair printed back to me correctly on the command line, so I figure add `| sponge parameters.json` but that then gives me an empty file.\r\n\r\nI also considered a sed workaround that trimmed the last line of the file and then appended the new keypair (and EOF) but of course sed doesn&#39;t play well with newlines and I can&#39;t get it to work. \r\n\r\nI&#39;m open to solutions that use anything in bash and anything in jq. I am still a bash/jq noob so detailed explanations are appreciated.\r\n    ",
        "link": "https://stackoverflow.com/questions/42817889/append-new-keypair-to-json-file-with-jq",
        "title": "Append new keypair to JSON file with jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "csv",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1489704288,
                "post_id": 42846102,
                "comment_id": 72800642,
                "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": 1489704330,
                "post_id": 42846102,
                "comment_id": 72800659,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2337869,
                    "reputation": 161,
                    "user_id": 2049783,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://www.gravatar.com/avatar/e8aed30d7cf7cee527a24c6e7adca60e?s=256&d=identicon&r=PG",
                    "display_name": "Sam G",
                    "link": "https://stackoverflow.com/users/2049783/sam-g"
                },
                "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": 1489706154,
                "post_id": 42846102,
                "comment_id": 72801225,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1489707641,
                "last_edit_date": 1489707641,
                "creation_date": 1489704523,
                "answer_id": 42846175,
                "question_id": 42846102,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To describe in your `jq` query how to navigate in the document to the data you want to extract might look like the following:\r\n\r\n    jq -r &#39;.hits.hits[]._source.customer_name&#39;\r\n\r\nIn this case, the output is:\r\n\r\n&lt;!-- language: none --&gt;\r\n\r\n    Timbuktu Inc\r\n    Bunnies Inc\r\n\r\n---\r\n\r\nTo generate a key/value CSV, one might use:\r\n\r\n    jq -r &#39;.hits.hits[]._source | to_entries | .[] | [.key, .value] | @csv&#39;\r\n\r\n...with output:\r\n\r\n    &quot;customer_app_version&quot;,&quot;el7.20150513&quot;\r\n    &quot;customer_num_apps&quot;,3\r\n    &quot;app_memory_capacity_bytes&quot;,405248409600\r\n    &quot;customer_name&quot;,&quot;Timbuktu Inc&quot;\r\n    &quot;app_disk_size_bytes&quot;,25117047875604\r\n    &quot;customer_app_version&quot;,&quot;el4.20150513&quot;\r\n    &quot;customer_num_apps&quot;,34\r\n    &quot;app_memory_capacity_bytes&quot;,58923439600\r\n    &quot;customer_name&quot;,&quot;Bunnies Inc&quot;\r\n    &quot;app_disk_size_bytes&quot;,36517984275604\r\n\r\n---\r\n\r\nIf you want customer name to be a column of its own, this might instead be:\r\n\r\n    jq -r &#39;.hits.hits[]._source | .customer_name as $name | del(.customer_name) | to_entries | .[] | [$name, .key, .value] | @csv&#39;\r\n\r\n...with output:\r\n\r\n    &quot;Timbuktu Inc&quot;,&quot;customer_app_version&quot;,&quot;el7.20150513&quot;\r\n    &quot;Timbuktu Inc&quot;,&quot;customer_num_apps&quot;,3\r\n    &quot;Timbuktu Inc&quot;,&quot;app_memory_capacity_bytes&quot;,405248409600\r\n    &quot;Timbuktu Inc&quot;,&quot;app_disk_size_bytes&quot;,25117047875604\r\n    &quot;Bunnies Inc&quot;,&quot;customer_app_version&quot;,&quot;el4.20150513&quot;\r\n    &quot;Bunnies Inc&quot;,&quot;customer_num_apps&quot;,34\r\n    &quot;Bunnies Inc&quot;,&quot;app_memory_capacity_bytes&quot;,58923439600\r\n    &quot;Bunnies Inc&quot;,&quot;app_disk_size_bytes&quot;,36517984275604\r\n\r\n---\r\n\r\nIf you&#39;re willing to hardcode the column names, consider instead:\r\n\r\n    jq -r &#39;.hits.hits[]._source | [.customer_name, .customer_app_version, .customer_num_apps, .app_memory_capacity_bytes, .app_disk_size_bytes] | @csv&#39;\r\n\r\nwith output:\r\n\r\n    &quot;Timbuktu Inc&quot;,&quot;el7.20150513&quot;,3,405248409600,25117047875604\r\n    &quot;Bunnies Inc&quot;,&quot;el4.20150513&quot;,34,58923439600,36517984275604",
                "title": "Extracting data from _source document in ElasticSearch results with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1489707641,
        "creation_date": 1489704157,
        "last_edit_date": 1495535394,
        "question_id": 42846102,
        "body_markdown": "I am reading this [StackOverFlow discussion][1] converting JSON into CSV and it seems great, but I cant get basic jq to work.. I am not sure what I am doing wrong. I have tried the basic thing and I cant crack whats wrong. Here is my ES query in a Shell Script\r\n\r\n    curl -XGET &#39;http://es-1:9200/data_latest/customer/_search?pretty&#39; -H &#39;Content-Type: application/json&#39; -d&#39;\r\n    {\r\n    &quot;_source&quot;: [&quot;customer_app_version&quot;, &quot;customer_num_apps&quot;, &quot;customer_name&quot;,&quot;app_disk_size_bytes&quot;,&quot;app_memory_capacity_bytes&quot;],\r\n    \t&quot;query&quot;: {\r\n    \t\t&quot;bool&quot;: {\r\n    \t\t\t&quot;must&quot;: [{\r\n    \t\t\t\t&quot;term&quot;: {\r\n    \t\t\t\t\t&quot;is_app_customer&quot;: {\r\n    \t\t\t\t\t\t&quot;value&quot;: &quot;true&quot;\r\n    \t\t\t\t\t}\r\n    \t\t\t\t}\r\n    \t\t\t}]\r\n    \t\t}\r\n    \t},\r\n    \t&quot;aggs&quot;: {\r\n    \t\t&quot;Customer_UUID&quot;: {\r\n    \t\t\t&quot;terms&quot;: {\r\n    \t\t\t\t&quot;field&quot;: &quot;customer_uuid&quot;,\r\n    \t\t\t\t&quot;size&quot;: 100\r\n    \t\t\t}\r\n    \t\t}\r\n    \t}\r\n    }\r\n&#39; \r\n**Shell Script Output**\r\n\r\n    {\r\n      &quot;took&quot;: 8,\r\n      &quot;timed_out&quot;: false,\r\n      &quot;_shards&quot;: {\r\n        &quot;total&quot;: 5,\r\n        &quot;successful&quot;: 5,\r\n        &quot;failed&quot;: 0\r\n      },\r\n      &quot;hits&quot;: {\r\n        &quot;total&quot;: 6171,\r\n        &quot;max_score&quot;: 1.8510876,\r\n        &quot;hits&quot;: [\r\n          {\r\n            &quot;_index&quot;: &quot;data_latest_v1&quot;,\r\n            &quot;_type&quot;: &quot;customer&quot;,\r\n            &quot;_id&quot;: &quot;0003245-4844-9015-1z2e-d4ae5234rd56&quot;,\r\n            &quot;_score&quot;: 1.8510876,\r\n            &quot;_source&quot;: {\r\n              &quot;customer_app_version&quot;: &quot;el7.20150513&quot;,\r\n              &quot;customer_num_apps&quot;: 3,\r\n              &quot;app_memory_capacity_bytes&quot;: 405248409600,\r\n              &quot;customer_name&quot;: &quot;Timbuktu Inc&quot;,\r\n              &quot;app_disk_size_bytes&quot;: 25117047875604\r\n            }\r\n          },\r\n          {\r\n            &quot;_index&quot;: &quot;data_latest_v1&quot;,\r\n            &quot;_type&quot;: &quot;customer&quot;,\r\n            &quot;_id&quot;: &quot;0003245-4844-9015-1z2e-d4ae5234rd56&quot;,\r\n            &quot;_score&quot;: 1.8510876,\r\n            &quot;_source&quot;: {\r\n              &quot;customer_app_version&quot;: &quot;el4.20150513&quot;,\r\n              &quot;customer_num_apps&quot;: 34,\r\n              &quot;app_memory_capacity_bytes&quot;: 58923439600,\r\n              &quot;customer_name&quot;: &quot;Bunnies Inc&quot;,\r\n              &quot;app_disk_size_bytes&quot;: 36517984275604\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\n(truncated, but the subset above is syntactically valid)\r\n\r\n 1. How do I use jq within the shell script to output the Keys and values in the _source field (nothing else) as a CSV? I know I am asking something that is described in the other discussion, but I tried and could not get it \r\n\r\nFor example, I added after the &#39; (end of the above script) I added \r\n| jq -r &#39;.&quot;customer_name&quot;&#39;\r\n\r\nand also tried\r\n\r\n| jq -r &#39;.customer_name&#39;\r\n\r\nFor both I get output like this. \r\n\r\n      % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                     Dload  Upload   Total   Spent    Left  Speed\r\n    103 13566  100 13566    0   346   507k  13248 --:--:-- --:--:-- --:--:--  537k\r\n    null\r\n\r\nWhat am i doing wrong? What do I need to do? would be super helpful if someone can guide me here. \r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/32960857/how-to-convert-arbirtrary-simple-json-to-csv-using-jq\r\n",
        "link": "https://stackoverflow.com/questions/42846102/extracting-data-from-source-document-in-elasticsearch-results-with-jq",
        "title": "Extracting data from _source document in ElasticSearch results with jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1489748268,
                "creation_date": 1489748268,
                "answer_id": 42855706,
                "question_id": 42855490,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "     ps aux | awk &#39;\r\n    BEGIN { ORS = &quot;&quot;; print &quot; [ &quot;}\r\n    { printf &quot;%s{\\&quot;user\\&quot;: \\&quot;%s\\&quot;, \\&quot;pid\\&quot;: \\&quot;%s\\&quot;, \\&quot;cpu\\&quot;: \\&quot;%s\\&quot;}&quot;,\r\n          separator, $1, $2, $3\r\n      separator = &quot;, &quot;\r\n    }\r\n    END { print &quot; ] &quot; }&#39;;\r\n\r\n\r\nJust adjust columns which you need from ps aux output.",
                "title": "Convert ps aux to json"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1490045322,
                "last_edit_date": 1490045322,
                "creation_date": 1490044432,
                "answer_id": 42914059,
                "question_id": 42855490,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`jq` can read non-JSON input. You&#39;ll want to pre-process the input with `awk` first:\r\n\r\n    ps aux |\r\n      awk -v OFS=, &#39;{print $1, $2}&#39; | \r\n      jq -R &#39;split(&quot;,&quot;) | {user: .[0], pid: .[1]}&#39;\r\n\r\nIf you want an array instead of a sequence of objects, pipe the output through `jq --slurp &#39;add&#39;`. (I swear there&#39;s a way to do that without an extra call to `jq`, but it escapes me at the moment.)",
                "title": "Convert ps aux to json"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1490082188,
                "last_edit_date": 1490082188,
                "creation_date": 1490050607,
                "answer_id": 42915488,
                "question_id": 42855490,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s an only-jq solution based on tokenization.\r\n\r\nTokenization can be done using:\r\n\r\n    def tokens:\r\n      def trim: sub(&quot;^ +&quot;;&quot;&quot;) |  sub(&quot; +$&quot;;&quot;&quot;);\r\n      trim | splits(&quot; +&quot;);\r\n  \r\nFor illustration and brevity, let&#39;s consider only the first 10 tokens:\r\n\r\n    [tokens] | .[0:9]\r\n\r\n    \r\nInvocation:\r\n\r\n    $ ps aux | jq -c -R  -f tokens.jq \r\n\r\nOr as a one-liner, you could get away with:\r\n\r\n    $  ps aux | jq -cR &#39;[splits(&quot; +&quot;)] | .[0:9]&#39;\r\n\r\n\r\nFirst few lines of output:\r\n\r\n    [&quot;USER&quot;,&quot;PID&quot;,&quot;%CPU&quot;,&quot;%MEM&quot;,&quot;VSZ&quot;,&quot;RSS&quot;,&quot;TT&quot;,&quot;STAT&quot;,&quot;STARTED&quot;]\r\n    [&quot;p&quot;,&quot;1595&quot;,&quot;55.9&quot;,&quot;0.4&quot;,&quot;2593756&quot;,&quot;32832&quot;,&quot;??&quot;,&quot;R&quot;,&quot;24Jan17&quot;]\r\n    [&quot;p&quot;,&quot;12472&quot;,&quot;26.6&quot;,&quot;12.6&quot;,&quot;4951848&quot;,&quot;1058864&quot;,&quot;??&quot;,&quot;R&quot;,&quot;Sat01AM&quot;]\r\n    [&quot;p&quot;,&quot;13239&quot;,&quot;10.9&quot;,&quot;1.5&quot;,&quot;4073756&quot;,&quot;128324&quot;,&quot;??&quot;,&quot;R&quot;,&quot;Sun12AM&quot;]\r\n    [&quot;p&quot;,&quot;12482&quot;,&quot;7.8&quot;,&quot;1.2&quot;,&quot;3876628&quot;,&quot;101736&quot;,&quot;??&quot;,&quot;R&quot;,&quot;Sat01AM&quot;]\r\n    [&quot;p&quot;,&quot;32039&quot;,&quot;7.7&quot;,&quot;1.4&quot;,&quot;4786968&quot;,&quot;118424&quot;,&quot;??&quot;,&quot;R&quot;,&quot;12Feb17&quot;]\r\n    [&quot;_windowserver&quot;,&quot;425&quot;,&quot;7.6&quot;,&quot;0.8&quot;,&quot;3445536&quot;,&quot;65052&quot;,&quot;??&quot;,&quot;Ss&quot;,&quot;24Jan17&quot;]\r\n\r\n\r\n### Using the headers as object keys\r\nSee e.g.\r\nhttps://github.com/stedolan/jq/wiki/Cookbook#convert-a-csv-file-with-headers-to-json",
                "title": "Convert ps aux to json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1534972411,
                "creation_date": 1534972411,
                "answer_id": 51975217,
                "question_id": 42855490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have a [gist][1] that to convert ps output to json.  It uses jq under the covers so you need to install that. But you do not need to know jq\r\n\r\n  [1]: https://gist.github.com/aberezin/a0cdec3c125851a96d4281183b6dd427",
                "title": "Convert ps aux to json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1676113507,
                "creation_date": 1676113507,
                "answer_id": 75419736,
                "question_id": 42855490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Dumps the fields specified by the -o flag as an array of PID objects:\r\n\r\n```\r\nps ax -o &quot;stat,euid,ruid,tty,tpgid,sess,pgrp,ppid,pid,wchan,sz,pcpu,command&quot; \\\r\n\t| jq -sRr &#39; sub(&quot;\\n$&quot;;&quot;&quot;) | split(&quot;\\n&quot;) | ([.[0]|splits(&quot; +&quot;)]) as $header | .[1:] | [.[] | [. as $x | range($header|length) | {&quot;key&quot;: $header[.], &quot;value&quot;: (if .==($header|length-1) then ([$x|splits(&quot; +&quot;)][.:]|join(&quot; &quot;)|tojson|.[1:length-1]) else ([$x|splits(&quot; +&quot;)][.]) end) } ] | from_entries]&#39;\r\n```\r\n\r\nThis builds an array of the header fields, maps an array of {key, value} objects per output object, and then uses the built-in from_entries filter to object-aggregate these into the outputs.",
                "title": "Convert ps aux to json"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 0,
        "last_activity_date": 1676113507,
        "creation_date": 1489747695,
        "question_id": 42855490,
        "body_markdown": "I try to convert the output of `ps aux` into Json format without using Perl or Python! For these I have read about jq. But I have success to convert the commandline output into json.\r\n\r\nHow to convert a simpe `ps aux` to Json?",
        "link": "https://stackoverflow.com/questions/42855490/convert-ps-aux-to-json",
        "title": "Convert ps aux to json"
    },
    {
        "tags": [
            "json",
            "bash",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1630078174,
                "last_edit_date": 1630078174,
                "creation_date": 1489862671,
                "answer_id": 42878432,
                "question_id": 42877900,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The task can be accomplished without invoking jq more than once.  \r\n\r\nSomething very much like the following should suffice:\r\n\r\n    jq -s &#39;{orgConfig: {departments: . }}&#39; jsonfiles/*.json\r\n\r\nThis solution of course assumes the .json files all hold valid JSON.\r\n\r\nThe trick is to use the -s (aka --slurp) option, as this converts the input into an array for you.  You&#39;ll probably find that using -s results in better run-times than some other approaches.",
                "title": "Dynamically add json object into array with jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1489868013,
                "last_edit_date": 1489868013,
                "creation_date": 1489863287,
                "answer_id": 42878544,
                "question_id": 42877900,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This can be done by turning off `jq`&#39;s automatic input reading, then piping the first explicit input through a filter that modifies its input using the remaining explicit inputs. Make sense? No :) But the code itself is simple:\r\n\r\n    jq -n &#39;input | .orgConfig.departments += [inputs]&#39; \\\r\n      employee.json chemistry.json physics.json math.json\r\n\r\n  1. The first `input` reads from the first argument (`employee.json`).\r\n  2. The `+=` gets its input from the `input` filter. Its left operand\r\n     selects the field to update; the right operand provides the value\r\n     to update it with.\r\n  3. `inputs` reads from the remaining command-line arguments, and puts their contents in an array, each file in a separate element.\r\n\r\nCombining this with your shell code to select the correct course files yields\r\n\r\n    source department.properties\r\n    IFS=, read -ra NAMES &lt;&lt;&lt; &quot;$departmentsToImport&quot;\r\n    for c in &quot;${NAMES[@]}&quot;; do\r\n        courses+=(&quot;./jsonfiles/$c.json&quot;)\r\n    done\r\n    jq -n &#39;input | .orgConfig.departments += [inputs]&#39; employee.json &quot;${courses[@]}&quot;",
                "title": "Dynamically add json object into array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1630078174,
        "creation_date": 1489859899,
        "question_id": 42877900,
        "body_markdown": "Below is the template of my employee.json file\r\n\r\n    {\r\n        &quot;orgConfig&quot;: {\r\n            &quot;departments&quot;: []\r\n        }\r\n    }\r\n\r\nwhere departments will have array of departments like below\r\n\r\n    {\r\n        &quot;name&quot; : &quot;physics&quot;,\r\n        &quot;id&quot; : &quot;1234&quot;,\r\n        &quot;head&quot; : &quot;abcd&quot;\r\n    }\r\nsimilarly\r\n\r\n    {\r\n        &quot;name&quot; : &quot;chemistry&quot;,\r\n        &quot;id&quot; : &quot;3421&quot;,\r\n        &quot;head&quot; : &quot;xyz&quot;\r\n    }\r\n\r\nso the final array structure i want to construct is as below\r\n\r\n    {\r\n        &quot;orgConfig&quot;: {\r\n            &quot;departments&quot;: [\r\n                {\r\n                    &quot;name&quot; : &quot;physics&quot;,\r\n                    &quot;id&quot; : &quot;1234&quot;,\r\n                    &quot;head&quot; : &quot;abcd&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot; : &quot;chemistry&quot;,\r\n                    &quot;id&quot; : &quot;3421&quot;,\r\n                    &quot;head&quot; : &quot;xyz&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot; : &quot;Maths&quot;,\r\n                    &quot;id&quot; : &quot;4634&quot;,\r\n                    &quot;head&quot; : &quot;jklm&quot;\r\n                }\r\n            ]\r\n        }\r\n    }\r\n\r\nBelow is the code where i am adding the json elements to an departments array dynamically\r\n\r\n    #!/bin/bash\r\n    \r\n    source department.properties   # will have departments=physiscs,chemistry,Maths,computers .. etc\r\n    IFS=&#39;,&#39; read -ra NAMES &lt;&lt;&lt; &quot;$departmentsToImport&quot;\r\n    \r\n    position=0\r\n    for i in &quot;${NAMES[@]}&quot;; do\r\n        #./jsonfiles will chemistry.json, physics.json, Maths.json etc\r\n        value=`cat ./jsonfiles/$i.json`    \r\n    \r\n        if [ $position -eq 0 ]\r\n        then\r\n           cat employee.json | jq --arg value &quot;$value&quot; &#39;.orgConfig.departments[0] |= .+ $value&#39; &gt; tmp.json &amp;&amp; mv tmp.json employee.json\r\n        else\r\n           cat employee.json | jq --arg position &quot;$position&quot; value &quot;$value&quot; &#39;.orgConfig.departments[$position] |= .+ $value&#39; &gt; tmp.json &amp;&amp; mv tmp.json employee.json\r\n        fi\r\n        ((position++))\r\n        rm -rf tmp.json\r\n    done\r\n    \r\n    exit $?\r\n\r\nbut program throws below error\r\n\r\n    jq: error (at &lt;stdin&gt;:51): Cannot index array with string &quot;1&quot;\r\n\r\nBut if use direct index instead of variable position then it works fine.\r\n\r\n    cat employee.json | jq --argjson value &quot;$value&quot; &#39;.orgConfig.departments[1] |= .+ $value&#39; &gt; tmp.json &amp;&amp; mv tmp.json employee.json \r\n\r\nI do not know how many key value maps of departments i have. I cannot hard code the index. Any help to above problem and Dynamically add json object into array?\r\n\r\nThanks\r\n",
        "link": "https://stackoverflow.com/questions/42877900/dynamically-add-json-object-into-array-with-jq",
        "title": "Dynamically add json object into array with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1490029775,
                "creation_date": 1490029775,
                "answer_id": 42909773,
                "question_id": 42908338,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use `del` and `recurse` together.\r\n\r\n    jq &#39;del(recurse|.store?)&#39; foo.json\r\n\r\nYou can also the short `..` for `recurse` with no arguments:\r\n\r\n    jq &#39;del(..|.store?)&#39; foo.json\r\n\r\nThe `?` prevents errors when `recurse` reaches something for which `.store` is an invalid filter.",
                "title": "jq: how to filter nested keys?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1490048845,
                "last_edit_date": 1490048845,
                "creation_date": 1490030517,
                "answer_id": 42910017,
                "question_id": 42908338,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you only want to remove the &quot;store&quot; key when it occurs at the second level, then consider:\r\n\r\n    map_values( del(.store) )\r\n\r\n###Postscript\r\n\r\nSubsequently, the OP asked:\r\n\r\n&gt; But what if the deleted fields are many? can we only keep &#39;docs&#39;\r\n\r\nAnswer (in this particular case):\r\n\r\n    map_values( {docs} ) ",
                "title": "jq: how to filter nested keys?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1490048845,
        "creation_date": 1490025610,
        "question_id": 42908338,
        "body_markdown": "I have done a lot of research on stackoverflow but cannot find any related post.\r\n \r\nassume I have a json like\r\n\r\n    {\r\n        &quot;talk&quot;: {\r\n            &quot;docs&quot;: {\r\n                &quot;count&quot;: 22038185,\r\n                &quot;deleted&quot;: 626193\r\n            },\r\n            &quot;store&quot;: {\r\n                &quot;size_in_bytes&quot;: 6885993125,\r\n                &quot;throttle_time_in_millis&quot;: 1836569\r\n            }\r\n        },\r\n        &quot;list&quot;: {\r\n            &quot;docs&quot;: {\r\n                &quot;count&quot;: 22038185,\r\n                &quot;deleted&quot;: 626193\r\n            },\r\n            &quot;store&quot;: {\r\n                &quot;size_in_bytes&quot;: 6885993125,\r\n                &quot;throttle_time_in_millis&quot;: 1836569\r\n            }\r\n        }\r\n    }\r\nI want to filter out &quot;store&quot; field in all keys to get an output like\r\n \r\n\r\n    {\r\n        &quot;talk&quot;: {\r\n            &quot;docs&quot;: {\r\n                &quot;count&quot;: 22038185,\r\n                &quot;deleted&quot;: 626193\r\n            }\r\n        },\r\n        &quot;list&quot;: {\r\n            &quot;docs&quot;: {\r\n                &quot;count&quot;: 22038185,\r\n                &quot;deleted&quot;: 626193\r\n            }\r\n        }\r\n    } \r\nHow can I achieve it with jq?",
        "link": "https://stackoverflow.com/questions/42908338/jq-how-to-filter-nested-keys",
        "title": "jq: how to filter nested keys?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1490106884,
                "last_edit_date": 1490106884,
                "creation_date": 1490098373,
                "answer_id": 42926819,
                "question_id": 42926472,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "An array is distinct from a multi-line string. Assuming there are no newlines in your data, changing your `jq` call to\r\n\r\n    jq -r &#39;[.data[].id]|.[]&#39;  # Could be simplified to &#39;.data[].id&#39;\r\nand use `readArray` (`bash` 4 or later) to populate a proper array.\r\n\r\n    readArray -t ids &lt; &lt;(jq -r &#39;[.data[].id]|.[]&#39; &quot;$myfilename&quot;)",
                "title": "When bash jq parsing json ,return a multi-line array but, how can I use this result?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1490106884,
        "creation_date": 1490097454,
        "last_edit_date": 1490097766,
        "question_id": 42926472,
        "body_markdown": "when I use the command: \r\n\r\n    ids=`cat $myfilename | jq -r &quot;[.data[].id]&quot;`\r\n\r\nand return like this:\r\n\r\n    [\r\n      &quot;PC_PACX_0017&quot;,\r\n      &quot;GS_ZGRS_0001&quot;,\r\n      &quot;PC_PACX_0018&quot;,\r\n      &quot;GS_ZGRS_0002&quot;,\r\n      &quot;AB_HXJK_0002&quot;,\r\n      &quot;AB_HXJK_0001&quot;,\r\n      &quot;TK_TKZX_0011&quot;,\r\n      &quot;TL_TBAL_0002&quot;,\r\n      &quot;TL_TBAL_0001&quot;,\r\n      &quot;TS_TKRS_0001&quot;,\r\n      &quot;TS_TKRS_0002&quot;,\r\n      &quot;TS_TKRS_0003&quot;\r\n    ]\r\n\r\n   \r\nbut it can&#39;t be seen as a array, it&#39;s length only be 1.How can I use this result?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/42926472/when-bash-jq-parsing-json-return-a-multi-line-array-but-how-can-i-use-this-res",
        "title": "When bash jq parsing json ,return a multi-line array but, how can I use this result?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7001013,
                    "reputation": 83,
                    "user_id": 5367057,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://graph.facebook.com/10207046749143518/picture?type=large",
                    "display_name": "Phoenix",
                    "link": "https://stackoverflow.com/users/5367057/phoenix"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1490110860,
                "post_id": 42930165,
                "comment_id": 72960816,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1490108132,
                "last_edit_date": 1490108132,
                "creation_date": 1490107274,
                "answer_id": 42930282,
                "question_id": 42930165,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "How about\r\n\r\n    .[] as $x | { price: ($x.price * -1) } \r\n\r\nHere is a working example:  \r\nhttps://jqplay.org/s/VeGHuouLRY\r\n",
                "title": "Using jq to change each variable in the array seperatly"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1490109254,
                "last_edit_date": 1490109254,
                "creation_date": 1490108757,
                "answer_id": 42930892,
                "question_id": 42930165,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If the output is to be an array, then consider:\r\n\r\n    map( .price |= -1 * . )\r\n\r\nIf the price on output must be negative even if the input price is already negative, then you could replace the expression in parens by:\r\n\r\n      if .price &gt; 0 then .price |= -1 * . else . end",
                "title": "Using jq to change each variable in the array seperatly"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1490109254,
        "creation_date": 1490107002,
        "question_id": 42930165,
        "body_markdown": "I have an array like this:\r\n\r\n    [\r\n    {&quot;price&quot;: 10},\r\n    {&quot;price&quot;: 20},\r\n    {&quot;price&quot;: 30}\r\n    ]\r\n\r\nI want to go over each price item and set it to be negative.\r\n\r\nIf i do something like this:\r\n\r\n    .[].price = .[].price * -1\r\n\r\nI&#39;ll get:\r\n\r\n    [\r\n      {\r\n        &quot;price&quot;: -10\r\n      },\r\n      {\r\n        &quot;price&quot;: -10\r\n      },\r\n      {\r\n        &quot;price&quot;: -10\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;price&quot;: -20\r\n      },\r\n      {\r\n        &quot;price&quot;: -20\r\n      },\r\n      {\r\n        &quot;price&quot;: -20\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        &quot;price&quot;: -30\r\n      },\r\n      {\r\n        &quot;price&quot;: -30\r\n      },\r\n      {\r\n        &quot;price&quot;: -30\r\n      }\r\n    ]\r\n\r\nHow do i do it properly so at the end it will look like this?\r\n\r\n    [\r\n    {&quot;price&quot;: -10},\r\n    {&quot;price&quot;: -20},\r\n    {&quot;price&quot;: -30}\r\n    ]",
        "link": "https://stackoverflow.com/questions/42930165/using-jq-to-change-each-variable-in-the-array-seperatly",
        "title": "Using jq to change each variable in the array seperatly"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1490116410,
                "creation_date": 1490116410,
                "answer_id": 42933947,
                "question_id": 42930707,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "\r\nBuild an array from each object that contains the two values, then use `map` to split the strings, `flatten` to join the resulting arrays, and `@csv` to produce the CSV output.\r\n\r\n    $ jq -r &#39;.[] | [.node, .adjacency] | map (split(&quot;;&quot;)) | flatten | @csv&#39; some.json\r\n    &quot;hosta&quot;,&quot;10.0.0.20&quot;,&quot;37038&quot;,&quot;hostb&quot;,&quot;10.0.0.10&quot;,&quot;4001&quot;\r\n    &quot;hostc&quot;,&quot;10.0.0.16&quot;,&quot;52732&quot;,&quot;hostd&quot;,&quot;10.0.0.24&quot;,&quot;4040&quot;",
                "title": "Split multiple property values in JSON object array with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1490132238,
                "creation_date": 1490132238,
                "answer_id": 42938562,
                "question_id": 42930707,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you don&#39;t want the strings to be quoted, and if you are sure that the quotation marks can be stripped off blindly, you could modify @chepner&#39;s answer by tacking on a call to `gsub/2`:\r\n\r\n    .[]\r\n    | [.node, .adjacency]\r\n    | map (split(&quot;;&quot;))\r\n    | flatten\r\n    | @csv\r\n    | gsub(&quot;\\&quot;&quot;;&quot;&quot;) \r\n\r\nSimilarly, if you only want the numbers in the output to be stripped of the quotation marks, you could add `map(tonumber?//.)` to the pipeline:\r\n\r\n\r\n    .[]\r\n    | [.node, .adjacency]\r\n    | map (split(&quot;;&quot;))\r\n    | flatten\r\n    | map(tonumber?//.)\r\n    | @csv ",
                "title": "Split multiple property values in JSON object array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1504649527,
        "creation_date": 1490108336,
        "last_edit_date": 1504649527,
        "question_id": 42930707,
        "body_markdown": "I&#39;m trying to convert the following JSON structure to CSV:\r\n\r\n    [\r\n     {\r\n       &quot;node&quot;: &quot;hosta;10.0.0.20;37038&quot;,\r\n       &quot;adjacency&quot;: &quot;hostb;10.0.0.10;4001&quot;\r\n     },\r\n     {\r\n      &quot;node&quot;: &quot;hostc;10.0.0.16;52732&quot;,\r\n      &quot;adjacency&quot;: &quot;hostd;10.0.0.24;4040&quot;\r\n     }\r\n    ]\r\n\r\nThe CSV should look like this:\r\n\r\n    hosta,10.0.0.20,37038,hostb,10.0.0.10,4001\r\n    hostc,10.0.0.16,52732,hostd,10.0.0.24,4040\r\n\r\nI know how to use the `split()` function to &quot;explode&quot; an individual property into three values using the semicolon as a divider - but how do I tell jq I want to split both the `node` and the `adjacency` property in the same pass?\r\n\r\n(I can see how I might do this in Python with a more procedural approach, but I&#39;m wondering if there&#39;s a more elegant way of doing it with a function like `map()` in jq) ",
        "link": "https://stackoverflow.com/questions/42930707/split-multiple-property-values-in-json-object-array-with-jq",
        "title": "Split multiple property values in JSON object array with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1490131254,
                "last_edit_date": 1490131254,
                "creation_date": 1490126509,
                "answer_id": 42937081,
                "question_id": 42934070,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You&#39;re right that the solution involves `fromjson`, but a simpler, more direct, and more efficient approach would be as follows:\r\n\r\n    map( { myfield1 } + ( .myfield2 | fromjson ) )\r\n\r\nIf you want to retain all the fields except &quot;myfield2&quot;, consider:\r\n\r\n    map( del(.myfield2) + ( .myfield2 | fromjson ) )",
                "title": "How to flatten string encoded json with jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1549480223,
                "creation_date": 1549480223,
                "answer_id": 54560908,
                "question_id": 42934070,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "My trick for making Terraform output, AWS cli output, and AWS logs readable will work here also.\r\n\r\n@peak is on the right path with `fromjson` but the use of `map` is very task specific. I suggest using `walk`\r\n\r\n```\r\n## Input:\r\njq &#39;walk(if type == &quot;string&quot; and .[0:2] == &quot;{\\&quot;&quot; then .=(.|fromjson) else . end)&#39;&lt;&lt;EOF\r\n[\r\n    {\r\n        &quot;myfield1&quot;: &quot;foo&quot;,\r\n        &quot;myfield2&quot;: &quot;{\\&quot;field1\\&quot;:6366987, \\&quot;field2\\&quot;:5501072}&quot;\r\n    },\r\n    {\r\n        &quot;myfield1&quot;: &quot;bar&quot;,\r\n        &quot;myfield2&quot;: &quot;{\\&quot;field1\\&quot;:123456, \\&quot;field2\\&quot;:123456}&quot;\r\n    }\r\n]\r\nEOF\r\n\r\n## Output:\r\n[\r\n  {\r\n    &quot;myfield1&quot;: &quot;foo&quot;,\r\n    &quot;myfield2&quot;: {\r\n      &quot;field1&quot;: 6366987,\r\n      &quot;field2&quot;: 5501072\r\n    }\r\n  },\r\n  {\r\n    &quot;myfield1&quot;: &quot;bar&quot;,\r\n    &quot;myfield2&quot;: {\r\n      &quot;field1&quot;: 123456,\r\n      &quot;field2&quot;: 123456\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nThis assumes that all embedded JSON is a minified dictionary. You can expand the simple logic if you need to support a list, whitespace, or the full [RFC7159][1]\r\n\r\n\r\n  [1]: http://www.rfc-editor.org/rfc/rfc7159.txt",
                "title": "How to flatten string encoded json with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1549480223,
        "creation_date": 1490116766,
        "last_edit_date": 1490117102,
        "question_id": 42934070,
        "body_markdown": "Hi I have the following json.\r\n\r\n    [\r\n        {\r\n            &quot;myfield1&quot;: &quot;foo&quot;,\r\n            &quot;myfield2&quot;: &quot;{\\&quot;field1\\&quot;:6366987, \\&quot;field2\\&quot;:5501072}&quot;\r\n        },\r\n        {\r\n            &quot;myfield1&quot;: &quot;bar&quot;,\r\n            &quot;myfield2&quot;: &quot;{\\&quot;field1\\&quot;:123456, \\&quot;field2\\&quot;:123456}&quot;\r\n        }\r\n    ]\r\n\r\nAnd would like to get...\r\n\r\n    [\r\n        {\r\n            &quot;myfield1&quot;: &quot;foo&quot;,\r\n            &quot;field1&quot;: 6366987,\r\n            &quot;field2&quot;: 5501072 \r\n        },\r\n        {\r\n            &quot;myfield1&quot;: &quot;foo&quot;,\r\n            &quot;field1&quot;: 123456,\r\n            &quot;field2&quot;: 123456 \r\n        },\r\n    ]\r\n\r\nSo far I got this...\r\n\r\njq &#39;[.[0] | {myfield1: .myfield1, myfield2: .myfield2|fromjson}]&#39;\r\n\r\nBut this means I have to specify each json field plus it doesn&#39;t flatten the json encoded string.\r\n\r\nEdit:\r\n\r\nI think I got it with this...\r\n\r\njq &#39;[.[0]|with_entries(select(.key != &quot;myfield2&quot;))+(.myfield2|fromjson)]&#39;\r\n\r\nDoes it make sense?",
        "link": "https://stackoverflow.com/questions/42934070/how-to-flatten-string-encoded-json-with-jq",
        "title": "How to flatten string encoded json with jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1490136984,
                "creation_date": 1490136984,
                "answer_id": 42939729,
                "question_id": 42938923,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use `[ keys[] ]` to iterate over the keys under `BBBB.VALUES` :\r\n\r\n    jq &#39;(.BBBB.VALUES | . [ keys[] ]) |= .+  { new: .old[1] }&#39; data.json",
                "title": "How do I modify objects within objects using jq while keeping all other objects unchanged?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1490149292,
                "creation_date": 1490149292,
                "answer_id": 42941574,
                "question_id": 42938923,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If one understands `with_entries/1`, an easy-to-read solution is possible:\r\n\r\n    .BBBB.VALUES\r\n    |= with_entries( .value.new = .value.old[1] ) )\r\n\r\n\r\nOr more briefly:\r\n\r\n    .BBBB.VALUES\r\n    |= with_entries( .value |= (.new = .old[1] ) )\r\n",
                "title": "How do I modify objects within objects using jq while keeping all other objects unchanged?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503029323,
                "creation_date": 1503029323,
                "answer_id": 45748401,
                "question_id": 42938923,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses **map_values**\r\n\r\n    .BBBB.VALUES |= map_values(.new = .old[1])",
                "title": "How do I modify objects within objects using jq while keeping all other objects unchanged?"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1503029323,
        "creation_date": 1490133588,
        "question_id": 42938923,
        "body_markdown": "I have a json object with a collection of additional objects.\r\n\r\nUsing `jq` I need to be able to modify some of the objects while keeping the others unchanged.\r\n\r\nI keep running into issues where I can get the change, but then all the other objects disappear. Or I make the change but it impacts every other object.\r\n\r\nHere is a sample json\r\n\r\n    {\r\n      &quot;AAAA&quot;: {\r\n        &quot;VALUES&quot;: {\r\n          &quot;val_1&quot;: {\r\n            &quot;key&quot;: &quot;A_KEY1&quot;\r\n          },\r\n          &quot;val_2&quot;: {\r\n            &quot;key&quot;: &quot;A_KEY2&quot;\r\n          }\r\n        }\r\n      },\r\n      &quot;BBBB&quot;: {\r\n        &quot;VALUES&quot;: {\r\n          &quot;val_a&quot;: {\r\n            &quot;key&quot;: &quot;KEY1&quot;,\r\n            &quot;old&quot;: [ 0, 1 ]\r\n          },\r\n          &quot;val_b&quot;: {\r\n            &quot;key&quot;: &quot;KEY2&quot;,\r\n            &quot;old&quot;: [ 2, 3 ]\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nWhat I am looking to get is no change to the `AAAA` object, however for each value in `BBBB.VALUES` I want to take the second value from the `old` array and create a new key value say &quot;new&quot;\r\n\r\n    {\r\n      &quot;AAAA&quot;: {\r\n        &quot;VALUES&quot;: {\r\n          &quot;val_1&quot;: {\r\n            &quot;key&quot;: &quot;A_KEY1&quot;\r\n          },\r\n          &quot;val_2&quot;: {\r\n            &quot;key&quot;: &quot;A_KEY2&quot;\r\n          }\r\n        }\r\n      },\r\n      &quot;BBBB&quot;: {\r\n        &quot;VALUES&quot;: {\r\n          &quot;val_a&quot;: {\r\n            &quot;key&quot;: &quot;KEY1&quot;,\r\n            &quot;old&quot;: [ 0, 1 ],\r\n            &quot;new&quot;: 1\r\n          },\r\n          &quot;val_b&quot;: {\r\n            &quot;key&quot;: &quot;KEY2&quot;,\r\n            &quot;old&quot;: [ 2, 3 ],\r\n            &quot;new&quot;: 3\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nThe array is guaranteed to be two elements long, the array does not need to be modified.\r\n\r\nI&#39;ve tried many incantations of `jq` and just can&#39;t seem to get it to work.\r\nThanks",
        "link": "https://stackoverflow.com/questions/42938923/how-do-i-modify-objects-within-objects-using-jq-while-keeping-all-other-objects",
        "title": "How do I modify objects within objects using jq while keeping all other objects unchanged?"
    },
    {
        "tags": [
            "json",
            "conditional-statements",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1490137594,
                "creation_date": 1490137594,
                "answer_id": 42939869,
                "question_id": 42938980,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This should get you on your way:\r\n\r\n    .Detail.Response[]\r\n    | { id: .ID, Name: (if .Name != &quot;&quot; then .Name else .FullName end) }",
                "title": "jq get first value by priority and condition"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1490144824,
                "creation_date": 1490144824,
                "answer_id": 42940964,
                "question_id": 42938980,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I figure out a way to do it using `map` and `select`.\r\n\r\n    jq &#39;[.Detail.Response[] | {id: .ID, name: [.Name, .FullName] | map(select(length &gt; 0)) | first }]&#39;",
                "title": "jq get first value by priority and condition"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1490146966,
        "creation_date": 1490133828,
        "last_edit_date": 1490146966,
        "question_id": 42938980,
        "body_markdown": "I have following json:\r\n\r\n\r\n    {\r\n      &quot;Detail&quot;: {\r\n        &quot;Response&quot;: [\r\n          {\r\n            &quot;ID&quot;: &quot;8000000D-1483989576&quot;,\r\n            &quot;Name&quot;: &quot;&quot;,\r\n            &quot;FullName&quot;: &quot;FullName 1&quot;\r\n          },\r\n          {\r\n            &quot;ID&quot;: &quot;8000000C-1483985849&quot;,\r\n            &quot;Name&quot;: &quot;Name 1&quot;\r\n          },\r\n          {\r\n            &quot;ID&quot;: &quot;80000006-1481277410&quot;,\r\n            &quot;Name&quot;: &quot;Name 2&quot;,\r\n            &quot;FullName&quot;: &quot;FullName 2&quot;\r\n          },\r\n          {\r\n            &quot;ID&quot;: &quot;8000000B-1481537384&quot;,\r\n            &quot;Name&quot;: &quot;Name 3&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nI&#39;m trying to create another json that will consider the non-empty/not null `.Name` as priority otherwise get `.FullName` regardless if it&#39;s empty or null, the final json would look like following:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;8000000D-1483989576&quot;,\r\n        &quot;name&quot;: &quot;FullName 1&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;8000000C-1483985849&quot;,\r\n        &quot;name&quot;: &quot;Name 1&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;80000006-1481277410&quot;,\r\n        &quot;name&quot;: &quot;FullName 2&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;8000000B-1481537384&quot;,\r\n        &quot;name&quot;: &quot;Name 3&quot;\r\n      }\r\n    ]\r\n\r\n\r\nThe temporary solution I got is to use `join`\r\n\r\n    jq &#39;[.Detail.Response[] | {id: .ID, name: [.Name, .FullName] | join(&quot;&quot;) }]&#39;\r\n\r\nBut of course, it&#39;ll only work if `.FullName` is empty or null.\r\n",
        "link": "https://stackoverflow.com/questions/42938980/jq-get-first-value-by-priority-and-condition",
        "title": "jq get first value by priority and condition"
    },
    {
        "tags": [
            "json",
            "bash",
            "decimal",
            "jq",
            "number-formatting"
        ],
        "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": 1490198836,
                "post_id": 42956806,
                "comment_id": 73008517,
                "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": 1490198936,
                "post_id": 42956806,
                "comment_id": 73008598,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10364944,
                    "reputation": 1042,
                    "user_id": 7644275,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/RtaM5.jpg?s=256",
                    "display_name": "Mario",
                    "link": "https://stackoverflow.com/users/7644275/mario"
                },
                "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": 1490199002,
                "post_id": 42956806,
                "comment_id": 73008647,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10364944,
                    "reputation": 1042,
                    "user_id": 7644275,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/RtaM5.jpg?s=256",
                    "display_name": "Mario",
                    "link": "https://stackoverflow.com/users/7644275/mario"
                },
                "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": 3,
                "creation_date": 1490199075,
                "post_id": 42956806,
                "comment_id": 73008714,
                "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": 1490199087,
                "post_id": 42956806,
                "comment_id": 73008725,
                "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": 1490199168,
                "post_id": 42956806,
                "comment_id": 73008778,
                "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": 1490199214,
                "post_id": 42956806,
                "comment_id": 73008809,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1490199454,
                "creation_date": 1490199454,
                "answer_id": 42957302,
                "question_id": 42956806,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can&#39;t change `jq`&#39;s behavior -- at present date, [relevant feature requests](https://github.com/stedolan/jq/issues/1192) are still open -- but you *can* reformat your numbers after they&#39;ve been retrieved. For example:\r\n\r\n    json=&#39;{&quot;decimal&quot;:0.00001}&#39;\r\n    decimal=$(jq &#39;.decimal&#39; &lt;&lt;&lt;&quot;$json&quot;)\r\n    decimal_f=$(awk -v decimal=&quot;$decimal&quot; &#39;BEGIN { printf(&quot;%f\\n&quot;, decimal) }&#39; &lt;/dev/null)\r\n\r\n    echo &quot;JQ emitted $decimal; reformatted as $decimal_f&quot;",
                "title": "jq reformatting decimals in scientific notation -- can this be avoided?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1490202514,
                "last_edit_date": 1490202514,
                "creation_date": 1490201449,
                "answer_id": 42957988,
                "question_id": 42956806,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Also, you can reformat your `JSON` using perl module [JSON::PP][1].\r\n\r\n    perl -0777 -MJSON::PP -E &#39;$s=&lt;&gt;; $j=JSON::PP-&gt;new-&gt;ascii-&gt;pretty-&gt;allow_nonref-&gt;allow_bignum;$p=$j-&gt;decode($s);say $j-&gt;encode($p)&#39;\r\n\r\nor nicer:\r\n\r\n    perl -0777 -MJSON::PP -E &#39;\r\n        $j=JSON::PP-&gt;new-&gt;ascii-&gt;pretty-&gt;allow_nonref-&gt;allow_bignum;\r\n        $p=$j-&gt;decode(&lt;&gt;);\r\n        say $j-&gt;encode($p)&#39;\r\n\r\nThe crucial is the `allow_bignum`.\r\n\r\nExample:\r\n\r\n    echo &#39;{&quot;decimal&quot;:0.00000001}&#39; | perl ....\r\n\r\nprints\r\n\r\n    {\r\n       &quot;decimal&quot; : 0.00000001\r\n    }\r\n\r\nbut without the `allow_bignum` prints\r\n\r\n    {\r\n       &quot;decimal&quot; : 1e-08\r\n    }\r\n\r\nPs: ... and also, is possible to validate the whole json using perl... :)\r\n\r\n  [1]: https://metacpan.org/pod/distribution/JSON/lib/JSON/backportPP.pm#allow_bignum",
                "title": "jq reformatting decimals in scientific notation -- can this be avoided?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1578003397,
                "creation_date": 1578003397,
                "answer_id": 59570720,
                "question_id": 42956806,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[A commit made on Oct 21, 2019][1], ensures that jq will generally preserve the &quot;external&quot; format of numbers. There are some exceptions, e.g. superfluous leading 0s.\r\n\r\nThe following page gives details about installing an &quot;unreleased&quot; version of jq: https://github.com/stedolan/jq/wiki/Installation\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/commit/cf4b48c7ba30cb30e116b523cff036ea481459f6",
                "title": "jq reformatting decimals in scientific notation -- can this be avoided?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 9,
        "last_activity_date": 1578003397,
        "creation_date": 1490198181,
        "last_edit_date": 1501524585,
        "question_id": 42956806,
        "body_markdown": "I found difference between json-data created by JavaScipt and via `jq` with bash (and other programming languages). With JavaScript I can create decimal numbers with up to six digits after the point, even when I use `float()`. But with `jq` its different, because adding a decimal value takes four digits after the decimal point only.\r\n\r\nMy problem is that I need decimal numbers to store in SQL, with up to six digits after the point.\r\n\r\nExample: \r\n\r\n    $ JSON=&#39;{&quot;decimal&quot;:0.00001}&#39;\r\n    $ echo &quot;$JSON&quot; | jq .\r\n    {\r\n      &quot;decimal&quot;: 1e-05\r\n    }\r\n\r\n My goal is to validate the decimal with this line ...\r\n\r\n    if [[ &quot;$TMP_DECIMAL&quot; =~ ^[0-9]+([.][0-9]+)?$ ]] ; then\r\n\r\n\r\nAny tip / suggsestion ?",
        "link": "https://stackoverflow.com/questions/42956806/jq-reformatting-decimals-in-scientific-notation-can-this-be-avoided",
        "title": "jq reformatting decimals in scientific notation -- can this be avoided?"
    },
    {
        "tags": [
            "bash",
            "sed",
            "command-line",
            "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": 1,
                "creation_date": 1490252278,
                "post_id": 42969020,
                "comment_id": 73031240,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1490252817,
                "creation_date": 1490252817,
                "answer_id": 42969342,
                "question_id": 42969020,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You weren&#39;t too far off with the jq, how about this?\r\n\r\n    jq &#39;.envConfig |= with_entries(.key |= sub(&quot;^environmentName$&quot;; &quot;prod&quot;))&#39;\r\n\r\nTwo differences: first off, we want to drill down to `envConfig` before doing a `with_entries`, and second, when we get there, the thing we want will be a key, not a value. In case there are any other keys besides `environmentName` they&#39;ll be preserved.",
                "title": "Replace an attribute or key in JSON using jq or sed"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1490254879,
                "last_edit_date": 1490254879,
                "creation_date": 1490253989,
                "answer_id": 42969652,
                "question_id": 42969020,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "TL,TR\r\n\r\nYou can use the following command:\r\n\r\n    jq &#39;(.envConfig |= (. + {&quot;prod&quot;:.environmentName}|del(.environmentName)))&#39; foo.json\r\n\r\n---\r\n\r\nLet&#39;s say you have the following json:\r\n\r\n    {\r\n        &quot;foo&quot;: {\r\n            &quot;hello&quot; : &quot;world&quot;\r\n        }   \r\n    }\r\n\r\nYou can rename the node `foo` to `bar` by first duplicating it and then remove the original node:\r\n\r\n    jq &#39;. + {&quot;bar&quot;:.foo}|del(.foo)&#39; foo.json\r\n\r\nOutput:\r\n\r\n\r\n    {\r\n        &quot;bar&quot;: {\r\n            &quot;hello&quot; : &quot;world&quot;\r\n        }   \r\n    }\r\n\r\nIt get&#39;s a bit more complicated if you want to replace a child key somewhere in the tree. Let&#39;s say you have the following json:\r\n\r\n    {\r\n      &quot;test&quot;: {\r\n        &quot;foo&quot;: {\r\n          &quot;hello&quot;: &quot;world&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nYou can use the following jq command for that:\r\n\r\n    jq &#39;(.test |= (. + {&quot;bar&quot;:.foo}|del(.foo)))&#39; foo.json\r\n\r\nNote the additional parentheses and the use of the assignment operator `|=`.\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;test&quot;: {\r\n        &quot;bar&quot;: {\r\n          &quot;hello&quot;: &quot;world&quot;\r\n        }\r\n      }\r\n    }\r\n\r\n\r\n",
                "title": "Replace an attribute or key in JSON using jq or sed"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1491336631,
                "creation_date": 1491336631,
                "answer_id": 43216794,
                "question_id": 42969020,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using `sed`:\r\n\r\n`sed -i &#39;/^    \\&quot;environmentName\\&quot;:/ s/environmentName/prod/&#39; &lt;yourfile&gt;`\r\n\r\nKeep in mind that `-i` will overwrite the file. You may want to make a backup first.",
                "title": "Replace an attribute or key in JSON using jq or sed"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 5,
        "last_activity_date": 1491336631,
        "creation_date": 1490251516,
        "question_id": 42969020,
        "body_markdown": "Have a big json like this\r\n\r\n    &quot;envConfig&quot;: {\r\n    \t&quot;environmentName&quot;: {\r\n    \t\t&quot;versions&quot;: [\r\n    \t\t\t{\r\n    \t\t\t\t&quot;name&quot;: &quot;version1&quot;,\r\n    \t\t\t\t&quot;value&quot;: &quot;Dev&quot;\r\n    \t\t\t},\r\n    \t\t\t{\r\n    \t\t\t\t&quot;name&quot;: &quot;version2&quot;,\r\n    \t\t\t\t&quot;host&quot;: &quot;qa&quot;\r\n    \t\t\t}\r\n    \t\t],\r\n    \t\t&quot;userRoles&quot;: [\r\n    \t\t\t{\r\n    \t\t\t\t&quot;name&quot;: &quot;Roles&quot;,\r\n    \t\t\t\t&quot;entry&quot;: [\r\n    \t\t\t\t\t{\r\n    \t\t\t\t\t\t&quot;name&quot;: &quot;employees&quot;,\r\n    \t\t\t\t\t\t&quot;value&quot;: &quot;rwx&quot;\r\n    \t\t\t\t\t},\r\n    \t\t\t\t\t{\r\n    \t\t\t\t\t\t&quot;name&quot;: &quot;customers&quot;,\r\n    \t\t\t\t\t\t&quot;value&quot;: &quot;rx&quot;\r\n    \t\t\t\t\t}\r\n    \t\t\t\t]\r\n    \t\t\t}\r\n    \t\t]\r\n    \t}\r\n    },\r\n    \r\nI wanted to change the JSON attribute from &quot;environmentName&quot; to &quot;prod&quot;. Below is the output i am expecting\r\n\r\n    &quot;envConfig&quot;: {\r\n    \t&quot;prod&quot;: {\r\n    \t\t&quot;versions&quot;: [\r\n    \t\t...\r\n    \t\t],\r\n    \t\t&quot;userRoles&quot;: [\r\n    \t\t...\r\n    \t\t]\r\n    \t}\r\n    }\r\n\r\nTried with sed command as below \r\n\r\n    sed &quot;s/\\(&#39;environmentName&#39;:\\)/\\1\\&quot;prod\\&quot;\\,/g&quot; version.json\r\n\r\nTried with jq as below but not working\r\n\r\n    cat version.json | jq  &#39; with_entries(.value |=   {&quot;prod&quot; : .environmentName} ) &#39;\r\n\r\nAny help here to replace the attribute/key of an json with desired value",
        "link": "https://stackoverflow.com/questions/42969020/replace-an-attribute-or-key-in-json-using-jq-or-sed",
        "title": "Replace an attribute or key in JSON using jq or sed"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1490254605,
                "creation_date": 1490254605,
                "answer_id": 42969849,
                "question_id": 42969486,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use the `to_entries` function as in:\r\n\r\n    jq -r &#39;to_entries[] | select(.value.Category | index(&quot;Shopping&quot;) != null) | .key&#39;",
                "title": "Where clause issue when parsing JSON file using jq"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1490266713,
                "creation_date": 1490266713,
                "answer_id": 42974076,
                "question_id": 42969486,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In this particular case, `to_entries` and its overhead can be avoided while still yielding a concise and clear solution:\r\n\r\n    keys[] as $k | select( .[$k].Category | index(&quot;Shopping&quot;) != null) | $k\r\n",
                "title": "Where clause issue when parsing JSON file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1493131031,
        "creation_date": 1490253327,
        "last_edit_date": 1493131031,
        "question_id": 42969486,
        "body_markdown": "I&#39;m trying to parse a `JSON` file which has 6 million lines. Which something looks like this:\r\n\r\n**temp.json**\r\n\r\n\r\n    {\r\n      &quot;bbc.com&quot;: {\r\n        &quot;Reputation&quot;: &quot;2.1&quot;,\r\n        &quot;Rank&quot;: &quot;448&quot;,\r\n        &quot;Category&quot;: [\r\n          &quot;News&quot;\r\n        ]\r\n      },\r\n      &quot;amazon.com&quot;: {\r\n        &quot;Reputation&quot;: &quot;2.1&quot;,\r\n        &quot;Rank&quot;: &quot;448&quot;,\r\n        &quot;Category&quot;: [\r\n          &quot;Shopping&quot;\r\n        ]\r\n      }\r\n    }\r\n\r\nI know how to parse the &quot;Keys&quot; alone. To get &quot;Keys&quot; of this `JSON` structure, I\r\ntried,\r\n\r\n    jq -r &#39;keys[]&#39; temp.json \r\n\r\nResult : \r\n\r\n    amazon.com\r\n    bbc.com\r\n\r\nTo get the &quot;Category&quot; in the above JSON file . I tried , \r\n\r\n    jq -r &#39;.[].Category[]&#39; temp.json \r\n\r\nResult :\r\n\r\n    Shopping\r\n    News\r\n\r\n\r\nHow to get the &quot;Keys&quot; where the &quot;Category&quot; only with &quot;Shopping&quot;?\r\n",
        "link": "https://stackoverflow.com/questions/42969486/where-clause-issue-when-parsing-json-file-using-jq",
        "title": "Where clause issue when parsing JSON file using jq"
    },
    {
        "tags": [
            "json",
            "filtering",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1490524963,
                "last_edit_date": 1490524963,
                "creation_date": 1490504637,
                "answer_id": 43025220,
                "question_id": 43025130,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Except for the initial and trailing JSON scalars, you&#39;d simply write:\r\n\r\n    .[] | .Item[] | select( .ItemName == &quot;Item_2&quot; ) | .Valid\r\n\r\nIn your particular case, to ensure the top-level JSON scalars are ignored, you could prefix the above with:\r\n\r\n     arrays |\r\n\r\n\r\n",
                "title": "parsing JSON with jq to return value of element where another element has a certain value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1490560757,
        "creation_date": 1490503840,
        "last_edit_date": 1490560757,
        "question_id": 43025130,
        "body_markdown": "I have some JSON output I am trying to parse with jq. I read some examples on filtering but I don&#39;t really understand it and my output it more complicated than the examples. I have no idea where to even begin beyond `jq &#39;.[]&#39;` as I don&#39;t understand the syntax of jq beyond that and the hierarchy and terminology are challenging as well. My JSON output is below. I want to return the value for `Valid` where the `ItemName` equals `Item_2`. How can I do this?\r\n\r\n    &quot;1&quot;\r\n    [\r\n      {\r\n        &quot;GroupId&quot;: &quot;1569&quot;,\r\n        &quot;Title&quot;: &quot;My_title&quot;,\r\n        &quot;Logo&quot;: &quot;logo.jpg&quot;,\r\n        &quot;Tags&quot;: [\r\n          &quot;tag1&quot;,\r\n          &quot;tag2&quot;,\r\n          &quot;tag3&quot;    \r\n        ],\r\n        &quot;Owner&quot;: [\r\n          {\r\n            &quot;Name&quot;: &quot;John Doe&quot;,\r\n            &quot;Id&quot;: &quot;53335&quot;\r\n          }\r\n        ],\r\n        &quot;ItemId&quot;: &quot;209766&quot;,\r\n        &quot;Item&quot;: [\r\n          {\r\n            &quot;Id&quot;: 47744,\r\n            &quot;ItemName&quot;: &quot;Item_1&quot;,\r\n            &quot;Valid&quot;: false\r\n          },\r\n          {\r\n            &quot;Id&quot;: 47872,\r\n            &quot;ItemName&quot;: &quot;Item_2&quot;,\r\n            &quot;Valid&quot;: true\r\n          },\r\n          {\r\n            &quot;Id&quot;: 47872,\r\n            &quot;ItemName&quot;: &quot;Item_3&quot;,\r\n            &quot;Valid&quot;: false\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n    &quot;Browse&quot;\r\n    &quot;8fj9438jgge9hdfv0jj0en34ijnd9nnf&quot;\r\n    &quot;v9er84n9ogjuwheofn9gerinneorheoj&quot;\r\n",
        "link": "https://stackoverflow.com/questions/43025130/parsing-json-with-jq-to-return-value-of-element-where-another-element-has-a-cert",
        "title": "parsing JSON with jq to return value of element where another element has a certain value"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "data-conversion",
            "lowercase"
        ],
        "answers": [
            {
                "up_vote_count": 45,
                "is_accepted": true,
                "score": 44,
                "last_activity_date": 1490592411,
                "creation_date": 1490592411,
                "answer_id": 43038520,
                "question_id": 43038453,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The short answer is yes, assuming you are referring to the ASCII characters.\r\n\r\nIn the particular case you mention, you could use this filter:\r\n\r\n    with_entries( .key |= ascii_downcase )\r\n\r\nHowever, you mention arrays.  If you are referring to JSON arrays, you will have to modify the above.\r\n\r\nOne possibility would be to use `walk/1`, but your jq might not have it.  If you want to use `walk/1`, you could find its definition in jq by googling for: jq def walk\r\n\r\nHere&#39;s how it could be used:\r\n\r\n    walk(if type==&quot;object&quot; then with_entries(.key|=ascii_downcase) else . end)\r\n\r\n   ",
                "title": "Convert all json keys to lowercase using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 20,
        "last_activity_date": 1609345418,
        "creation_date": 1490591987,
        "last_edit_date": 1609345418,
        "question_id": 43038453,
        "body_markdown": "I&#39;m looking to ingest a JSON file with arrays into my database. The json file with array items is as below:-\r\n\r\n       {\r\n      &quot;campaignId&quot;: &quot;11067182&quot;,\r\n      &quot;campaignName&quot;: &quot;11067182&quot;,\r\n      &quot;channelId&quot;: &quot;%pxbid_universal_site_id=!;&quot;,\r\n      &quot;channelName&quot;: &quot;%pxbid_universal_site_id=!;&quot;,\r\n      &quot;placementId&quot;: &quot;%epid!&quot;,\r\n      &quot;placementName&quot;: &quot;%epid!&quot;,\r\n      &quot;publisherId&quot;: &quot;%esid!&quot;,\r\n      &quot;publisherName&quot;: &quot;%esid!&quot;,\r\n      &quot;hitDate&quot;: &quot;2017-03-23&quot;,\r\n      &quot;lowRiskImpressions&quot;: &quot;61485&quot;,\r\n      &quot;lowRiskPct&quot;: &quot;64.5295&quot;,\r\n      &quot;moderateRiskImpressions&quot;: &quot;1887&quot;,\r\n      &quot;moderateRiskPct&quot;: &quot;1.9804&quot;,\r\n      &quot;highRiskImpressions&quot;: &quot;43&quot;,\r\n      &quot;highRiskPct&quot;: &quot;0.0451&quot;,\r\n      &quot;veryHighRiskImpressions&quot;: &quot;860&quot;,\r\n      &quot;veryHighRiskPct&quot;: &quot;0.9026&quot;,\r\n      &quot;totalRated&quot;: &quot;95274&quot;,\r\n      &quot;unrated&quot;: &quot;8&quot;,\r\n      &quot;unratedPct&quot;: &quot;0.0084&quot;,\r\n      &quot;visibleCount&quot;: &quot;64283&quot;,\r\n      &quot;pctVisible&quot;: &quot;67.4660&quot;,\r\n      &quot;invisibleCount&quot;: &quot;30999&quot;,\r\n      &quot;totalImpressions&quot;: &quot;95282&quot;\r\n    }\r\n    {\r\n      &quot;campaignId&quot;: &quot;11067182&quot;,\r\n      &quot;campaignName&quot;: &quot;11067182&quot;,\r\n      &quot;channelId&quot;: &quot;%pxbid_universal_site_id=!;&quot;,\r\n      &quot;channelName&quot;: &quot;%pxbid_universal_site_id=!;&quot;,\r\n      &quot;placementId&quot;: &quot;%epid!&quot;,\r\n      &quot;placementName&quot;: &quot;%epid!&quot;,\r\n      &quot;publisherId&quot;: &quot;%esid!&quot;,\r\n      &quot;publisherName&quot;: &quot;%esid!&quot;,\r\n      &quot;hitDate&quot;: &quot;2017-03-22&quot;,\r\n      &quot;lowRiskImpressions&quot;: &quot;17929&quot;,\r\n      &quot;lowRiskPct&quot;: &quot;52.9379&quot;,\r\n      &quot;moderateRiskImpressions&quot;: &quot;1872&quot;,\r\n      &quot;moderateRiskPct&quot;: &quot;5.5273&quot;,\r\n      &quot;highRiskImpressions&quot;: &quot;9&quot;,\r\n      &quot;highRiskPct&quot;: &quot;0.0266&quot;,\r\n      &quot;veryHighRiskImpressions&quot;: &quot;139&quot;,\r\n      &quot;veryHighRiskPct&quot;: &quot;0.4104&quot;,\r\n      &quot;totalRated&quot;: &quot;33850&quot;,\r\n      &quot;unrated&quot;: &quot;18&quot;,\r\n      &quot;unratedPct&quot;: &quot;0.0531&quot;,\r\n      &quot;visibleCount&quot;: &quot;19967&quot;,\r\n      &quot;pctVisible&quot;: &quot;58.9554&quot;,\r\n      &quot;invisibleCount&quot;: &quot;13901&quot;,\r\n      &quot;totalImpressions&quot;: &quot;33868&quot;\r\n    }\r\n\r\nIs there a way to reproduce the same array, but with the keys converted to lowercase using `jq`?",
        "link": "https://stackoverflow.com/questions/43038453/convert-all-json-keys-to-lowercase-using-jq",
        "title": "Convert all json keys to lowercase using JQ"
    },
    {
        "tags": [
            "json",
            "parsing",
            "amazon-web-services",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1490649136,
                "last_edit_date": 1490649136,
                "creation_date": 1490642685,
                "answer_id": 43054797,
                "question_id": 43053569,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here are two potential solutions. Other variants are of course possible.\r\n\r\n### walk/1\r\n\r\nIf you don&#39;t want to be bothered with the details of exactly where the relevant &quot;image&quot; tag is located, consider using `walk/1`:\r\n\r\nInvocation:\r\n\r\n    jq --arg old &quot;docker.org/alpha/alpha-app-newgen:12.2.3&quot; --arg new &quot;HELLO&quot; -f update.jq input.json\r\n\r\nupdate.jq:\r\n\r\n    walk(if type == &quot;object&quot; and .image == $old then .image=$new else . end)\r\n\r\n\r\nIf your jq does not have walk/1, then consider updating or getting its jq definition by googling: jq def walk\r\n\r\n### Targeted update\r\n\r\nInvocation: as above\r\n\r\nupdate.jq:\r\n\r\n    .taskDefinition.containerDefinitions[].image |= (if . == $old then $new else . end)\r\n",
                "title": "Using jq to find and replace elements from Json sub collection"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1490649136,
        "creation_date": 1490638222,
        "question_id": 43053569,
        "body_markdown": "I am trying to parse convert Json Task definition with new image.\r\n\r\nI want to change the `&quot;image&quot;: &quot;docker.org/alpha/alpha-app-newgen:12.2.3&quot;` value in Json to `&quot;image&quot;: &quot;docker.org/alpha/alpha-app-newgen:12.5.0&quot;` or any other version dynamically.\r\n\r\nbelow is my Json task def:\r\n\r\n    {\r\n      &quot;taskDefinition&quot;: {\r\n        &quot;family&quot;: &quot;ing-stack&quot;,\r\n        &quot;volumes&quot;: [\r\n          {\r\n            &quot;host&quot;: {\r\n              &quot;sourcePath&quot;: &quot;/tmp/nginx/elb.conf&quot;\r\n            },\r\n            &quot;name&quot;: &quot;volume-0&quot;\r\n          }\r\n        ],\r\n        &quot;containerDefinitions&quot;: [\r\n          {\r\n            &quot;dnsSearchDomains&quot;: [],\r\n            &quot;environment&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;API_SECRET&quot;,\r\n                &quot;value&quot;: &quot;ING-SECRET&quot;\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;API_KEY&quot;,\r\n                &quot;value&quot;: &quot;AVERA-CADA-VERA-KEY&quot;\r\n              }\r\n            ],\r\n            &quot;readonlyRootFilesystem&quot;: false,\r\n            &quot;name&quot;: &quot;ing-stg&quot;,\r\n            &quot;links&quot;: [],\r\n            &quot;mountPoints&quot;: [],\r\n            &quot;image&quot;: &quot;docker.org/alpha/alpha-app-newgen:12.2.3&quot;,\r\n            &quot;privileged&quot;: false,\r\n            &quot;essential&quot;: true,\r\n            &quot;portMappings&quot;: [\r\n              {\r\n                &quot;protocol&quot;: &quot;tcp&quot;,\r\n                &quot;containerPort&quot;: 19000,\r\n                &quot;hostPort&quot;: 19000\r\n              }\r\n            ],\r\n            &quot;dockerLabels&quot;: {}\r\n          },\r\n          {\r\n            &quot;dnsSearchDomains&quot;: [],\r\n            &quot;environment&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;NG_PROXY&quot;,\r\n                &quot;value&quot;: &quot;ing&quot;\r\n              }\r\n            ],\r\n            &quot;readonlyRootFilesystem&quot;: false,\r\n            &quot;name&quot;: &quot;web&quot;,\r\n            &quot;links&quot;: [\r\n              &quot;identity-ng&quot;\r\n            ],\r\n            &quot;mountPoints&quot;: [\r\n              {\r\n                &quot;sourceVolume&quot;: &quot;volume-0&quot;,\r\n                &quot;readOnly&quot;: false,\r\n                &quot;containerPath&quot;: &quot;/etc/nginx/conf.d/default.conf&quot;\r\n              }\r\n            ],\r\n            &quot;image&quot;: &quot;docker.org/alpha/alpha-ui:6.4.7&quot;,\r\n            &quot;portMappings&quot;: [\r\n              {\r\n                &quot;protocol&quot;: &quot;tcp&quot;,\r\n                &quot;containerPort&quot;: 443,\r\n                &quot;hostPort&quot;: 443\r\n              },\r\n              {\r\n                &quot;protocol&quot;: &quot;tcp&quot;,\r\n                &quot;containerPort&quot;: 80,\r\n                &quot;hostPort&quot;: 80\r\n              }\r\n            ],\r\n            &quot;memory&quot;: 512,\r\n            &quot;command&quot;: [\r\n              &quot;sh&quot;,\r\n              &quot;prep-run-nginx.sh&quot;\r\n            ],\r\n            &quot;dockerLabels&quot;: {}\r\n          }\r\n        ],\r\n        &quot;revision&quot;: 136\r\n      }\r\n    }\r\n\r\nI need to get the same structure back with new value for the image.\r\n\r\nI tried the following\r\n`jq &#39;. | select(.containerDefinitions[].image | contains(&quot;&#39;$new_img_no_ver&#39;&quot;)  ) | .image |= &quot;my new image&quot;&#39;`, but its adding to the end of the JSON.\r\n\r\nCan anybody tell me how to achieve this.",
        "link": "https://stackoverflow.com/questions/43053569/using-jq-to-find-and-replace-elements-from-json-sub-collection",
        "title": "Using jq to find and replace elements from Json sub collection"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1490657401,
                "creation_date": 1490657401,
                "answer_id": 43058133,
                "question_id": 43057955,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use `--argfile` to process multiple files : \r\n\r\n    jq --argfile f1 result.json --argfile f2 output.json -n &#39;$f1 | .output = $f2&#39;",
                "title": "replace json node with another json file with command line jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1490670009,
                "creation_date": 1490670009,
                "answer_id": 43059915,
                "question_id": 43057955,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Basically the same as Bertrand Martel&#39;s answer, but using a different (and shorter) approach to reading the two files.\r\n\r\n    jq -n &#39;input | .output = input&#39; result.json output.json\r\n",
                "title": "replace json node with another json file with command line jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1490670009,
        "creation_date": 1490656401,
        "question_id": 43057955,
        "body_markdown": "I have a `result.json`:\r\n\r\n    {\r\n       &quot;Msg&quot;: &quot;This is output&quot;,\r\n       &quot;output&quot;: {}\r\n    }\r\n\r\nand a `output.json`:\r\n\r\n    {\r\n       &quot;type&quot;: &quot;string&quot;,\r\n       &quot;value&quot;: &quot;result is here&quot;\r\n    }\r\n\r\nI want to replace `output` field in `result.json` with whole file `output.json` as \r\n\r\n    {\r\n       &quot;Msg&quot;: &quot;This is output&quot;,\r\n       &quot;output&quot;: {\r\n           &quot;type&quot;: &quot;string&quot;,\r\n           &quot;value&quot;: &quot;result is here&quot;\r\n       }\r\n    }\r\n\r\n\r\nand idea with `jq` command line? Thank you in advance.",
        "link": "https://stackoverflow.com/questions/43057955/replace-json-node-with-another-json-file-with-command-line-jq",
        "title": "replace json node with another json file with command line jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1490805951,
                "creation_date": 1490805951,
                "answer_id": 43099499,
                "question_id": 43089326,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. You can read in your list of predefined values using one of the command-line options, e.g.\r\n\r\n    jq --argfile list FILEPATH ...\r\n\r\nThis makes the contents of the file available as $list\r\n\r\n2. To check whether a JSON value is in an array, you could use `index/1`, e.g. using this helper function:\r\n\r\n    def check: . as $in | $list | index($in);\r\n\r\n(It probably isn&#39;t necessary to use such a helper function, but it illustrates the idea.)\r\n\r\n3. Without more specifics, it&#39;s difficult to be more specific, so for now let me just wish you good luck!",
                "title": "Is there a way to use hashmap/list as jq tool condition building block?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1490805951,
        "creation_date": 1490779076,
        "question_id": 43089326,
        "body_markdown": "I have set of jsons in a file as input\r\n\r\nI am looking for a way to keep only those objects that meet the following (pseudo-jq) condition:\r\n\r\nsingle_json[key] IN List\r\n\r\nwhere List is predefined list of values (around 50k) - stored in another file (lets say one value per line)\r\n\r\nIs smth like that possible and **feasible**? thanks",
        "link": "https://stackoverflow.com/questions/43089326/is-there-a-way-to-use-hashmap-list-as-jq-tool-condition-building-block",
        "title": "Is there a way to use hashmap/list as jq tool condition building block?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1490802863,
                "post_id": 43098269,
                "comment_id": 73278317,
                "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": 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": 1490803962,
                "post_id": 43098269,
                "comment_id": 73279155,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1490802792,
                "creation_date": 1490802792,
                "answer_id": 43098430,
                "question_id": 43098269,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You pretty much have it correct. You don&#39;t need the quotes around `$email`, because unlike shell, `jq` actually treats that as a variable containing a value, rather than something to expand to arbitrary text. You probably also want to use the `-r` option so that the output is `bar1`, rather than `&quot;bar1&quot;`.\r\n\r\n    #!/usr/bin/env bash\r\n    \r\n    EMAIL=$1\r\n    \r\n    emailAdd=$(jq -r --arg email &quot;$EMAIL&quot; &#39;.[] | select(.ParameterKey==$email) | .ParameterValue&#39; &lt; emails.json)\r\n    \r\n    echo &quot;address is $emailAdd&quot; ",
                "title": "jq extract value of keypair and assign to bash variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1490802792,
        "creation_date": 1490802351,
        "question_id": 43098269,
        "body_markdown": "jq does my head in sometimes. Assume you have a json file called `emails.json` that looks like this;\r\n\r\n    [\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;foo1&quot;,\r\n        &quot;ParameterValue&quot;: &quot;bar1&quot;\r\n      },\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;foo2&quot;,\r\n        &quot;ParameterValue&quot;: &quot;bar2&quot;\r\n      }\r\n    ]\r\n\r\nIf I run my bash script (let&#39;s call it `script.sh`) using the argument foo1, I want to have bar1 assigned to a variable called `emailAdd`. Likewise, if I use the argument foo2, I want bar2 assigned. \r\n\r\nI thought my script would look like the following, but I&#39;m getting an empty variable. \r\n\r\n    #!/usr/bin/env bash\r\n\r\n    EMAIL=$1\r\n\r\n    emailAdd=$(jq --arg email &quot;$EMAIL&quot; &#39;.[] | select(.ParameterKey==&quot;$email&quot;) | .ParameterValue&#39; &lt; emails.json)\r\n\r\n    echo &quot;address is &quot; $emailAdd \r\n\r\nSo, running `sh script.sh foo1` I would expect `address is bar1`, etc",
        "link": "https://stackoverflow.com/questions/43098269/jq-extract-value-of-keypair-and-assign-to-bash-variable",
        "title": "jq extract value of keypair and assign to bash variable"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1490992897,
                "creation_date": 1490992897,
                "answer_id": 43149353,
                "question_id": 43148797,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "What&#39;s wrong with:\r\n\r\n    .TechQuestions.category[0,1].question[] += {&quot;codefile&quot; : &quot;a string to be defined&quot;}\r\n\r\nUsing `walk/1`, you could consider:\r\n\r\n    walk( if type == &quot;object&quot; and has(&quot;question&quot;)\r\n          then .question[] += {&quot;codefile&quot; : &quot;a string to be defined&quot;}\r\n          else .\r\n          end)",
                "title": "jq: how to add an object, key/value in a nested json tree with arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1490992897,
        "creation_date": 1490990501,
        "last_edit_date": 1495535451,
        "question_id": 43148797,
        "body_markdown": "I am pretty new to JQ ... so sorry if it seems obvious..\r\nThe bare problem first. I have this JSON file:\r\n\r\nLink: https://github.com/mariotti/technical_interview_questions/blob/master/QUESTIONS.json\r\n\r\nExtract.\r\n\r\n    cat QUESTIONS.json | jq &#39;.TechQuestions.category[0,1].question[0,1]&#39;\r\n    output:\r\n    {\r\n    ID: Q1,\r\n    categoryname: General,\r\n    idC: C1,\r\n    idCQ: C1Q1,\r\n    idQ: Q1,\r\n    title: Find the most frequent integer in an array\r\n    }\r\n    {\r\n    ID: Q21,\r\n    categoryname: Strings,\r\n    idC: C2,\r\n    idCQ: C2Q1,\r\n    idQ: Q1,\r\n    title: Find the first non-repeated character in a String\r\n    }\r\n    {\r\n    ID: Q2,\r\n    categoryname: General,\r\n    idC: C1,\r\n    idCQ: C1Q2,\r\n    idQ: Q2,\r\n    title: Find pairs in an integer array whose sum is equal to 10 (bonus; do it in linear time)\r\n    }\r\n    {\r\n    ID: Q22,\r\n    categoryname: Strings,\r\n    idC: C2,\r\n    idCQ: C2Q2,\r\n    idQ: Q2,\r\n    title: Reverse a String iteratively and recursively\r\n    }\r\n\r\nAs you can see, this is &quot;deep&quot; into:\r\n\r\n    {\r\n    &quot;TechQuestions&quot;: {\r\n    &quot;category&quot;: [\r\n      {\r\n        &quot;catname&quot;: &quot;General&quot;,\r\n        &quot;idC&quot;: &quot;C1&quot;,\r\n        &quot;question&quot;: [\r\n          {\r\n            &quot;ID&quot;: &quot;Q1&quot;,\r\n            &quot;categoryname&quot;: &quot;General&quot;,\r\n            &quot;idC&quot;: &quot;C1&quot;,\r\n            &quot;idCQ&quot;: &quot;C1Q1&quot;,\r\n            &quot;idQ&quot;: &quot;Q1&quot;,\r\n            &quot;title&quot;: &quot;Find the most frequent integer in an array&quot;\r\n          },\r\n\r\nI want to add the key/field:\r\n\r\n    &quot;codefile&quot; : &quot;a string to be defined&quot;\r\n\r\nwithin the question[] items to get something like:\r\n\r\n          {\r\n            &quot;ID&quot;: &quot;Q1&quot;,\r\n            &quot;categoryname&quot;: &quot;General&quot;,\r\n            &quot;idC&quot;: &quot;C1&quot;,\r\n            &quot;idCQ&quot;: &quot;C1Q1&quot;,\r\n            &quot;idQ&quot;: &quot;Q1&quot;,\r\n            &quot;title&quot;: &quot;Find the most frequent integer in an array&quot;,\r\n            &quot;codefile&quot; : &quot;not present&quot;\r\n          },\r\n\r\nAnd I want to do it programmatically as I might need to develop a bit further...\r\n\r\nFrom other sources (https://stackoverflow.com/questions/31756724/transforming-the-name-of-key-deeper-in-the-json-structure-with-jq) I could for example rename a key with this:\r\n\r\n    cat QUESTIONS.json | jq &#39;.&#39; | jq &#39;\r\n    # Apply f to composite entities recursively, and to atoms\r\n    def walk(f):\r\n     . as $in\r\n     | if type == &quot;object&quot; then\r\n          reduce keys[] as $key\r\n            ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n      elif type == &quot;array&quot; then map( walk(f) ) | f\r\n      else f\r\n      end;\r\n    (.  |= walk(\r\n               if type == &quot;object&quot;\r\n               then with_entries( if .key == &quot;name&quot; then .key |= sub(&quot;name&quot;;&quot;title&quot;) else . end)\r\n               else .\r\n               end))&#39;\r\n\r\nI was trying to modify this bit without success. It seems I am unable to simply add a key/value!\r\n\r\nI will avoid to overload you with odd references and a further list of attempts.\r\nBut maybe I give you an example of a try:\r\n\r\n    (.  |= walk(\r\n           if type == &quot;object&quot;\r\n           then with_entries(\r\n                if .key == &quot;question&quot;\r\n                then . = ( . + {&quot;freshly&quot;: &quot;added&quot;})\r\n                else .\r\n                end)\r\n           else .\r\n           end))&#39;\r\n\r\nThe solution doesn&#39;t have to match my attempts. Actually if there is a more straight full way it is very appreciated.",
        "link": "https://stackoverflow.com/questions/43148797/jq-how-to-add-an-object-key-value-in-a-nested-json-tree-with-arrays",
        "title": "jq: how to add an object, key/value in a nested json tree with arrays"
    },
    {
        "tags": [
            "json",
            "updates",
            "increment",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1491071738,
                "creation_date": 1491071738,
                "answer_id": 43160585,
                "question_id": 43158831,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To update the relevant &quot;calls&quot; along the lines you were exploring:\r\n\r\n    map( (.mobiles[] | select(.number == $number) | .calls) += $incr)\r\n\r\nwhere the values of $number and $incr can (for example) be specified on the command line, e.g.\r\n\r\n    jq --arg number 44444 --argjson incr 5 -f update.jq input.json\r\n\r\nTo update the relevant &quot;total&quot;, you could use `any/2`:\r\n\r\n    map( if any(.mobiles[]; .number == $number) \r\n         then .total += $incr\r\n         else . \r\n         end)\r\n\r\nYou could chain these two together, either literally, or (presumably more efficiently) by combining the two filters into a single `map`.  For readability and maintainability, you might also want to define helper functions (i.e., using `def`).",
                "title": "How to update JSON using JQ and get the updated value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1491071811,
        "creation_date": 1491061500,
        "last_edit_date": 1491071811,
        "question_id": 43158831,
        "body_markdown": "I have some data in JSON which I want to edit using JQ.\r\n\r\n - It&#39;s a list of persons.\r\n - Each person can have one or more `mobile`.\r\n - Each `mobile` has a `number` (which is obviously unique) and no. of `calls` made.\r\n - Also person keep track of `total` calls (sum of calls for each mobile they have)\r\n\r\n*I have tried to use self explanatory variables here. Please let me know if the data is not clear enough.*\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Person1&quot;,\r\n        &quot;mobiles&quot;: [{\r\n          &quot;number&quot;: &quot;11111&quot;,\r\n          &quot;calls&quot;: 2\r\n        },{\r\n          &quot;number&quot;: &quot;22222&quot;,\r\n          &quot;calls&quot;: 3\r\n        }],\r\n        &quot;total&quot;: 5\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Person2&quot;,\r\n        &quot;mobiles&quot;: [{\r\n          &quot;number&quot;: &quot;33333&quot;,\r\n          &quot;calls&quot;: 1\r\n        },{\r\n          &quot;number&quot;: &quot;44444&quot;,\r\n          &quot;calls&quot;: 2\r\n        },{\r\n          &quot;number&quot;: &quot;55555&quot;,\r\n          &quot;calls&quot;: 1\r\n        }],\r\n        &quot;total&quot;: 4\r\n      }\r\n    ]\r\n\r\nWhat I want is, given a mobile number and no. of calls made for that mobile on a particular day, update the json (update both the individual counter and the total)\r\n\r\nEg. Let&#39;s say for number `444444` calls made are 5, then the final json should be\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Person1&quot;,\r\n        &quot;mobiles&quot;: [{\r\n          &quot;number&quot;: &quot;11111&quot;,\r\n          &quot;calls&quot;: 2\r\n        },{\r\n          &quot;number&quot;: &quot;22222&quot;,\r\n          &quot;calls&quot;: 3\r\n        }],\r\n        &quot;total&quot;: 5\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Person2&quot;,\r\n        &quot;mobiles&quot;: [{\r\n          &quot;number&quot;: &quot;33333&quot;,\r\n          &quot;calls&quot;: 1\r\n        },{\r\n          &quot;number&quot;: &quot;44444&quot;,\r\n          &quot;calls&quot;: 7 // previous value was 2, added 5 more\r\n        },{\r\n          &quot;number&quot;: &quot;55555&quot;,\r\n          &quot;calls&quot;: 1\r\n        }],\r\n        &quot;total&quot;: 9 // previous total was 4, added 5 more\r\n      }\r\n    ]\r\n\r\n## What I have tried so far\r\n\r\nI am able to update the `total` calls but not the individual calls for the given number\r\n\r\n`map(select(.mobiles[].number == &quot;44444&quot;).total = .total + 5)` gives\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Person1&quot;,\r\n        &quot;mobiles&quot;: [\r\n          {\r\n            &quot;number&quot;: &quot;11111&quot;,\r\n            &quot;calls&quot;: 2\r\n          },\r\n          {\r\n            &quot;number&quot;: &quot;22222&quot;,\r\n            &quot;calls&quot;: 3\r\n          }\r\n        ],\r\n        &quot;total&quot;: 5\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Person2&quot;,\r\n        &quot;mobiles&quot;: [\r\n          {\r\n            &quot;number&quot;: &quot;33333&quot;,\r\n            &quot;calls&quot;: 1\r\n          },\r\n          {\r\n            &quot;number&quot;: &quot;44444&quot;,\r\n            &quot;calls&quot;: 2 // How do I update this\r\n          },\r\n          {\r\n            &quot;number&quot;: &quot;55555&quot;,\r\n            &quot;calls&quot;: 1\r\n          }\r\n        ],\r\n        &quot;total&quot;: 9 // This is correct\r\n      }\r\n    ]\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/43158831/how-to-update-json-using-jq-and-get-the-updated-value",
        "title": "How to update JSON using JQ and get the updated value"
    },
    {
        "tags": [
            "json",
            "updates",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1491243542,
                "last_edit_date": 1491243542,
                "creation_date": 1491215389,
                "answer_id": 43182250,
                "question_id": 43180340,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following filter should perform the update you want:\r\n\r\n    (.git_namespaces[] | select(.name==&quot;NamespaceY&quot;).modules) += [&quot;moduleF&quot;]\r\n\r\nNote that the initial &#39;.|&#39; in your attempt is not needed; that &quot;NamespaceY&quot; is capitalized in config.json; that the parens as shown are the keys to success; and that += can be used here.\r\n\r\nOne way to write back to the original file would perhaps be to use &#39;sponge&#39;; other possibilities are discussed on the jq FAQ https://github.com/stedolan/jq/wiki/FAQ",
                "title": "How to update a subitem in a json file using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1491245647,
        "creation_date": 1491209681,
        "last_edit_date": 1491245647,
        "question_id": 43180340,
        "body_markdown": "Using `jq` I tried to update this json document:\r\n\r\n    {\r\n    &quot;git_defaults&quot;: {\r\n        &quot;branch&quot;: &quot;master&quot;,\r\n        &quot;email&quot;: &quot;jenkins@host&quot;,\r\n        &quot;user&quot;: &quot;Jenkins&quot;\r\n    },\r\n    &quot;git_namespaces&quot;: [\r\n    {\r\n        &quot;name&quot;: &quot;NamespaceX&quot;,\r\n            &quot;modules&quot;: [\r\n                &quot;moduleA&quot;,\r\n                &quot;moduleB&quot;,\r\n                &quot;moduleC&quot;,\r\n                &quot;moduleD&quot;\r\n            ]\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;NamespaceY&quot;,\r\n        &quot;modules&quot;: [\r\n            &quot;moduleE&quot;\r\n        ]\r\n    }\r\n    ]\r\n    }\r\n\r\nwith adding `moduleF` to `NamespaceY`. I need to write the file back again to the original source file. \r\n\r\nI came close (but no cigar) with:\r\n\r\n    jq  &#39;. | .git_namespaces[] | select(.name==&quot;namespaceY&quot;).modules |= (.+ [&quot;moduleF&quot;])&#39; config.json\r\n\r\nand \r\n\r\n    jq &#39;. | select(.git_namespaces[].name==&quot;namespaceY&quot;).modules |= (.+ [&quot;moduleF&quot;])&#39; config.json\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/43180340/how-to-update-a-subitem-in-a-json-file-using-jq",
        "title": "How to update a subitem in a json file using jq?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 87,
                "is_accepted": true,
                "score": 87,
                "last_activity_date": 1491247547,
                "creation_date": 1491247547,
                "answer_id": 43192740,
                "question_id": 43192556,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your best bet is probably to output each record in something like TSV format, then read that from a shell loop.\r\n\r\n    jq -r &#39;.[]|[.user, .date, .email] | @tsv&#39; |\r\n      while IFS=$&#39;\\t&#39; read -r user date email; do\r\n        mycommand -u &quot;$user&quot; -d &quot;$date&quot; -e &quot;$email&quot;\r\n      done\r\n\r\n`jq` itself doesn&#39;t have anything like a `system` call to run an external command from within a filter, although it seems that [they are working on it](https://github.com/stedolan/jq/issues/147).",
                "title": "Using jq with bash to run command for each object in array"
            },
            {
                "up_vote_count": 37,
                "is_accepted": false,
                "score": 37,
                "last_activity_date": 1491248773,
                "creation_date": 1491248773,
                "answer_id": 43193054,
                "question_id": 43192556,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could have `jq` output the commands to execute, something like\r\n\r\n    .[] | &quot;mycommand \\(.user|@sh) \\(.date|@sh) \\(.email|@sh)&quot;\r\n\r\nThen execute it. Something like\r\n\r\n    bash &lt;(jq -r &#39;.[] | &quot;mycommand \\(.user|@sh) \\(.date|@sh) \\(.email|@sh)&quot;&#39; foo)",
                "title": "Using jq with bash to run command for each object in array"
            },
            {
                "up_vote_count": 52,
                "is_accepted": false,
                "score": 51,
                "last_activity_date": 1528920596,
                "creation_date": 1528920596,
                "answer_id": 50845457,
                "question_id": 43192556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With xargs:\r\n\r\n\r\n    curl localhost:8082/connectors | jq .[] | xargs -L1 -I&#39;{}&#39; curl -XDELETE &#39;localhost:8082/connectors/{}&#39; \r\n\r\nOr equivalently, to show the output of that first curl:\r\n\r\n    echo &#39;[&quot;quickstart-file-sink4&quot;,&quot;quickstart-file-source&quot;,&quot;quickstart-file-sink&quot;,&quot;quickstart-file-sink2&quot;,&quot;quickstart-file-sink3&quot;,&quot;quickstart-file-source2&quot;]&#39; | jq .[] | xargs -L1 -I&#39;{}&#39; curl -XDELETE &#39;localhost:8082/connectors/{}&#39; \r\n\r\n`jq .[]` strips off one level of containment, so that a list becomes output as one line per item.\r\n\r\n`xargs -L1` processes one line at a time\r\n\r\n`xargs -I&#39;{}&#39;` specifies that the string `{}` be replaced with the input line when invoking the following command.\r\n\r\n`xargs` is essentially a map operator for the shell. ",
                "title": "Using jq with bash to run command for each object in array"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1542081867,
                "creation_date": 1542081867,
                "answer_id": 53273617,
                "question_id": 43192556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I came across the same problem recently where xargs doesn&#39;t help that much due to the relatively complicated set of arguments I wanted to pass around. Thus I implemented an `sh` filter (and its friends) to jq. I haven&#39;t yet had enough time to write documentation and tests for it so not creating a PR for it to become a part of the official codebase yet. So now it&#39;s only for the ones who are willing to compile this version themselves:\r\n\r\nhttps://github.com/haochenx/jq/tree/sh-support",
                "title": "Using jq with bash to run command for each object in array"
            },
            {
                "up_vote_count": 24,
                "is_accepted": false,
                "score": 24,
                "last_activity_date": 1712271833,
                "last_edit_date": 1712271833,
                "creation_date": 1568889398,
                "answer_id": 58009121,
                "question_id": 43192556,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is another variation which I based on the answer from @chepner.\r\n\r\n    echo &quot;$config&quot; | jq -c &#39;.[]&#39; |\r\n    while IFS=$&quot;\\n&quot; read -r c; do\r\n        echo &quot;start&quot;\r\n        host=$(echo &quot;$c&quot; | jq -r &#39;.host&#39;)\r\n        echo $host\r\n        echo &quot;end&quot;\r\n    done\r\n\r\nI used jq&#39;s -c option to output &quot;compact&quot; jsons, so they are all on one line. \r\n\r\nIn combination with `IFS=$&quot;\\n&quot;`, I was able to loop over each item in the input json&#39;s array and do what I wanted to do.\r\n\r\nSo, with an input of \r\n\r\n    [\r\n     {\r\n      &quot;host&quot;: &quot;host1&quot;,\r\n      &quot;settings&quot;: {}\r\n     },\r\n     {\r\n      &quot;host&quot;: &quot;host2&quot;,\r\n      &quot;settings&quot;: {}\r\n     }\r\n    ]\r\n\r\nthe output is\r\n\r\n    start\r\n    host1\r\n    end\r\n    start\r\n    host2\r\n    end\r\n\r\n",
                "title": "Using jq with bash to run command for each object in array"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 77,
        "last_activity_date": 1712271833,
        "creation_date": 1491246836,
        "last_edit_date": 1638215344,
        "question_id": 43192556,
        "body_markdown": "How can I run a Bash command for every JSON object in a JSON array using `jq`? So far I have this:\r\n\r\n    cat credentials.json | jq -r &#39;.[] | .user, .date, .email&#39; | mycommand -u {user} -d {date} -e {email}\r\n\r\nThis doesn&#39;t seem to work. How can I take the parameters out of the JSON array into my command?\r\n\r\nMy JSON file looks something like this:\r\n\r\n    [\r\n       &quot;user&quot;: &quot;danielrvt&quot;,\r\n       &quot;date&quot;: &quot;11/10/1988&quot;,\r\n       &quot;email&quot;: &quot;myemail@domain.com&quot;,\r\n       ...\r\n    ]",
        "link": "https://stackoverflow.com/questions/43192556/using-jq-with-bash-to-run-command-for-each-object-in-array",
        "title": "Using jq with bash to run command for each object in array"
    },
    {
        "tags": [
            "json",
            "sorting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1491324825,
                "creation_date": 1491324825,
                "answer_id": 43213266,
                "question_id": 43211290,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can sort all the arrays by &quot;name&quot;, while keeping everything else intact, like this:\r\n\r\n    walk(if type == &quot;array&quot; then sort_by(.name) else . end)",
                "title": "sort json document using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1491324825,
        "creation_date": 1491319111,
        "last_edit_date": 1495540950,
        "question_id": 43211290,
        "body_markdown": "I have a json document that is a (SSAS Tabular model .bim file)\r\n\r\nIts full structure is attached [example json][1] but it is a nested object structure as per below. Every object has a name property that I would like to use to sort on\r\n\r\n    {\r\n    &quot;name&quot;: &quot;SemanticModel&quot;,\r\n    &quot;compatibilityLevel&quot;: 1200,\r\n    &quot;model&quot;: {\r\n    &quot;culture&quot;: &quot;en-US&quot;,\r\n    &quot;dataSources&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;BlahDW&quot;,\r\n        &quot;connectionString&quot;: &quot;Provider=SQLOLEDB;Data Source=sql.blah.com;Persist Security Info=false;Integrated Security=SSPI;Initial Catalog=Blah&quot;,\r\n        &quot;impersonationMode&quot;: &quot;impersonateAccount&quot;,\r\n        &quot;account&quot;: &quot;blah\\\\blah&quot;,\r\n        &quot;annotations&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;ConnectionEditUISource&quot;,\r\n            &quot;value&quot;: &quot;SqlServer&quot;\r\n          }\r\n        ]\r\n      }\r\n    ],\r\n    &quot;tables&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Employees&quot;,\r\n        &quot;isHidden&quot;: true,\r\n        &quot;columns&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;Employee Key&quot;,\r\n            &quot;dataType&quot;: &quot;int64&quot;,\r\n            &quot;isHidden&quot;: true,\r\n            &quot;isUnique&quot;: true,\r\n            &quot;isNullable&quot;: false,\r\n            &quot;sourceColumn&quot;: &quot;Employee Key&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;Employee Code&quot;,\r\n            &quot;dataType&quot;: &quot;string&quot;,\r\n            &quot;isHidden&quot;: true,\r\n            &quot;sourceColumn&quot;: &quot;Employee Code&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;Employee Name&quot;,\r\n            &quot;dataType&quot;: &quot;string&quot;,\r\n            &quot;isHidden&quot;: true,\r\n            &quot;sourceColumn&quot;: &quot;Employee Name&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;Home Village Code&quot;,\r\n            &quot;dataType&quot;: &quot;string&quot;,\r\n            &quot;isHidden&quot;: true,\r\n            &quot;sourceColumn&quot;: &quot;Home Village Code&quot;\r\n          }\r\n        ],\r\n    ....\r\n\r\nI have tried the walk/1 method as mentioned here https://stackoverflow.com/questions/38257725/how-can-i-completely-sort-arbitrary-json-using-jq but it doesn&#39;t work as it is not trying to sort the objects in the collections I don&#39;t think. \r\n\r\nI have found that this works &quot;.model.tables|=sort_by(.name)&quot; to just sort one collection (thanks to https://stackoverflow.com/questions/30331504/how-to-sort-a-json-file-by-keys-and-values-of-those-keys-in-jq) but I cannot work out how to combine this with the walk so I don&#39;t need to explicitly recreate the same json structure\r\n\r\nI am at my limit of my jq knowledge here so wondered if someone could put me in the right direction\r\n\r\n\r\n  [1]: https://valueretail1-my.sharepoint.com/personal/bgerhardi_valueretail_com/_layouts/15/guestaccess.aspx?docid=0885457a25f824090b233b3d8a0fe8c4e&amp;authkey=AdejzB0uZ-0Inaya7rI-Ox4",
        "link": "https://stackoverflow.com/questions/43211290/sort-json-document-using-jq",
        "title": "sort json document using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "updates",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1491328005,
                "creation_date": 1491328005,
                "answer_id": 43214178,
                "question_id": 43213672,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could chain together the updates like so:\r\n\r\n    .Start |= (strptime(&quot;%Y-%m-%d %H:%M:%S&quot;) | mktime)\r\n    | .End |= (strptime(&quot;%Y-%m-%d %H:%M:%S&quot;) | mktime)\r\n    | .Period = (.End - .Start)\r\n\r\n\r\n\r\n    ",
                "title": "JSON and jq updating multiple values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1491341152,
        "creation_date": 1491326150,
        "last_edit_date": 1491341152,
        "question_id": 43213672,
        "body_markdown": "Hi I am trying to perform a calculation within a single &quot;jq&quot; command but I cannot workout how to reference the new values.\r\n\r\nOriginal JSON\r\n\r\n    {\r\n      &quot;Status&quot;: &quot;Down&quot;,\r\n      &quot;StatusID&quot;: &quot;75328241&quot;,\r\n      &quot;Start&quot;: &quot;2017-03-17 15:06:40&quot;,\r\n      &quot;End&quot;: &quot;2017-03-17 15:08:37&quot;,\r\n      &quot;Period&quot;: &quot;1 Minutes &quot;\r\n    }\r\n\r\nMy goal is to convert the start and end times to epoch and workout the duration in seconds. Then output the same object with the new values.\r\n\r\nWhen I do this\r\n\r\n    echo $J_SON | jq &#39;.Start |= (strptime(&quot;%Y-%m-%d %H:%M:%S&quot;) | mktime),.End |= (strptime(&quot;%Y-%m-%d %H:%M:%S&quot;) | mktime)&#39;\r\n\r\nOutput is:\r\n\r\n    {\r\n      &quot;Status&quot;: &quot;Down&quot;,\r\n      &quot;StatusID&quot;: &quot;75328241&quot;,\r\n      &quot;Start&quot;: 1489763200,\r\n      &quot;End&quot;: &quot;2017-03-17 15:08:37&quot;,\r\n      &quot;Period&quot;: &quot;1 Minutes &quot;\r\n    }\r\n    {\r\n      &quot;Status&quot;: &quot;Down&quot;,\r\n      &quot;StatusID&quot;: &quot;75328241&quot;,\r\n      &quot;Start&quot;: &quot;2017-03-17 15:06:40&quot;,\r\n      &quot;End&quot;: 1489763317,\r\n      &quot;Period&quot;: &quot;1 Minutes &quot;\r\n    }\r\n\r\nWhich makes sense, the manual says that this is default behaviour. \r\n\r\n&gt; Assignment works a little differently in jq than in most programming\r\n&gt; languages. jq doesn’t distinguish between references to and copies of\r\n&gt; something - two objects or arrays are either equal or not equal,\r\n&gt; without any further notion of being “the same object” or “not the same\r\n&gt; object”.\r\n&gt; \r\n&gt; If an object has two fields which are arrays, .foo and .bar, and you\r\n&gt; append something to .foo, then .bar will not get bigger, even if\r\n&gt; you’ve previously set .bar = .foo. If you’re used to programming in\r\n&gt; languages like Python, Java, Ruby, Javascript, etc. then you can think\r\n&gt; of it as though jq does a full deep copy of every object before it\r\n&gt; does the assignment (for performance it doesn’t actually do that, but\r\n&gt; that’s the general idea).\r\n\r\nBut I would then like to output the values in epoch as well as seconds.\r\n\r\nI managed to successfully get the duration like this:\r\n\r\n    echo $J_SON | jq &#39;.Period = ((.End | strptime(&quot;%Y-%m-%d %H:%M:%S&quot;) | mktime)-(.Start | strptime(&quot;%Y-%m-%d %H:%M:%S&quot;) | mktime))&#39;\r\n\r\n\r\n**Output**\r\n\r\n    {\r\n      &quot;Status&quot;: &quot;Down&quot;,\r\n      &quot;StatusID&quot;: &quot;75328241&quot;,\r\n      &quot;Start&quot;: &quot;2017-03-17 15:06:40&quot;,\r\n      &quot;End&quot;: &quot;2017-03-17 15:08:37&quot;,\r\n      &quot;Period&quot;: 117\r\n    }\r\n\r\n\r\n**Problem:**\r\n\r\nI can get the individual values of each variables but not sure how to then concatenate them all in a single output object.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/43213672/json-and-jq-updating-multiple-values",
        "title": "JSON and jq updating multiple values"
    },
    {
        "tags": [
            "bash",
            "docker",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1491329519,
                "last_edit_date": 1491329519,
                "creation_date": 1491328942,
                "answer_id": 43214460,
                "question_id": 43214376,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "why not :\r\n\r\n    docker inspect  --format &#39;{{ (index (index .NetworkSettings.Ports &quot;22/tcp&quot;) 0).HostPort }}&#39; blah\r\n\r\nthis will eliminate the needs of another tool.",
                "title": "Docker inspect: Select field that has forward slash using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1491329116,
                "creation_date": 1491329116,
                "answer_id": 43214519,
                "question_id": 43214376,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`jq` supports double quotes for keys with special characters:\r\n\r\n    jq &#39;.&quot;22/tcp&quot;.HostPort&#39;\r\n\r\nedit: this is mentioned in [the docs](https://stedolan.github.io/jq/manual/#example2), which also mention that you can add brackets to help with readability, if you want:\r\n\r\n    jq &#39;.[&quot;22/tcp&quot;].HostPort&#39;",
                "title": "Docker inspect: Select field that has forward slash using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1595465093,
                "creation_date": 1595465093,
                "answer_id": 63045153,
                "question_id": 43214376,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The above answer is close but needs to add a bracket to work correctly. \r\n\r\n`jq &#39;.&quot;22/tcp&quot;[].HostPort&#39;`",
                "title": "Docker inspect: Select field that has forward slash using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1595465093,
        "creation_date": 1491328686,
        "last_edit_date": 1491332666,
        "question_id": 43214376,
        "body_markdown": "    # docker inspect blah | jq &#39;.[] | .NetworkSettings.Ports&#39;\r\n    {\r\n        &quot;22/tcp&quot;: [\r\n         {\r\n           &quot;HostIp&quot;: &quot;0.0.0.0&quot;,\r\n           &quot;HostPort&quot;: &quot;32776&quot;\r\n         }\r\n        ]\r\n    }\r\n\r\nHow the heck do I get the `HostPort` value? I tried the following but that failed.\r\n\r\n    # docker inspect blah | jq &#39;.[] | .NetworkSettings.Ports.22\\/tcp.HostPort&#39;\r\n",
        "link": "https://stackoverflow.com/questions/43214376/docker-inspect-select-field-that-has-forward-slash-using-jq",
        "title": "Docker inspect: Select field that has forward slash using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 80651,
                    "reputation": 2023,
                    "user_id": 227927,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://i.sstatic.net/jhmpw.jpg?s=256",
                    "display_name": "fedeisas",
                    "link": "https://stackoverflow.com/users/227927/fedeisas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1491342530,
                "post_id": 43218242,
                "comment_id": 73507758,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2847044,
                    "reputation": 43,
                    "user_id": 2445149,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3Q4VS.jpg?s=256",
                    "display_name": "Messi Of DevOps",
                    "link": "https://stackoverflow.com/users/2445149/messi-of-devops"
                },
                "reply_to_user": {
                    "account_id": 80651,
                    "reputation": 2023,
                    "user_id": 227927,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://i.sstatic.net/jhmpw.jpg?s=256",
                    "display_name": "fedeisas",
                    "link": "https://stackoverflow.com/users/227927/fedeisas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1491343168,
                "post_id": 43218242,
                "comment_id": 73508029,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 80651,
                    "reputation": 2023,
                    "user_id": 227927,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://i.sstatic.net/jhmpw.jpg?s=256",
                    "display_name": "fedeisas",
                    "link": "https://stackoverflow.com/users/227927/fedeisas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1491344027,
                "post_id": 43218242,
                "comment_id": 73508395,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2847044,
                    "reputation": 43,
                    "user_id": 2445149,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3Q4VS.jpg?s=256",
                    "display_name": "Messi Of DevOps",
                    "link": "https://stackoverflow.com/users/2445149/messi-of-devops"
                },
                "reply_to_user": {
                    "account_id": 80651,
                    "reputation": 2023,
                    "user_id": 227927,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://i.sstatic.net/jhmpw.jpg?s=256",
                    "display_name": "fedeisas",
                    "link": "https://stackoverflow.com/users/227927/fedeisas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1491389212,
                "post_id": 43218242,
                "comment_id": 73527617,
                "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": 1491533074,
                "post_id": 43218242,
                "comment_id": 73606142,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2847044,
                    "reputation": 43,
                    "user_id": 2445149,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3Q4VS.jpg?s=256",
                    "display_name": "Messi Of DevOps",
                    "link": "https://stackoverflow.com/users/2445149/messi-of-devops"
                },
                "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": 1491547755,
                "post_id": 43218242,
                "comment_id": 73611148,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2847044,
                    "reputation": 43,
                    "user_id": 2445149,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3Q4VS.jpg?s=256",
                    "display_name": "Messi Of DevOps",
                    "link": "https://stackoverflow.com/users/2445149/messi-of-devops"
                },
                "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": 1491548066,
                "post_id": 43218242,
                "comment_id": 73611309,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1491808493,
                "last_edit_date": 1491808493,
                "creation_date": 1491345431,
                "answer_id": 43218865,
                "question_id": 43218242,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It appears that you should be using `index/1` to check .tag_list (not .tag_list[]):\r\n\r\n\r\n    [ .[] | select(.tag_list | index($gitlab_tag)) \r\n\r\njq has no knowledge of bash array variables.  For these, you therefore have two basic options: 1) use bash to iterate over the bash array variable (calling jq as often as necessary); 2) present the contents of the bash array variable in a way that jq can handle.\r\n\r\nThere are many variations of (2).  Consider for example:\r\n\r\n    $ a=(a &quot;b c&quot;)\r\n    \r\n    $ printf &quot;%s\\n&quot; &quot;${a[@]}&quot; | jq -R | jq -s  \r\n    [\r\n      &quot;a&quot;,\r\n      &quot;b c&quot;\r\n    ]\r\n\r\n\r\n\r\n",
                "title": "jq won&#39;t allow to iterate over results"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1491808493,
        "creation_date": 1491342325,
        "last_edit_date": 1491343156,
        "question_id": 43218242,
        "body_markdown": "In code below I&#39;m trying to match values from a bash array with values from json array using jq.\r\n\r\n    PROJECTS=$(curl -H &quot;PRIVATE-TOKEN: ${GITLAB_TOKEN}&quot; &quot;${GITLAB_URL}/api/v4/projects&quot;)\r\n    for GITLAB_TAG in &quot;${GITLAB_TAGS[@]}&quot;; do\r\n        PROJECTS=`echo &quot;${PROJECTS}&quot; \\\r\n        | jq --arg gitlab_tag &quot;$GITLAB_TAG&quot; &#39;[ .[] | select(.tag_list[] | contains($gitlab_tag)) ]&#39;`\r\n    done\r\n\r\n    PROJECTS=$(echo &quot;$PROJECTS&quot; | jq -r &#39;.[]&#39;)\r\n\r\nConsider the following JSON payload as a sample API response:\r\n\r\n    [{&quot;id&quot;:31,&quot;description&quot;:&quot;&quot;,&quot;default_branch&quot;:null,&quot;tag_list&quot;:[&quot;dev&quot;,&quot;app&quot;],&quot;archived&quot;:false,&quot;visibility&quot;:&quot;private&quot;},{&quot;id&quot;:28,&quot;description&quot;:&quot;&quot;,&quot;default_branch&quot;:&quot;master&quot;,&quot;tag_list&quot;:[&quot;dev&quot;,&quot;app&quot;],&quot;archived&quot;:false,&quot;visibility&quot;:&quot;private&quot;}]\r\n\r\nThis works only partially, because I can&#39;t iterate over results ($PROJECTS). \r\n\r\n`printf &quot;${PROJECTS[0]}&quot;` prints the whole array. \r\n\r\nAm I missing something here?",
        "link": "https://stackoverflow.com/questions/43218242/jq-wont-allow-to-iterate-over-results",
        "title": "jq won&#39;t allow to iterate over results"
    },
    {
        "tags": [
            "json",
            "key",
            "grouping",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 80,
                "is_accepted": true,
                "score": 78,
                "last_activity_date": 1491364525,
                "creation_date": 1491364525,
                "answer_id": 43221520,
                "question_id": 43221453,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I figured it out myself. I first group by `.component` and then just create new lists of ips that are indexed by the component of the first object of each group:\r\n\r\n`jq &#39; group_by(.component)[] | {(.[0].component): [.[] | .ip]}&#39;`",
                "title": "jq: group and key by property"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1597180606,
                "creation_date": 1597180606,
                "answer_id": 63366491,
                "question_id": 43221453,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As a further example of [@replay&#39;s technique][1], after many failures using other methods, I finally built a filter that condenses this Wazuh report (excerpted for brevity):\r\n\r\n```\r\n{\r\n  &quot;took&quot; : 228,\r\n  &quot;timed_out&quot; : false,\r\n  &quot;hits&quot; : {\r\n    &quot;total&quot; : {\r\n      &quot;value&quot; : 2806,\r\n      &quot;relation&quot; : &quot;eq&quot;\r\n    },\r\n    &quot;hits&quot; : [\r\n      {\r\n        &quot;_source&quot; : {\r\n          &quot;agent&quot; : {\r\n            &quot;name&quot; : &quot;100360xx&quot;\r\n          },\r\n          &quot;data&quot; : {\r\n            &quot;vulnerability&quot; : {\r\n              &quot;severity&quot; : &quot;High&quot;,\r\n              &quot;package&quot; : {\r\n                &quot;condition&quot; : &quot;less than 78.0&quot;,\r\n                &quot;name&quot; : &quot;Mozilla Firefox 68.11.0 ESR (x64 en-US)&quot;\r\n              }\r\n            }\r\n          }\r\n        }\r\n      },\r\n      {\r\n        &quot;_source&quot; : {\r\n          &quot;agent&quot; : {\r\n            &quot;name&quot; : &quot;100360xx&quot;\r\n          },\r\n          &quot;data&quot; : {\r\n            &quot;vulnerability&quot; : {\r\n              &quot;severity&quot; : &quot;High&quot;,\r\n              &quot;package&quot; : {\r\n                &quot;condition&quot; : &quot;less than 78.0&quot;,\r\n                &quot;name&quot; : &quot;Mozilla Firefox 68.11.0 ESR (x64 en-US)&quot;\r\n              }\r\n            }\r\n          }\r\n        }\r\n      },\r\n      ...\r\n```\r\nHere is the `jq` filter I use to provide an array of objects, each consisting of an **agent name** followed by an **array of names of the agent&#39;s vulnerable packages**:\r\n```\r\njq &#39; .hits.hits |= unique_by(._source.agent.name, ._source.data.vulnerability.package.name) | .hits.hits | group_by(._source.agent.name)[] | { (.[0]._source.agent.name): [.[]._source.data.vulnerability.package | .name ]}&#39;\r\n```\r\nHere is an excerpt of the output produced by the filter:\r\n```\r\n{\r\n  &quot;100360xx&quot;: [\r\n    &quot;Mozilla Firefox 68.11.0 ESR (x64 en-US)&quot;,\r\n    &quot;VLC media player&quot;,\r\n    &quot;Windows 10&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;WIN-KD5C4xxx&quot;: [\r\n    &quot;Windows Server 2019&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;fridxxx&quot;: [\r\n    &quot;java-1.8.0-openjdk&quot;,\r\n    &quot;kernel&quot;,\r\n    &quot;kernel-headers&quot;,\r\n    &quot;kernel-tools&quot;,\r\n    &quot;kernel-tools-libs&quot;,\r\n    &quot;python-perf&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;mcd-xxx-xxx&quot;: [\r\n    &quot;dbus&quot;,\r\n    &quot;fribidi&quot;,\r\n    &quot;gnupg2&quot;,\r\n    &quot;graphite2&quot;,\r\n    ...\r\n```\r\n\r\n\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/43221520/5025060",
                "title": "jq: group and key by property"
            },
            {
                "up_vote_count": 27,
                "is_accepted": false,
                "score": 27,
                "last_activity_date": 1714680005,
                "last_edit_date": 1714680005,
                "creation_date": 1632743373,
                "answer_id": 69346071,
                "question_id": 43221453,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The accepted answer doesn&#39;t produce valid json, but:\r\n\r\n````json\r\n{\r\n  &quot;name1&quot;: [\r\n    &quot;1.1.1.1&quot;,\r\n    &quot;1.1.1.2&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;name2&quot;: [\r\n    &quot;1.1.1.3&quot;,\r\n    &quot;1.1.1.4&quot;\r\n  ]\r\n}\r\n````\r\n\r\n`name1` as well as `name2` are valid json objects, but the output as a whole isn&#39;t.\r\n\r\nThe following `jq` statement results in the desired output as specified in the question:\r\n\r\n````jq\r\ngroup_by(.component) | map({ key: .[0].component, value: [.[] | .ip] }) | from_entries\r\n````\r\n\r\nOutput:\r\n\r\n````json\r\n{\r\n  &quot;name1&quot;: [\r\n    &quot;1.1.1.1&quot;,\r\n    &quot;1.1.1.2&quot;\r\n  ],\r\n  &quot;name2&quot;: [\r\n    &quot;1.1.1.3&quot;,\r\n    &quot;1.1.1.4&quot;\r\n  ]\r\n}\r\n````\r\n\r\nSuggestions for simpler approaches are welcome.\r\n\r\nIf human readability is preferred over valid json, I&#39;d suggest something like ...\r\n\r\n````bash\r\njq -r &#39;group_by(.component)[] | &quot;IPs for &quot; + .[0].component + &quot;: &quot; + (map(.ip) | tostring)&#39;\r\n````\r\n\r\n... which results in ...\r\n\r\n````\r\nIPs for name1: [&quot;1.1.1.1&quot;,&quot;1.1.1.2&quot;]\r\nIPs for name2: [&quot;1.1.1.3&quot;,&quot;1.1.1.4&quot;]\r\n````",
                "title": "jq: group and key by property"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1706555132,
                "creation_date": 1706555132,
                "answer_id": 77902050,
                "question_id": 43221453,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As an simpler alternative to yaccob&#39;s answer, you can just use the `add` operator to merge the list of JSON objects into a single object.\r\n\r\n```\r\njq &#39;[group_by(.component)[] | {(.[0].component): [.[] | .ip]}] | add&#39;\r\n```\r\n\r\nOutput:\r\n```\r\n{\r\n  &quot;name1&quot;: [\r\n    &quot;1.1.1.1&quot;,\r\n    &quot;1.1.1.2&quot;\r\n  ],\r\n  &quot;name2&quot;: [\r\n    &quot;1.1.1.3&quot;,\r\n    &quot;1.1.1.4&quot;\r\n  ]\r\n}\r\n```",
                "title": "jq: group and key by property"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 56,
        "last_activity_date": 1714680005,
        "creation_date": 1491364010,
        "last_edit_date": 1491974260,
        "question_id": 43221453,
        "body_markdown": "I have a list of objects that look like this:\r\n\r\n    [\r\n      {\r\n        &quot;ip&quot;: &quot;1.1.1.1&quot;,\r\n        &quot;component&quot;: &quot;name1&quot;\r\n      },\r\n      {\r\n        &quot;ip&quot;: &quot;1.1.1.2&quot;,\r\n        &quot;component&quot;: &quot;name1&quot;\r\n      },\r\n      {\r\n        &quot;ip&quot;: &quot;1.1.1.3&quot;,\r\n        &quot;component&quot;: &quot;name2&quot;\r\n      },\r\n      {\r\n        &quot;ip&quot;: &quot;1.1.1.4&quot;,\r\n        &quot;component&quot;: &quot;name2&quot;\r\n      }\r\n    ]\r\n\r\nNow I&#39;d like to group and key that by the component and assign a list of ips to each of the components:\r\n\r\n    {\r\n      &quot;name1&quot;: [\r\n        &quot;1.1.1.1&quot;,\r\n        &quot;1.1.1.2&quot;\r\n      ]\r\n    },{\r\n      &quot;name2&quot;: [\r\n        &quot;1.1.1.3&quot;,\r\n        &quot;1.1.1.4&quot;\r\n      ]\r\n    }",
        "link": "https://stackoverflow.com/questions/43221453/jq-group-and-key-by-property",
        "title": "jq: group and key by property"
    },
    {
        "tags": [
            "bash",
            "sed",
            "grep",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 233824,
                    "reputation": 47381,
                    "user_id": 499581,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/1ba2cebc4582467916f2ddd6128447f4?s=256&d=identicon&r=PG",
                    "display_name": "l&#39;L&#39;l",
                    "link": "https://stackoverflow.com/users/499581/lll"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1491395243,
                "post_id": 43231154,
                "comment_id": 73532177,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4203120,
                    "reputation": 11256,
                    "user_id": 4923629,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/2abZO.png?s=256",
                    "display_name": "123",
                    "link": "https://stackoverflow.com/users/4923629/123"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1491395263,
                "post_id": 43231154,
                "comment_id": 73532192,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 225921,
                    "reputation": 863,
                    "user_id": 486670,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f9ae30fae8a36dc3827269b98b6a6a51?s=256&d=identicon&r=PG",
                    "display_name": "keeer",
                    "link": "https://stackoverflow.com/users/486670/keeer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1491396625,
                "post_id": 43231154,
                "comment_id": 73533252,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2387472,
                    "reputation": 74949,
                    "user_id": 2088135,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://i.sstatic.net/YB10Q.jpg?s=256",
                    "display_name": "Tom Fenech",
                    "link": "https://stackoverflow.com/users/2088135/tom-fenech"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1491398373,
                "post_id": 43231154,
                "comment_id": 73534720,
                "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": 1491399664,
                "post_id": 43231154,
                "comment_id": 73535821,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 225921,
                    "reputation": 863,
                    "user_id": 486670,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f9ae30fae8a36dc3827269b98b6a6a51?s=256&d=identicon&r=PG",
                    "display_name": "keeer",
                    "link": "https://stackoverflow.com/users/486670/keeer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1491399670,
                "post_id": 43231154,
                "comment_id": 73535831,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1301452,
                    "reputation": 47599,
                    "user_id": 1331399,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4a22763d295c9d45db0dd0c692bb4051?s=256&d=identicon&r=PG",
                    "display_name": "Thor",
                    "link": "https://stackoverflow.com/users/1331399/thor"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1491400051,
                "post_id": 43231154,
                "comment_id": 73536146,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 225921,
                    "reputation": 863,
                    "user_id": 486670,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f9ae30fae8a36dc3827269b98b6a6a51?s=256&d=identicon&r=PG",
                    "display_name": "keeer",
                    "link": "https://stackoverflow.com/users/486670/keeer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1491400103,
                "post_id": 43231154,
                "comment_id": 73536189,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2387472,
                    "reputation": 74949,
                    "user_id": 2088135,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://i.sstatic.net/YB10Q.jpg?s=256",
                    "display_name": "Tom Fenech",
                    "link": "https://stackoverflow.com/users/2088135/tom-fenech"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1491400165,
                "post_id": 43231154,
                "comment_id": 73536246,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1491400296,
                "last_edit_date": 1491400296,
                "creation_date": 1491400123,
                "answer_id": 43233135,
                "question_id": 43231154,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here we are, ***jq*** approach:\r\n\r\nA valid json input should look like (let&#39;s say `test.json`):\r\n\r\n    [\r\n      {\r\n        &quot;team&quot;: &quot;veg&quot;,\r\n        &quot;food&quot;: &quot;raspberry&quot;\r\n      },\r\n      {\r\n        &quot;team&quot;: &quot;veg&quot;,\r\n        &quot;food&quot;: &quot;carrot&quot;\r\n      },\r\n      {\r\n        &quot;team&quot;: &quot;veg&quot;,\r\n        &quot;food&quot;: &quot;strawberry&quot;\r\n      }\r\n    ]\r\n\r\n\r\n----------\r\n\r\n    jq &#39;map(select(.food == &quot;strawberry&quot; or .food == &quot;raspberry&quot; or .food == &quot;apple&quot;).team |=&quot;fruit&quot;)&#39; test.json\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;team&quot;: &quot;fruit&quot;,\r\n        &quot;food&quot;: &quot;raspberry&quot;\r\n      },\r\n      {\r\n        &quot;team&quot;: &quot;veg&quot;,\r\n        &quot;food&quot;: &quot;carrot&quot;\r\n      },\r\n      {\r\n        &quot;team&quot;: &quot;fruit&quot;,\r\n        &quot;food&quot;: &quot;strawberry&quot;\r\n      }\r\n    ]\r\n\r\n&gt; `map(x)` For any filter *x*, *map(x)* will run that filter for each\r\n&gt; element of the input array, and return the outputs in a new array\r\n\r\n`|=&quot;fruit&quot;` - *update assignment*, https://stedolan.github.io/jq/manual/#Assignment\r\n",
                "title": "Conditional sed with a grep"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1491400853,
        "creation_date": 1491395132,
        "last_edit_date": 1491400853,
        "question_id": 43231154,
        "body_markdown": "I want to use [tag:sed] to conditionally change the **team** name to **fruit** if the **food** on the line below contains the word  \r\n`raspberry`  \r\n`strawberry`  \r\n`apple`    \r\nbut to leave it alone if the search isn&#39;t matched. An example of the file contents below:\r\n\r\n    {\r\n    &quot;team&quot;:&quot;veg&quot;,\r\n    &quot;food&quot;:&quot;raspberry&quot;,\r\n    },\r\n    {\r\n    &quot;team&quot;:&quot;veg&quot;,\r\n    &quot;food&quot;:&quot;carrot&quot;,\r\n    },\r\n    {\r\n    &quot;team&quot;:&quot;veg&quot;,\r\n    &quot;food&quot;:&quot;strawberry&quot;,\r\n    }\r\n\r\n\r\nHappy to use another tool if it&#39;s better suited :) I will be replacing the file (ideally), so will probably need sed with the -i flag.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/43231154/conditional-sed-with-a-grep",
        "title": "Conditional sed with a grep"
    },
    {
        "tags": [
            "bash",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1491406507,
                "last_edit_date": 1491406507,
                "creation_date": 1491405544,
                "answer_id": 43235337,
                "question_id": 43234692,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use Format Strings and Escaping together with String Interpolation (both section titles in the jq manual) in a map, followed by reduce:\r\n\r\n    jq -r &#39;\r\n      .form_data | \r\n      to_entries | \r\n      map(@uri &quot;\\(.key)=\\(.value)&quot;) | \r\n      reduce .[1:][] as $i (.[0]; .+&quot;&amp;&quot;+$i)\r\n    &#39;\r\n\r\n",
                "title": "Bash JQ FormData object to encoded parameters string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1491406507,
        "creation_date": 1491403940,
        "question_id": 43234692,
        "body_markdown": "I would like using the JQ command line to transform a FormData json object into a string like `id=johndoe&amp;password=secret&amp;foo=bar`\r\n\r\n\r\n     {\r\n          &quot;name&quot;: &quot;example&quot;,\r\n          &quot;auth_url&quot;: &quot;http://example.com/login&quot;,\r\n          &quot;form_data&quot;: {\r\n              &quot;id&quot;: &quot;johndoe&quot;,\r\n              &quot;password&quot;: &quot;secret&quot;,\r\n              &quot;foo&quot;: &quot;bar&quot;\r\n          }\r\n     }\r\n\r\nSo far, I came up with this function, which works, but doesn&#39;t look elegant or optimized\r\n\r\n    function form_data_to_encoded() {\r\n        local obj=$1\r\n        form_data_keys=$(echo $obj | jq &#39;.form_data | keys&#39;)\r\n        length=$(echo $form_data_keys | jq &#39;length&#39;)\r\n        encoded=&quot;&quot;\r\n        for ((i=0; i&lt;$length; i++)); do\r\n            key=$(echo &quot;$form_data_keys&quot; | jq --raw-output &quot;.[$i]&quot;)\r\n            value=$(echo &quot;$obj&quot; | jq --raw-output &quot;.form_data.$key&quot;)\r\n            encoded=&quot;$encoded$key=$value&quot;\r\n            if (( ((i+1)) &lt; &quot;$length&quot; )); then\r\n                encoded=&quot;$encoded&amp;&quot;\r\n            fi\r\n        done\r\n        echo &quot;$encoded&quot;\r\n    }\r\n\r\nIs there a way to create achieve this using only one (or fewer) JQ filter ?\r\nThanks for your help or insight :)\r\n",
        "link": "https://stackoverflow.com/questions/43234692/bash-jq-formdata-object-to-encoded-parameters-string",
        "title": "Bash JQ FormData object to encoded parameters string"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "membership",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 12,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1560800180,
                "last_edit_date": 1560800180,
                "creation_date": 1491493659,
                "answer_id": 43259947,
                "question_id": 43259563,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[WARNING: SEE THE COMMENTS AND ALTERNATIVE ANSWERS.]\r\n\r\n```\r\ncat fruit.json | jq &#39;.fruit | contains([&quot;orange&quot;])&#39;\r\n```",
                "title": "How to check if element exists in array with jq"
            },
            {
                "up_vote_count": 118,
                "is_accepted": true,
                "score": 118,
                "last_activity_date": 1748984109,
                "last_edit_date": 1748984109,
                "creation_date": 1491535585,
                "answer_id": 43269105,
                "question_id": 43259563,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The semantics of &#39;contains&#39; is not straightforward at all.  In general, it would be better to use &#39;index&#39; to test if an array has a specific value, e.g.\r\n\r\n    .fruit | index( &quot;orange&quot; )\r\n\r\nHowever, if the item of interest is itself an array, the general form:\r\n\r\n     ARRAY | index( [ITEM] )\r\n\r\nshould be used, e.g.:\r\n\r\n    [1, [2], 3] | index( [[2]] )  #=&gt; 1\r\n\r\n### IN/1\r\n\r\nIf your jq has `IN/1` then a better solution is to use it:\r\n\r\n    .fruit as $f | &quot;orange&quot; | IN($f[])\r\n\r\nIf your jq has `first/1` (as does jq 1.5), then here is a fast definition of `IN/1` to use:\r\n\r\n    def IN(s): first((s == .) // empty) // false;\r\n\r\n## `any(_;_)`\r\n\r\nAnother efficient alternative that is sometimes more convenient is to use `any/2`, e.g.\r\n\r\n    any(.fruit[]; . == &quot;orange&quot;)\r\n\r\nor equivalently:\r\n\r\n`any(.fruit[] == &quot;orange&quot;; .)`\r\n\r\n## WARNING regarding \\`in\\` \r\n\r\nIn a comment, someone suggested using \\`in\\`, but \\`in\\` has very different semantics compared to \\`IN\\`.  For example, consider that the following returns \\`true\\`:\r\n\r\n`jq -n &#39;1 | in([0,4])&#39;` ",
                "title": "How to check if element exists in array with jq"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1527180733,
                "last_edit_date": 1527180733,
                "creation_date": 1506606821,
                "answer_id": 46470951,
                "question_id": 43259563,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For future visitors, if you happen to have the array in a variable and want to check the *input* against it, and you have jq 1.5 (without IN), your best option is `index` but with a second variable:\r\n\r\n`.inputField as $inputValue | $storedArray|index($inputValue)`\r\n\r\nThis is functionally equivalent to `.inputField | IN($storedArray[])`.",
                "title": "How to check if element exists in array with jq"
            },
            {
                "up_vote_count": 31,
                "is_accepted": false,
                "score": 30,
                "last_activity_date": 1617584178,
                "last_edit_date": 1617584178,
                "creation_date": 1547035582,
                "answer_id": 54109775,
                "question_id": 43259563,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To have `jq` return success if the array `fruit` contains `&quot;apple&quot;`, and error otherwise:\r\n\r\n    jq -e &#39;.fruit|any(. == &quot;apple&quot;)&#39; fruit.json &gt;/dev/null\r\n\r\nTo output the element(s) found, change to\r\n\r\n    jq -e &#39;.fruit[]|select(. == &quot;apple&quot;)&#39; fruit.json\r\n\r\nIf searching for a fixed string, this isn&#39;t very relevant, but it might be if the `select` expression might match different values, e.g. if it&#39;s a regexp.\r\n\r\nTo output only distinct values, pass the results to `unique`.\r\n\r\n    jq &#39;[.fruit[]|select(match(&quot;^app&quot;))]|unique&#39; fruit.json\r\n\r\nwill search for all fruits starting with `app`, and output unique values. (Note that the original expression had to be wrapped in `[]` in order to be passed to `unique`.)",
                "title": "How to check if element exists in array with jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1630352589,
                "creation_date": 1630352589,
                "answer_id": 68989548,
                "question_id": 43259563,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Expanding on the answers here, If you need to **filter the array** of fruit **against another array** of fruit, you could do something like this:\r\n\r\n    cat food.json | jq &#39;[.fruit[] as $fruits | ([&quot;banana&quot;, &quot;apple&quot;] | contains([$fruits])) as $results | $fruits | select($results)]&#39;\r\n\r\nThis will return an array only containing &quot;apple&quot; in the above sample json.",
                "title": "How to check if element exists in array with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -3,
                "last_activity_date": 1647117732,
                "last_edit_date": 1647117732,
                "creation_date": 1636739348,
                "answer_id": 69947098,
                "question_id": 43259563,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This modified sample did worked here:\r\n\r\n`jq -r &#39;.fruit | index( &quot;orange&quot; )&#39; fruit.json | tail -n 1`\r\n\r\nIt gets only the last line of the output.\r\n\r\nIf it exist, it returns `0`.\r\nIf don&#39;t, it returns `null`.",
                "title": "How to check if element exists in array with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1744110407,
                "creation_date": 1744110407,
                "answer_id": 79561858,
                "question_id": 43259563,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "had a case where i needed to check this byt for multiple elements. seems like a perfect case for the `contains` function:\r\n\r\n```\r\n$ jq --args &#39;contains ($ARGS.positional)&#39; foobar bazbeq &lt;&lt;&lt; &#39;[&quot;foobar&quot;, &quot;bazbeq&quot;, &quot;xxx&quot;]&#39;\r\ntrue\r\n$ jq --args &#39;contains ($ARGS.positional)&#39; foobar bazbeq yyy &lt;&lt;&lt; &#39;[&quot;foobar&quot;, &quot;bazbeq&quot;, &quot;xxx&quot;]&#39;\r\nfalse\r\n```\r\n\r\nbut there&#39;s an issue: `contains` checks the containment also for strings. so you have to watch out for substrings:\r\n\r\n```\r\n$ jq --args &#39;contains ($ARGS.positional)&#39; foo baz &lt;&lt;&lt; &#39;[&quot;foobar&quot;, &quot;bazbeq&quot;, &quot;xxx&quot;]&#39;\r\ntrue\r\n```\r\n\r\nSolutions I came up with:\r\n\r\n# wrapper + contains\r\n\r\nJust wrap each elem in some &quot;delimiter&quot; - can be whatever\r\n\r\n```\r\n$ jq --args &#39;[.[] | &quot;#\\(.)#&quot;] | contains ([$ARGS.positional[] | &quot;#\\(.)#&quot;])&#39; foo bar baz beq &lt;&lt;&lt; &#39;[&quot;foobar&quot;, &quot;bazbeq&quot;, &quot;xxx&quot;]&#39;\r\nfalse\r\n$ jq --args &#39;[.[] | &quot;#\\(.)#&quot;] | contains ([$ARGS.positional[] | &quot;#\\(.)#&quot;])&#39; foobar bazbeq &lt;&lt;&lt; &#39;[&quot;foobar&quot;, &quot;bazbeq&quot;, &quot;xxx&quot;]&#39;\r\ntrue\r\n```\r\n\r\n# any + all\r\n\r\n```\r\n$ jq --args &#39;[$ARGS.positional[] as $X | [$X == .[]] | any] | all&#39; foo bar baz beq &lt;&lt;&lt; &#39;[&quot;foobar&quot;, &quot;bazbeq&quot;, &quot;xxx&quot;]&#39;\r\nfalse\r\n$ jq --args &#39;[$ARGS.positional[] as $X | [$X == .[]] | any] | all&#39; foobar bazbeq &lt;&lt;&lt; &#39;[&quot;foobar&quot;, &quot;bazbeq&quot;, &quot;xxx&quot;]&#39;                                              true\r\n```\r\n\r\n# index + all\r\n\r\n```\r\n$ jq --args &#39;[ . | index ($ARGS.positional[]) ] | all&#39; foo bar baz beq &lt;&lt;&lt; &#39;[&quot;foobar&quot;, &quot;bazbeq&quot; , &quot;xxx&quot;, &quot;yyy&quot;]&#39;\r\nfalse\r\n$ jq --args &#39;[ . | index ($ARGS.positional[]) ] | all&#39; foobar bazbeq &lt;&lt;&lt; &#39;[&quot;foobar&quot;, &quot;bazbeq&quot; , &quot;xxx&quot;, &quot;yyy&quot;]&#39;\r\ntrue\r\n```",
                "title": "How to check if element exists in array with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1744563352,
                "creation_date": 1744563352,
                "answer_id": 79571799,
                "question_id": 43259563,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Like mentioned in other answers, `contains` is a massive footgun. Here&#39;s why:\r\n\r\n```bash\r\n$ jq &#39;contains([&quot;bar&quot;])&#39; &lt;&lt;&lt;&#39;[&quot;foo&quot;]&#39;\r\nfalse\r\n\r\n$ jq &#39;contains([&quot;bar&quot;])&#39; &lt;&lt;&lt;&#39;[&quot;foo&quot;,&quot;bar&quot;]&#39;\r\ntrue\r\n\r\n$ jq &#39;contains([&quot;bar&quot;])&#39; &lt;&lt;&lt;&#39;[&quot;foo&quot;,&quot;barzzz&quot;]&#39;\r\ntrue\r\n```\r\n\r\nUnless you explicitly want the behavior above, prefer `index`:\r\n\r\n```bash\r\n$ jq &#39;index(&quot;bar&quot;)&#39; &lt;&lt;&lt;&#39;[&quot;foo&quot;]&#39;\r\nnull\r\n\r\n$ jq &#39;index(&quot;bar&quot;)&#39; &lt;&lt;&lt;&#39;[&quot;foo&quot;,&quot;bar&quot;]&#39;\r\n1\r\n\r\n$ jq &#39;index(&quot;bar&quot;)&#39; &lt;&lt;&lt;&#39;[&quot;foo&quot;,&quot;barzzz&quot;]&#39;\r\nnull\r\n```\r\n\r\nIn jq, `null` and `false` are considered falsy, while every other values are truthy. So you can easily use them inside conditions, like:\r\n\r\n```bash\r\n$ jq &#39;if index(&quot;foo&quot;) then true else false end&#39; &lt;&lt;&lt;&#39;[&quot;foo&quot;]&#39;\r\ntrue\r\n```",
                "title": "How to check if element exists in array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 8,
        "score": 79,
        "last_activity_date": 1748984109,
        "creation_date": 1491492701,
        "last_edit_date": 1491974143,
        "question_id": 43259563,
        "body_markdown": "I have an array and I need to check if elements exists in that array or to get that element from the array using \r\njq, **fruit.json**:\r\n\r\n    {\r\n        &quot;fruit&quot;: [\r\n            &quot;apple&quot;, \r\n            &quot;orange&quot;,\r\n            &quot;pomegranate&quot;,\r\n            &quot;apricot&quot;,\r\n            &quot;mango&quot;\r\n        ]\r\n    }\r\n\r\n\r\n    cat fruit.json | jq &#39;.fruit .apple&#39; \r\n\r\ndoes not work\r\n",
        "link": "https://stackoverflow.com/questions/43259563/how-to-check-if-element-exists-in-array-with-jq",
        "title": "How to check if element exists in array with jq"
    },
    {
        "tags": [
            "bash",
            "jq",
            "television"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1491637141,
                "post_id": 43291389,
                "comment_id": 73650220,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8148221,
                    "reputation": 8514,
                    "user_id": 6136214,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/f12e30845d0c23b2e12991ccf0e9e9bc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "agc",
                    "link": "https://stackoverflow.com/users/6136214/agc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1491643477,
                "post_id": 43291389,
                "comment_id": 73651823,
                "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": 1491690519,
                "post_id": 43291389,
                "comment_id": 73667414,
                "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": 1491691562,
                "post_id": 43291389,
                "comment_id": 73667648,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2696307,
                    "reputation": 1020,
                    "user_id": 2328273,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://www.gravatar.com/avatar/32f1434b9993745b80b2e3c3335d0a58?s=256&d=identicon&r=PG",
                    "display_name": "user2328273",
                    "link": "https://stackoverflow.com/users/2328273/user2328273"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1491763563,
                "post_id": 43291389,
                "comment_id": 73685805,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 66,
                "is_accepted": true,
                "score": 65,
                "last_activity_date": 1573208947,
                "last_edit_date": 1573208947,
                "creation_date": 1491651005,
                "answer_id": 43293515,
                "question_id": 43291389,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use separate variables with `read` : \r\n\r\n    read var1 var2 var3 &lt; &lt;(echo $(curl -s &#39;https://api.github.com/repos/torvalds/linux&#39; | \r\n         jq -r &#39;.id, .name, .full_name&#39;))\r\n    \r\n    echo &quot;id        : $var1&quot;\r\n    echo &quot;name      : $var2&quot;\r\n    echo &quot;full_name : $var3&quot;\r\n\r\nUsing array : \r\n\r\n    read -a arr &lt; &lt;(echo $(curl -s &#39;https://api.github.com/repos/torvalds/linux&#39; | \r\n         jq -r &#39;.id, .name, .full_name&#39;))\r\n    \r\n    echo &quot;id        : ${arr[0]}&quot;\r\n    echo &quot;name      : ${arr[1]}&quot;\r\n    echo &quot;full_name : ${arr[2]}&quot;\r\n\r\nAlso you can split [tag:jq] output with some character :\r\n\r\n    IFS=&#39;|&#39; read var1 var2 var3 var4 &lt; &lt;(curl &#39;......&#39; | jq -r &#39;.data | \r\n        map([.absoluteNumber, .airedEpisodeNumber, .episodeName, .overview] | \r\n        join(&quot;|&quot;)) | join(&quot;\\n&quot;)&#39;)\r\n\r\nOr use an array like :\r\n\r\n    set -f; IFS=&#39;|&#39; data=($(curl &#39;......&#39; | jq -r &#39;.data | \r\n        map([.absoluteNumber, .airedEpisodeNumber, .episodeName, .overview] | \r\n        join(&quot;|&quot;)) | join(&quot;\\n&quot;)&#39;)); set +f\r\n\r\n`absoluteNumber`, `airedEpisodeNumber`, `episodeName` &amp; `overview` are respectively `${data[0]}`, `${data[1]}`, `${data[2]}`, `${data[3]}`. `set -f` and `set +f` are used to respectively disable &amp; enable [globbing][1].\r\n\r\nFor the [tag:jq] part, all your required fields are mapped and delimited with a `&#39;|&#39;` character with `join(&quot;|&quot;)`\r\n\r\nIf your are using jq &lt; 1.5, you&#39;ll have to convert Number to String with `tostring` for each Number fields eg:\r\n\r\n    IFS=&#39;|&#39; read var1 var2 var3 var4 &lt; &lt;(curl &#39;......&#39; | jq -r &#39;.data | \r\n        map([.absoluteNumber|tostring, .airedEpisodeNumber|tostring, .episodeName, .overview] | \r\n        join(&quot;|&quot;)) | join(&quot;\\n&quot;)&#39;)\r\n\r\n\r\n  [1]: http://www.tldp.org/LDP/abs/html/globbingref.html\r\n\r\n\r\n",
                "title": "using jq to assign multiple output variables"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1491652619,
                "last_edit_date": 1491652619,
                "creation_date": 1491651120,
                "answer_id": 43293533,
                "question_id": 43291389,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "jq always produces a stream of zero or more values. For example, to produce the two values corresponding to &quot;episodeName&quot; and &quot;id&quot;&#39; you could write:\r\n\r\n    .data[] | ( .episodeName, .id )\r\n\r\nFor your purposes, it might be helpful to use the -c command-line option, to ensure each JSON output value is presented on a single line. You might also want to use the -r command-line option, which removes the outermost quotation marks from each output value that is a JSON string. \r\n\r\nFor further variations, please see the jq FAQ https://github.com/stedolan/jq/wiki/FAQ, e.g. the question:\r\n\r\n&gt; Q: How can a stream of JSON texts produced by jq be converted into a bash array of corresponding values?",
                "title": "using jq to assign multiple output variables"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1539187167,
                "last_edit_date": 1539187167,
                "creation_date": 1491652527,
                "answer_id": 43293784,
                "question_id": 43291389,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Experimental conversion of quoted OP input, (*tv.dat*), to a series of `bash` variables, (and an array).  The `jq` code is mostly borrowed from here and there, but I don&#39;t know how to get `jq` to unroll an array within an array, so the `sed` code does that, (that&#39;s only good for one level, but so are `bash` arrays):   \r\n\r\n    jq -r &quot;.[] | to_entries | map(\\&quot;DAT_\\(.key) \\(.value|tostring)\\&quot;) | .[]&quot; tv.dat | \r\n    while read a b ; do echo &quot;${a,,}=&#39;$b&#39;&quot; ; done |\r\n    sed -e &#39;/{.*}/s/&quot;\\([^&quot;]*\\)&quot;:/[\\1]=/g;y/{},/() /&#39; -e &quot;s/=&#39;(/=(/;s/)&#39;$/)/&quot;\r\n\r\nOutput:\r\n\r\n    dat_absolutenumber=&#39;51&#39;\r\n    dat_airedepisodenumber=&#39;6&#39;\r\n    dat_airedseason=&#39;4&#39;\r\n    dat_airedseasonid=&#39;680431&#39;\r\n    dat_dvdepisodenumber=&#39;6&#39;\r\n    dat_dvdseason=&#39;4&#39;\r\n    dat_episodename=&#39;We Will Rise&#39;\r\n    dat_firstaired=&#39;2017-03-15&#39;\r\n    dat_id=&#39;5939660&#39;\r\n    dat_language=([episodeName]=&quot;en&quot; [overview]=&quot;en&quot;)\r\n    dat_lastupdated=&#39;1490769062&#39;\r\n    dat_overview=&#39;Clarke and Roan must work together in hostile territory in order to deliver an invaluable asset to Abby and her team.&#39;\r\n",
                "title": "using jq to assign multiple output variables"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 43,
        "last_activity_date": 1573208947,
        "creation_date": 1491636401,
        "last_edit_date": 1491643649,
        "question_id": 43291389,
        "body_markdown": "I am trying to use `jq` to parse information from the [TVDB api][1]. I need to pull a couple of fields and assign the values to variables that I can continue to use in my `bash` script. I know I can easily assign the output to one variable through bash with `variable=&quot;$(command)&quot;` but I need the output to produce multiple variables and I don&#39;t want to make to use multiple commands.\r\n\r\nI read this documentation:\r\n\r\nhttps://stedolan.github.io/jq/manual/v1.5/#Advancedfeatures\r\n\r\nbut I don&#39;t know if this relevant to what I am trying to do.\r\n\r\n`jq &#39;.data&#39;` produces the following output:\r\n\r\n    [\r\n      {\r\n        &quot;absoluteNumber&quot;: 51,\r\n        &quot;airedEpisodeNumber&quot;: 6,\r\n        &quot;airedSeason&quot;: 4,\r\n        &quot;airedSeasonID&quot;: 680431,\r\n        &quot;dvdEpisodeNumber&quot;: 6,\r\n        &quot;dvdSeason&quot;: 4,\r\n        &quot;episodeName&quot;: &quot;We Will Rise&quot;,\r\n        &quot;firstAired&quot;: &quot;2017-03-15&quot;,\r\n        &quot;id&quot;: 5939660,\r\n        &quot;language&quot;: {\r\n          &quot;episodeName&quot;: &quot;en&quot;,\r\n          &quot;overview&quot;: &quot;en&quot;\r\n        },\r\n        &quot;lastUpdated&quot;: 1490769062,\r\n        &quot;overview&quot;: &quot;Clarke and Roan must work together in hostile territory in order to deliver an invaluable asset to Abby and her team.&quot;\r\n      }\r\n    ]\r\n\r\nI tried `jq &#39;.data | {episodeName:$name}&#39;` and `jq &#39;.data | .episodeName as $name&#39;` just to try and get one working. I don&#39;t understand the documentation or even if it&#39;s what I&#39;m looking for. Is there a way to do what I am trying to do?\r\n\r\n\r\n  [1]: https://api.thetvdb.com/swagger",
        "link": "https://stackoverflow.com/questions/43291389/using-jq-to-assign-multiple-output-variables",
        "title": "using jq to assign multiple output variables"
    },
    {
        "tags": [
            "json",
            "sorting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1491710368,
                "creation_date": 1491710368,
                "answer_id": 43302879,
                "question_id": 43300736,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Does this do what you want?\r\n\r\n    jq -r &#39;\r\n    def NameAndSeed(f): f | {nameRaw, &quot;teamSeed&quot; : (.teamSeed | tonumber)};\r\n    [ \r\n      .scoreboard[].games[]\r\n      | select(.bracketRound==&quot;First Round&quot; and .bracketRegion==&quot;EAST&quot;)\r\n      | NameAndSeed(.home), NameAndSeed(.away)\r\n    ]\r\n    | sort_by(.teamSeed) \r\n    | .[].nameRaw&#39;\r\n\r\nTo get sort_by to do what I think you want, I put the objects in an array and converted the teamSeed values to numbers.",
                "title": "jq - sorting value by a related value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1491866485,
                "last_edit_date": 1491866485,
                "creation_date": 1491803682,
                "answer_id": 43315855,
                "question_id": 43300736,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Given your data, the following filter:\r\n\r\n    [ .scoreboard[].games[]\r\n      | select(.bracketRound==&quot;First Round&quot; and .bracketRegion==&quot;EAST&quot;)\r\n      | (.home, .away) ]\r\n    | sort_by(.teamSeed | tonumber) \r\n    | .[]\r\n    | [.teamSeed, .nameRaw ]\r\n\r\nproduces:\r\n\r\n\r\n    [&quot;2&quot;,&quot;Duke&quot;]\r\n    [&quot;3&quot;,&quot;Baylor&quot;]\r\n    [&quot;6&quot;,&quot;SMU&quot;]\r\n    [&quot;7&quot;,&quot;South Carolina&quot;]\r\n    [&quot;10&quot;,&quot;Marquette&quot;]\r\n    [&quot;11&quot;,&quot;USC&quot;]\r\n    [&quot;14&quot;,&quot;New Mexico St.&quot;]\r\n    [&quot;15&quot;,&quot;Troy&quot;]\r\n\r\nIf you just want the &quot;nameRaw&quot; values, then replace the last line of the filter by: `| .nameRaw`\r\n\r\nNote that `tonumber` is required here as the seed values are given as strings.\r\n\r\n\r\n### Handling multiple top-level objects\r\n\r\nIn a comment, the OP gave a pastebin (https://pastebin.com/1eTAX4y3) consisting of two top-level objects each with a &quot;scoreboard&quot;.  Let us therefore consider the case of an arbitrary number of such objects.\r\n\r\nFor clarity, we begin by defining a function for selecting the home/away objects from a JSON object with &quot;scoreboard&quot;:\r\n\r\n    def games:\r\n      [.scoreboard[].games[]\r\n       | select(.bracketRound==&quot;First Round&quot; and .bracketRegion==&quot;EAST&quot;)\r\n       | (.home, .away) ] ;\r\n\r\nUsing the -s command-line option, we can ensure the JSON input is an array of objects.  The arrays produced by `games` can be combined using `add`:\r\n\r\n\r\n    map(games)\r\n    | add\r\n    | sort_by(.teamSeed | tonumber) \r\n    | .[]\r\n    | [.teamSeed, .nameRaw ]\r\n\r\nGiven the pastebin data, the invocation using the command-line options -s and -c options produces:\r\n\r\n    [&quot;1&quot;,&quot;Villanova&quot;]\r\n    [&quot;2&quot;,&quot;Duke&quot;]\r\n    [&quot;3&quot;,&quot;Baylor&quot;]\r\n    [&quot;4&quot;,&quot;Florida&quot;]\r\n    [&quot;5&quot;,&quot;Virginia&quot;]\r\n    [&quot;6&quot;,&quot;SMU&quot;]\r\n    [&quot;7&quot;,&quot;South Carolina&quot;]\r\n    [&quot;8&quot;,&quot;Wisconsin&quot;]\r\n    [&quot;9&quot;,&quot;Virginia Tech&quot;]\r\n    [&quot;10&quot;,&quot;Marquette&quot;]\r\n    [&quot;11&quot;,&quot;USC&quot;]\r\n    [&quot;12&quot;,&quot;UNCW&quot;]\r\n    [&quot;13&quot;,&quot;East Tenn. St.&quot;]\r\n    [&quot;14&quot;,&quot;New Mexico St.&quot;]\r\n    [&quot;15&quot;,&quot;Troy&quot;]\r\n    [&quot;16&quot;,&quot;Mt. St. Mary&#39;s&quot;]\r\n\r\n",
                "title": "jq - sorting value by a related value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1491866485,
        "creation_date": 1491688404,
        "last_edit_date": 1491809580,
        "question_id": 43300736,
        "body_markdown": "Basically I&#39;m just trying to make a list of NCAA March Madness teams sorted by their respective seeds.\r\n\r\nI&#39;m using the JSON file from http://data.ncaa.com/jsonp/scoreboard/basketball-men/d1/2017/03/17/scoreboard.html. It&#39;s actually JSONP, but I convert it to JSON before parsing through it using:\r\n\r\n    jq -s -R  &#39;.[1+index(&quot;(&quot;): rindex(&quot;)&quot;)] | fromjson&#39;\r\n\r\nPiping that into the following command I can generate a nice list of the teams:\r\n\r\n    jq -r &#39;.scoreboard[].games[] | select(.bracketRound==&quot;First Round&quot; and .bracketRegion==&quot;EAST&quot;) | .home,.away | .nameRaw&#39;\r\n\r\n...but I want them to be in order of their seed. I&#39;ve tried using sort and sort_by in various ways to no avail. I&#39;m out of ideas.",
        "link": "https://stackoverflow.com/questions/43300736/jq-sorting-value-by-a-related-value",
        "title": "jq - sorting value by a related value"
    },
    {
        "tags": [
            "json",
            "merge",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1491888429,
                "last_edit_date": 1491888429,
                "creation_date": 1491888099,
                "answer_id": 43337323,
                "question_id": 43337056,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "### Part 1\r\n\r\nThe following jq function combines an array of objects in the manner envisioned by the first part of the question.\r\n\r\n    # Given an array of objects, produce a single object with an array at\r\n    # every key, the array at each key, k, being formed from all the values at k.\r\n    def merge:\r\n      reduce .[] as $o ({}; reduce ($o|keys)[] as $key (.; .[$key] += $o[$key] ));\r\n\r\nWith this definition together with the line:\r\n\r\n    merge\r\n\r\nin a file, and with the example input modified to be a valid JSON array,\r\nthe result is:\r\n\r\n    {\r\n      &quot;1.NBT.B&quot;: [\r\n        {\r\n          &quot;id&quot;: 545\r\n        },\r\n        {\r\n          &quot;id&quot;: 546\r\n        },\r\n        {\r\n          &quot;id&quot;: 1281\r\n        },\r\n        {\r\n          &quot;id&quot;: 1077\r\n        }\r\n      ]\r\n    }\r\n\r\n### Part 2\r\n\r\nWith `merge` as defined above, the filter:\r\n\r\n    merge | with_entries( .value |= map(.id) )\r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;1.NBT.B&quot;: [\r\n        545,\r\n        546,\r\n        1281,\r\n        1077\r\n      ]\r\n    }",
                "title": "jq: How can I combine data from duplicate keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1491965196,
        "creation_date": 1491886515,
        "last_edit_date": 1491965196,
        "question_id": 43337056,
        "body_markdown": "I have a fairly complex JSON data structure that I&#39;ve managed to use jq to filter down to certain keys and their values.  I need to combine the results though, so duplicate keys have only one array of values.  \r\ne.g.\r\n\r\n         {\r\n        &quot;1.NBT.B&quot;: [\r\n          {\r\n            &quot;id&quot;: 545\r\n          },\r\n          {\r\n            &quot;id&quot;: 546\r\n           }\r\n        ]\r\n      },\r\n      {\r\n        &quot;1.NBT.B&quot;: [\r\n          {\r\n            &quot;id&quot;: 1281\r\n          },\r\n          {\r\n            &quot;id&quot;: 1077\r\n          }\r\n        ]\r\n      }\r\n    \r\n\r\nwould result in \r\n\r\n     {\r\n        &quot;1.NBT.B&quot;: [\r\n          {\r\n            &quot;id&quot;: 545\r\n          },\r\n          {\r\n            &quot;id&quot;: 546\r\n           },\r\n          {\r\n            &quot;id&quot;: 1281\r\n          },\r\n          {\r\n            &quot;id&quot;: 1077\r\n          }\r\n        ]\r\n      },\r\n    ...\r\n   \r\n\r\nor even better:\r\n\r\n    [{&quot;1.NBT.B&quot;: [545, 546, 1281, 1077]}, ...]\r\n\r\n I need to do it without having to put in the key (&quot;1.NBT.B&quot;) directly, since there are hundreds of these keys.  I think what has me most stuck is that the objects here aren&#39;t named -- the keys are not the same between objects.\r\n\r\nSomething like this only gives me the 2nd set of ids, completing skipping the first:\r\n\r\n    reduce .[] as $item ({}; . + $item)",
        "link": "https://stackoverflow.com/questions/43337056/jq-how-can-i-combine-data-from-duplicate-keys",
        "title": "jq: How can I combine data from duplicate keys"
    },
    {
        "tags": [
            "json",
            "nested",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1492032253,
                "creation_date": 1492032253,
                "answer_id": 43379886,
                "question_id": 43379692,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This does what you want but it doesn&#39;t return the data in an array, but it should be an easy modification:\r\n\r\nhttps://github.com/ilyash/show-struct\r\n\r\nyou can also check out this page:\r\nhttps://ilya-sher.org/2016/05/11/most-jq-you-will-ever-need/",
                "title": "Extract schema of nested JSON object"
            },
            {
                "up_vote_count": 13,
                "is_accepted": true,
                "score": 13,
                "last_activity_date": 1689482309,
                "last_edit_date": 1689482309,
                "creation_date": 1492032962,
                "answer_id": 43380040,
                "question_id": 43379692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input, the invocation:\r\n\r\n    jq &#39;leaf_paths | join(&quot;.&quot;)&#39;\r\n\r\nproduces:\r\n\r\n    &quot;name&quot;\r\n    &quot;age&quot;\r\n    &quot;visits.2017-01-25&quot;\r\n    &quot;visits.2016-07-26&quot;\r\n    &quot;visits.2016-01-24&quot;\r\n\r\nIf you want to include &quot;visits&quot;, use `paths`.  If you want the result as a JSON array, enclose the filter with square brackets: [ ... ]\r\n\r\nIf your input might include arrays, then unless you are using jq 1.6 or later, you will need to convert the integer indices to strings explicitly; also, since `leaf_paths` is now deprecated, you might want to use its def.  The result:\r\n\r\n    jq &#39;paths(scalars) | map(tostring) | join(&quot;.&quot;)&#39;\r\n\r\n\r\n### allpaths\r\n\r\nTo include paths to null, you could use `allpaths` defined as follows:\r\n\r\n    def allpaths:\r\n      def conditional_recurse(f):  def r: ., (select(.!=null) | f | r); r;\r\n      path(conditional_recurse(.[]?)) | select(length &gt; 0);\r\n\r\nExample:\r\n\r\n    {&quot;a&quot;: null, &quot;b&quot;: false} | allpaths | join(&quot;.&quot;)\r\n\r\nproduces:\r\n\r\n    &quot;a&quot;\r\n    &quot;b&quot;\r\n\r\n### all_leaf_paths\r\n\r\nAssuming jq version 1.5 or higher, we can get to `all_leaf_paths` by following the strategy used in builtin.jq, that is, by adding these definitions:\r\n\r\n    def allpaths(f):\r\n      . as $in | allpaths | select(. as $p|$in|getpath($p)|f);\r\n\r\n    def isscalar:\r\n      . == null or . == true or . == false or type == &quot;number&quot; or type == &quot;string&quot;;\r\n\r\n    def all_leaf_paths: allpaths(isscalar);\r\n\r\nExample:\r\n\r\n    {&quot;a&quot;: null, &quot;b&quot;: false, &quot;object&quot;:{&quot;x&quot;:0} } | all_leaf_paths | join(&quot;.&quot;)\r\n\r\nproduces:\r\n\r\n    &quot;a&quot;\r\n    &quot;b&quot;\r\n    &quot;object.x&quot;\r\n\r\n\r\n",
                "title": "Extract schema of nested JSON object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1564435365,
                "creation_date": 1564435365,
                "answer_id": 57261588,
                "question_id": 43379692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Some time ago, I wrote a structural-schema inference engine that\r\nproduces simple structural schemas that mirror the JSON documents under consideration,\r\ne.g. for the sample JSON given here, the inferred schema is:\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;string&quot;,\r\n  &quot;age&quot;: &quot;number&quot;,\r\n  &quot;visits&quot;: {\r\n    &quot;2017-01-25&quot;: &quot;number&quot;,\r\n    &quot;2016-07-26&quot;: &quot;number&quot;,\r\n    &quot;2016-01-24&quot;: &quot;number&quot;\r\n  }\r\n}\r\n```\r\n\r\nThis is not exactly the format requested in the original posting, but\r\nfor large collections of objects, it does provide a useful overview.\r\n\r\nMore importantly, there is now a complementary validator for\r\nchecking whether a collection of JSON documents matches a structural\r\nschema.  The validator checks against schemas written in\r\n[JESS][1] (JSON Extended Structural Schemas), a superset of the simple\r\nstructural schemas (SSS) produced by the schema inference engine .\r\n\r\n(The idea is that one can use the SSS as a starting point to add\r\nmore elaborate constraints, including recursive constraints,\r\nwithin-document referential integrity constraints, etc.)\r\n\r\nFor reference, here is how one the SSS for your sample.json\r\nwould be produced using the [&quot;schema&quot; module][2]:\r\n\r\n    jq &#39;include &quot;schema&quot;; schema&#39; source.json &gt; source.schema.json\r\n\r\nAnd to validate source.json against a SSS or ESS:\r\n\r\n    JESS --schema  source.schema.json  source.json\r\n\r\n\r\n  [1]: https://bitbucket.org/pkoppstein/jess/\r\n  [2]: https://gist.github.com/pkoppstein/a5abb4ebef3b0f72a6ed",
                "title": "Extract schema of nested JSON object"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 10,
        "last_activity_date": 1689482309,
        "creation_date": 1492031348,
        "last_edit_date": 1492062813,
        "question_id": 43379692,
        "body_markdown": "Let&#39;s assume this is the source json file:\r\n\r\n    {    \r\n        &quot;name&quot;: &quot;tom&quot;,\r\n        &quot;age&quot;: 12,\r\n        &quot;visits&quot;: {\r\n            &quot;2017-01-25&quot;: 3,\r\n            &quot;2016-07-26&quot;: 4,\r\n            &quot;2016-01-24&quot;: 1\r\n        }\r\n    }\r\n\r\nI want to get:\r\n\r\n    [\r\n      &quot;age&quot;,\r\n      &quot;name&quot;,\r\n      &quot;visits.2017-01-25&quot;,\r\n      &quot;visits.2016-07-26&quot;,\r\n      &quot;visits.2016-01-24&quot;\r\n    ]\r\n\r\nI am able to extract the keys using: `jq &#39;. | keys&#39; file.json`, but this skips nested fields. How to include those?\r\n",
        "link": "https://stackoverflow.com/questions/43379692/extract-schema-of-nested-json-object",
        "title": "Extract schema of nested JSON object"
    },
    {
        "tags": [
            "jq",
            "gnu-parallel"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1492077556,
                "post_id": 43389055,
                "comment_id": 73839251,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 96260,
                    "reputation": 15262,
                    "user_id": 261718,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://www.gravatar.com/avatar/f9005f9e68699af4039f6cb718f932dc?s=256&d=identicon&r=PG",
                    "display_name": "Drake Guan",
                    "link": "https://stackoverflow.com/users/261718/drake-guan"
                },
                "reply_to_user": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1492077915,
                "post_id": 43389055,
                "comment_id": 73839503,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1492077999,
                "post_id": 43389055,
                "comment_id": 73839571,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 96260,
                    "reputation": 15262,
                    "user_id": 261718,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://www.gravatar.com/avatar/f9005f9e68699af4039f6cb718f932dc?s=256&d=identicon&r=PG",
                    "display_name": "Drake Guan",
                    "link": "https://stackoverflow.com/users/261718/drake-guan"
                },
                "reply_to_user": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1492078373,
                "post_id": 43389055,
                "comment_id": 73839788,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1492078881,
                "post_id": 43389055,
                "comment_id": 73840072,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 96260,
                    "reputation": 15262,
                    "user_id": 261718,
                    "user_type": "registered",
                    "accept_rate": 74,
                    "profile_image": "https://www.gravatar.com/avatar/f9005f9e68699af4039f6cb718f932dc?s=256&d=identicon&r=PG",
                    "display_name": "Drake Guan",
                    "link": "https://stackoverflow.com/users/261718/drake-guan"
                },
                "reply_to_user": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1492091634,
                "post_id": 43389055,
                "comment_id": 73849329,
                "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": 1492094605,
                "post_id": 43389055,
                "comment_id": 73851581,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1492109879,
                "last_edit_date": 1492109879,
                "creation_date": 1492108048,
                "answer_id": 43399307,
                "question_id": 43389055,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "https://www.gnu.org/software/parallel/man.html#QUOTING says:\r\n\r\n&gt; Conclusion: To avoid dealing with the quoting problems it may be easier just to write a small script or a function (remember to `export -f` the function) and have GNU parallel call that.\r\n\r\nIn your case it will look like this:\r\n\r\n    doit() {\r\n      cat &quot;$1&quot; |\r\n        jq &#39;.responses[0] | {labelAnnotations: .labelAnnotations}&#39; &gt; &quot;$2&quot; \r\n    }\r\n    export -f doit\r\n\r\n    parallel doit {} output/{/} ::: input/*.json\r\n\r\nA nice thing about this is that you can test it:\r\n\r\n    doit input/foo1.json output/foo1.json\r\n\r\nAnd when that works, parallelizing it is trivial.\r\n\r\nIf you have newer version of GNU Parallel this should work, too:\r\n\r\n    parallel --results output/{/} -q jq &#39;.responses[0] | {labelAnnotations: .labelAnnotations}&#39; ::: input/*.json\r\n",
                "title": "Parallel executing of commands with pipe by GNU Parallel?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1492109879,
        "creation_date": 1492077306,
        "last_edit_date": 1492077793,
        "question_id": 43389055,
        "body_markdown": "Given a task with several commands combined by pipe:\r\n\r\n`cat input/file1.json | jq &#39;.responses[0] | {labelAnnotations: .labelAnnotations}&#39; &gt; output/file1.json`\r\n\r\nNow, there are thousands of input JSON files, and I like to leverage GNU Parallel to parallelize all process. How could I do that? Something like this?\r\n\r\n`parallel cat {} | jq &#39;...&#39; &gt; output/{./} ::: input/*.json`\r\n\r\nnote: It gets even more complicated if there is a pipe inside `jq`&#39;s filter...",
        "link": "https://stackoverflow.com/questions/43389055/parallel-executing-of-commands-with-pipe-by-gnu-parallel",
        "title": "Parallel executing of commands with pipe by GNU Parallel?"
    },
    {
        "tags": [
            "json",
            "aws-cli",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4496958,
                    "reputation": 53951,
                    "user_id": 4296747,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-muYS9LV5AoA/AAAAAAAAAAI/AAAAAAAACG4/KcTmlFyGWRI/s256-rj/photo.jpg",
                    "display_name": "Frederic Henri",
                    "link": "https://stackoverflow.com/users/4296747/frederic-henri"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1492101211,
                "post_id": 43397216,
                "comment_id": 73855798,
                "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": 1492105742,
                "post_id": 43397216,
                "comment_id": 73858121,
                "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": 1492126148,
                "post_id": 43397216,
                "comment_id": 73866949,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1492103644,
                "creation_date": 1492103644,
                "answer_id": 43398135,
                "question_id": 43397216,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;m quite new to JQ, but I feel like I have a solution here:\r\n\r\nhttps://jqplay.org/s/DljtxNX_72\r\n\r\n    select((.[0].Tags[1].Key) == &quot;hc-class&quot; and (.[0].Tags[1].Value) == &quot;staging-standalone&quot;)",
                "title": "Filter array with jq based on nested values"
            },
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1492126224,
                "last_edit_date": 1492126224,
                "creation_date": 1492106111,
                "answer_id": 43398788,
                "question_id": 43397216,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With the given input, the following filter produces the output as shown below:\r\n\r\n    .[] | select(any(.Tags[]; .Key == &quot;hc-class&quot; and .Value == &quot;staging-standalone&quot;))\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;PublicIpAddress&quot;: &quot;111.222.333.444&quot;,\r\n      &quot;PrivateIpAddress&quot;: &quot;555.666.777.888&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Value&quot;: &quot;staging99.blah.com&quot;,\r\n          &quot;Key&quot;: &quot;Name&quot;\r\n        },\r\n        {\r\n          &quot;Value&quot;: &quot;staging-standalone&quot;,\r\n          &quot;Key&quot;: &quot;hc-class&quot;\r\n        }\r\n      ]\r\n    }",
                "title": "Filter array with jq based on nested values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1492126224,
        "creation_date": 1492100277,
        "last_edit_date": 1492125362,
        "question_id": 43397216,
        "body_markdown": "I am writing some bash scripts to help automate the management of AWS resources. I am using `aws-cli` and `jq`, and so far things have been great.\r\n\r\nI am tagging my resources with custom tags. In certain circumstances I would like to filter a list of resources based on both `Key` and `Value` of the custom tag. But I am having trouble working out a succinct `jq` query to do it.\r\n\r\nSo, for example, if the (trimmed) JSON output for my ec2 instances is like:\r\n\r\n    [\r\n        {\r\n            &quot;PublicIpAddress&quot;: &quot;11.22.33.44&quot;,\r\n            &quot;PrivateIpAddress&quot;: &quot;55.66.77.88&quot;,\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Value&quot;: &quot;live199.blah.com&quot;,\r\n                    &quot;Key&quot;: &quot;Name&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;live-standalone&quot;,\r\n                    &quot;Key&quot;: &quot;hc-class&quot;\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n    [\r\n        {\r\n            &quot;PublicIpAddress&quot;: &quot;111.222.333.444&quot;,\r\n            &quot;PrivateIpAddress&quot;: &quot;555.666.777.888&quot;,\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Value&quot;: &quot;staging99.blah.com&quot;,\r\n                    &quot;Key&quot;: &quot;Name&quot;\r\n                },\r\n                {\r\n                    &quot;Value&quot;: &quot;staging-standalone&quot;,\r\n                    &quot;Key&quot;: &quot;hc-class&quot;\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n\r\n...and I need find the entry where `Tags.Key == &quot;hc-class&quot;` and `Tags.Value = &quot;staging-standalone&quot;`, how do I do it in a succinct way with `jq`?\r\n\r\nAny help greatly appreciated.",
        "link": "https://stackoverflow.com/questions/43397216/filter-array-with-jq-based-on-nested-values",
        "title": "Filter array with jq based on nested values"
    },
    {
        "tags": [
            "arrays",
            "json",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1492357062,
                "last_edit_date": 1492357062,
                "creation_date": 1492203789,
                "answer_id": 43419246,
                "question_id": 43418382,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following assumes that file1.json and file2.json contain valid JSON. You can convert the quasi-JSON to JSON using jq by running: `jq -n -f fileN.json`\r\n\r\n    def extend_arrays(o):\r\n      reduce keys[] as $k \r\n        (.; if (.[$k]|type) == &quot;array&quot; and (o[$k]|type == &quot;array&quot;)\r\n            then .[$k] += o[$k] else . end);\r\n\r\n    .field1 |= extend_arrays($second|.field1)\r\n\r\nWith these lines in the file program.jq, the invocation:\r\n\r\n    jq -c --argfile second file2.json -f program.jq file1.json \r\n\r\nproduces the required output:\r\n\r\n    {&quot;field1&quot;:{&quot;item1&quot;:0,&quot;array1&quot;:[0,0,0,1,1,1],&quot;array2&quot;:[0,0,1,1],&quot;array3&quot;:[0,1]},&quot;field2&quot;:{&quot;dummy&quot;:0}}",
                "title": "Merge every array of an sub-object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1492357062,
        "creation_date": 1492199797,
        "last_edit_date": 1492219577,
        "question_id": 43418382,
        "body_markdown": "I have the two following json files.\r\n\r\nfile1.json\r\n\r\n    {&quot;field1&quot;:{&quot;item1&quot;:0,&quot;array1&quot;:[0,0,0],&quot;array2&quot;:[0,0],&quot;array3&quot;:[0]},&quot;field2&quot;:{&quot;dummy&quot;:0}}\r\n\r\nfile2.json\r\n\r\n    {&quot;field1&quot;:{&quot;item1&quot;:1,&quot;array1&quot;:[1,1,1],&quot;array2&quot;:[1,1],&quot;array3&quot;:[1]},&quot;field2&quot;:{&quot;dummy&quot;:0}}\r\n\r\nI want to obtain this :\r\n\r\n    {&quot;field1&quot;:{&quot;item1&quot;:0,&quot;array1&quot;:[0,0,0,1,1,1],&quot;array2&quot;:[0,0,1,1],&quot;array3&quot;:[0,1]},&quot;field2&quot;:{&quot;dummy&quot;:0}}\r\n\r\nI am able to do it manually array by array but I would prefer a method to do it automatically for each array of field1. Does someone have a tip for me ?\r\n\r\nThanks a lot for your help !\r\n\r\n",
        "link": "https://stackoverflow.com/questions/43418382/merge-every-array-of-an-sub-object",
        "title": "Merge every array of an sub-object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1492255015,
                "creation_date": 1492255015,
                "answer_id": 43425383,
                "question_id": 43424542,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It can be because the 2nd nested array doesn&#39;t satisfy the condition \n\n    select(.type == &quot;type2&quot;)",
                "title": "Selecting from nested array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1492516033,
                "creation_date": 1492516033,
                "answer_id": 43471270,
                "question_id": 43424542,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I am quite new to `jq` so this is probably not an optimal solution.  \r\n\r\nIf you `map` the `select` onto the _records_ array instead, the surrounding object is not removed. For example:\r\n\r\n&lt;!-- language: lang-jq --&gt;\r\n\r\n_parse.jq_\r\n\r\n    [\r\n      .data[] | \r\n      {\r\n        id    : .id,\r\n        Item1 : .metadata.item1,\r\n        Name  : .records | map(select(.type == &quot;type2&quot;))[0].name\r\n      }\r\n    ]\r\n\r\nRun it like this:\r\n\r\n    jq -f parse.jq file.json\r\n\r\nOutput:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;001&quot;,\r\n        &quot;Item1&quot;: 1,\r\n        &quot;Name&quot;: &quot;type2&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;002&quot;,\r\n        &quot;Item1&quot;: 1,\r\n        &quot;Name&quot;: null\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;003&quot;,\r\n        &quot;Item1&quot;: null,\r\n        &quot;Name&quot;: &quot;type2&quot;\r\n      }\r\n    ]",
                "title": "Selecting from nested array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1492517231,
        "creation_date": 1492249320,
        "last_edit_date": 1492517231,
        "question_id": 43424542,
        "body_markdown": "Given this input\r\n\r\n    {\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;001&quot;,\r\n          &quot;metadata&quot;: {\r\n            &quot;item1&quot;: 1\r\n          },\r\n          &quot;records&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;name1&quot;,\r\n              &quot;type&quot;: &quot;type1&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;name2&quot;,\r\n              &quot;type&quot;: &quot;type2&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;002&quot;,\r\n          &quot;metadata&quot;: {\r\n            &quot;item1&quot;: 1\r\n          },\r\n          &quot;records&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;name1&quot;,\r\n              &quot;type&quot;: &quot;type1&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;003&quot;,\r\n          &quot;metadata&quot;: {},\t\r\n          &quot;records&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;name1&quot;,\r\n              &quot;type&quot;: &quot;type1&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;name2&quot;,\r\n              &quot;type&quot;: &quot;type2&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nI am trying to output this\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;001&quot;,\r\n        &quot;Item1&quot;: 1,\r\n        &quot;Name&quot;: &quot;name2&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;002&quot;,\r\n        &quot;Item1&quot;: 1,\r\n        &quot;Name&quot;: null\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;003&quot;,\r\n        &quot;Item1&quot;: null,\r\n        &quot;Name&quot;: &quot;name2&quot;\r\n      }\r\n    ]\r\n\r\nHowever using this \r\n\r\n    jq &#39;[.data[] | {id, &quot;Item1&quot;: .metadata.item1, &quot;Name&quot;: .records[] | select(.type == &quot;type2&quot;).name}]&#39;\r\n\r\njq query I am getting this \r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;001&quot;,\r\n        &quot;Item1&quot;: 1,\r\n        &quot;Name&quot;: &quot;name2&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;003&quot;,\r\n        &quot;Item1&quot;: null,\r\n        &quot;Name&quot;: &quot;name2&quot;\r\n      }\r\n    ]\r\n\r\nHow can I get the &#39;002&#39; id object to output as well? I have tried various if then else conditions statements but to no avail.",
        "link": "https://stackoverflow.com/questions/43424542/selecting-from-nested-array",
        "title": "Selecting from nested array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1492446404,
                "creation_date": 1492446404,
                "answer_id": 43455359,
                "question_id": 43454997,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use `select` to filter a specific document : \r\n\r\n    jq -r &#39;.last_run_uuid as $uuid | .builds[] | select(.packer_run_uuid == $uuid) | .artifact_id&#39; data.json\r\n\r\n",
                "title": "How to extract the string based on the value from another field?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1492458078,
                "last_edit_date": 1492458078,
                "creation_date": 1492446668,
                "answer_id": 43455428,
                "question_id": 43454997,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. The initial `.|` in your answer is not needed.\r\n\r\n2. Since the &quot;last_run_uuid&quot; key is at the top-level, it is worthwhile extracting its value first, as in the following filter:\r\n\r\n&lt;/&gt;\r\n\r\n    .[&quot;last_run_uuid&quot;] as $last \r\n    | .builds[]\r\n    | select( $last == .[&quot;packer_run_uuid&quot;] )\r\n    | .artifact_id\r\n\r\n3. Since in your case the key names are sufficiently ordinary, you can also write:\r\n\r\n&lt;/&gt;\r\n\r\n     .last_run_uuid as $last | .builds[] | select( $last == .packer_run_uuid) | .artifact_id\r\n\r\n4. If the schema of a large JSON document is uncertain, it may help to determine the &quot;implicit schema&quot; so that one can be confident in the correctness of a query.  Using the jq-defined schema inference engine available at [schema.jq][1]\r\n(see also [Issue 748][2]), the input given by the OP results in the following JSON schema:\r\n\r\n&lt;/&gt;\r\n\r\n    {\r\n      &quot;builds&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;string&quot;,\r\n          &quot;builder_type&quot;: &quot;string&quot;,\r\n          &quot;build_time&quot;: &quot;number&quot;,\r\n          &quot;files&quot;: &quot;null&quot;,\r\n          &quot;artifact_id&quot;: &quot;string&quot;,\r\n          &quot;packer_run_uuid&quot;: &quot;string&quot;\r\n        }\r\n      ],\r\n      &quot;last_run_uuid&quot;: &quot;string&quot;\r\n    }\r\n\r\n\r\n  [1]: https://gist.github.com/pkoppstein/a5abb4ebef3b0f72a6ed &quot;schema.jq&quot;\r\n  [2]: https://github.com/stedolan/jq/issues/748 &quot;this issue&quot;",
                "title": "How to extract the string based on the value from another field?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1523736852,
        "creation_date": 1492445021,
        "last_edit_date": 1523736852,
        "question_id": 43454997,
        "body_markdown": "Please consider the following JSON in `packer_manifest.json`:\r\n\r\n\r\n    {\r\n      &quot;builds&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;builder_type&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;build_time&quot;: 1490743286,\r\n          &quot;files&quot;: null,\r\n          &quot;artifact_id&quot;: &quot;us-east-1:ami-ae4af3b8&quot;,\r\n          &quot;packer_run_uuid&quot;: &quot;76afaf47-2ac2-8b50-da43-ea5bff541ae6&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;builder_type&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;build_time&quot;: 1490744203,\r\n          &quot;files&quot;: null,\r\n          &quot;artifact_id&quot;: &quot;us-east-1:ami-994ff68f&quot;,\r\n          &quot;packer_run_uuid&quot;: &quot;d5655333-4240-bbf5-8b08-94be7606536d&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;builder_type&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;build_time&quot;: 1490744956,\r\n          &quot;files&quot;: null,\r\n          &quot;artifact_id&quot;: &quot;us-east-1:ami-e241f8f4&quot;,\r\n          &quot;packer_run_uuid&quot;: &quot;5f7efb09-4b45-9239-ffe6-903a0aed26e4&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;builder_type&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;build_time&quot;: 1490745669,\r\n          &quot;files&quot;: null,\r\n          &quot;artifact_id&quot;: &quot;us-east-1:ami-4046ff56&quot;,\r\n          &quot;packer_run_uuid&quot;: &quot;69fd6d30-fdfd-6778-54ac-338abbea2d88&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;builder_type&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;build_time&quot;: 1490746077,\r\n          &quot;files&quot;: null,\r\n          &quot;artifact_id&quot;: &quot;us-east-1:ami-dc3b82ca&quot;,\r\n          &quot;packer_run_uuid&quot;: &quot;4c74241d-f7e2-bdad-6fa7-3fb84e56c9b3&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;builder_type&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;build_time&quot;: 1490806537,\r\n          &quot;files&quot;: null,\r\n          &quot;artifact_id&quot;: &quot;us-east-1:ami-2c4cf43a&quot;,\r\n          &quot;packer_run_uuid&quot;: &quot;afcbe826-1a0a-7042-35cb-3e3c2569b48b&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;builder_type&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;build_time&quot;: 1491921968,\r\n          &quot;files&quot;: null,\r\n          &quot;artifact_id&quot;: &quot;us-east-1:ami-69a8207f&quot;,\r\n          &quot;packer_run_uuid&quot;: &quot;57ad32f1-6291-7a60-5ee9-3bf46aacd288&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;builder_type&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;build_time&quot;: 1491940019,\r\n          &quot;files&quot;: null,\r\n          &quot;artifact_id&quot;: &quot;us-east-1:ami-035ad215&quot;,\r\n          &quot;packer_run_uuid&quot;: &quot;a0124439-8002-9d13-59bf-43fdcef6eb5e&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;builder_type&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;build_time&quot;: 1491940543,\r\n          &quot;files&quot;: null,\r\n          &quot;artifact_id&quot;: &quot;us-east-1:ami-7e5fd768&quot;,\r\n          &quot;packer_run_uuid&quot;: &quot;42a0f104-460f-789a-6a86-37ea6b9fbf93&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;builder_type&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;build_time&quot;: 1491941479,\r\n          &quot;files&quot;: null,\r\n          &quot;artifact_id&quot;: &quot;us-east-1:ami-0252da14&quot;,\r\n          &quot;packer_run_uuid&quot;: &quot;13fd9737-e41f-ce82-b991-b363fae971b5&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;builder_type&quot;: &quot;amazon-ebs&quot;,\r\n          &quot;build_time&quot;: 1492026265,\r\n          &quot;files&quot;: null,\r\n          &quot;artifact_id&quot;: &quot;us-east-1:ami-a3159eb2&quot;,\r\n          &quot;packer_run_uuid&quot;: &quot;83d55673-620e-05ee-2983-24cab0a009d5&quot;\r\n        }\r\n      ],\r\n      &quot;last_run_uuid&quot;: &quot;83d55673-620e-05ee-2983-24cab0a009d5&quot;\r\n    }\r\n\r\nI am trying to extract the string `us-east-1:ami-a3159eb2` only using `jq`.\r\n\r\nI would imagine I need to execute something like this:\r\n\r\n    jq -r &#39;. | .builds[].artifact_id(where &quot;packer_run_uuid&quot; == .last_run_uuid)&#39;\r\n",
        "link": "https://stackoverflow.com/questions/43454997/how-to-extract-the-string-based-on-the-value-from-another-field",
        "title": "How to extract the string based on the value from another field?"
    },
    {
        "tags": [
            "json",
            "ubuntu",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1492507719,
                "creation_date": 1492507719,
                "answer_id": 43468426,
                "question_id": 43466783,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    map( if .node ==  &quot;cp-phix-app-uat14.hcinternal.net:80&quot;\r\n         then .state = &quot;active&quot;\r\n         else .\r\n         end )",
                "title": "change json values using jq in ubuntu linux machine"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1492507719,
        "creation_date": 1492502508,
        "question_id": 43466783,
        "body_markdown": "I have a json file as example.json\r\n\r\n     [\r\n      {\r\n        &quot;node&quot;: &quot;cp-phix-app-uat14.hcinternal.net:80&quot;,\r\n        &quot;priority&quot;: 1,\r\n        &quot;state&quot;: &quot;draining&quot;,\r\n        &quot;weight&quot;: 1\r\n      },\r\n      {\r\n        &quot;node&quot;: &quot;cp-phix-app-uat13.hcinternal.net:80&quot;,\r\n        &quot;priority&quot;: 1,\r\n        &quot;state&quot;: &quot;active&quot;,\r\n        &quot;weight&quot;: 1\r\n      }\r\n    ]\r\n\r\n\r\nI want to make a query using jq where if my node key is &quot;cp-phix-app-uat14.hcinternal.net:80&quot; then put state as &quot;active&#39; so my output should be like :-\r\n\r\n     [\r\n      {\r\n        &quot;node&quot;: &quot;cp-phix-app-uat14.hcinternal.net:80&quot;,\r\n        &quot;priority&quot;: 1,\r\n        **&quot;state&quot;: &quot;active&quot;,**\r\n        &quot;weight&quot;: 1\r\n      },\r\n      {\r\n        &quot;node&quot;: &quot;cp-phix-app-uat13.hcinternal.net:80&quot;,\r\n        &quot;priority&quot;: 1,\r\n        &quot;state&quot;: &quot;active&quot;,\r\n        &quot;weight&quot;: 1\r\n      }\r\n    ]\r\n\r\n\r\nWhat query i can make.. i am using linux ubuntu machine.",
        "link": "https://stackoverflow.com/questions/43466783/change-json-values-using-jq-in-ubuntu-linux-machine",
        "title": "change json values using jq in ubuntu linux machine"
    },
    {
        "tags": [
            "json",
            "stream",
            "geojson",
            "jq",
            "bigdata"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1492523730,
                "last_edit_date": 1492523730,
                "creation_date": 1492513317,
                "answer_id": 43470380,
                "question_id": 43469103,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "An alternative solution could be for example:\r\n\r\n    jq &#39;.features |= map_values(.tippecanoe.minzoom = 13)&#39;\r\n\r\nTo test this, I created a sample JSON as\r\n\r\n    d = {&#39;features&#39;: [{&quot;type&quot;:&quot;Feature&quot;, &quot;properties&quot;:{&quot;FEATCODE&quot;: 15014}} for i in range(0,N)]}\r\n\r\nand inspected the execution time as a function of `N`. Interestingly, while the `map_values` approach seems to have linear complexity in `N`, `.features[].tippecanoe.minzoom = 13` exhibits quadratic behavior (already for N=50000, the former method finishes in about 0.8 seconds, while the latter needs around 47 seconds)\r\n\r\nAlternatively, one might just do it manually with, e.g., Python:\r\n\r\n    import json\r\n    import sys\r\n    \r\n    data = {}\r\n    with open(sys.argv[1], &#39;r&#39;) as F:\r\n        data = json.load(F)\r\n    \r\n    extra_item = {&quot;minzoom&quot; : 13}\r\n    for feature in data[&#39;features&#39;]:\r\n        feature[&quot;tippecanoe&quot;] = extra_item\r\n    \r\n    with open(sys.argv[2], &#39;w&#39;) as F:\r\n        F.write(json.dumps(data))",
                "title": "Process huge GEOJson file with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1492533324,
                "last_edit_date": 1492533324,
                "creation_date": 1492530119,
                "answer_id": 43476622,
                "question_id": 43469103,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In this case, `map` rather than `map_values` is far faster (*): \r\n\r\n    .features |= map(.tippecanoe.minzoom = 13)\r\n\r\nHowever, using this approach will still require enough RAM.\r\n\r\n\r\np.s. If you want to use jq to generate a large file for timing, consider:\r\n\r\n    def N: 1000000;\r\n\r\n    def data:\r\n       {&quot;features&quot;: [range(0;N) | {&quot;type&quot;:&quot;Feature&quot;, &quot;properties&quot;: {&quot;FEATCODE&quot;: 15014}}] };\r\n\r\n(*) Using `map`, 20s for 100MB, and approximately linear.\r\n    ",
                "title": "Process huge GEOJson file with jq"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1493006000,
                "last_edit_date": 1493006000,
                "creation_date": 1492665332,
                "answer_id": 43510749,
                "question_id": 43469103,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A one-pass jq-only approach may require more RAM than is available.  If that is the case, then a simple all-jq approach is shown below, together with a more economical approach based on using jq along with awk.\r\n\r\nThe two approaches are the same except for the reconstitution of the stream of objects into a single JSON document.  This step can be accomplished very economically using awk.\r\n\r\nIn both cases, the large JSON input file with objects of the required form is assumed to be named input.json.\r\n\r\n### jq-only\r\n\r\n    jq -c  &#39;.features[]&#39; input.json |\r\n        jq -c &#39;.tippecanoe.minzoom = 13&#39; |\r\n        jq -c -s &#39;{type: &quot;FeatureCollection&quot;, features: .}&#39;\r\n\r\n\r\n### jq and awk\r\n\r\n    jq -c &#39;.features[]&#39; input.json |\r\n       jq -c &#39;.tippecanoe.minzoom = 13&#39; | awk &#39;\r\n         BEGIN {print &quot;{\\&quot;type\\&quot;: \\&quot;FeatureCollection\\&quot;, \\&quot;features\\&quot;: [&quot;; }\r\n         NR==1 { print; next }\r\n               {print &quot;,&quot;; print}\r\n         END   {print &quot;] }&quot;;}&#39;\r\n\r\n### Performance comparison\r\n\r\nFor comparison, an input file with 10,000,000 objects in .features[] was used. Its size is about 1GB.\r\n\r\nu+s:\r\n\r\n    jq-only:              15m 15s\r\n    jq-awk:                7m 40s\r\n    jq one-pass using map: 6m 53s\r\n",
                "title": "Process huge GEOJson file with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1492889669,
                "creation_date": 1492889669,
                "answer_id": 43563750,
                "question_id": 43469103,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here, based on the work of @nicowilliams at GitHub, is a solution that uses the streaming parser available with jq.  The solution is very economical with memory, but is currently quite slow if the input is large.\r\n\r\nThe solution has two parts: a function for injecting the update into the stream produced using the --stream command-line option; and a function for converting the stream back to JSON in the original form.\r\n\r\n### Invocation:\r\n\r\n    jq -cnr --stream -f program.jq input.json\r\n\r\n\r\n### program.jq\r\n\r\n    # inject the given object into the stream produced from &quot;inputs&quot; with the --stream option\r\n    def inject(object):\r\n      [object|tostream] as $object\r\n      | 2\r\n      | truncate_stream(inputs)\r\n      | if (.[0]|length == 1) and length == 1\r\n        then $object[]\r\n        else .\r\n        end ;\r\n    \r\n    # Input: the object to be added\r\n    # Output: text\r\n    def output:\r\n      . as $object\r\n      | ( &quot;[&quot;,\r\n          foreach fromstream( inject($object) ) as $o\r\n            (0;\r\n             if .==0 then 1 else 2 end;\r\n             if .==1 then $o else &quot;,&quot;, $o end),\r\n          &quot;]&quot; ) ;\r\n    \r\n    {}\r\n    | .tippecanoe.minzoom = 13\r\n    | output\r\n\r\n### Generation of test data\r\n    def data(N):\r\n     {&quot;features&quot;:\r\n      [range(0;2) | {&quot;type&quot;:&quot;Feature&quot;, &quot;properties&quot;: {&quot;FEATCODE&quot;: 15014}}] };\r\n\r\n### Example output\r\nWith N=2:\r\n\r\n    [\r\n    {&quot;type&quot;:&quot;Feature&quot;,&quot;properties&quot;:{&quot;FEATCODE&quot;:15014},&quot;tippecanoe&quot;:{&quot;minzoom&quot;:13}}\r\n    ,\r\n    {&quot;type&quot;:&quot;Feature&quot;,&quot;properties&quot;:{&quot;FEATCODE&quot;:15014},&quot;tippecanoe&quot;:{&quot;minzoom&quot;:13}}\r\n    ]\r\n\r\n\r\n",
                "title": "Process huge GEOJson file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 3,
        "last_activity_date": 1653467432,
        "creation_date": 1492509637,
        "last_edit_date": 1653467432,
        "question_id": 43469103,
        "body_markdown": "Given a GEOJson file as follows:-\r\n\r\n    {\r\n      &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n      &quot;features&quot;: [\r\n       {\r\n         &quot;type&quot;: &quot;Feature&quot;,\r\n         &quot;properties&quot;: {\r\n         &quot;FEATCODE&quot;: 15014\r\n      },\r\n      &quot;geometry&quot;: {\r\n        &quot;type&quot;: &quot;Polygon&quot;,\r\n        &quot;coordinates&quot;: [\r\n         .....\r\n\r\n\r\nI want to end up with the following:-\r\n\r\n    {\r\n      &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n      &quot;features&quot;: [\r\n       {\r\n         &quot;tippecanoe&quot; : {&quot;minzoom&quot; : 13},\r\n         &quot;type&quot;: &quot;Feature&quot;,\r\n         &quot;properties&quot;: {\r\n         &quot;FEATCODE&quot;: 15014\r\n      },\r\n      &quot;geometry&quot;: {\r\n        &quot;type&quot;: &quot;Polygon&quot;,\r\n        &quot;coordinates&quot;: [\r\n         .....\r\n\r\nie. I have added the tippecanoe object to each feature in the array **features**\r\n\r\nI can make this work with:-\r\n\r\n     jq &#39;.features[].tippecanoe.minzoom = 13&#39; &lt;GEOJSON FILE&gt; &gt; &lt;OUTPUT FILE&gt;\r\n\r\nWhich is fine for small files. But processing a large file of 414Mb seems to take forever with the processor maxing out and nothing being written to the OUTPUT FILE\r\n\r\nReading further into jq it appears that the **--stream** command line parameter may help but I am completely confused as to how to use this for my purposes.\r\n\r\nI would be grateful for an example command line that serves my purposes along with an explanation as to what --stream is doing.",
        "link": "https://stackoverflow.com/questions/43469103/process-huge-geojson-file-with-jq",
        "title": "Process huge GEOJson file with jq"
    },
    {
        "tags": [
            "concatenation",
            "trim",
            "jq",
            "strip"
        ],
        "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": 1492555230,
                "post_id": 43475525,
                "comment_id": 74022617,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1492911271,
                "last_edit_date": 1492911271,
                "creation_date": 1492528286,
                "answer_id": 43475944,
                "question_id": 43475525,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Consider:\r\n\r\n    def trim: sub(&quot;^ *&quot;;&quot;&quot;) | sub(&quot; *$&quot;;&quot;&quot;);\r\n\r\nOr you could simply use: gsub(&quot;^\\\\s|\\\\s*$&quot;;&quot;&quot;)\r\n\r\nThere are other ways to trim a string but the above should get you started.",
                "title": "jq: How to Catenate an Array and Strip Spaces"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1492911271,
        "creation_date": 1492527180,
        "question_id": 43475525,
        "body_markdown": "The following `jq` command (Windows) successfully catenates all the &quot;text&quot; properties into one string replacing any spaces with a single space albeit in a roundabout way. Almost correct. What I really want is to first replace any leading or trailing space in &quot;text&quot;, then catenate all &quot;text&quot; properties. A difference being that embedded (non-leading, non-trailing) spaces must not be removed. How can this be done?\r\n\r\n    jq &quot;.segments[].words | map(.text?) | join(\\&quot;,\\&quot;) | gsub(\\&quot;[ ]\\&quot;; \\&quot;\\&quot;) | gsub(\\&quot;[,]\\&quot;; \\&quot; \\&quot;)&quot;",
        "link": "https://stackoverflow.com/questions/43475525/jq-how-to-catenate-an-array-and-strip-spaces",
        "title": "jq: How to Catenate an Array and Strip Spaces"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1492533937,
                "post_id": 43477830,
                "comment_id": 74010996,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1492533961,
                "post_id": 43477830,
                "comment_id": 74011016,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2126868,
                    "reputation": 2364,
                    "user_id": 1888770,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/af4152b4613ca7aff85cf9a140a135e8?s=256&d=identicon&r=PG",
                    "display_name": "Timmo",
                    "link": "https://stackoverflow.com/users/1888770/timmo"
                },
                "reply_to_user": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1492534058,
                "post_id": 43477830,
                "comment_id": 74011090,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1492539527,
                "last_edit_date": 1492539527,
                "creation_date": 1492534444,
                "answer_id": 43477995,
                "question_id": 43477830,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using AWK for your example:\r\n\r\n    irsend LIST lgtv &quot;&quot; | awk &#39;BEGIN{print &quot;[&quot;}{{printf(&quot;{&#39;&quot;&#39;&quot;&#39;code&#39;&quot;&#39;&quot;&#39; : &#39;&quot;&#39;&quot;&#39;%s&#39;&quot;&#39;&quot;&#39;, &#39;&quot;&#39;&quot;&#39;key&#39;&quot;&#39;&quot;&#39;, &#39;&quot;&#39;&quot;&#39;%s&#39;&quot;&#39;&quot;&#39;}\\n&quot;,$2,$3)}END{print &quot;]&quot;}&#39;\r\n\r\nThe crazy `&#39;&quot;&#39;&quot;&#39;` construct makes sure a `&#39;` is actually output. Using double quotes is easier (and JSONier):\r\n\r\n    irsend LIST lgtv &quot;&quot; | awk &#39;BEGIN{print &quot;[&quot;}{{printf(&quot;{\\&quot;code\\&quot; : \\&quot;%s\\&quot;, \\&quot;key\\&quot;, \\&quot;%s\\&quot;}\\n&quot;,$2,$3)}END{print &quot;]&quot;}&#39;\r\n\r\n",
                "title": "Bash Script - irsend LIST Output to JSON"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1493199251,
                "last_edit_date": 1493199251,
                "creation_date": 1492537687,
                "answer_id": 43478988,
                "question_id": 43477830,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The key here is the -R command-line option, which allows lines to be read one-at-a-time. With your input, the following invocation produces the results shown (truncated):\r\n\r\n    $ jq -c -R &#39;split(&quot; &quot;) | {code: .[1], key: .[2]}&#39; input.txt\r\n    {&quot;code&quot;:&quot;00000000000010ef&quot;,&quot;key&quot;:&quot;KEY_POWER&quot;}\r\n    {&quot;code&quot;:&quot;0000000000008877&quot;,&quot;key&quot;:&quot;KEY_1&quot;}\r\n    {&quot;code&quot;:&quot;00000000000048b7&quot;,&quot;key&quot;:&quot;KEY_2&quot;}\r\n\r\nYou might want to consider tokenizing the input string, e.g. if your jq has `splits/1`:\r\n\r\n    [splits(&quot; +&quot;)] | {code: .[1], key: .[2]}\r\n\r\nNotice that `splits/1` produces a stream, whereas `split/1` produces an array.\r\n\r\nIf you want the result as a single array, then you could pipe the above into `jq -s .`.",
                "title": "Bash Script - irsend LIST Output to JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1493199251,
        "creation_date": 1492533866,
        "last_edit_date": 1492536025,
        "question_id": 43477830,
        "body_markdown": "I have this command:\r\n\r\n    irsend LIST lgtv &quot;&quot;\r\n\r\nwhich outputs like this:\r\n\r\n    irsend: 00000000000010ef KEY_POWER\r\n    irsend: 0000000000008877 KEY_1\r\n    irsend: 00000000000048b7 KEY_2\r\n    irsend: 000000000000c837 KEY_3\r\n    irsend: 00000000000028d7 KEY_4\r\n    irsend: 000000000000a857 KEY_5\r\n    irsend: 0000000000006897 KEY_6\r\n    irsend: 000000000000e817 KEY_7\r\n    irsend: 00000000000018e7 KEY_8\r\n    irsend: 0000000000009867 KEY_9\r\n    irsend: 00000000000008f7 KEY_0\r\n\r\nHow do I grab each line and get the codes and key name and output them into JSON format?\r\n\r\nEG:\r\n\r\n    [\r\n        {&quot;code&quot;: &quot;00000000000010ef&quot;, &quot;key&quot;: &quot;KEY_POWER&quot; },\r\n        {&quot;code&quot;: &quot;0000000000008877&quot;, &quot;key&quot;: &quot;KEY_1&quot; },\r\n        {&quot;code&quot;: &quot;00000000000048b7&quot;, &quot;key&quot;: &quot;KEY_2&quot; }\r\n    ]",
        "link": "https://stackoverflow.com/questions/43477830/bash-script-irsend-list-output-to-json",
        "title": "Bash Script - irsend LIST Output to JSON"
    },
    {
        "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": 1492624558,
                "post_id": 43499236,
                "comment_id": 74060099,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2601686,
                    "reputation": 119,
                    "user_id": 2253884,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/46252129a04176b363707d048e629d24?s=256&d=identicon&r=PG",
                    "display_name": "user2253884",
                    "link": "https://stackoverflow.com/users/2253884/user2253884"
                },
                "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": 1492698846,
                "post_id": 43499236,
                "comment_id": 74098464,
                "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": 1492699314,
                "post_id": 43499236,
                "comment_id": 74098839,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503028759,
                "creation_date": 1503028759,
                "answer_id": 45748318,
                "question_id": 43499236,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It&#39;s hard to do much without some actual data but [this answer](https://stackoverflow.com/a/45704642/8379597) to [a similar question](https://stackoverflow.com/questions/26543318/parse-aws-cli-output-security-groups-with-jq) produces a report from the output of\r\n\r\n    aws ec2 describe-security-groups --group-ids sg-0000001 sg-0000002\r\n\r\nPerhaps it may be of help.\r\n",
                "title": "Converting AWS JSON output to CSV using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1503028759,
        "creation_date": 1492613611,
        "last_edit_date": 1492698726,
        "question_id": 43499236,
        "body_markdown": "I am working on a script to combine my AWS Security Groups and Instances so I can have a consolidated list that looks something like this, in Excel/CSV format:\r\n\r\n    Security Groups | Security Group Name | Instances | Rules | Source\r\n    SG1             | GroupName           | Instance1 | :80   | 0.0.0.0\\0\r\n                    |                     | Instance2 | :443  | 0.0.0.0\\0\r\n\r\nPlease note I am VERY new to jq, and really have just been fumbling in the dark.\r\n\r\nI use a series of API calls and jq to format my data, but my last string is formatted as flat json.\r\n\r\nMy script:\r\n\r\n    #!/bin/bash\r\n\r\n    ### Get ALL data for all Instances\r\n    all_instances=$(aws ec2 describe-instances \\\r\n    --query &#39;Reservations[].Instances[]&#39; \\\r\n    --profile dev)\r\n\r\n    ### Get Only the Instance ID&#39;s\r\n    instanceids=$(aws ec2 describe-instances \\\r\n    --query &#39;Reservations[].Instances[].InstanceId&#39; \\\r\n    --output text \\\r\n    --profile dev)\r\n\r\n    ### Get all data from Security Groups\r\n    all_securitygroups=&quot;$(aws ec2 describe-security-groups --profile dev)&quot;\r\n\r\n    ### Match the Instances to the SG&#39;s, and pull the IP Rules as well\r\n    for instance in $instanceids; do\r\n    instance_sgids=$(echo $all_instances|jq -r &quot;map(select(.InstanceId == \\&quot;$instance\\&quot;))[].SecurityGroups[].GroupId&quot;)\r\n      for sg in $instance_sgids; do\r\n        rules=$(echo $all_securitygroups|jq -r &quot;map(select(.[].GroupId == \\&quot;$sg\\&quot;))[]&quot; )\r\n\r\n    ### Convert that silly Json to beautiful csv...\r\n    newrules=$(echo $rules|jq --compact-output --raw-output &#39;{SGID: .[].GroupId, Description: .[].Description,Protocol: .[].IpPermissions[].IpProtocol, Port: .[].IpPermissions[].FromPort, CIDR: .[].IpPermissions[].IpRanges[].CidrIp} | flatten | @csv&#39;)\r\n    \r\n    #flattenrules=$(echo $rules|jq -r [{ .Description } + (IpPermissions[] | { FromPort } + (IpRanges[] | {CidrIp}))])\r\n    \r\n    echo &quot;SecurityGroup, Name, Port, Source&quot; &gt; ~/Documents/output.csv\r\n    echo &quot;$newrules&quot; | sort | uniq &gt;&gt; ~/Documents/output.csv\r\n\r\n      done\r\n    done\r\n\r\nThis gets me oh so close, but I just can&#39;t seem to figure the last leg out. I have the instance ID&#39;s, and now I have all of the SG information. My problem now finding a way to output it in the format I describe above...\r\n\r\n\r\nI know I am probably missing something simple, but would love if any of you jq/shell guru&#39;s could point me in the right direction. I&#39;ve seen other questions here that mention using Perl and other languages, but I would really like to keep this within jq/shell.\r\n\r\nThanks in advance!\r\n",
        "link": "https://stackoverflow.com/questions/43499236/converting-aws-json-output-to-csv-using-jq",
        "title": "Converting AWS JSON output to CSV using jq"
    },
    {
        "tags": [
            "json",
            "join",
            "merge",
            "concatenation",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1492625125,
                "creation_date": 1492625125,
                "answer_id": 43503067,
                "question_id": 43502877,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Group the pairs by key, then combine the values.\r\n\r\n    group_by(.key) | map({key:.[0].key,value:(map(.value) | join(&quot; &quot;))})",
                "title": "how to use jq to merge/join/concat values with the same key"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1492634509,
                "last_edit_date": 1492634509,
                "creation_date": 1492633567,
                "answer_id": 43505450,
                "question_id": 43502877,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For this type of problem, I prefer to avoid the overhead of sorting, and to guarantee that the ordering of the objects in the input is respected. \r\n \r\n\r\nHere&#39;s one approach that assumes the values associated with &quot;key&quot; and &quot;value&quot; are all strings (as is the case in the example).  This assumption makes it easy to avoid an inefficient lookup:\r\n\r\n    def merge_by_key(separator):\r\n      reduce .[] as $o\r\n        ({}; $o[&quot;key&quot;] as $k\r\n             | if .[$k] then .[$k] += (separator + $o[&quot;value&quot;])\r\n               else .[$k] = $o[&quot;value&quot;] end);\r\n\r\n    merge_by_key(&quot; &quot;) | to_entries\r\n\r\nOutput:\r\n\r\n    [{&quot;key&quot;:&quot;john&quot;,&quot;value&quot;:&quot;ontario toronto&quot;},\r\n     {&quot;key&quot;:&quot;ryan&quot;,&quot;value&quot;:&quot;chicago illinois&quot;}]\r\n\r\n\r\n### Generic solution\r\n\r\n    def merge_at_key(separator):\r\n      reduce .[] as $o\r\n        ([];\r\n         $o[&quot;key&quot;] as $k\r\n         | (map(.key) | index($k)) as $i\r\n         | if $i then (.[$i] | .value) += (separator + $o[&quot;value&quot;])\r\n           else . + [$o] end);\r\n\r\n",
                "title": "how to use jq to merge/join/concat values with the same key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1492634509,
        "creation_date": 1492624477,
        "question_id": 43502877,
        "body_markdown": "I need to aggregate values by key. Example JSON input is:\r\n\r\n    $ cat json | jq \r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;john&quot;,\r\n        &quot;value&quot;: &quot;ontario&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;ryan&quot;,\r\n        &quot;value&quot;: &quot;chicago&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;ryan&quot;,\r\n        &quot;value&quot;: &quot;illinois&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;john&quot;,\r\n        &quot;value&quot;: &quot;toronto&quot;\r\n      },\r\n    ]\r\n\r\n\r\nIs it possible and if so how to merge/join/concat values with the same key so that the result is:\r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;john&quot;,\r\n        &quot;value&quot;: &quot;toronto ontario&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;ryan&quot;,\r\n        &quot;value&quot;: &quot;illinois chicago&quot;\r\n      },\r\n    ]\r\n\r\nI am targetting JQ specifically because of its ease of use from cfengine.",
        "link": "https://stackoverflow.com/questions/43502877/how-to-use-jq-to-merge-join-concat-values-with-the-same-key",
        "title": "how to use jq to merge/join/concat values with the same key"
    },
    {
        "tags": [
            "arrays",
            "json",
            "csv",
            "elasticsearch",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1492628157,
                "creation_date": 1492628157,
                "answer_id": 43503932,
                "question_id": 43503155,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use `(....) + (....)` to create the array before piping to `@csv` : \r\n\r\n\tjq -r &#39;.buckets[] |\r\n\t    (.latest.hits.hits[]._source | [.&quot;is_external&quot;,.&quot;time_ms&quot;]) + \r\n\t    (.perf_QS_percentiles.values | [.&quot;80.0&quot;,.&quot;95.0&quot;]) | @csv&#39;",
                "title": "JQ Error for parsing multiple array objects in JSON to CSV jq: error (at &lt;stdin&gt;:734665): Cannot index array with string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1492638899,
        "creation_date": 1492625399,
        "last_edit_date": 1492638899,
        "question_id": 43503155,
        "body_markdown": "I have a JSON result from an ElasticSearch query that provides multiple objects in the JSON result. \r\n\r\n    {\r\n        &quot;buckets&quot;: [{\r\n            &quot;perf_SP_percentiles&quot;: {\r\n                &quot;values&quot;: {\r\n                    &quot;80.0&quot;: 0,\r\n                    &quot;95.0&quot;: 0\r\n                }\r\n            },\r\n            &quot;perf_QS_percentiles&quot;: {\r\n                &quot;values&quot;: {\r\n                    &quot;80.0&quot;: 12309620299487,\r\n                    &quot;95.0&quot;: 12309620299487\r\n                }\r\n            },\r\n            &quot;latest&quot;: {\r\n                &quot;hits&quot;: {\r\n                    &quot;total&quot;: 3256,\r\n                    &quot;max_score&quot;: null,\r\n                    &quot;hits&quot;: [{\r\n                        &quot;_source&quot;: {\r\n                            &quot;is_external&quot;: true,\r\n                            &quot;time_ms&quot;: 1492110000000\r\n                        },\r\n                        &quot;sort&quot;: [\r\n                            1492110000\r\n                        ]\r\n                    }]\r\n                }\r\n            }\r\n        }]\r\n    }\r\n    \r\n\r\nI wrote the following jq with help from others \r\n\r\n    jq -r &#39;.buckets[].latest.hits.hits[]._source | [.&quot;is_external&quot;,.&quot;time_ms&quot;] | @csv&#39;\r\n\r\nI need to add the perf_QS_Percentiles to the CSV but getting an error.\r\n\r\n    jq -r &#39;.buckets[].latest.hits.hits[]._source | [.&quot;is_external&quot;,.&quot;time_ms&quot;], .buckets[].perf_QS_percentiles.values | [.&quot;80.0&quot;,.&quot;95.0&quot;]  | @csv&#39;\r\n\r\nI am getting an error `jq: error (at &lt;stdin&gt;:734665): Cannot index array with string`. may be I am missing something here. I am reading the JQ manual https://stedolan.github.io/jq/manual/#Basicfilters to see how to parse different JSON objects in the array, but asking here as someone may be able to point out more easily. \r\n",
        "link": "https://stackoverflow.com/questions/43503155/jq-error-for-parsing-multiple-array-objects-in-json-to-csv-jq-error-at-stdin",
        "title": "JQ Error for parsing multiple array objects in JSON to CSV jq: error (at &lt;stdin&gt;:734665): Cannot index array with string"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 34,
                "is_accepted": false,
                "score": 34,
                "last_activity_date": 1683183722,
                "last_edit_date": 1683183722,
                "creation_date": 1492699038,
                "answer_id": 43522618,
                "question_id": 43522133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key (:-) is with_entries.  E.g., given a single object:\r\n\r\n    with_entries(if .key == &quot;veg&quot; then .key = &quot;fruit2&quot; else . end)\r\n\r\nIn your case, since you have an array of objects, you could wrap the above in `map( ... )`.\r\n\r\n---\r\nNote that if the original JSON object already has a key named &quot;fruit2&quot;, then the usual &quot;last-most wins&quot; rule applies, where in this case, &quot;last-most&quot; refers to the array of key-value pairs that is used to determine the final result (as per the def of `with_entries`).\r\n",
                "title": "Using jq how can I replace the name of a key with something else"
            },
            {
                "up_vote_count": 56,
                "is_accepted": true,
                "score": 55,
                "last_activity_date": 1553719764,
                "last_edit_date": 1553719764,
                "creation_date": 1492699300,
                "answer_id": 43522716,
                "question_id": 43522133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the following ***jq*** approach:\r\n\r\n    jq &#39;[.[] | .[&quot;fruit2&quot;] = .veg | .[&quot;job&quot;] = .worker | del(.veg, .worker)]&#39; file\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;fruit&quot;: &quot;strawberry&quot;,\r\n        &quot;fruit2&quot;: &quot;apple&quot;,\r\n        &quot;job&quot;: &quot;gardener&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "Using jq how can I replace the name of a key with something else"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1677629806,
                "creation_date": 1677629806,
                "answer_id": 75598521,
                "question_id": 43522133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For anyone looking to manipulate the `key` with a value from `value`:\r\n\r\n    $ echo &#39;{ &quot;foo&quot;: {&quot;id&quot;: 123}, &quot;bar&quot;: {&quot;id&quot;:456} }&#39;  | jq &#39;to_entries | map({key:(.key + &quot;-&quot; +(.value.id|tostring)), value:.value}) | from_entries&#39;\r\n\r\nIf there is a shorter way to do it (maybe using `with_entries`), I would be happy to know.",
                "title": "Using jq how can I replace the name of a key with something else"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1689370648,
                "creation_date": 1689370648,
                "answer_id": 76691247,
                "question_id": 43522133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s how to use [`if-then-else-end`](https://jqlang.github.io/jq/manual/#if-then-else-end) with `elif` to rename multiple keys:\r\n\r\n```jq\r\nmap(with_entries(.key |=\r\n  if . == &quot;fruit&quot;  then &quot;fruit2&quot;\r\nelif . == &quot;worker&quot; then &quot;job&quot;\r\nelse . end))\r\n```\r\n&lt;sup&gt;(jqplay [example][1])&lt;/sup&gt;\r\n\r\nNote in the current development branch / upcoming 1.7 release the empty `else` branch will be optional and could be removed, but it&#39;s still required in v1.6.\r\n\r\n\r\n  [1]: https://jqplay.org/s/4LgHVFT_sb-",
                "title": "Using jq how can I replace the name of a key with something else"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1690999955,
                "last_edit_date": 1690999955,
                "creation_date": 1690998822,
                "answer_id": 76822399,
                "question_id": 43522133,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;[.[] | { fruit2: .veg, other_key: .other_orig_key }]&#39;\r\n```\r\n\r\ncheck [this example](https://jqplay.org/s/gs9pLKloGWX)",
                "title": "Using jq how can I replace the name of a key with something else"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 52,
        "last_activity_date": 1738764659,
        "creation_date": 1492697877,
        "last_edit_date": 1738764659,
        "question_id": 43522133,
        "body_markdown": "This should be easy enough... I want to rename a few keys (ideally with jq`)`, whatever I do seems to error though. Here is a JSON example below:\r\n\r\n    $ cat fruitfile.json\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;fruit&quot;: &quot;strawberry&quot;,\r\n    &quot;veg&quot;: &quot;apple&quot;,\r\n    &quot;worker&quot;: &quot;gardener&quot;\r\n  }\r\n]\r\n```\r\n\r\nI&#39;d like to rename the `veg` key to `fruit2` (or example, whatever is easiest) and also the `worker` key to `job`.\r\n\r\nI realize this is possible in `sed`, but I&#39;m trying to get to grips with `jq`.",
        "link": "https://stackoverflow.com/questions/43522133/using-jq-how-can-i-replace-the-name-of-a-key-with-something-else",
        "title": "Using jq how can I replace the name of a key with something else"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1492833579,
                "last_edit_date": 1492833579,
                "creation_date": 1492797254,
                "answer_id": 43549148,
                "question_id": 43545806,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. There is a superfluous comma in the given input. The following assumes it has been removed.\r\n2. The requested output is not valid JSON, so the following assumes the intent is for the output to be an array of objects (as shown below).  Other output formats are of course possible, including the one given in the original posting.\r\n3. The following makes use of jq&#39;s &quot;map&quot; and &quot;reduce&quot; filters; please consult the jq documentation if you are unfamiliar with either of them.\r\n\r\n4. For clarity, the following solution uses a helper function to combine an array of values with an array of key names:\r\n\r\n        def convolve(headers):\r\n          . as $in\r\n          | reduce range(0; length) as $i ({}; . + {(headers[$i]): $in[$i]} );\r\n\r\n5. With `convolve/1` as defined, we can now create the array of objects:\r\n\r\n        .headers as $h | .rows | map( convolve($h) )\r\n \r\n6. With the above jq program in a file (say program.jq), and the JSON in a file named input.json, the invocation:\r\n\r\n        jq -f program.jq input.json\r\n\r\n produces:\r\n    \r\n        [\r\n          {\r\n            &quot;key1&quot;: &quot;value1&quot;,\r\n            &quot;key2&quot;: &quot;value2&quot;,\r\n            &quot;key3&quot;: &quot;value3&quot;\r\n          },\r\n          {\r\n            &quot;key1&quot;: &quot;value1&quot;,\r\n            &quot;key2&quot;: &quot;value2&quot;,\r\n            &quot;key3&quot;: &quot;value3&quot;\r\n          },\r\n          {\r\n            &quot;key1&quot;: &quot;value1&quot;,\r\n            &quot;key2&quot;: &quot;value2&quot;,\r\n            &quot;key3&quot;: &quot;value3&quot;\r\n          }\r\n        ]\r\n\r\n \r\n7.  Here is a reduce-free definition of `convolve`; it assumes the availability of `transpose/0`, which is included with jq 1.5 and above:\r\n\r\n        def convolve(headers):\r\n          [., headers] | transpose | map( {(.[0]): .[1]} ) | add;\r\n\r\n8. The following snippet is functionally equivalent to that shown in 5. above:\r\n\r\n        .headers as $h\r\n        | reduce .rows[] as $row ([]; . + [$row|convolve($h)])\r\n   \r\n \r\n\r\n",
                "title": "Map headers with values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1503026777,
                "creation_date": 1503026777,
                "answer_id": 45748038,
                "question_id": 43545806,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses a recursive function **obj** to build an object from arrays of keys and values.\r\n\r\n    def obj($keys; $values):\r\n        if   $keys|length &lt; 1\r\n        then {} \r\n        else {($keys[0]): $values[0]} + obj($keys[1:]; $values[1:])\r\n        end\r\n    ;\r\n\r\n    [ obj(.headers; .rows[]) ]",
                "title": "Map headers with values"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1503026777,
        "creation_date": 1492786401,
        "last_edit_date": 1492833657,
        "question_id": 43545806,
        "body_markdown": "I have a &quot;kind of JSON&quot; (I have no idea if this is a standard format) which I would like to parse with jq. I have tried a ton of variations but I can&#39;t get it to work with jq.\r\n\r\nThe &quot;JSON&quot; looks like this:\r\n\r\n    {\r\n       &quot;headers&quot; : [\r\n          &quot;key1&quot;,\r\n          &quot;key2&quot;,\r\n          &quot;key3&quot;,\r\n       ],\r\n       &quot;rows&quot; : [\r\n          [\r\n             &quot;value1&quot;,\r\n             &quot;value2&quot;,\r\n             &quot;value3&quot;\r\n          ],\r\n          [\r\n             &quot;value1&quot;,\r\n             &quot;value2&quot;,\r\n             &quot;value3&quot;\r\n          ],\r\n          [\r\n             &quot;value1&quot;,\r\n             &quot;value2&quot;,\r\n             &quot;value3&quot;\r\n          ]\r\n       ],\r\n       &quot;total_rows&quot; : &quot;3&quot;\r\n    }\r\n\r\nI would like to use the headers section as keys for each row. So the output should look like this:\r\n\r\n      [\r\n         &quot;key1&quot; : &quot;value1&quot;,\r\n         &quot;key2&quot; : &quot;value2&quot;,\r\n         &quot;key3&quot; : &quot;value3&quot;\r\n      ],\r\n      [\r\n         &quot;key1&quot; : &quot;value1&quot;,\r\n         &quot;key2&quot; : &quot;value2&quot;,\r\n         &quot;key3&quot; : &quot;value3&quot;\r\n      ],\r\n      [\r\n         &quot;key1&quot; : &quot;value1&quot;,\r\n         &quot;key2&quot; : &quot;value2&quot;,\r\n         &quot;key3&quot; : &quot;value3&quot;\r\n      ]\r\n",
        "link": "https://stackoverflow.com/questions/43545806/map-headers-with-values",
        "title": "Map headers with values"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1493034263,
                "last_edit_date": 1493034263,
                "creation_date": 1492796000,
                "answer_id": 43548813,
                "question_id": 43548387,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. There is a missing comma in Main.json\r\n\r\n2. After fixing the problem, the desired result can be obtained by using `+=`, which is analogous to += in other languages, but here uses addition of arrays in the sense of concatenation:\r\n\r\n&lt;/&gt;\r\n\r\n     .person += $sub.person\r\n\r\nHere it is assumed that $sub contains the JSON in Sub.json; assuming your jq supports the --argfile command-line option, this can be accomplished using the following invocation:\r\n\r\n    jq --argfile sub Sub.json &#39;.person += $sub.person&#39; Main.json\r\n\r\n3.\r\nIf your jq does not have the --argfile option, then one possibility would be to use the &quot;slurp&quot; (-s) option as follows:\r\n\r\n&lt;/&gt;\r\n\r\n     jq -s &#39;.[1] as $sub | .[0]|.person += $sub.person&#39;  Main.json Sub.json",
                "title": "Concatenate JSON object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1493034263,
        "creation_date": 1492794357,
        "last_edit_date": 1492794481,
        "question_id": 43548387,
        "body_markdown": "Hi is there a way to add object to json using jq\r\n\r\nMain.JSON\r\n\r\n    {\r\n            &quot;person&quot;:\r\n    \t\t[\r\n    \t\t\t{\r\n    \t\t\t&quot;name&quot;: &quot;John&quot;,\r\n    \t\t\t&quot;Age&quot;: 10\r\n    \t\t\t}\r\n    \t\t]\r\n    \t\t&quot;Work&quot;:\r\n    \t\t[\r\n    \t\t\t{\r\n    \t\t\t&quot;Type&quot;:&quot;HR&quot;\r\n    \t\t\t}\r\n    \t\t]\r\n    }\r\n\r\n\r\nSub.JSON\r\n\r\n    {\r\n            &quot;person&quot;:\r\n    \t\t[\r\n    \t\t\t{\r\n    \t\t\t&quot;name&quot;: &quot;smith&quot;,\r\n    \t\t\t&quot;Age&quot;: 20\r\n    \t\t\t}\r\n    \t\t]\r\n    }\r\n\r\nUsing Jq how to add sub person to the main Json so that desired output is\r\n\r\n    {\r\n    \t&quot;person&quot;: [{\r\n    \t\t\t&quot;name&quot;: &quot;John&quot;,\r\n    \t\t\t&quot;Age&quot;: 10\r\n    \t\t},\r\n    \t\t{\r\n    \t\t\t&quot;name&quot;: &quot;smith&quot;,\r\n    \t\t\t&quot;Age&quot;: 20\r\n    \t\t}\r\n    \t],\r\n    \t&quot;Work&quot;: [{\r\n    \t\t&quot;Type&quot;: &quot;HR&quot;\r\n    \t}]\r\n    }\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/43548387/concatenate-json-object-using-jq",
        "title": "Concatenate JSON object using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1492830414,
                "post_id": 43553348,
                "comment_id": 74161528,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1492816706,
                "creation_date": 1492816706,
                "answer_id": 43553367,
                "question_id": 43553348,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to *pipe* the output of `.[]` into the next filter.\r\n\r\n    jq -r &#39;.[] | .success.username&#39; tmp.json",
                "title": "I cannot get jq to give me the value I&#39;m looking for."
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1492866425,
                "last_edit_date": 1495541916,
                "creation_date": 1492816935,
                "answer_id": 43553398,
                "question_id": 43553348,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**tl;dr**\r\n\r\n    # Extract .success.username from ALL array elements.\r\n    # .[] enumerates all array elements\r\n    # -r produces raw (unquoted) output\r\n    jq -r &#39;.[].success.username&#39; file.json\r\n\r\n    # Extract .success.username only from the 1st array element.\r\n    jq -r &#39;.[0].success.username&#39; file.json\r\n\r\n\r\n----------\r\n\r\n**Your input is an _array_, so in order to access its _elements_ you need `.[]`**, the [array/object-value iterator](https://stedolan.github.io/jq/manual/#Basicfilters) (as the name suggests, it can also enumerate the *properties* of an *object*):\r\n\r\nJust `. |` sends the input (`.`) array _as a whole_ through the pipeline, and an array only has _numerical_ indices, so the attempt to index (access) it with `.success.username` fails.\r\n\r\nThus, simply replacing `. |` with `.[] |` in your original attempt, combined with `-r` to get _raw_ (unquoted output), should solve your problem, as shown in [chepner&#39;s helpful answer](https://stackoverflow.com/a/43553367/45375).\r\n\r\nHowever, [peak](https://stackoverflow.com/users/997358/peak) points out that since at least `jq 1.3` (current as of this writing is `jq 1.5`) you don&#39;t strictly need a _pipeline_, as demonstrated in the commands at the top.   \r\nSo the 2nd command in your question _should_ work with your sample input, unless you&#39;re using an older version.\r\n",
                "title": "I cannot get jq to give me the value I&#39;m looking for."
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1492866425,
        "creation_date": 1492816554,
        "last_edit_date": 1495539193,
        "question_id": 43553348,
        "body_markdown": "I&#39;m trying to use jq to get a value from the JSON that cURL returns. \r\n\r\nThis is the JSON cURL passes to jq (and, FTR, I want jq to return &quot;VALUE-I-WANT&quot; without the quotation marks):\r\n\r\n    [  \r\n       {  \r\n          &quot;success&quot;:{  \r\n             &quot;username&quot;:&quot;VALUE-I-WANT&quot;\r\n          }\r\n       }\r\n    ]\r\n\r\nI initially tried this:\r\n\r\n    jq &#39; . | .success | .username&#39;\r\nand got\r\n\r\n    jq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;success&quot;\r\n\r\nI then tried a bunch of variations, with no luck.\r\n\r\nWith a bunch of searching the web, I found [this SE entry][1], and thought it might have been my saviour (spoiler, it wasn&#39;t). But it led me to try these:\r\n\r\n    jq -r &#39;.[].success.username&#39;\r\n    jq -r &#39;.[].success&#39;\r\n\r\nThey didn&#39;t return an error, they returned &quot;null&quot;. Which may or may not be an improvement. \r\n\r\nCan anybody tell me what I&#39;m doing wrong here? And why it&#39;s wrong?  \r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/34543829/jq-cannot-index-array-with-string\r\n",
        "link": "https://stackoverflow.com/questions/43553348/i-cannot-get-jq-to-give-me-the-value-im-looking-for",
        "title": "I cannot get jq to give me the value I&#39;m looking for."
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1493166835,
                "last_edit_date": 1493166835,
                "creation_date": 1493059810,
                "answer_id": 43595635,
                "question_id": 43588044,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The trick here is to define a helper function:\r\n\r\n    # Given a part, extract the desired bits and the sum of the lengths:\r\n    def part: \r\n      { (.serialnumber):\r\n          {position_in,\r\n           duplicate,\r\n           last: (.positions | map(.length) | add) }};\r\n\r\nNow we can essentially write down what we want declaratively:\r\n\r\n    { (.serialnumber): { duplicate, &quot;parts&quot;: (.parts | map(part) ) } }\r\n\r\n### Output\r\nWith your data in sample.json, and the above in a file named program.jq, the invocation:\r\n\r\n     jq -f program.jq sample.json\r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;5690&quot;: {\r\n        &quot;duplicate&quot;: true,\r\n        &quot;parts&quot;: [\r\n          {\r\n            &quot;43&quot;: {\r\n              &quot;position_in&quot;: true,\r\n              &quot;duplicate&quot;: true,\r\n              &quot;last&quot;: 6\r\n            }\r\n          },\r\n          {\r\n            &quot;745&quot;: {\r\n              &quot;position_in&quot;: true,\r\n              &quot;duplicate&quot;: false,\r\n              &quot;last&quot;: 10\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\n",
                "title": "json transformations using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1493166835,
        "creation_date": 1493036740,
        "last_edit_date": 1493047266,
        "question_id": 43588044,
        "body_markdown": "I have many JSON objects, which look like below, and what I would like to do, is transform each object, where apart from the small adjustments, the node named last, adds the length nodes, so as in the end, we have the sum of lengths, for each part:\r\n\r\nInput sample JSON object       \r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    { \r\n        &quot;serialnumber&quot;: &quot;5690&quot;,\r\n        &quot;duplicate&quot;: true,\r\n        &quot;parts&quot;: [\r\n            {\r\n                &quot;serialnumber&quot;: &quot;43&quot;,\r\n                &quot;position_in&quot;: true,\r\n                &quot;duplicate&quot;: true,\r\n                &quot;positions&quot;: [\r\n                    {\r\n                        &quot;self&quot;: 0,\r\n                        &quot;length&quot;: 3\r\n                    },\r\n                    {\r\n                        &quot;self&quot;: 4,\r\n                        &quot;length&quot;: 1\r\n                    },\r\n                    {\r\n                        &quot;self&quot;: 5,\r\n                        &quot;length&quot;: 2\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;serialnumber&quot;: &quot;745&quot;,\r\n                &quot;position_in&quot;: true,\r\n                &quot;duplicate&quot;: false,\r\n                &quot;positions&quot;: [\r\n                    {\r\n                        &quot;self&quot;: 0,\r\n                        &quot;length&quot;: 8\r\n                    },\r\n                    {\r\n                        &quot;self&quot;: 8,\r\n                        &quot;length&quot;: 1\r\n                    },\r\n                    {\r\n                        &quot;self&quot;: 9,\r\n                        &quot;length&quot;: 1\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\r\nDesired JSON output:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    {\r\n        &quot;5690&quot;: {\r\n            &quot;duplicate&quot;: true,\r\n            &quot;parts&quot;: {\r\n                &quot;43&quot;: {\r\n                    &quot;position_in&quot;: true,\r\n                    &quot;duplicate&quot;: true,\r\n                    &quot;last&quot;: &quot;7&quot;\r\n                },\r\n                &quot;745&quot;: {\r\n                    &quot;position_in&quot;: true,\r\n                    &quot;duplicate&quot;: false,\r\n                    &quot;last&quot;: &quot;10&quot;\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\nHow would you achieve the desired result, using jq, and the + operator?",
        "link": "https://stackoverflow.com/questions/43588044/json-transformations-using-jq",
        "title": "json transformations using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1493065961,
                "post_id": 43594976,
                "comment_id": 74244695,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1493127439,
                "last_edit_date": 1493127439,
                "creation_date": 1493115304,
                "answer_id": 43607832,
                "question_id": 43594976,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you are just interested in line-number and length, I would use `awk` instead, e.g.:\r\n\r\n    awk &#39;{ print NR, length, $0 }&#39; traffictest.json\r\n\r\nOr if you want to keep the syntax highlighting:\r\n\r\n    paste &lt;(jq    . traffictest.json | awk &#39;{ print NR, length }&#39; OFS=&#39;\\t&#39;) \\\r\n          &lt;(jq -C . traffictest.json)",
                "title": "How do I print line number with the output for JQ in json file"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1499739610,
                "creation_date": 1499739610,
                "answer_id": 45024316,
                "question_id": 43594976,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "jq has a built-in filter, `input_line_number`, which emits the line number of the input being read.  For example, given this input:\r\n\r\n    [1,2]\r\n\r\n    &quot;abcd&quot;\r\n\r\n    {&quot;a&quot;:1,&quot;b&quot;:1,&quot;c&quot;:1,&quot;d&quot;:1, &quot;e&quot;:1}\r\n\r\nthe invocation:\r\n\r\n    jq -r &quot;\\(input_line_number): \\(length)&quot; \r\n\r\nyields:\r\n\r\n    1: 2\r\n    3: 4\r\n    5: 5\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "How do I print line number with the output for JQ in json file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1499739610,
        "creation_date": 1493057338,
        "last_edit_date": 1493115203,
        "question_id": 43594976,
        "body_markdown": "I know there is a -n option and tried many combinations but couldn&#39;t get it to work. I&#39;d like to print the line number and the length of the each line for the json file\r\n\r\n    cat -n traffictest.json | jq &#39;. |length&#39;\r\n\r\n    jq -C . | cat -n traffictest.json | jq &#39;. |length&#39;",
        "link": "https://stackoverflow.com/questions/43594976/how-do-i-print-line-number-with-the-output-for-jq-in-json-file",
        "title": "How do I print line number with the output for JQ in json file"
    },
    {
        "tags": [
            "json",
            "bash",
            "grep",
            "jq",
            "pathname"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1493058651,
                "creation_date": 1493058651,
                "answer_id": 43595321,
                "question_id": 43595121,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In your case, `sub(&quot;.*/&quot;;&quot;&quot;)` will do the trick as * is greedy:\r\n\r\n    .[].networkProfile.networkInterfaces[].id | sub(&quot;.*/&quot;;&quot;&quot;)",
                "title": "Linux CLI - How to get substring from JSON jq + grep?"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1493128450,
                "last_edit_date": 1493128450,
                "creation_date": 1493058885,
                "answer_id": 43595378,
                "question_id": 43595121,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this:\r\n\r\n    jq -r &#39;.[]|.networkProfile.networkInterfaces[].id | split(&quot;/&quot;) | last&#39;\r\n\r\nThe `-r` tells JQ to print the output in &quot;raw&quot; form - in this case, that means no double-quotes around the string value.\r\n\r\nAs for the `jq` expression, after you access the `id` you want, piping it (still inside `jq`) through `split(&quot;/&quot;)` turns it into an array of the parts between slashes. Piping that through the `last` function (thanks, @Thor) returns just the last element of the array.",
                "title": "Linux CLI - How to get substring from JSON jq + grep?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1493114789,
                "creation_date": 1493114789,
                "answer_id": 43607627,
                "question_id": 43595121,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you want to do it with `grep` here is one way:\r\n\r\n    jq -r &#39;.[].networkProfile.networkInterfaces[].id&#39; | grep -o &#39;[^/]*$&#39;\r\n\r\nOutput:\r\n\r\n    A10NICvw4konls2vfbw-data",
                "title": "Linux CLI - How to get substring from JSON jq + grep?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 11,
        "last_activity_date": 1493128450,
        "creation_date": 1493057912,
        "last_edit_date": 1493118744,
        "question_id": 43595121,
        "body_markdown": "I need to pull a substring from JSON.  In the JSON doc below, I need the end of the value of `jq &#39;.[].networkProfile.networkInterfaces[].id&#39;`  In other words, I need just `A10NICvw4konls2vfbw-data` to pass to another command.  I can&#39;t seem to figure out how to pull a substring using grep.  I&#39;ve seem regex examples out there but haven&#39;t been successful with them.\r\n\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;/subscriptions/blah/resourceGroups/IPv6v2/providers/Microsoft.Compute/virtualMachines/A10VNAvw4konls2vfbw&quot;,\r\n        &quot;instanceView&quot;: null,\r\n        &quot;licenseType&quot;: null,\r\n        &quot;location&quot;: &quot;centralus&quot;,\r\n        &quot;name&quot;: &quot;A10VNAvw4konls2vfbw&quot;,\r\n        &quot;networkProfile&quot;: {\r\n          &quot;networkInterfaces&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;/subscriptions/blah/resourceGroups/IPv6v2/providers/Microsoft.Network/networkInterfaces/A10NICvw4konls2vfbw-data&quot;,\r\n              &quot;resourceGroup&quot;: &quot;IPv6v2&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n",
        "link": "https://stackoverflow.com/questions/43595121/linux-cli-how-to-get-substring-from-json-jq-grep",
        "title": "Linux CLI - How to get substring from JSON jq + grep?"
    },
    {
        "tags": [
            "json",
            "shell",
            "date",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1301452,
                    "reputation": 47599,
                    "user_id": 1331399,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4a22763d295c9d45db0dd0c692bb4051?s=256&d=identicon&r=PG",
                    "display_name": "Thor",
                    "link": "https://stackoverflow.com/users/1331399/thor"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1493114447,
                "post_id": 43597719,
                "comment_id": 74263874,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1493071267,
                "last_edit_date": 1493071267,
                "creation_date": 1493070080,
                "answer_id": 43598172,
                "question_id": 43597719,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There are basically two ways to proceed:\r\n\r\n1) If your jq is sufficiently recent, use jq&#39;s time-and-date functions, starting with `now`:\r\n\r\n    $ jq -n now\r\n    1493069762.538462\r\n\r\n    $ jq -n &#39;now|strftime(&quot;%Y-%m-%d&quot;)&#39;\r\n    &quot;2017-04-24&quot;\r\n\r\n\r\nFor further details, see the &quot;Date&quot; section of the online manual: https://stedolan.github.io/jq/manual/\r\n\r\n2) Pass the date string in to jq using a suitable command-line option, e.g.\r\n\r\n    $ jq -n --arg date &quot;$(date +%F)&quot; &#39;$date&#39;\r\n    &quot;2017-04-24&quot;",
                "title": "Adding today&#39;s date into a CSV while converting a JSON to CSV using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1493071267,
        "creation_date": 1493068004,
        "last_edit_date": 1493071195,
        "question_id": 43597719,
        "body_markdown": "I have a JSON result from ElasticSearch that I parse with jq and retrieve the values I need out of the JSON and flatten it to CSV. There is no date in the fields coming from the JSON file. I need to be able to write a specific date as the first value in each row of the CSV.\r\n\r\n    ES_Query | jq -r &#39;.aggregations.distinct_UUID.buckets[] | (.latest.hits.hits[]._source | [.&quot;_uuid&quot;,.&quot;site_name&quot;,.&quot;Jar&quot;]) + (.PS_percentiles.values | [.&quot;80.0&quot;,.&quot;95.0&quot;]) | @csv&#39; &gt;&gt; /home/Outputs/res_wk_${end_date[$weeknum]}.csv\r\n\r\nFor example, in each row, I want to write the output of date +%F before the UUID, Sitename and Jar values.  Is it possible?\r\n\r\nB T W, I tried adding (`date +%F`) at the beginning and ending of the jq and got a compile time error. \r\n",
        "link": "https://stackoverflow.com/questions/43597719/adding-todays-date-into-a-csv-while-converting-a-json-to-csv-using-jq",
        "title": "Adding today&#39;s date into a CSV while converting a JSON to CSV using JQ"
    },
    {
        "tags": [
            "bash",
            "amazon-web-services",
            "curl",
            "amazon-ec2",
            "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": 1493184815,
                "post_id": 43625589,
                "comment_id": 74300228,
                "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": 1493568501,
                "post_id": 43625589,
                "comment_id": 74460830,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1493184974,
                "creation_date": 1493184974,
                "answer_id": 43625834,
                "question_id": 43625589,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Append:\r\n\r\n    | grep -Eo &#39;[0-9.]{7,14}&#39; | xargs -I {} echo curl http://{}:8081/version\r\n\r\nIf everything looks okay, remove `echo`.",
                "title": "How do I get the output of jq to pipe to curl"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1511864618,
        "creation_date": 1493183796,
        "last_edit_date": 1511864618,
        "question_id": 43625589,
        "body_markdown": "I&#39;m trying to query AWS EC2 ip addresses and use that addresses to curl the version of the box. The query path I could do it but I&#39;m not sure how to get the output of `jq` to `curl`\r\n\r\nHere&#39;s the command I use\r\n\r\n    aws ec2 describe-instances \\\r\n            --filters &quot;Name=tag:App,Values=app01&quot; \\\r\n            --query &quot;Reservations[*].Instances[*].PrivateIpAddress&quot; | jq &#39;flatten&#39;\r\n\r\n\r\nAnd this is the results I got\r\n\r\n    [\r\n      &quot;10.xx.xx.xxx&quot;,\r\n      &quot;10.xx.xx.xxx&quot;,\r\n    ]\r\n\r\nWhat I would like it to be is \r\n\r\n`curl http://10.xx.xx.xxx:8081/version`",
        "link": "https://stackoverflow.com/questions/43625589/how-do-i-get-the-output-of-jq-to-pipe-to-curl",
        "title": "How do I get the output of jq to pipe to curl"
    },
    {
        "tags": [
            "json",
            "node.js",
            "bash",
            "makefile",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1493310279,
                "last_edit_date": 1495535482,
                "creation_date": 1493301931,
                "answer_id": 43660169,
                "question_id": 43659066,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since this is in a `makefile`, there are two things that need to be understood.  First, to understand the &quot;$$&quot; variable (`$$dep`), see this stackoverflow question:\r\n \r\nhttps://stackoverflow.com/questions/19589957/makefile-and-use-of\r\n\r\nSecond, to understand the ... in `do ... done`, remember that this is essentially equivalent to a shell conditional of the form:\r\n\r\n    if [ -f _ ] ; then echo _ ; fi\r\n\r\nFor details about the test, see e.g. http://wiki.bash-hackers.org/commands/classictest\r\n",
                "title": "Using jq to extract information about dependencies from package.json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1493310279,
        "creation_date": 1493299133,
        "question_id": 43659066,
        "body_markdown": "So I am trying to run a jq command inside a makefile to link some dependencies, and I do not understand what the line inside the do-done does. If using only echo &quot;$$dep&quot; I understand what&#39;s going on, but when using the full line of code ([ -f &quot;$$dep/package.json&quot; ] &amp;&amp; echo &quot;$$dep&quot;;) I seem to be lost.  Does anyone have any idea? Thanks.\r\n\r\n    jq -r &#39;.dependencies,.devDependencies|keys[]&#39; $&lt; | while read -r dep; do \\\r\n        [ -f &quot;$$dep/package.json&quot; ] &amp;&amp; echo &quot;$$dep&quot;; \\\r\n    done | (piping forward)\r\n",
        "link": "https://stackoverflow.com/questions/43659066/using-jq-to-extract-information-about-dependencies-from-package-json",
        "title": "Using jq to extract information about dependencies from package.json"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1493321865,
                "post_id": 43665877,
                "comment_id": 74380001,
                "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": 1493356723,
                "post_id": 43665877,
                "comment_id": 74391109,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1493385459,
                "creation_date": 1493385459,
                "answer_id": 43681198,
                "question_id": 43665877,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since your purpose is to make comparisons simpler, this is what I&#39;d suggest, even though it is not exactly what you want:\r\n\r\n    walk(if type == &quot;array&quot; and all(.[]|type; . != &quot;array&quot; and . != &quot;object&quot;)\r\n         then tostring else . end)\r\n\r\nThis has the desired effect of flattening arrays of scalars, though it does so by converting them to strings:\r\n\r\n\r\n    {\r\n      &quot;fields&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;stat_1&quot;,\r\n          &quot;type&quot;: &quot;long&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;stat_2&quot;,\r\n          &quot;type&quot;: &quot;[\\&quot;long\\&quot;,\\&quot;null\\&quot;]&quot;\r\n        }\r\n      ],\r\n      &quot;name&quot;: &quot;rm&quot;\r\n    }\r\n\r\n### Variant\r\n\r\nIf your jq has `isempty` (or if you don&#39;t mind adding its definition, e.g. to your ~/.jq), the above can be shortened to:\r\n\r\n    walk(if type == &quot;array&quot; and isempty(.[]|iterables) then tostring else . end)\r\n\r\n### isempty\r\n\r\nIf your jq does not have `isempty`, here is its definition:\r\n\r\n    def isempty(g): 0 == ((label $go | g | (1, break $go)) // 0);\r\n\r\n\r\n",
                "title": "How to control JQ display output format for arrays"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1493385459,
        "creation_date": 1493319303,
        "question_id": 43665877,
        "body_markdown": "I would like to have JQ print out arrays on a single line. My input is a an Avro schema that I want to normalize. This is mainly just to normalize the output in a way that facilitates easier Git diffs as we evolve our schemas. I was able to get down to a filter like this that controls the order of the fields but got stuck with how to force the array to a single line. The format of the output seems to be under JQ&#39;s control.\r\n\r\n    jq &#39;{name: .name, fields: .fields | map({ name: .name, type: .type})}&#39; my.json\r\n\r\nI would like to able to display this:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;rm&quot;,\r\n      &quot;fields&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;stat_1&quot;,\r\n          &quot;type&quot;: &quot;long&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;stat_2&quot;,\r\n          &quot;type&quot;: [\r\n            &quot;long&quot;,\r\n            &quot;null&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nlike this:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;rm&quot;,\r\n      &quot;fields&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;stat_1&quot;,\r\n          &quot;type&quot;: &quot;long&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;stat_2&quot;,\r\n          &quot;type&quot;: [&quot;long&quot;, &quot;null&quot;]  &lt;&lt; FLATTENED\r\n        }\r\n      ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/43665877/how-to-control-jq-display-output-format-for-arrays",
        "title": "How to control JQ display output format for arrays"
    },
    {
        "tags": [
            "arrays",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1493378149,
                "creation_date": 1493378149,
                "answer_id": 43678907,
                "question_id": 43678724,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "***jq*** approach:\r\n\r\n    jq &#39;to_entries[] | select(.value.name == &quot;after-sshd-fixes&quot;).key&#39; jsonfile\r\nThe output:\r\n\r\n    &quot;{d773d5b7-94d4-4f78-a943-f50e4eb68fe0}&quot;\r\n\r\n",
                "title": "jq extracting the object key based on value of nested property"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1684164221,
        "creation_date": 1493377619,
        "last_edit_date": 1684164221,
        "question_id": 43678724,
        "body_markdown": "Given this JSON:   \r\n\r\n    {\r\n        &quot;{c156e78e-a4ac-422b-bf86-afe12f548dfb}&quot;: {\r\n           \t&quot;name&quot;: &quot;after-gluster3.8&quot;,\r\n            &quot;date&quot;: &quot;2017-04-16 14:31:20&quot;,\r\n            &quot;state&quot;: &quot;poweron&quot;,\r\n            &quot;current&quot;: false,\r\n            &quot;parent&quot;: &quot;&quot;\r\n        }\r\n        ,\r\n        &quot;{d773d5b7-94d4-4f78-a943-f50e4eb68fe0}&quot;: {\r\n        \t&quot;name&quot;: &quot;after-sshd-fixes&quot;,\r\n        \t&quot;date&quot;: &quot;2017-04-16 16:58:32&quot;,\r\n        \t&quot;state&quot;: &quot;poweroff&quot;,\r\n        \t&quot;current&quot;: true,\r\n        \t&quot;parent&quot;: &quot;{c156e78e-a4ac-422b-bf86-afe12f548dfb}&quot;\r\n        }\r\n    }\r\n\r\n\r\nI&#39;m in need to extract the key, based on the value of name, ie. I&#39;m searching for ```&quot;after-sshd-fixes&quot;``` and then want ```&quot;{d773d5b7-94d4-4f78-a943-f50e4eb68fe0}&quot;``` as output.\r\n\r\nusing ```.[]``` throws away the key of the array, and I&#39;m a bit overwhelmed with the rest of the jq manual to figure out how to put the key of the array into a temporary value, do the test, and then to output the specific array key:value\r\n",
        "link": "https://stackoverflow.com/questions/43678724/jq-extracting-the-object-key-based-on-value-of-nested-property",
        "title": "jq extracting the object key based on value of nested property"
    },
    {
        "tags": [
            "json",
            "windows",
            "batch-file",
            "mule",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5198511,
                    "reputation": 14472,
                    "user_id": 4158862,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/fKDhB.png?s=256",
                    "display_name": "SomethingDark",
                    "link": "https://stackoverflow.com/users/4158862/somethingdark"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1493691293,
                "post_id": 43728994,
                "comment_id": 74501727,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10808249,
                    "reputation": 43,
                    "user_id": 7949650,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/dcb327405223caeb2d4196774cce5ab8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sam",
                    "link": "https://stackoverflow.com/users/7949650/sam"
                },
                "reply_to_user": {
                    "account_id": 5198511,
                    "reputation": 14472,
                    "user_id": 4158862,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/fKDhB.png?s=256",
                    "display_name": "SomethingDark",
                    "link": "https://stackoverflow.com/users/4158862/somethingdark"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1493691464,
                "post_id": 43728994,
                "comment_id": 74501757,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1493691604,
                "creation_date": 1493691604,
                "answer_id": 43729089,
                "question_id": 43728994,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Windows is attempting to pipe the output of `jq` into `select`, but can&#39;t find the executable `select`.\r\n\r\nI&#39;m unfamiliar with `curl` and `jq` but it would appear that you require a literal `|`. In the quoted-command format you are using, a literal `|` can be produced with `^^^|`\r\n",
                "title": "JQ with Windows Batch - select failing"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1493747038,
                "last_edit_date": 1493747038,
                "creation_date": 1493692091,
                "answer_id": 43729142,
                "question_id": 43728994,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You&#39;re escaping things unnecessarily, the command interpreter is probably inserting them literally.  That and your use of double quotes is inconsistent.  You probably cut the strings off prematurely and the filter is effectively being run as additional piped commands.\r\n\r\nRunning this directly in a command prompt works for me:\r\n\r\n    for /f &quot;tokens=*&quot; %a in (&#39;jq &quot;.data[] | select(.name==\\&quot;test-mmc-deploy\\&quot;).id&quot; input.json&#39;) do (echo &quot;Application found: %a&quot;)\r\n\r\nThen in a batch file, you _only_ need to double the `%` for your loop variable.\r\n\r\n    for /f &quot;tokens=*&quot; %%a in (&#39;jq &quot;.data[] | select(.name==\\&quot;test-mmc-deploy\\&quot;).id&quot; input.json&#39;) do (\r\n        set app_id=%%a\r\n    )\r\n    echo Application found: %app_id%\r\n\r\nTo be able to pipe the curl response directly to jq, just escape the pipe (and nothing else).\r\n\r\n    for /f &quot;tokens=*&quot; %%a in (&#39;curl --basic -u admin:admin http://localhost:9090/mmc-console-3.8.2/api/deployments ^| jq &quot;.data[] | select(.name==\\&quot;test-mmc-deploy\\&quot;).id&quot;&#39;) do (\r\n        set app_id=%%a\r\n    )\r\n    echo Application found: %app_id%",
                "title": "JQ with Windows Batch - select failing"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1630385987,
        "creation_date": 1493690873,
        "last_edit_date": 1493691371,
        "question_id": 43728994,
        "body_markdown": "Using a Windows batch file with JQ and trying to pipe the select filter. \r\n\r\nExample Json which is being parsed with JQ:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;test-mmc-deploy&quot;,\r\n      &quot;id&quot;: &quot;local$3d2075c5-73c0-47aa-8df5-cee3a70f68c4&quot;,\r\n      &quot;lastModified&quot;: &quot;Mon, 1 May 2017 13:56:15.980 AEST&quot;,\r\n      &quot;servers&quot;: [\r\n        &quot;local$520ee705-bdbb-4132-94cf-63bb213d2b46&quot;\r\n      ],\r\n      &quot;status&quot;: &quot;DEPLOYED&quot;,\r\n      &quot;applications&quot;: [\r\n        &quot;local$f3d791bd-14d9-4491-9541-5fa04d8c3164&quot;\r\n      ],\r\n      &quot;href&quot;: &quot;http://localhost:9090/mmc-console-3.8.2/api/deployments/local$3d2075c5-73c0-47aa-8df5-cee3a70f68c4&quot;,\r\n      &quot;clusterNames&quot;: [],\r\n      &quot;reconciled&quot;: false,\r\n      &quot;clusterIds&quot;: []\r\n    }\r\n\r\nNormal command line JQ works with Curl and gives output as follows:\r\n\r\ncurl --basic -u admin:admin http://localhost:9090/mmc-console-3.8.2/api/deployments | jq &quot;.data[] | select(.name==\\&quot;test-mmc-deploy\\&quot;).id\r\n\r\n*&quot;local$3d2075c5-73c0-47aa-8df5-cee3a70f68c4&quot;*\r\n\r\n\r\nTrying to get the below command working in a Windows batch file is creating an escape character nightmare. Need some help please.\r\n\r\n    for /f &quot;tokens=*&quot; %%a in (&#39;echo %%app_deploy_list%% ^| jq &quot;&quot;.data[] ^| select(.name==\\&quot;test-mmc-deploy\\&quot;^).id&quot;&quot;&#39;) do (set app_id=%%a)\r\n    echo Application found: %app_id%\r\n\r\nwhere %%app_deploy_list%% holds the json declared above.\r\n\r\nThe error I am getting is:\r\n&#39;select&#39; is not recognized as an internal or external command\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/43728994/jq-with-windows-batch-select-failing",
        "title": "JQ with Windows Batch - select failing"
    },
    {
        "tags": [
            "json",
            "parsing",
            "key",
            "environment-variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 15,
                "is_accepted": true,
                "score": 15,
                "last_activity_date": 1494833306,
                "last_edit_date": 1494833306,
                "creation_date": 1493696373,
                "answer_id": 43729713,
                "question_id": 43729643,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To convert an array of two strings (e.g. [&quot;k&quot;, &quot;v&quot;]) to an object, you can write:\r\n\r\n    { (.[0]) : .[1] }\r\n\r\nSo you&#39;ll want to write something like:\r\n\r\n     map(.Config.Env |= (map( split(&quot;=&quot;) | { (.[0]) : .[1] } ) | add))\r\n\r\n### a2o\r\n\r\nAbstracting out the array-to-object functionality makes the solution a bit more digestible:\r\n\r\n    def a2o: map( split(&quot;=&quot;) | { (.[0]) : .[1] } ) | add;\r\n\r\n    map(.Config.Env |= a2o)\r\n\r\n### Using `match` or `capture` instead of `split`\r\n\r\nSince it is possible for an &quot;=&quot; character to appear in the &quot;value&quot; part of each `var=value` string, using `split` naively might not be such a great idea.  Here is a more robust alternative, assuming your jq supports regular expressions:\r\n\r\n    match(&quot;([^=]*)=(.*)&quot;) | .captures | {(.[0].string) : .[1].string}\r\n\r\nOr, slightly more succinctly and perhaps elegantly:\r\n\r\n    [capture( &quot;(?&lt;key&gt;[^:]*):(?&lt;value&gt;.*)&quot; )] | from_entries\r\n\r\n### `index/1`\r\n\r\nIf your jq does not have regex support, you could use `index/1`, along these lines:\r\n\r\n    index(&quot;=&quot;) as $ix | {(.[:$ix]) : .[$ix+1:]}",
                "title": "Use jq to turn x=y pairs into key/value pairs"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1565739478,
                "creation_date": 1565739478,
                "answer_id": 57486515,
                "question_id": 43729643,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given collection of items to convert to a single object, I generally would opt to using `reduce` for this purpose. Turn those items to their constituent keys and values, then assign to the result object.\r\n\r\n    reduce (.[] | split(&quot;=&quot;)) as [$key, $value] ({}; .[$key] = $value)\r\n\r\nThough using `from_entries` is also useful here as well, instead you&#39;d create an array of the key/value objects that it expects.\r\n\r\n    map(split(&quot;=&quot;) as [$key, $value] | {$key, $value}) | from_entries\r\n\r\nThen put it all together with the update of the `Env` property using whichever method you choose.\r\n\r\n    .[].Config.Env |= reduce (.[] | split(&quot;=&quot;)) as [$key, $value] ({}; .[$key] = $value)\r\n    #or\r\n    .[].Config.Env |= (map(split(&quot;=&quot;) as [$key, $value] | {$key, $value}) | from_entries)\r\n\r\nhttps://jqplay.org/s/qfItW5U-Tf\r\n",
                "title": "Use jq to turn x=y pairs into key/value pairs"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1565739478,
        "creation_date": 1493695967,
        "last_edit_date": 1493707301,
        "question_id": 43729643,
        "body_markdown": "I&#39;m trying to parse environment variables from the JSON output of `docker inspect`.  Annoyingly, those environment variables aren&#39;t returned as useful key-value pairs.  They&#39;re just an array of x=y strings.  Here&#39;s a relevant snippet of the output:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    [\r\n        {\r\n            &quot;Config&quot;: {\r\n                &quot;Env&quot;: [\r\n                    &quot;JENKINS_HOST=1.2.3.4&quot;,\r\n                    &quot;JENKINS_INSTANCE=tea&quot;,\r\n                    &quot;JENKINS_NAME=Enterprise Architecture Tools&quot;,\r\n                    &quot;JENKINS_VERSION=2.46.2&quot;,\r\n                    &quot;JENKINS_PROTOCOL=http&quot;\r\n                ]\r\n            }\r\n        }\r\n    ]\r\n\r\nI would like to convert that array into something like this:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    {\r\n      &quot;Config&quot;: {\r\n        &quot;Env&quot;: {\r\n          &quot;JENKINS_HOST&quot;: &quot;1.2.3.4&quot;,\r\n          &quot;JENKINS_INSTANCE&quot;: &quot;tea&quot;,\r\n          &quot;JENKINS_NAME&quot;: &quot;Enterprise Architecture Tools&quot;,\r\n          &quot;JENKINS_VERSION&quot;: &quot;2.46.2&quot;,\r\n          &quot;JENKINS_PROTOCOL&quot;: &quot;http&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nThat way, I can use a command like `jq &#39;.[] | .Config.Env.JENKINS_HOST&#39;` to get the values that I care about.  I can&#39;t figure out how to accomplish this.\r\n\r\nIt&#39;s relatively easy to select the data and even split the key and value into separate elements.  For instance, if I use `jq &#39;.[] | .Config.Env | .[] | split(&quot;=&quot;)&#39;`, I get data like this:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    [\r\n      &quot;JENKINS_HOST&quot;,\r\n      &quot;1.2.3.4&quot;\r\n    ]\r\n    [\r\n      &quot;JENKINS_INSTANCE&quot;,\r\n      &quot;tea&quot;\r\n    ]\r\n    [\r\n      &quot;JENKINS_NAME&quot;,\r\n      &quot;Enterprise Architecture Tools&quot;\r\n    ]\r\n    [\r\n      &quot;JENKINS_VERSION&quot;,\r\n      &quot;2.46.2&quot;\r\n    ]\r\n    [\r\n      &quot;JENKINS_PROTOCOL&quot;,\r\n      &quot;http&quot;\r\n    ]\r\n\r\nHowever, I can&#39;t figure out how to turn that data into an object assignment.  It seems like it should probably be some combination of `map` or `reduce`, but I&#39;m stumped.  Can anyone point me in the right direction?",
        "link": "https://stackoverflow.com/questions/43729643/use-jq-to-turn-x-y-pairs-into-key-value-pairs",
        "title": "Use jq to turn x=y pairs into key/value pairs"
    },
    {
        "tags": [
            "json",
            "mongodb",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1493766340,
                "last_edit_date": 1493766340,
                "creation_date": 1493740364,
                "answer_id": 43742272,
                "question_id": 43739846,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If your jq has &#39;walk/1&#39; then the simplest completely generic solution would be along these lines:\r\n\r\n    walk( if type==&quot;object&quot;\r\n          then with_entries( if .value | (type == &quot;object&quot; and has(&quot;numberLong&quot;))\r\n                             then .value |= .numberLong\r\n                             else . end)\r\n          else . end )\r\n\r\n\r\n\r\nIf your jq does not have &#39;walk&#39;, then it would be best to upgrade, as that will also improve speed; otherwise you can google for its def in jq.\r\n\r\nIf this is too slow for your very large files, you may have to track down the precise locations where the transformation is needed to avoid the overhead of a completely generic approach.\r\n\r\n### Notes on handling very large files\r\nYour example (&quot;What I have initially&quot;) gives a stream of objects, so it might be worth pointing out that since jq is stream-oriented, it has no problem handling very large files consisting of streams of JSON entities (aka &quot;documents&quot;) that are not so large individually.  \r\n\r\n(An approximate rule of thumb is that if the largest JSON entity in the input has size N units, and if the largest JSON entity created by jq has size M units, then jq might need access to about M + N + max(M,N) units of memory.)\r\n\r\nTo handle a very large file containing a single JSON array, it might be advisable to begin by producing a stream of the top-level elements for subsequent processing. \r\n\r\nIn the worst-possible case (a very large file with one very large, complex JSON document) you might have to use a streaming parser such as the one that jq has.\r\n\r\nFor illustrations of various techniques for handling very large files, see\r\nhttps://stackoverflow.com/questions/43469103/process-huge-geojson-file-with-jq/43476622#43476622",
                "title": "jq: Flatten objects with unnecessary nested levels"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1493766340,
        "creation_date": 1493733597,
        "last_edit_date": 1495540025,
        "question_id": 43739846,
        "body_markdown": "I&#39;m facing the problem of having a  json file where the same key sometimes has a flat value, while others it has an additional nested (and for my purposes unnecessary) level which then includes the related value. \r\n\r\nThe file is newline delimited and I am trying to get rid of any additional levels. So far I&#39;ve managed to do that only if the nested level appears in the first branch of the tree, using\r\n\r\n    jq -c &#39;[.] | map(.[] |= if type == &quot;object&quot; and (.number | length) &gt; 0 then .numberLong else . end) | .[]&#39; mongoDB.json\r\n\r\nThe example below illustrates that further. What I have initially:\r\n\r\n\r\n      {\r\n        &quot;name&quot;: &quot;John&quot;,\r\n        &quot;age&quot;: {\r\n            &quot;numberLong&quot;: 22\r\n          }\r\n      }\r\n      {\r\n        &quot;name&quot;: &quot;Jane&quot;,\r\n        &quot;age&quot;: 24\r\n      }\r\n      {\r\n        &quot;name&quot;: &quot;Dennis&quot;,\r\n        &quot;age&quot;: 34,\r\n        &quot;details&quot;: [\r\n          {\r\n            &quot;telephone_number&quot;: 555124124\r\n          }\r\n        ]\r\n      }\r\n      {\r\n        &quot;name&quot;: &quot;Frances&quot;,\r\n        &quot;details&quot;: [\r\n          {\r\n            &quot;telephone_number&quot;: {\r\n                &quot;numberLong&quot;: 444245523\r\n              }\r\n          }\r\n        ]\r\n      }\r\n\r\n\r\n\r\nWhat my script does (the second `numberLong` is ignored):\r\n\r\n      {\r\n        &quot;name&quot;: &quot;John&quot;,\r\n        &quot;age&quot;: 22\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Jane&quot;,\r\n        &quot;age&quot;: 24\r\n      }\r\n      {\r\n        &quot;name&quot;: &quot;Dennis&quot;,\r\n        &quot;age&quot;: 34,\r\n        &quot;details&quot;: [\r\n          {\r\n            &quot;telephone_number&quot;: 555124124\r\n          }\r\n        ]\r\n      }\r\n      {\r\n        &quot;name&quot;: &quot;Frances&quot;,\r\n        &quot;details&quot;: [\r\n          {\r\n            &quot;telephone_number&quot;:  {\r\n                &quot;numberLong&quot;: 444245523\r\n              }\r\n          }\r\n        ]\r\n      }\r\n\r\nWhat I am actually hoping to achieve (recursively copy the values of all `numberLong` keys one level up, regardless of where they belong in the file)  :\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;John&quot;,\r\n        &quot;age&quot;: 22\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Jane&quot;,\r\n        &quot;age&quot;: 24\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Dennis&quot;,\r\n        &quot;age&quot;: 34,\r\n        &quot;details&quot;: [\r\n          {\r\n            &quot;telephone_number&quot;: 555124124\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Frances&quot;,\r\n        &quot;details&quot;: [\r\n          {\r\n            &quot;telephone_number&quot;: 444245523\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nThis transformation is part of a daily pipeline and is applied to several files with sizes up to 70GB, so speed while traversing the files could potentially be an issue. The problem stems from MongoDB&#39;s different types: https://stackoverflow.com/questions/17185220/mongodb-differences-between-numberlong-and-simple-integer\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/43739846/jq-flatten-objects-with-unnecessary-nested-levels",
        "title": "jq: Flatten objects with unnecessary nested levels"
    },
    {
        "tags": [
            "json",
            "jq",
            "data-extraction"
        ],
        "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": 1493805123,
                "post_id": 43755787,
                "comment_id": 74554658,
                "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": 1493806710,
                "post_id": 43755787,
                "comment_id": 74555769,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1493996168,
                "last_edit_date": 1493996168,
                "creation_date": 1493811060,
                "answer_id": 43758837,
                "question_id": 43755787,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. The input sample given is not quite valid JSON.  The following assumes it has been fixed up.\r\n2. The following assumes that the typographical case of the output key names may reflect the input keys names more closely.\r\n3. The following produces the desired result, but is probably not exactly what you want, since it is unclear what you expect if the .zones, .sails and/or .cabins arrays have more than one item.\r\n\r\n&lt;/&gt;\r\n\r\n    {nid, nights, zone: .zones[0].title} +\r\n    (.sails[0]\r\n     | { sails_nid: .nid, arrival, departure } +\r\n       (.cabins[0] \r\n        | { cabintype: .cabinType.kindName, catalogPrice, discountPrice, currency } ))\r\n\r\n### All combinations\r\n\r\nIf you want &quot;all combinations&quot; of zones, sails, and cabins, simply replace [0] with [] in the above:\r\n\r\n    {nid, nights, zone: .zones[].title} +\r\n    (.sails[]\r\n     | ({ sails_nid: .nid, arrival, departure } ) +\r\n        (.cabins[] \r\n         | { cabintype: .cabinType.kindName, catalogPrice, discountPrice, currency } ) )\r\n\r\nWith the sample input, this emits 21 JSON objects.",
                "title": "JQ: Nested JSON transformation"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1493996168,
        "creation_date": 1493802757,
        "last_edit_date": 1493897275,
        "question_id": 43755787,
        "body_markdown": "I actually looking for a software to transform json files (i am a complete json noobie) that i got from a web api, for a better load to my SQL database. Some hours Google Research later i found jq, that hit my needs nearly to 100%. \r\nI though i found the necessary filter Operation on jq for my needs but runs now in a &quot;little&quot; Problem. My source json is heavly nested and i Need to extract several data (from objects/Arrays) from different layer in the jsons paths. I built following filter on jqplay:\r\n\r\n    . | {cruise_nid: .nid} + {nights: .nights} + {zone: .zones[].title} +  {sails_nid: .sails[].nid} + {arrival: .sails[].arrival} + {departure: .sails[].departure} + {cabintype: .sails[].cabins[].cabinType.kindName} + {catalogprice: .sails[].cabins[].catalogPrice} + {discountprice: .sails[].cabins[].discountPrice} + {currency: .sails[].cabins[].currency}\r\n\r\nsource json (shorted):\r\n\r\n    {\r\n\t&quot;nid&quot;: 434508,\r\n\t&quot;nights&quot;: 121,\r\n\t&quot;zones&quot;: [\r\n\t\t{\r\n\t\t\t&quot;nid&quot;: 35761,\r\n\t\t\t&quot;title&quot;: &quot;Weltreise&quot;,\r\n\t\t}\r\n\t],\r\n\t&quot;sails&quot;: [\r\n\t\t{\r\n\t\t\t&quot;nid&quot;: 434516,\r\n\t\t\t&quot;arrival&quot;: 1525644000,\r\n\t\t\t&quot;bookingServiceCode&quot;: &quot;kreuzfahrt/c8a3/mit-der-columbus-einmal-um-die-ganze-welt-once-in-a-lifetime&quot;,\r\n\t\t\t&quot;departure&quot;: 1515193200,\r\n\t\t\t&quot;optionalFlightPrice&quot;: null,\r\n\t\t\t&quot;cabins&quot;: [\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379723,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Gl&#252;ckskabine Innen (Kat. IG): &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;Bei Buchung einer Garantiekabine &#252;berlassen Sie der Reederei die Wahl Ihrer Kabinennummer und Deck. Sie entscheiden sich f&#252;r die Route, einen der zur Auswahl stehenden Termine, sowie die Kabinenkategorie. F&#252;r Ihre Flexibilit&#228;t werden Sie mit attraktiven Vorzugspreisen belohnt.&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;IG&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;IG&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 19,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Innenkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;inside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 2,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: true,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;Bei Buchung einer Garantiekabine &#252;berlassen Sie der Reederei die Wahl Ihrer Kabinennummer und Deck. Sie entscheiden sich f&#252;r die Route, einen der zur Auswahl stehenden Termine, sowie die Kabinenkategorie. F&#252;r Ihre Flexibilit&#228;t werden Sie mit attraktiven Vorzugspreisen belohnt.&quot;,\r\n\t\t\t\t\t\t&quot;amenities&quot;: [],\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 2,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 9519,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 17879,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.4675876726886291,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379730,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Innenkabine Standard (Kat. 1): &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 5&lt;/li&gt;\\r\\n&lt;li&gt;2 Einzelbetten&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;1&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;1&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 19,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Innenkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;inside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 2,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 5&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;18 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;2 Einzelbetten&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 2,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 10239,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 18599,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.44948653153395346,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379731,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Innenkabine Standard Plus (Kat. 2): &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 6&lt;/li&gt;\\r\\n&lt;li&gt;2 Einzelbetten&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;2&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;2&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 19,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Innenkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;inside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 2,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 6&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;18 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;2 Einzelbetten&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 2,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 11299,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 20519,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.4493396364345241,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379732,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Innenkabine Superior (Kat. 3): &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 10&lt;/li&gt;\\r\\n&lt;li&gt;2 Einzelbetten&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;3&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;3&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 19,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Innenkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;inside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 2,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 10&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;18 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;2 Einzelbetten&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 1,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 11999,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 21809,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.44981429684992436,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379734,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Innenkabine Premium (Kat. 4): &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 11&lt;/li&gt;\\r\\n&lt;li&gt;2 Einzelbetten&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;\\r\\n&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;4&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;4&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 19,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Innenkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;inside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 2,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 11&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;18 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;2 Einzelbetten&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 1,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 12709,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 23089,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.44956472779245527,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379740,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Gl&#252;ckskabine Au&#223;en (Kat. OG): &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;Bei Buchung einer Garantiekabine &#252;berlassen Sie der Reederei die Wahl Ihrer Kabinennummer und Deck. Sie entscheiden sich f&#252;r die Route, einen der zur Auswahl stehenden Termine, sowie die Kabinenkategorie. F&#252;r Ihre Flexibilit&#228;t werden Sie mit attraktiven Vorzugspreisen belohnt.&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;OG&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;OG&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 20,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Au&#223;enkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;outside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 2,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;Fenster&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: true,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;Bei Buchung einer Garantiekabine &#252;berlassen Sie der Reederei die Wahl Ihrer Kabinennummer und Deck. Sie entscheiden sich f&#252;r die Route, einen der zur Auswahl stehenden Termine, sowie die Kabinenkategorie. F&#252;r Ihre Flexibilit&#228;t werden Sie mit attraktiven Vorzugspreisen belohnt.&quot;,\r\n\t\t\t\t\t\t&quot;amenities&quot;: [],\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 2,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 12119,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 22739,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.4670390078719381,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379748,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Au&#223;enkabine Standard mit eingeschr&#228;nkter Sicht (Kat. 6C): &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 8&lt;/li&gt;\\r\\n&lt;li&gt;1 Doppelbett&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Fenster&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;6C&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;6C&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 20,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Au&#223;enkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;outside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 2,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 8&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;18 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;1 Doppelbett&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;Fenster mit eingeschr&#228;nkter Sicht&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 1,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 12989,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 23609,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.4498284552501165,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379749,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Au&#223;enkabine Standard mit eingeschr&#228;nkter Sicht (Kat. 6B): &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 9&lt;/li&gt;\\r\\n&lt;li&gt;1 Doppelbett&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Fenster&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;6B&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;6B&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 20,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Au&#223;enkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;outside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 2,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 9&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;18 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;1 Doppelbett&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;Fenster mit eingeschr&#228;nkter Sicht&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 1,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 13409,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 24379,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.4499774395996554,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379750,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Au&#223;enkabine Standard (Kat. 6): &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 4&lt;/li&gt;\\r\\n&lt;li&gt;1 Doppelbett&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Bullauge&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;6&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;6&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 20,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Au&#223;enkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;outside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 2,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 4&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;18 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;1 Doppelbett&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;Bullauge&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 1,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 14119,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 25659,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.4497447289450095,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379751,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Au&#223;enkabine Standard (Kat. 7): &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 6&lt;/li&gt;\\r\\n&lt;li&gt;1 Doppelbett&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Fenster&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;7&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;7&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 20,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Au&#223;enkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;outside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 2,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 6&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;18 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;1 Doppelbett&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;Fenster&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 1,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 14459,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 26299,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.4502072322141526,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379752,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Au&#223;enkabine Standard Plus (Kat. 8): &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 8 &amp; 9&lt;/li&gt;\\r\\n&lt;li&gt;1 Doppelbett&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Fenster&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;8&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;8&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 20,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Au&#223;enkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;outside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 2,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 8 &amp; 9&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;18 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;1 Doppelbett&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;Fenster&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 1,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 15169,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 27579,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.44998005728996704,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379753,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Au&#223;enkabine Superior (Kat. 9): &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 10&lt;/li&gt;\\r\\n&lt;li&gt;1 Doppelbett&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Fenster&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;9&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;9&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 20,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Au&#223;enkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;outside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 2,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 10&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;18 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;1 Doppelbett&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;Fenster&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 1,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 16939,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 30779,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.4496572338282595,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379754,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Au&#223;enkabine Superior Plus (Kat. 11): &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 10&lt;/li&gt;\\r\\n&lt;li&gt;1 Doppelbett&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Fenster&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;11&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;11&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 20,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Au&#223;enkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;outside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 2,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 10&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;18 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;1 Doppelbett&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;Fenster&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 1,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 18349,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 33349,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.4497885993583016,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379756,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Au&#223;enkabine Premium (Kat. 12): &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 11&lt;/li&gt;\\r\\n&lt;li&gt;1 Doppelbett&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Fenster&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;12&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;12&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 20,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Au&#223;enkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;outside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 2,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 11&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;18 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;1 Doppelbett&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;Fenster&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 1,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 19759,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 35909,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.44974797404550393,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379758,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Innenkabine Superior zur Einzelbelegung (Kat. 5):&quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 10&lt;/li&gt;\\r\\n&lt;li&gt;1 Doppelbett&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;5&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;5&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 19,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Innenkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;inside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 1,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 10&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;18 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;1 Doppelbett&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 2,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 14989,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 27259,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.45012656370373083,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379759,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Au&#223;enkabine zur Einzelbelegung (Kat. 7S): &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 6&lt;/li&gt;\\r\\n&lt;li&gt;1 Doppelbett&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Fenster&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;7S&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;7S&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 20,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Au&#223;enkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;outside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 1,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 6&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;18 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;1 Doppelbett&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;Fenster&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 2,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 18089,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 32869,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.4496638169703976,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379760,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Au&#223;enkabine zur Einzelbelegung (Kat. 8S): &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 8 &amp; 9&lt;/li&gt;\\r\\n&lt;li&gt;1 Doppelbett&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Fenster&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;8S&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;8S&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 20,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Au&#223;enkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;outside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 1,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 8 &amp; 9&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;18 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;1 Doppelbett&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;Fenster&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 1,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 18959,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 34469,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.44996953784560034,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379761,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Au&#223;enkabine Superior zur Einzelbelegung (Kat. 10):&quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 10&lt;/li&gt;\\r\\n&lt;li&gt;1 Doppelbett&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Fenster&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;10&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;10&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 20,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Au&#223;enkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;outside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 1,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 10&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;18 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;1 Doppelbett&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;Fenster&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 2,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 21169,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 38479,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.44985576548247097,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379762,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Au&#223;enkabine Standard (Kat. 6P): &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 4&lt;/li&gt;\\r\\n&lt;li&gt;1 Doppelbett&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Bullauge&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;6P&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;6P&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 20,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Au&#223;enkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;outside&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 2,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 4&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;18 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;1 Doppelbett&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;Bullauge&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 1,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 13409,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 24379,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.4499774395996554,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379763,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Balkonkabine De Luxe (Kat. DL): &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 11&lt;/li&gt;\\r\\n&lt;li&gt;1 Doppelbett&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Balkon&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;DL&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;DL&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 21,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Balkonkabine&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;balcony&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 2,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 11&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;24 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;1 Doppelbett&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;Raumhohe Fenster&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;Balkon&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 2,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 28229,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 51299,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.44971636874013143,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;cabinType&quot;: {\r\n\t\t\t\t\t\t&quot;nid&quot;: 379764,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Junior Suite (Kat. JS) &quot;,\r\n\t\t\t\t\t\t&quot;description&quot;: &quot;&lt;ul&gt;\\r\\n&lt;li&gt;Lage: Deck 11&lt;/li&gt;\\r\\n&lt;li&gt;1 Doppelbett&lt;/li&gt;\\r\\n&lt;li&gt;Bad mit Dusche/WC&lt;/li&gt;\\r\\n&lt;li&gt;Balkon&lt;/li&gt;\\r\\n&lt;li&gt;Wohnbereich&lt;/li&gt;\\r\\n&lt;li&gt;Flatscreen-Fernseher&lt;/li&gt;\\r\\n&lt;li&gt;Radio&lt;/li&gt;\\r\\n&lt;li&gt;Minibar&lt;/li&gt;\\r\\n&lt;li&gt;Direktwahl-Telefon&lt;/li&gt;\\r\\n&lt;li&gt;Safe&lt;/li&gt;\\r\\n&lt;li&gt;Individuell regulierbare Klimaanlage&lt;/li&gt;\\r\\n&lt;li&gt;Badem&#228;ntel und Handt&#252;cher&lt;/li&gt;\\r\\n&lt;li&gt;F&#246;hn&lt;/li&gt;\\r\\n&lt;/ul&gt;&quot;,\r\n\t\t\t\t\t\t&quot;bookingServiceCode&quot;: &quot;JS&quot;,\r\n\t\t\t\t\t\t&quot;externalCode&quot;: &quot;JS&quot;,\r\n\t\t\t\t\t\t&quot;kindId&quot;: 22,\r\n\t\t\t\t\t\t&quot;kindName&quot;: &quot;Suite&quot;,\r\n\t\t\t\t\t\t&quot;kind&quot;: &quot;suite&quot;,\r\n\t\t\t\t\t\t&quot;validFrom&quot;: null,\r\n\t\t\t\t\t\t&quot;validTo&quot;: null,\r\n\t\t\t\t\t\t&quot;disabledForDirectBooking&quot;: false,\r\n\t\t\t\t\t\t&quot;bedQuantity&quot;: 2,\r\n\t\t\t\t\t\t&quot;maxPassengers&quot;: null,\r\n\t\t\t\t\t\t&quot;location&quot;: &quot;Deck 11&quot;,\r\n\t\t\t\t\t\t&quot;size&quot;: &quot;35 m&#178;&quot;,\r\n\t\t\t\t\t\t&quot;bed&quot;: &quot;1 Doppelbett&quot;,\r\n\t\t\t\t\t\t&quot;windows&quot;: &quot;Raumhohe Fenster&quot;,\r\n\t\t\t\t\t\t&quot;balcony&quot;: &quot;Balkon&quot;,\r\n\t\t\t\t\t\t&quot;information&quot;: null,\r\n\t\t\t\t\t\t&quot;isGuaranteeCabin&quot;: false,\r\n\t\t\t\t\t\t&quot;guaranteeCabinInfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t&quot;amenities&quot;: [\r\n\t\t\t\t\t\t\t&quot;Bad mit Dusche/WC&quot;,\r\n\t\t\t\t\t\t\t&quot;Balkon&quot;,\r\n\t\t\t\t\t\t\t&quot;Wohnbereich&quot;,\r\n\t\t\t\t\t\t\t&quot;Flatscreen-Fernseher&quot;,\r\n\t\t\t\t\t\t\t&quot;Radio&quot;,\r\n\t\t\t\t\t\t\t&quot;Minibar&quot;,\r\n\t\t\t\t\t\t\t&quot;Direktwahl-Telefon&quot;,\r\n\t\t\t\t\t\t\t&quot;Safe&quot;,\r\n\t\t\t\t\t\t\t&quot;Individuell regulierbare Klimaanlage&quot;,\r\n\t\t\t\t\t\t\t&quot;Badem&#228;ntel und Handt&#252;cher&quot;,\r\n\t\t\t\t\t\t\t&quot;F&#246;hn&quot;\r\n\t\t\t\t\t\t],\r\n\t\t\t\t\t\t&quot;advantages&quot;: []\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;state&quot;: 2,\r\n\t\t\t\t\t&quot;fees&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;gratuities&quot;: &quot;0&quot;,\r\n\t\t\t\t\t&quot;discountPrice&quot;: 31739,\r\n\t\t\t\t\t&quot;catalogPrice&quot;: 57709,\r\n\t\t\t\t\t&quot;discountPercentage&quot;: 0.45001646190368916,\r\n\t\t\t\t\t&quot;currency&quot;: &quot;EUR&quot;\r\n\t\t\t\t}\r\n\t\t\t],\r\n\t\t}\r\n\t],\r\n\t\r\n}\r\n\r\nThe result is like:\r\n\r\n    {\r\n      &quot;cruise_nid&quot;: 434508,\r\n      &quot;nights&quot;: 121,\r\n      &quot;zone&quot;: &quot;Weltreise&quot;,\r\n      &quot;sails_nid&quot;: 434516,\r\n      &quot;arrival&quot;: 1525644000,\r\n      &quot;departure&quot;: 1515193200,\r\n      &quot;cabintype&quot;: &quot;Innenkabine&quot;,\r\n      &quot;catalogprice&quot;: 17879,\r\n      &quot;discountprice&quot;: 9519,\r\n      &quot;currency&quot;: &quot;EUR&quot;\r\n    }\r\n\r\nFrom the json source (100 kB) i expected arround 30 objects like that. But i receive 194481 objects (arround 50 mb file). I actually have no idea why that happens and how i can fix it. Any ideas?\r\n\r\nthanks\r\n\r\nregards\r\ntimo\r\n\r\n",
        "link": "https://stackoverflow.com/questions/43755787/jq-nested-json-transformation",
        "title": "JQ: Nested JSON transformation"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 423789,
                    "reputation": 2824,
                    "user_id": 803422,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://www.gravatar.com/avatar/51b462bd16ac918a8563fa50c6ce416f?s=256&d=identicon&r=PG",
                    "display_name": "user803422",
                    "link": "https://stackoverflow.com/users/803422/user803422"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1493931856,
                "post_id": 43764041,
                "comment_id": 74626224,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7344001,
                    "reputation": 9,
                    "user_id": 7955898,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b3e65c401c64a559eef06cd686da9d82?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Leo",
                    "link": "https://stackoverflow.com/users/7955898/leo"
                },
                "reply_to_user": {
                    "account_id": 423789,
                    "reputation": 2824,
                    "user_id": 803422,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://www.gravatar.com/avatar/51b462bd16ac918a8563fa50c6ce416f?s=256&d=identicon&r=PG",
                    "display_name": "user803422",
                    "link": "https://stackoverflow.com/users/803422/user803422"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1494060639,
                "post_id": 43764041,
                "comment_id": 74675596,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user663031"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1494063447,
                "post_id": 43764041,
                "comment_id": 74676345,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7344001,
                    "reputation": 9,
                    "user_id": 7955898,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b3e65c401c64a559eef06cd686da9d82?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Leo",
                    "link": "https://stackoverflow.com/users/7955898/leo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1494067567,
                "post_id": 43764041,
                "comment_id": 74677450,
                "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": 1494281921,
                "post_id": 43764041,
                "comment_id": 74751935,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4341220,
                    "reputation": 6230,
                    "user_id": 3544399,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/30608c0bc46e774eecc9f458417b194b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "hmedia1",
                    "link": "https://stackoverflow.com/users/3544399/hmedia1"
                },
                "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": 1494528875,
                "post_id": 43764041,
                "comment_id": 74880066,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1494528292,
                "last_edit_date": 1495541411,
                "creation_date": 1494528292,
                "answer_id": 43923361,
                "question_id": 43764041,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is something that will reproduce your desired result.  It&#39;s by no means automatic, It&#39;s really a proof of concept at this stage.\r\n\r\nOne liner:\r\n\r\n    jq -s &#39;. as $in | ($in[0][].children[].children + $in[1][].children[0].children | unique) as $a1 | $in[1][].children[1] as $s1 | $in[0] | .[0].children[0].children = ($a1) | .[0].children += [$s1]&#39; file1.json file2.json\r\nMulti line breakdown (Copy/Paste):\r\n\r\n\r\n    jq -s &#39;. as $in \r\n    | ($in[0][].children[].children + $in[1][].children[0].children\r\n    | unique) as $a1\r\n    | $in[1][].children[1] as $s1\r\n    | $in[0]\r\n    | .[0].children[0].children = ($a1)\r\n    | .[0].children += [$s1]&#39; file1.json file2.json\r\n\r\nWhere:\r\n\r\n - `$in` : file1.json and file2.json combined input\r\n - `$a1`: merged &quot;SubSubTitle&quot; array\r\n - `$s1`: second subtitle object\r\n\r\nI suspect the reason [this][1] didn&#39;t work was because your schema is different and has nested arrays.\r\n\r\nI find it quite hypnotic looking at this, it would be good if you could elaborate a bit on how fixed the structure is and what the requirements are.\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/19529688/how-to-merge-2-json-file-using-jq",
                "title": "Deep JSON merge"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1503016632,
                "creation_date": 1503016632,
                "answer_id": 45746828,
                "question_id": 43764041,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a recursive solution which uses `group_by(.key)` to decide\r\nwhich objects to combine.  This could be a little simpler if `.children`\r\nwere more uniform. Sometimes it&#39;s absent in the sample data and sometimes it&#39;s the unusual value `[{}]`.\r\n\r\n    def merge:\r\n\r\n        def kids:\r\n            map(\r\n                .children\r\n              | if length&lt;1 then empty else .[] end\r\n            )\r\n          | if length&lt;1 then {} else {children:merge} end\r\n        ; \r\n\r\n        def mergegroup:\r\n          {\r\n              title: .[0].title\r\n            , key:   .[0].key\r\n          } + kids\r\n        ;\r\n\r\n        if   .==[{}] then .\r\n        else group_by(.key) | map(mergegroup)\r\n        end\r\n    ;\r\n\r\n    [ .[] | .[] ] | merge\r\n\r\n\r\n\r\nWhen run with the `-s` option as follows\r\n\r\n    jq -M -s -f filter.jq file1.json file2.json\r\n\r\nIt produces the following output.\r\n\r\n    [\r\n      {\r\n        &quot;title&quot;: &quot;Title1&quot;,\r\n        &quot;key&quot;: &quot;12345678&quot;,\r\n        &quot;children&quot;: [\r\n          {\r\n            &quot;title&quot;: &quot;SubTitle2&quot;,\r\n            &quot;key&quot;: &quot;123456713&quot;,\r\n            &quot;children&quot;: [\r\n              {}\r\n            ]\r\n          },\r\n          {\r\n            &quot;title&quot;: &quot;SubTitle1&quot;,\r\n            &quot;key&quot;: &quot;12345679&quot;,\r\n            &quot;children&quot;: [\r\n              {\r\n                &quot;title&quot;: &quot;SubSubTitle1&quot;,\r\n                &quot;key&quot;: &quot;12345610&quot;\r\n              },\r\n              {\r\n                &quot;title&quot;: &quot;SubSubTitle2&quot;,\r\n                &quot;key&quot;: &quot;12345611&quot;\r\n              },\r\n              {\r\n                &quot;title&quot;: &quot;DifferentSubSubTitle1&quot;,\r\n                &quot;key&quot;: &quot;12345612&quot;\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n    \r\nIf the ordering of the objects within the `.children` matters\r\nthen an a `sort_by` can be added to the `{children:merge}` expression,\r\ne.g. `{children:merge|sort_by(.key)}`\r\n",
                "title": "Deep JSON merge"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1503016632,
        "creation_date": 1493824615,
        "last_edit_date": 1495540493,
        "question_id": 43764041,
        "body_markdown": "I have multiple JSON files that I&#39;d like to merge into one.\r\nSome have the same root element but different children. I don&#39;t want to overwrite the children but too extend them if they have the same parent element.\r\nI&#39;ve tried [this answer][1], but it doesn&#39;t work:\r\n\r\n    jq: error (at file2.json:0): array ([{&quot;title&quot;:&quot;...) and array ([{&quot;title&quot;:&quot;...) cannot be multiplied\r\n\r\n[Sample files and wanted result (Gist)][2]\r\n\r\nThank you in advance.\r\n\r\n  [1]: https://stackoverflow.com/questions/19529688/how-to-merge-2-json-file-using-jq\r\n  [2]: https://gist.github.com/anonymous/8032404a1ac78908d2ae15765e861859",
        "link": "https://stackoverflow.com/questions/43764041/deep-json-merge",
        "title": "Deep JSON merge"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1494024025,
                "last_edit_date": 1494024025,
                "creation_date": 1493858238,
                "answer_id": 43772034,
                "question_id": 43771630,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following assumes the availability of `splits/1` for splitting a string based on a regex. If your jq does not have it, and if you cannot or don&#39;t want to upgrade, you could devise a workaround using `split/1`, which only works on strings.\r\n\r\nFirst, let&#39;s start with a simple variant of the problem that does not require recycling the headers.  If the following jq program is in a file (say program.jq):\r\n\r\n    # Assuming header is an array of strings,\r\n    # create an object from an array of values:\r\n    def objectify(headers):\r\n      . as $in\r\n      | reduce range(0; headers|length) as $i ({}; .[headers[$i]] = ($in[$i]) );\r\n\r\n    # From an object of the form {key: _, value: _},\r\n    # construct an object by splitting each _\r\n    def devolve:\r\n      if .key|index(&quot;;&quot;)\r\n      then .key as $key\r\n      | ( [.value | splits(&quot;; *&quot;)] ) | objectify([$key | splits(&quot;; *&quot;)])\r\n      else { (.key): .value }\r\n      end;\r\n\r\n  \r\n    to_entries | map( devolve )\r\n\r\nand if the following JSON is in input.json:\r\n\r\n    {\r\n     &quot;field1&quot; : &quot;value1&quot;,\r\n     &quot;field2.1; Field2.2; Field2.3&quot; : &quot;Field2.1Value0; Field2.2Value0; Field2.3Value0&quot;\r\n    }\r\n\r\nthen the invocation:\r\n\r\n    jq -f program.jq input.json\r\n\r\nshould yield:\r\n\r\n    [\r\n      {\r\n        &quot;field1&quot;: &quot;value1&quot;\r\n      },\r\n      {\r\n        &quot;field2.1&quot;: &quot;Field2.1Value0&quot;,\r\n        &quot;Field2.2&quot;: &quot;Field2.2Value0&quot;,\r\n        &quot;Field2.3&quot;: &quot;Field2.3Value0&quot;\r\n      }\r\n    ]\r\n\r\n\r\nIt might make sense to add some error-checking or error-correcting code.\r\n\r\n### Recycling the headers\r\n\r\nNow let&#39;s modify the above so that headers will be recycled in accordance with the problem statement.\r\n\r\n    def objectifyRows(headers):\r\n      (headers|length) as $m\r\n      | (length / $m)  as $n\r\n      | . as $in\r\n      | reduce range(0; $n) as $i ( [];\r\n          .[$i] = (reduce range(0; $m) as $h ({};\r\n                     .[headers[$h]] = $in[($i * $m) + $h] ) ) );\r\n    \r\n    def devolveRows:\r\n      if .key|index(&quot;;&quot;)\r\n      then .key as $key\r\n      | ( [.value | splits(&quot;; *&quot;)] ) \r\n      | objectifyRows([$key | splits(&quot;; *&quot;)])\r\n      else { (.key): .value }\r\n      end;\r\n\r\n\r\n    to_entries | map( devolveRows )\r\n\r\nWith input:\r\n\r\n    {\r\n     &quot;field1&quot; : &quot;value1&quot;,\r\n     &quot;field2.1; Field2.2; Field2.3&quot; :\r\n       &quot;Field2.1Value0; Field2.2Value0; Field2.3Value0; Field2.4Value0; Field2.5Value0; Field2.6Value0&quot;\r\n    }\r\n\r\nthe output would be:\r\n\r\n    [\r\n      {\r\n        &quot;field1&quot;: &quot;value1&quot;\r\n      },\r\n      [\r\n        {\r\n          &quot;field2.1&quot;: &quot;Field2.1Value0&quot;,\r\n          &quot;Field2.2&quot;: &quot;Field2.2Value0&quot;,\r\n          &quot;Field2.3&quot;: &quot;Field2.3Value0&quot;\r\n        },\r\n        {\r\n          &quot;field2.1&quot;: &quot;Field2.4Value0&quot;,\r\n          &quot;Field2.2&quot;: &quot;Field2.5Value0&quot;,\r\n          &quot;Field2.3&quot;: &quot;Field2.6Value0&quot;\r\n        }\r\n      ]\r\n    ]\r\n\r\n     \r\nThis output can now easily be tweaked along the lines suggested by the OP, e.g. to introduce a new key, one could pipe the above into:\r\n\r\n    .[0] + { newfield: .[1] }\r\n\r\n\r\n### Functional definitions\r\n\r\nHere are reduce-free but efficient (assuming jq &gt;= 1.5) implementations of `objectify` and `objectifyRows`: \r\n\r\n    def objectify(headers):\r\n      [headers, .] | transpose | map( {(.[0]): .[1]} ) | add;\r\n\r\n    def objectifyRows(headers):\r\n      def gather(n):\r\n        def g: if length&gt;0 then .[0:n], (.[n:] | g ) else empty end;\r\n        g;\r\n      [gather(headers|length) | objectify(headers)] ;\r\n\r\n    \r\n\r\n\r\n",
                "title": "jq iterate over a array of values a subset at a time"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1494038811,
                "creation_date": 1494038811,
                "answer_id": 43816179,
                "question_id": 43771630,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is my almost final solution that inserts the new key as well as uses the first element of the &quot;;&quot; list as the key for sorting the array.\r\n\r\n    def objectifyRows(headers):\r\n      (headers|length) as $m\r\n      | (headers[0]) as $firstkey\r\n      | (length / $m)  as $n\r\n      | . as $in\r\n      | reduce range(0; $n) as $i ( [];\r\n          .[$i] = (reduce range(0; $m) as $h ({};\r\n                     .[headers[$h]] = $in[($i * $m) + $h] ) ) )\r\n      ;\r\n\r\n    def devolveRows:\r\n      if .key|index(&quot;;&quot;)\r\n      then .key as $multikey\r\n        | ( [.value | splits(&quot;; *&quot;)] ) \r\n        # Create a new key with value being an array of the &quot;splits&quot; \r\n        | { ($multikey): objectifyRows([$multikey | splits(&quot;; *&quot;)])}\r\n        # here &quot;arbitrarily&quot; sort by the first split key\r\n        | .[$multikey] |= sort_by(.[[$multikey | splits(&quot;; *&quot;)][0]])\r\n      else { (.key): .value }\r\n      end;\r\n\r\n    to_entries | map( devolveRows )\r\n",
                "title": "jq iterate over a array of values a subset at a time"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1494038811,
        "creation_date": 1493854470,
        "question_id": 43771630,
        "body_markdown": "I have json (that actually starts as csv) of the form of an array of elements of the form:\r\n\r\n    {\r\n        &quot;field1&quot; : &quot;value1&quot;\r\n        &quot;field2.1; Field2.2 Field2.3&quot; : &quot;Field2.1Value0; Field2.2Value0; Field2.3Value0; Field2.1Value1; Field2.2Value1; Field2.3Value1; ...&quot;\r\n    }\r\n    ...\r\n\r\nI would like to iterate over the string of the field &quot;field2.1; Field2.2 Field2.3&quot;, three &quot;;&quot; separated items at a time to produce an array of key value pairs\r\n\r\n    {\r\n        &quot;field1&quot; : &quot;value1&quot;\r\n        &quot;newfield&quot; : [\r\n              { &quot;Field2.1&quot;: &quot;Field2.1Value0&quot;,\r\n                &quot;Field2.2&quot;: &quot;Field2.2Value0&quot;,\r\n                &quot;Field2.3&quot;: &quot;Field2.1Value0&quot; },\r\n              { &quot;Field2.1&quot;: &quot;Field2.1Value1&quot;,\r\n                &quot;Field2.2&quot;: &quot;Field2.2Value1&quot;,\r\n                &quot;Field2.3&quot;: &quot;Field2.3Value1&quot;},\r\n              ...\r\n        ]\r\n    }\r\n    ...\r\n\r\nnote that there are actually a couple of keys that need to be expanded like this. Each with a variable number of &quot;sub-keys&quot;.\r\n\r\nIn other words, the original CSV file contains some columns that represent tuples of field values separated by semicolons.\r\n\r\nI know how to get down to the &quot;field2.1; Field2.2 Field2.3&quot; and say split it on the &quot;;&quot; but then I&#39;m stuck trying to iterate through that 3 (or however many) items at a time to produce the separate 3 tuples.\r\n\r\nThe real world example/context is the format of the CSV from catalog export from the Google Play Store.\r\n\r\nFor example Field2.1 is Locale, Field2.2 is Title and Field3.3 is Description:\r\n\r\n    jq &#39;.&quot;Locale; Title; Description&quot; |= split(&quot;;&quot;) &#39; \r\n\r\nIf possible, then it would be nice if the iteration is based on the number of semicolon separated &quot;subfields&quot; in the key value. There is another column that has a similar format for the price in each country.\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/43771630/jq-iterate-over-a-array-of-values-a-subset-at-a-time",
        "title": "jq iterate over a array of values a subset at a time"
    },
    {
        "tags": [
            "json",
            "bash",
            "command-line-interface",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10648681,
                    "reputation": 13005,
                    "user_id": 7840440,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8YBUl.png?s=256",
                    "display_name": "Raman Sailopal",
                    "link": "https://stackoverflow.com/users/7840440/raman-sailopal"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1493905212,
                "post_id": 43784145,
                "comment_id": 74609409,
                "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": 1493943315,
                "post_id": 43784145,
                "comment_id": 74629848,
                "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": 1494063502,
                "post_id": 43784145,
                "comment_id": 74676369,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1494064555,
                "last_edit_date": 1494064555,
                "creation_date": 1493905010,
                "answer_id": 43784459,
                "question_id": 43784145,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; to select the name of entry which has aNo = 66\r\n\r\nThis response assumes file.json contains the array:\r\n\r\n    [\r\n    {\r\n      &quot;aNo&quot;: 66,\r\n      &quot;name&quot;: &quot;Fella&quot;\r\n    },\r\n    {\r\n      &quot;aNo&quot;: 77,\r\n      &quot;name&quot;: &quot;Bella&quot;\r\n    }\r\n    ]\r\n\r\n***jq*** approach:\r\n\r\n    jq &#39;.[] | select(.aNo == 66).name&#39; file.json\r\n\r\nThe output:\r\n\r\n    &quot;Fella&quot;\r\n\r\n\r\n",
                "title": "json - select object without quotation using jq tool"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1642839011,
                "creation_date": 1642839011,
                "answer_id": 70811078,
                "question_id": 43784145,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First convert the unstructured json into proper one using --slurp/-s option\r\n\r\n&gt; --slurp/-s: Instead of running the filter for each JSON object in the input, read the entire input stream into a large array and run the\r\n&gt; filter just once.\r\n\r\n    cat file.json\r\n    {\r\n      &quot;aNo&quot;: 66,\r\n      &quot;name&quot;: &quot;Fella&quot;\r\n    }\r\n    {\r\n      &quot;aNo&quot;: 77,\r\n      &quot;name&quot;: &quot;Bella&quot;\r\n    }\r\n\r\n    cat file.json | jq -s\r\n    [\r\n      {\r\n        &quot;aNo&quot;: 66,\r\n        &quot;name&quot;: &quot;Fella&quot;\r\n      },\r\n      {\r\n        &quot;aNo&quot;: 77,\r\n        &quot;name&quot;: &quot;Bella&quot;\r\n      }\r\n    ]\r\n\r\n    cat file.json | jq -s | jq -r &#39;.[]|select(.aNo == 66).name&#39;\r\n    Fella\r\n\r\n",
                "title": "json - select object without quotation using jq tool"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1642839011,
        "creation_date": 1493904218,
        "question_id": 43784145,
        "body_markdown": "I have the following json file:\r\n\r\n    {\r\n      &quot;aNo&quot;: 66,\r\n      &quot;name&quot;: &quot;Fella&quot;\r\n    }\r\n    {\r\n      &quot;aNo&quot;: 77,\r\n      &quot;name&quot;: &quot;Bella&quot;\r\n    }\r\nI am trying to select the name of entry which has aNo = 66 without success. However the vice versa is working, I am using this example :\r\n\r\n\r\n&gt; cat file.json | jq &#39;.[] | select(.name==&quot;Fella&quot;)\r\n\r\nIt works, I get the whole key :\r\n\r\n    {\r\n      &quot;aNo&quot;: 66,\r\n      &quot;name&quot;: &quot;Fella&quot;\r\n    }\r\nNow what I am asking about, is :\r\n\r\n 1. How to get the key based on aNo? \r\n 2. How to get only the name without any other values in the result.  \r\n 3. Why I can&#39;t pipeline jq results ?? I get error messages when I do.\r\n\r\nThank you all for your great help !",
        "link": "https://stackoverflow.com/questions/43784145/json-select-object-without-quotation-using-jq-tool",
        "title": "json - select object without quotation using jq tool"
    },
    {
        "tags": [
            "json",
            "wildcard",
            "jq",
            "alternation"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1494094809,
                "last_edit_date": 1494094809,
                "creation_date": 1494091028,
                "answer_id": 43823287,
                "question_id": 43822906,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The trick is to define a helper function.  If, for example, you write:\r\n\r\n    def payloads(keys): . as $in\r\n      | reduce keys[] as $key ({}; .[$key] = ($in|.[$key].payload?) );\r\n\r\nthen your query becomes:\r\n\r\n    .containers[] | { \r\n        name: .container_name,\r\n \t    package_inventory: (.capabilities | payloads( [&quot;apk&quot;,&quot;dpkg&quot;,&quot;rpm&quot;] ))\r\n    }\r\n\r\nOther variants of course are also possible. For example, you could define `payloads` as an arity-2 function, and thereby pass in &quot;capabilities&quot;.\r\n\r\n### Using a JSON object to specify the keys\r\n\r\nHere is a variant of `payloads/1` illustrating (a) how to avoid `reduce`, and (b) how the keys can be specified by giving a JSON object as template:\r\n\r\n    def payloads_at(object):\r\n      . as $in\r\n      | object as $object\r\n      | ({}\r\n         | [($object|keys_unsorted[]) as $key\r\n            | .[$key] = ($in|.[$key].payload?) ])\r\n      | add;\r\n\r\n This could be called like so: payloads_at( {apk, dpkg, rpm} ), or if you want the keys to be dynamically determined:\r\n\r\n    (.capabilities | payloads_at( . ) )\r\n",
                "title": "How can I filter for multiple object identifiers using the equivalent of wildcards or alternation in jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1494316417,
                "last_edit_date": 1494316417,
                "creation_date": 1494100010,
                "answer_id": 43824717,
                "question_id": 43822906,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This helper function is perhaps closer to what you&#39;re looking for:\r\n\r\n    def star(pre; template; post):\r\n      pre as $object\r\n      | ({} | [($object|template|keys_unsorted[]) as $key | .[$key] = ($object | .[$key] | post) ])\r\n      | add;\r\n\r\n\r\n### Usage\r\n\r\nExplicit list of key names:\r\n\r\n    star(.capabilities; {apk,dpkg,rpm}; .payload)\r\n\r\nKeys of .capabilities:\r\n\r\n\tstar(.capabilities; .; .payload)\r\n\r\n### Example:\r\n\r\n    .containers[] | { \r\n        name: .container_name,\r\n\t    package_inventory: star(.capabilities; .; .payload)\r\n    }\r\n\r\n",
                "title": "How can I filter for multiple object identifiers using the equivalent of wildcards or alternation in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1494316417,
        "creation_date": 1494088726,
        "question_id": 43822906,
        "body_markdown": "## Summary\r\nI have a working [jq][1] filter which correctly parses three different *name* and *payload* objects and massages them into the desired output format. The problem is that I&#39;m having to express each object path explicitly, as I can&#39;t see to find a way to express alternation within the object identifiers.\r\n\r\nI would like the filter to be more flexible so that it can show the data structure from `containers` down to any package manager with a title that starts with `Packages`. I need the whole structure, though, and not just the terminal nodes.\r\n\r\nWhat I *think* I need is to express my object identifiers with alternation or wildcards, such as:\r\n\r\n- `.capabilities.*.payload?`\r\n- `.capabilities.([apk, dpkg, rpm]).payload?`\r\n\r\nI realize neither of the above is valid jq syntax, which is the reason for the question. I have included a test corpus with valid JSON immediately below, and my current jq filter is listed in the section below that.\r\n\r\n## Minimal JSON File\r\n\r\nThis is my test corpus, stored as *minimal.json* in the current directory.\r\n\r\n    {\r\n      &quot;containers&quot;: {\r\n        &quot;3dc76c82e566a116e5b64bc91a0b6220c71db7052f68317ebbe90521db55bf36&quot;: {\r\n          &quot;container_name&quot;: &quot;/apache-46869&quot;,\r\n          &quot;capabilities&quot;: {\r\n            &quot;apk&quot;: {\r\n              &quot;title&quot;: &quot;Packages (APK)&quot;\r\n            },\r\n            &quot;dpkg&quot;: {\r\n              &quot;title&quot;: &quot;Packages (DPKG)&quot;,\r\n              &quot;payload&quot;: {\r\n                &quot;apt&quot;: &quot;1.0.9.8.4&quot;,\r\n                &quot;libnghttp2-14&quot;: &quot;1.18.1-1&quot;\r\n              }\r\n            },\r\n            &quot;rpm&quot;: {\r\n              &quot;title&quot;: &quot;Packages (RPM)&quot;\r\n            }\r\n          }\r\n        },\r\n        &quot;474047a1fe238e39fa1917aff0c93154624bbf159d321d49d5e685302589ab51&quot;: {\r\n          &quot;container_name&quot;: &quot;/nginx-alpine-46869&quot;,\r\n          &quot;capabilities&quot;: {\r\n            &quot;apk&quot;: {\r\n              &quot;title&quot;: &quot;Packages (APK)&quot;,\r\n              &quot;payload&quot;: {\r\n                &quot;.nginx-rundeps&quot;: &quot;0&quot;,\r\n                &quot;apk-tools&quot;: &quot;2.6.8-r2&quot;\r\n              }\r\n            },\r\n            &quot;dpkg&quot;: {\r\n              &quot;title&quot;: &quot;Packages (DPKG)&quot;\r\n            },\r\n            &quot;rpm&quot;: {\r\n              &quot;title&quot;: &quot;Packages (RPM)&quot;\r\n            }\r\n          }\r\n        },\r\n        &quot;d7dcd90791240d78022941cf054a6b474f5329acd79aa15b58dc342f95a8ce33&quot;: {\r\n          &quot;container_name&quot;: &quot;/apache-alpine-46869&quot;,\r\n          &quot;capabilities&quot;: {\r\n            &quot;apk&quot;: {\r\n              &quot;title&quot;: &quot;Packages (APK)&quot;,\r\n              &quot;payload&quot;: {\r\n                &quot;.httpd-rundeps&quot;: &quot;0&quot;,\r\n                &quot;apk-tools&quot;: &quot;2.6.8-r2&quot;,\r\n                &quot;apr&quot;: &quot;1.5.2-r1&quot;,\r\n                &quot;apr-util&quot;: &quot;1.5.4-r2&quot;\r\n              }\r\n            },\r\n            &quot;dpkg&quot;: {\r\n              &quot;title&quot;: &quot;Packages (DPKG)&quot;\r\n            },\r\n            &quot;rpm&quot;: {\r\n              &quot;title&quot;: &quot;Packages (RPM)&quot;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n## Explicit jq Filter\r\nThis is my current filter, which works but explicitly defines each [optional object indentifier-index][2].\r\n\r\n    jq &#39;\r\n        [ .containers[] | { \r\n            name: .container_name, package_inventory: {\r\n                apk: .capabilities.apk.payload?,\r\n                dpkg: .capabilities.dpkg.payload?,\r\n                rpm: .capabilities.rpm.payload?\r\n            }   \r\n        }]  \r\n    &#39; minimal.json\r\n\r\n## Expected Output\r\n\r\nMy current output (shown below) is correct. The goal isn&#39;t to fix the output, but rather to make the filter more flexible.\r\n\r\n&gt;     [\r\n&gt;       {\r\n&gt;         &quot;name&quot;: &quot;/apache-46869&quot;,\r\n&gt;         &quot;package_inventory&quot;: {\r\n&gt;           &quot;apk&quot;: null,\r\n&gt;           &quot;dpkg&quot;: {\r\n&gt;             &quot;apt&quot;: &quot;1.0.9.8.4&quot;,\r\n&gt;             &quot;libnghttp2-14&quot;: &quot;1.18.1-1&quot;\r\n&gt;           },\r\n&gt;           &quot;rpm&quot;: null\r\n&gt;         }\r\n&gt;       },\r\n&gt;       {\r\n&gt;         &quot;name&quot;: &quot;/nginx-alpine-46869&quot;,\r\n&gt;         &quot;package_inventory&quot;: {\r\n&gt;           &quot;apk&quot;: {\r\n&gt;             &quot;.nginx-rundeps&quot;: &quot;0&quot;,\r\n&gt;             &quot;apk-tools&quot;: &quot;2.6.8-r2&quot;\r\n&gt;           },\r\n&gt;           &quot;dpkg&quot;: null,\r\n&gt;           &quot;rpm&quot;: null\r\n&gt;         }\r\n&gt;       },\r\n&gt;       {\r\n&gt;         &quot;name&quot;: &quot;/apache-alpine-46869&quot;,\r\n&gt;         &quot;package_inventory&quot;: {\r\n&gt;           &quot;apk&quot;: {\r\n&gt;             &quot;.httpd-rundeps&quot;: &quot;0&quot;,\r\n&gt;             &quot;apk-tools&quot;: &quot;2.6.8-r2&quot;,\r\n&gt;             &quot;apr&quot;: &quot;1.5.2-r1&quot;,\r\n&gt;             &quot;apr-util&quot;: &quot;1.5.4-r2&quot;\r\n&gt;           },\r\n&gt;           &quot;dpkg&quot;: null,\r\n&gt;           &quot;rpm&quot;: null\r\n&gt;         }\r\n&gt;       }\r\n&gt;     ]\r\n\r\n  [1]: https://stedolan.github.io/jq/\r\n  [2]: https://stedolan.github.io/jq/manual/#Basicfilters",
        "link": "https://stackoverflow.com/questions/43822906/how-can-i-filter-for-multiple-object-identifiers-using-the-equivalent-of-wildcar",
        "title": "How can I filter for multiple object identifiers using the equivalent of wildcards or alternation in jq?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "select",
            "jq",
            "whitelist"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1494176057,
                "creation_date": 1494176057,
                "answer_id": 43834161,
                "question_id": 43833974,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Changed `contains` for `inside` and it seems to work now:\r\n\r\n    $ jq --compact-output --null-input &#39;[1,2,3,4,5] | map(select([.] | inside([3,4,7])))&#39;\r\n    [3,4]\r\n    $",
                "title": "Whitelisting objects using select"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1604678289,
                "last_edit_date": 1604678289,
                "creation_date": 1494183759,
                "answer_id": 43835465,
                "question_id": 43833974,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The filter you&#39;d use with `contains` is:\r\n\r\n    map(. as $x | select([3,4,7] | contains([$x])))\r\n\r\nYour attempt uses . incorrectly.\r\n\r\n### Using index/1\r\nFor this type of problem, it might be better to use `index/1` than `contains` or its inverse, `inside`. The reasons stem from both semantic and efficiency considerations.\r\n\r\nIf the whitelist is available as $whitelist and if you want to use map(select(...)), an appropriate filter would be:\r\n\r\n    map( . as $x | select($whitelist|index($x)))\r\n\r\nFor long arrays, this of course is very inefficient. For such arrays, you will almost surely want to look at alternatives, such as using `bsearch` (binary search), or a JSON object (hash).\r\n\r\n### def ix:\r\n\r\nThe current implementation of `index/1` is less than ideal for the present purpose, but it is fast because it is written in C.  Here&#39;s an alternative definition that assumes the availability of `any/2`:\r\n\r\n    def ix(x): any(.[]; .==x);",
                "title": "Whitelisting objects using select"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1604678289,
        "creation_date": 1494175026,
        "last_edit_date": 1494453729,
        "question_id": 43833974,
        "body_markdown": "I&#39;m trying to filter lists using `contains` function, provided by jq. **My input**,\r\n\r\n    [1, 2, 3, 4, 5]\r\n\r\nAnd I have a **&quot;whitelist&quot;**:\r\n\r\n    [3, 4, 7]\r\n\r\nI need to filter input list through whitelist. **Expected output**:\r\n\r\n    [3, 4]\r\n\r\nI&#39;m able to filter comparing a single item:\r\n\r\n    jq --compact-output --null-input &#39;[1,2,3,4,5] | map(select(. | contains(3)))&#39;\r\n    [3]\r\n\r\nI tried this:\r\n\r\n    $ jq --compact-output --null-input &#39;[1,2,3,4,5] | map(select([3,4,7] | contains([.])))&#39;\r\n    []\r\n    $\r\n\r\nHere `[3,4,7] | contains([.])` intents to pose question:\r\n\r\n&gt; is `[.]` a sublist of list `[3,4,7]`?\r\n\r\nBut it doesn&#39;t work. What am I missing?\r\n\r\n**How do I filter using a whitelist**?",
        "link": "https://stackoverflow.com/questions/43833974/whitelisting-objects-using-select",
        "title": "Whitelisting objects using select"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 26,
                "is_accepted": true,
                "score": 26,
                "last_activity_date": 1674758232,
                "last_edit_date": 1674758232,
                "creation_date": 1494231549,
                "answer_id": 43842886,
                "question_id": 43842672,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "According to the [jq manual](https://stedolan.github.io/jq/manual/#Array/ObjectValueIterator:.[]), `.[]` gets the values of the object when applied to object.\r\n\r\nSo you get two objects, one for value of `&quot;properties&quot;` and another for value of `&quot;uri&quot;`:\r\n\r\n    {\r\n      &quot;CloudSanityPassed&quot;: [\r\n        &quot;true&quot;\r\n      ],\r\n      &quot;GITCOMMIT&quot;: [\r\n        &quot;test1&quot;\r\n      ],\r\n      &quot;buildNumber&quot;: [\r\n        &quot;54&quot;\r\n      ],\r\n      &quot;jobName&quot;: [\r\n        &quot;InveergDB-UI&quot;\r\n      ]\r\n    }\r\n    &quot;http://ergctory:8081/aergergory/api/storage/test-reergerglease-reergpo/cergom/cloergud/waf/ergregBUI/1ergerggregSHOT/ergregerg-34.zip&quot;\r\n\r\n`jq` tries to apply `.&quot;CloudSanityPassed&quot;` operator to each object.\r\n\r\nSince former object is dictionary (aka hash), you can apply `.&quot;CloudSanityPassed&quot;` and get the value `[&quot;true&quot;]`, however, latter is a simple string against which you cannot apply `.&quot;CloudSanityPassed&quot;`, so `jq` outputs an error at that point.\r\n\r\nMaybe the command you want is just `.properties.CloudSanityPassed`.",
                "title": "jq - Cannot index string with string"
            },
            {
                "up_vote_count": 21,
                "is_accepted": false,
                "score": 21,
                "last_activity_date": 1594226604,
                "creation_date": 1594226604,
                "answer_id": 62799570,
                "question_id": 43842672,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In my case `jq &#39;[.[] | group_by(.foo)]&#39;` gave the error but\r\n`jq &#39;[.[]] | group_by(.foo)&#39;` worked",
                "title": "jq - Cannot index string with string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 32,
        "last_activity_date": 1674758232,
        "creation_date": 1494230814,
        "question_id": 43842672,
        "body_markdown": "The content is\r\n\r\n    {\r\n      &quot;properties&quot; : {\r\n        &quot;CloudSanityPassed&quot; : [ &quot;true&quot; ],\r\n        &quot;GITCOMMIT&quot; : [ &quot;test1&quot; ],\r\n        &quot;buildNumber&quot; : [ &quot;54&quot; ],\r\n        &quot;jobName&quot; : [ &quot;InveergDB-UI&quot; ]\r\n      },\r\n      &quot;uri&quot; : &quot;http://ergctory:8081/aergergory/api/storage/test-reergerglease-reergpo/cergom/cloergud/waf/ergregBUI/1ergerggregSHOT/ergregerg-34.zip&quot;\r\n    }\r\n\r\nI use this command\r\n\r\n    .[] | .&quot;CloudSanityPassed&quot; | .[]\r\n\r\nAnd I get this message \r\n\r\n    jq: error (at &lt;stdin&gt;:8): Cannot index string with string &quot;CloudSanityPassed&quot;\r\n    &quot;true&quot;\r\n    exit status 5\r\n\r\nI get, what I want (&quot;true&quot; value), but there is a error in output. Could you explain me, how to avoid it and why does it happen?",
        "link": "https://stackoverflow.com/questions/43842672/jq-cannot-index-string-with-string",
        "title": "jq - Cannot index string with string"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1494258818,
                "creation_date": 1494258818,
                "answer_id": 43852090,
                "question_id": 43851953,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`jq &#39;map(select(.id | contains(1,3)))&#39;`\r\n\r\nMan, jq is so great\r\n\r\nhttps://github.com/stedolan/jq/wiki/Cookbook#filter-objects-based-on-the-contents-of-a-key",
                "title": "How to select objects with specific IDs from a JSON array with jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1494317635,
                "last_edit_date": 1494317635,
                "creation_date": 1494275015,
                "answer_id": 43856686,
                "question_id": 43851953,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The solution using `contains/1` as presented on this page could just as well be written using `==`:\r\n\r\n    map(select(.id == (1,3)))\r\n\r\nThe main reason for mentioning this is that `contains` is full of potential surprises. (Consider, for example, what would happen if `.id` were string-valued.)\r\n\r\nUnfortunately, using either `==` or `contains` as above is computationally inefficient (it is O(m*n)), though in practice it is quite fast.\r\n\r\n      \r\n\r\n",
                "title": "How to select objects with specific IDs from a JSON array with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1494317635,
        "creation_date": 1494258419,
        "question_id": 43851953,
        "body_markdown": "I have a JSON file containing an array of objects (_test.json_):\r\n\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;Test 1&quot;,\r\n            &quot;id&quot;: 1\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;Test 2&quot;,\r\n            &quot;id&quot;: 2\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;Test 3&quot;,\r\n            &quot;id&quot;: 3\r\n        }\r\n    ]\r\n\r\n\r\nI want to extract all objects, that have a certain ID. I managed to get an object if I want just one specific ID: `jq &#39;map(select(.id == 2 ))&#39; test.json`.\r\n\r\nThing is, I have a list of IDs, say 1 and 3. How do I get a list containing only those object? So in this example a list containing the objects with ID 1 and 3?\r\n\r\nYou can check the example here: https://jqplay.org/s/xQgpA4yJAz",
        "link": "https://stackoverflow.com/questions/43851953/how-to-select-objects-with-specific-ids-from-a-json-array-with-jq",
        "title": "How to select objects with specific IDs from a JSON array with jq?"
    },
    {
        "tags": [
            "json",
            "awk",
            "sed",
            "stream",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 262968,
                    "reputation": 789094,
                    "user_id": 548225,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/dab08478b226280d4a30894c9a7ed719?s=256&d=identicon&r=PG",
                    "display_name": "anubhava",
                    "link": "https://stackoverflow.com/users/548225/anubhava"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1494430312,
                "post_id": 43896931,
                "comment_id": 74827832,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1247396,
                    "reputation": 2020,
                    "user_id": 1208557,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6a00febf9d0d332f604585754d70919a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jinxmcg",
                    "link": "https://stackoverflow.com/users/1208557/jinxmcg"
                },
                "reply_to_user": {
                    "account_id": 262968,
                    "reputation": 789094,
                    "user_id": 548225,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/dab08478b226280d4a30894c9a7ed719?s=256&d=identicon&r=PG",
                    "display_name": "anubhava",
                    "link": "https://stackoverflow.com/users/548225/anubhava"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1494430592,
                "post_id": 43896931,
                "comment_id": 74828017,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1494433793,
                "last_edit_date": 1494433793,
                "creation_date": 1494432528,
                "answer_id": 43897717,
                "question_id": 43896931,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With GNU or OSX sed for ERE support via `-E`:\r\n\r\n    $ sed -E &#39;s#(.*&quot;url&quot;:&quot;([^&quot;]+\\/\\/)?([^&quot;/]+).*&quot;dm&quot;:&quot;)-&quot;#\\1\\3&quot;#&#39; file\r\n    {&quot;id&quot;:13, &quot;url&quot;:&quot;https://sub.domain.com/path&quot;, &quot;dm&quot;:&quot;sub.domain.com&quot;, &quot;ip&quot;:&quot;192.168.0.1&quot;}\r\n    {&quot;id&quot;:14, &quot;url&quot;:&quot;sub.domain2.com/?param=value&quot;, &quot;dm&quot;:&quot;sub.domain2.com&quot;, &quot;ip&quot;:&quot;192.168.0.1&quot;}\r\n    {&quot;id&quot;:15, &quot;url&quot;:&quot;domain.com/path&quot;, &quot;dm&quot;:&quot;domain.com&quot;, &quot;ip&quot;:&quot;192.168.0.1&quot;}\r\n\r\nWith GNU awk for the 3rd arg to match():\r\n\r\n    $ awk &#39;match($0,/(.*&quot;url&quot;:&quot;([^&quot;]+\\/\\/)?([^&quot;/]+).*&quot;dm&quot;:&quot;)-(&quot;.*)/,a){$0=a[1] a[3] a[4]} 1&#39; file\r\n    {&quot;id&quot;:13, &quot;url&quot;:&quot;https://sub.domain.com/path&quot;, &quot;dm&quot;:&quot;sub.domain.com&quot;, &quot;ip&quot;:&quot;192.168.0.1&quot;}\r\n    {&quot;id&quot;:14, &quot;url&quot;:&quot;sub.domain2.com/?param=value&quot;, &quot;dm&quot;:&quot;sub.domain2.com&quot;, &quot;ip&quot;:&quot;192.168.0.1&quot;}\r\n    {&quot;id&quot;:15, &quot;url&quot;:&quot;domain.com/path&quot;, &quot;dm&quot;:&quot;domain.com&quot;, &quot;ip&quot;:&quot;192.168.0.1&quot;}\r\n\r\n\r\n\r\n",
                "title": "Replace pattern with part of matched string from the sameline in bash"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1494452017,
                "last_edit_date": 1494452017,
                "creation_date": 1494433107,
                "answer_id": 43897914,
                "question_id": 43896931,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With `jq-1.5` (the most recent version atm) you can do:\r\n\r\n    jq &#39;if .dm == &quot;-&quot; then .dm = (.url|sub(&quot;https?://&quot;;&quot;&quot;)|sub(&quot;/.*&quot;;&quot;&quot;)) else . end&#39; a.json\r\n\r\nExplanation:\r\n\r\n    if .dm == &quot;-&quot; ...           # Runs the following only if .dm exists and it&#39;s value is &quot;-&quot;\r\n    .dm=(...)                   # Assigns to .dm\r\n    .url|sub(&quot;^https?://&quot;; &quot;&quot;)  # Takes .url and replaces http/https:// from the beginning\r\n    ...|sub(&quot;/.*&quot;; &quot;&quot;)          # Replaces everything after the first / (including it)",
                "title": "Replace pattern with part of matched string from the sameline in bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1494433645,
                "last_edit_date": 1494433645,
                "creation_date": 1494433181,
                "answer_id": 43897935,
                "question_id": 43896931,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use sed to do it, but I&#39;d suggest you to use something that actually comprehends the data if there is any variation in the format:\r\n\r\n    sed -i -r &#39;s/^(.*&quot;url&quot;:&quot;)(.*\\/\\/)?(.*)(\\/.*)&quot;-&quot;/\\1\\2\\3\\4&quot;\\3&quot;/g&#39; your_file",
                "title": "Replace pattern with part of matched string from the sameline in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1494452017,
        "creation_date": 1494430261,
        "last_edit_date": 1494438925,
        "question_id": 43896931,
        "body_markdown": "I have a file with one json per line of the following format:\r\n\r\n    {&quot;id&quot;:13, &quot;url&quot;:&quot;https://sub.domain.com/path&quot;, &quot;dm&quot;:&quot;-&quot;, &quot;ip&quot;:&quot;192.168.0.1&quot;}\r\n    {&quot;id&quot;:14, &quot;url&quot;:&quot;sub.domain2.com/?param=value&quot;, &quot;dm&quot;:&quot;-&quot;, &quot;ip&quot;:&quot;192.168.0.1&quot;}\r\n    {&quot;id&quot;:15, &quot;url&quot;:&quot;domain.com/path&quot;, &quot;dm&quot;:&quot;prefilled.com&quot;, &quot;ip&quot;:&quot;192.168.0.1&quot;}\r\n\r\nand I need to replace &quot;dm&quot;:&quot;-&quot; with the respective domain from the same line to get this output:\r\n\r\n    {&quot;id&quot;:13, &quot;url&quot;:&quot;https://sub.domain.com/path&quot;, &quot;dm&quot;:&quot;sub.domain.com&quot;, &quot;ip&quot;:&quot;192.168.0.1&quot;}\r\n    {&quot;id&quot;:14, &quot;url&quot;:&quot;sub.domain2.com/?param=value&quot;, &quot;dm&quot;:&quot;sub.domain2.com&quot;, &quot;ip&quot;:&quot;192.168.0.1&quot;}\r\n    {&quot;id&quot;:15, &quot;url&quot;:&quot;domain.com/path&quot;, &quot;dm&quot;:&quot;prefilled.com&quot;, &quot;ip&quot;:&quot;192.168.0.1&quot;}\r\n\r\nwith any bash commands only for the lines that have &quot;dm&quot;:&quot;-&quot; in an optimized way as the files are more than 10k lines long",
        "link": "https://stackoverflow.com/questions/43896931/replace-pattern-with-part-of-matched-string-from-the-sameline-in-bash",
        "title": "Replace pattern with part of matched string from the sameline in bash"
    },
    {
        "tags": [
            "json",
            "google-bigquery",
            "jq",
            "reformatting",
            "jsonlines"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1494495642,
                "last_edit_date": 1494495642,
                "creation_date": 1494493449,
                "answer_id": 43911027,
                "question_id": 43910858,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The key here is the &quot;-c&quot; option, which in effect tells jq to use the JSONLines output format.  \r\n\r\nIn your particular case, the solution is simply:\r\n\r\n    jq -c &#39;.[]&#39;\r\n\r\nYour shell might even allow you to drop the quotation marks :-)",
                "title": "Make one (sub-)JSON object appearing on one line by jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1494495642,
        "creation_date": 1494492937,
        "last_edit_date": 1494495528,
        "question_id": 43910858,
        "body_markdown": "In Cloud BigQuery, the accepted JSON format is:\r\n\r\n&gt; One JSON object, including any nested/repeated fields, must appear on each line.\r\n&gt;\r\n&gt; refer to: https://cloud.google.com/bigquery/data-formats#json_format\r\n\r\nNow, given a json:\r\n\r\n    {\r\n      &quot;1&quot;: {\r\n        &quot;kind&quot;: &quot;person&quot;,\r\n        &quot;fullName&quot;: &quot;John Doe&quot;,\r\n        &quot;age&quot;: 22,\r\n        &quot;gender&quot;: &quot;Male&quot;,\r\n        &quot;citiesLived&quot;: [\r\n          {\r\n            &quot;place&quot;: &quot;Seattle&quot;,\r\n            &quot;numberOfYears&quot;: 5\r\n          },\r\n          {\r\n            &quot;place&quot;: &quot;Stockholm&quot;,\r\n            &quot;numberOfYears&quot;: 6\r\n          }\r\n        ]\r\n      },\r\n      &quot;2&quot;: {\r\n        &quot;kind&quot;: &quot;person&quot;,\r\n        &quot;fullName&quot;: &quot;Jane Austen&quot;,\r\n        &quot;age&quot;: 24,\r\n        &quot;gender&quot;: &quot;Female&quot;,\r\n        &quot;citiesLived&quot;: [\r\n          {\r\n            &quot;place&quot;: &quot;Los Angeles&quot;,\r\n            &quot;numberOfYears&quot;: 2\r\n          },\r\n          {\r\n            &quot;place&quot;: &quot;Tokyo&quot;,\r\n            &quot;numberOfYears&quot;: 2\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nHow to convert it into the following by `jq`?\r\n\r\n    {&quot;kind&quot;: &quot;person&quot;, &quot;fullName&quot;: &quot;John Doe&quot;, &quot;age&quot;: 22, &quot;gender&quot;: &quot;Male&quot;, &quot;citiesLived&quot;: [{ &quot;place&quot;: &quot;Seattle&quot;, &quot;numberOfYears&quot;: 5}, {&quot;place&quot;: &quot;Stockholm&quot;, &quot;numberOfYears&quot;: 6}]}\r\n    {&quot;kind&quot;: &quot;person&quot;, &quot;fullName&quot;: &quot;Jane Austen&quot;, &quot;age&quot;: 24, &quot;gender&quot;: &quot;Female&quot;, &quot;citiesLived&quot;: [{&quot;place&quot;: &quot;Los Angeles&quot;, &quot;numberOfYears&quot;: 2}, {&quot;place&quot;: &quot;Tokyo&quot;, &quot;numberOfYears&quot;: 2}]}\r\n",
        "link": "https://stackoverflow.com/questions/43910858/make-one-sub-json-object-appearing-on-one-line-by-jq",
        "title": "Make one (sub-)JSON object appearing on one line by jq"
    },
    {
        "tags": [
            "json",
            "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": 1494535053,
                "post_id": 43924402,
                "comment_id": 74883535,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1494534878,
                "creation_date": 1494534878,
                "answer_id": 43925057,
                "question_id": 43924402,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following seems to work:\r\n\r\n    .taskDefinition.containerDefinitions[] |\r\n      select(\r\n        select(\r\n         .environment[] | .name == &quot;DATABASES_DEFAULT&quot;\r\n        ).name == &quot;baz&quot;\r\n      )\r\n\r\nThe output is the object with the `name` key mapped to &quot;baz&quot;.\r\n\r\n\r\n    $ jq &#39;.taskDefinition.containerDefinitions[] | select(select(.environment[]|.name == &quot;DATABASES_DEFAULT&quot;).name==&quot;baz&quot;)&#39; tmp.json\r\n    {\r\n      &quot;dnsSearchDomains&quot;: [],\r\n      &quot;environment&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;bar4&quot;,\r\n          &quot;value&quot;: &quot;bar5&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;bar6&quot;,\r\n          &quot;value&quot;: &quot;bar7&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;DATABASES_DEFAULT&quot;,\r\n          &quot;value&quot;: &quot;foo&quot;\r\n        }\r\n      ],\r\n      &quot;name&quot;: &quot;baz&quot;,\r\n      &quot;links&quot;: []\r\n    }",
                "title": "jq get the value of x based on y in a complex json file"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1494537911,
                "creation_date": 1494537911,
                "answer_id": 43925802,
                "question_id": 43924402,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I like to think of it as digging down into the structure, so first you open the outer layers:\r\n\r\n    .taskDefinition.containerDefinitions[]\r\n\r\nNow select the one you want:\r\n\r\n    select(.name ==&quot;baz&quot;)\r\n\r\nOpen the inner structure:\r\n\r\n    .environment[]\r\n\r\nSelect the desired object:\r\n\r\n    select(.name == &quot;DATABASES_DEFAULT&quot;)\r\n\r\nChoose the key you want:\r\n\r\n    .value\r\n\r\nTaken together:\r\n\r\n&lt;!-- language: lang-jq --&gt;\r\n\r\n_parse.jq_\r\n\r\n    .taskDefinition.containerDefinitions[] |\r\n    select(.name ==&quot;baz&quot;)                  |\r\n    .environment[]                         |\r\n    select(.name == &quot;DATABASES_DEFAULT&quot;)   |\r\n    .value\r\n\r\nRun it like this:\r\n\r\n    &lt;infile jq -f parse.jq\r\n\r\nOutput:\r\n\r\n    &quot;foo&quot;",
                "title": "jq get the value of x based on y in a complex json file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1494537911,
        "creation_date": 1494532319,
        "question_id": 43924402,
        "body_markdown": "jq strikes again. Trying to get the value of `DATABASES_DEFAULT` based on the `name` in a json file that has a whole lot of `name`s and I&#39;m completely lost. \r\n\r\nMy file looks like the following (output of an `aws ecs describe-task-definition`) only much more complex; I&#39;ve stripped this to the most basic example I can where the structure is still intact. \r\n\r\n    {\r\n        &quot;taskDefinition&quot;: {\r\n            &quot;status&quot;: &quot;bar&quot;, \r\n            &quot;family&quot;: &quot;bar2&quot;,  \r\n            &quot;volumes&quot;: [], \r\n            &quot;taskDefinitionArn&quot;: &quot;bar3&quot;, \r\n            &quot;containerDefinitions&quot;: [\r\n                {\r\n                    &quot;dnsSearchDomains&quot;: [], \r\n                    &quot;environment&quot;: [\r\n                        {\r\n                            &quot;name&quot;: &quot;bar4&quot;, \r\n                            &quot;value&quot;: &quot;bar5&quot;\r\n                        }, \r\n                        {\r\n                            &quot;name&quot;: &quot;bar6&quot;, \r\n                            &quot;value&quot;: &quot;bar7&quot;\r\n                        },  \r\n                        {\r\n                            &quot;name&quot;: &quot;DATABASES_DEFAULT&quot;, \r\n                            &quot;value&quot;: &quot;foo&quot;\r\n                        }\r\n                    ], \r\n                    &quot;name&quot;: &quot;baz&quot;, \r\n                    &quot;links&quot;: []\r\n                },\r\n                {\r\n                    &quot;dnsSearchDomains&quot;: [], \r\n                    &quot;environment&quot;: [\r\n                        {\r\n                            &quot;name&quot;: &quot;bar4&quot;, \r\n                            &quot;value&quot;: &quot;bar5&quot;\r\n                        }, \r\n                        {\r\n                            &quot;name&quot;: &quot;bar6&quot;, \r\n                            &quot;value&quot;: &quot;bar7&quot;\r\n                        },  \r\n                        {\r\n                            &quot;name&quot;: &quot;DATABASES_DEFAULT&quot;, \r\n                            &quot;value&quot;: &quot;foo2&quot;\r\n                        }\r\n                    ], \r\n                    &quot;name&quot;: &quot;boo&quot;, \r\n                    &quot;links&quot;: []\r\n                }\r\n            ], \r\n            &quot;revision&quot;: 1\r\n        }\r\n    }\r\n\r\nI need the value of `DATABASES_DEFAULT` where the `name` is `baz`. Note that there are a lot of keypairs with `name`, I&#39;m specifically talking about the one outside of `environment`.\r\n\r\nI&#39;ve been tinkering with this but only got this far before realizing that I don&#39;t understand how to access nested values.\r\n\r\n    jq &#39;.[] | select(.name==DATABASES_DEFAULT) | .value&#39;\r\n\r\nwhich is returning\r\n\r\n    jq: error: DATABASES_DEFAULT/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .[] | select(.name==DATABASES_DEFAULT) | .value\r\n    jq: 1 compile error\r\n\r\nObviously this a) doesn&#39;t work, and b) even if it did, it&#39;s independant of the `name` value. My thought was to return all the db defaults and then identify the one with baz, but I don&#39;t know if that&#39;s the right approach. \r\n\r\n",
        "link": "https://stackoverflow.com/questions/43924402/jq-get-the-value-of-x-based-on-y-in-a-complex-json-file",
        "title": "jq get the value of x based on y in a complex json file"
    },
    {
        "tags": [
            "json",
            "filtering",
            "jq",
            "recursive-datastructures"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1494621367,
                "creation_date": 1494621367,
                "answer_id": 43946093,
                "question_id": 43946092,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The filter in the following `jq` command recurses down a &quot;path&quot; of objects that have `name` properties which correspond to the &quot;path&quot; aaa/bbb/ccc/ddd:\r\n\r\n    jq &#39;.subs[] | select(.name = &quot;aaa&quot;) | .subs[] | select(.name = &quot;bbb&quot;) | .subs[] | select(.name = &quot;ccc&quot;) | .subs[] | .payload&#39;\r\n\r\nHere it is live on qplay.org:\r\n\r\nhttps://jqplay.org/s/tblW7UX0Si",
                "title": "How to recurse with jq on nested JSON where each object has a name property?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1494793030,
                "last_edit_date": 1494793030,
                "creation_date": 1494625084,
                "answer_id": 43946830,
                "question_id": 43946092,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is the basis for a generic solution:\r\n\r\n    def descend(name): .subs[] | select(.name == name);\r\n\r\nSo your particular query could be formulated as follows:\r\n\r\n    descend( &quot;aaa&quot;) | descend( &quot;bbb&quot;) | descend( &quot;ccc&quot;) | descend( &quot;ddd&quot;) | .payload\r\n\r\nOr slightly better, still using the above definition of `descend`:\r\n\r\n    def path(array): \r\n      if (array|length)==0 then . \r\n      else descend(array[0]) | path(array[1:])\r\n      end;\r\n\r\n    path( [&quot;aaa&quot;, &quot;bbb&quot;, &quot;ccc&quot;, &quot;ddd&quot;] ) | .payload\r\n\r\n### TCO\r\nThe above recursive definition of `path/1` is simple enough but would be unsuitable for very deeply nested data structures, e.g. if the depth is greater than 1000.  Here is an alternative definition that takes advantage of jq&#39;s tail-call optimization, and that therefore runs very quickly:\r\n\r\n    def atpath(array):\r\n      [array, .] \r\n      |  until( .[0] == []; .[0] as $a | .[1] | descend($a[0]) | [$a[1:], . ] )\r\n      | .[1];\r\n\r\n   \r\n### .aaa.bbb.ccc.ddd\r\n\r\nIf you want to be able to use the .aaa.bbb.ccc.ddd notation, one approach would be to begin by &quot;flattening&quot; the data:\r\n\r\n    def flat:\r\n      { (.name): (if .subs then (.subs[] | flat) else .payload end) };\r\n\r\nSince the top-level element does not have a &quot;name&quot; tag, the query would then be: \r\n\r\n    .subs[] | flat | .aaa.bbb.ccc.ddd\r\n\r\nHere is a more efficient approach, once again using `descend` defined above:\r\n\r\n    def payload(p):\r\n      def get($array):\r\n        if $array == []\r\n        then .payload\r\n        else descend($array[0]) | get($array[1:]) end;\r\n      get( null | path(p) );\r\n    \r\n    payload( .aaa.bbb.ccc.ddd )\r\n\r\n\r\n",
                "title": "How to recurse with jq on nested JSON where each object has a name property?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1494793030,
        "creation_date": 1494621367,
        "last_edit_date": 1495540504,
        "question_id": 43946092,
        "body_markdown": "I have a nested JSON object where each level has the same property key and what distinguishes each level is a property called `name`.  If I want to traverse down to a level which has a particular &quot;path&quot; of `name` properties, how would I formulate the `jq` filter?\r\n\r\nHere is some sample JSON data that represents a file system&#39;s directory structure:\r\n\r\n    {\r\n      &quot;subs&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;aaa&quot;,\r\n          &quot;subs&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;bbb&quot;,\r\n              &quot;subs&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;ccc&quot;,\r\n                  &quot;subs&quot;: [\r\n                    {\r\n                      &quot;name&quot;: &quot;ddd&quot;,\r\n                      &quot;payload&quot;: &quot;xyz&quot;\r\n                    }\r\n                  ]\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nWhat&#39;s a `jq` filter for obtaining the value of the payload in the &quot;path&quot; aaa/bbb/ccc/ddd?\r\n\r\n*Prior research:*\r\n\r\n 1. https://stackoverflow.com/questions/23268506/jq-select-objects-with-given-key-name - helpful but looks for any element in the JSON which contains the specified name whereas I&#39;m looking for an element that&#39;s nested under a set of objects who also have specific names.\r\n\r\n 2. http://arjanvandergaag.nl/blog/wrestling-json-with-jq.html - helpful in section 4 where it shows how to extract an object having a property `name` having a particular value.  However, the recursion performed is based a specific known set of property names (&quot;values[].links.clone[]&quot;).  In my case, my equivalent is just &quot;subs[].subs[].subs[]&quot;.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/43946092/how-to-recurse-with-jq-on-nested-json-where-each-object-has-a-name-property",
        "title": "How to recurse with jq on nested JSON where each object has a name property?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1494670828,
                "creation_date": 1494670828,
                "answer_id": 43951947,
                "question_id": 43950580,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "#Try \r\n\r\n- &lt;pre&gt;\r\njq -s &#39;{staticstring:[{PutRequest:{Item:.[]}}]}&#39; **inputfile.json**\r\n\r\n\r\n&lt;/pre&gt;\r\n",
                "title": "adding parent element to json objects using jq/bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1494670828,
        "creation_date": 1494661650,
        "question_id": 43950580,
        "body_markdown": "I want to add a parent to each of the json objects within a file.\r\nMy starting point is the following json file containing two json items:\r\n  \r\n    {\r\n      &quot;id&quot;: {\r\n        &quot;S&quot;: &quot;cf7ebec368f241ead7ecf818ce9ed098406afa63&quot;\r\n      },\r\n      &quot;test&quot;: {\r\n        &quot;N&quot;: &quot;5&quot;\r\n      },\r\n      &quot;added&quot;: {\r\n        &quot;S&quot;: &quot;2017-02-15T17:56:19.958917+00:00&quot;\r\n      },\r\n      &quot;foo&quot;: {\r\n        &quot;N&quot;: &quot;88&quot;\r\n      },\r\n      &quot;web&quot;: {\r\n        &quot;N&quot;: &quot;103&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;id&quot;: {\r\n        &quot;S&quot;: &quot;cf7ebec368f241ead7ecf818ce9ed098406afa63&quot;\r\n      },\r\n      &quot;image_server_id&quot;: {\r\n        &quot;N&quot;: &quot;5&quot;\r\n      },\r\n      &quot;added&quot;: {\r\n        &quot;S&quot;: &quot;2017-02-15T17:56:19.958917+00:00&quot;\r\n      },\r\n      &quot;result&quot;: {\r\n        &quot;N&quot;: &quot;88&quot;\r\n      },\r\n      &quot;data&quot;: {\r\n         &quot;foo&quot;: {\r\n           &quot;N&quot;: &quot;103&quot;,\r\n           &quot;S&quot;: &quot;test&quot;\r\n         }\r\n      }\r\n    }\r\n\r\n\r\nUsing jq and/or bash I want to generate the following json file:\r\n\r\n    {\r\n       &quot;*StaticString*&quot;: [\r\n\t     {\r\n            &quot;PutRequest&quot;: {\r\n                &quot;Item&quot;: {\r\n\t\t\t       &quot;id&quot;: {\r\n\t\t\t         &quot;S&quot;: &quot;cf7ebec368f241ead7ecf818ce9ed098406afa63&quot;\r\n\t\t\t       },\r\n\t\t\t       &quot;test&quot;: {\r\n\t\t\t         &quot;N&quot;: &quot;5&quot;\r\n\t\t\t       },\r\n\t\t\t       &quot;added&quot;: {\r\n\t\t\t         &quot;S&quot;: &quot;2017-02-15T17:56:19.958917+00:00&quot;\r\n\t\t\t       },\r\n\t\t\t       &quot;foo&quot;: {\r\n\t\t\t         &quot;N&quot;: &quot;88&quot;\r\n\t\t\t       },\r\n\t\t\t       &quot;web&quot;: {\r\n\t\t\t         &quot;N&quot;: &quot;103&quot;\r\n\t\t\t       }   \r\n\t\t        **}\r\n             }\r\n         },\r\n\t     {\r\n            &quot;PutRequest&quot;: {\r\n                &quot;Item&quot;: {\r\n\t\t\t       &quot;id&quot;: {\r\n\t\t\t         &quot;S&quot;: &quot;cf7ebec368f241ead7ecf818ce9ed098406afa63&quot;\r\n\t\t\t       },\r\n\t\t\t       &quot;image_server_id&quot;: {\r\n\t\t\t         &quot;N&quot;: &quot;5&quot;\r\n\t\t\t       },\r\n\t\t\t       &quot;added&quot;: {\r\n\t\t\t         &quot;S&quot;: &quot;2017-02-15T17:56:19.958917+00:00&quot;\r\n\t\t\t       },\r\n\t\t\t       &quot;result&quot;: {\r\n\t\t\t         &quot;N&quot;: &quot;88&quot;\r\n\t\t\t       },\r\n\t\t\t       &quot;data&quot;: {\r\n\t\t\t         &quot;foo&quot;: {\r\n\t\t\t           &quot;N&quot;: &quot;103&quot;,\r\n\t\t\t           &quot;S&quot;: &quot;test&quot;\r\n\t\t\t         }\r\n\t\t\t       }  \r\n\t            **}\r\n            }\r\n         }\r\n       ]\r\n      }\r\n\r\nTo sum up I want to add\r\n\r\n    {\r\n    &quot;StaticString&quot;: [\r\n\t{\r\n\r\nat the beginning of the file.\r\nThen I need to put each json item into a parent\r\n\r\n       &quot;PutRequest&quot;: {\r\n                &quot;Item&quot;: {\r\n                ...\r\n                }\r\n       }\r\nand generate an array out of the json items.\r\n\r\nI&#39;m already knowing how to generate an array of the json items using\r\n`jq -s . testfile.json`\r\nBut I don&#39;t know how to add a parent to each json item.\r\n\r\nI hope it&#39;s clear what I want to achieve.\r\n\r\nThank&#39;s for your help,\r\nChris",
        "link": "https://stackoverflow.com/questions/43950580/adding-parent-element-to-json-objects-using-jq-bash",
        "title": "adding parent element to json objects using jq/bash"
    },
    {
        "tags": [
            "bash",
            "sh",
            "jq",
            "tee"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1494821887,
                "creation_date": 1494821887,
                "answer_id": 43971494,
                "question_id": 43971184,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Based on your description, it looks like you want:\r\n\r\n     echo &quot;start process $(date -u)&quot; | tee -a &quot;$logfilename.txt&quot; | jq . &gt;&gt; &quot;$logfilename.json&quot;\r\n\r\netc.\r\n",
                "title": "Using tee and jq to write txt and json log files"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1494821887,
        "creation_date": 1494818897,
        "question_id": 43971184,
        "body_markdown": "I&#39;d like to write two log files using tee, first log file as txt, second log file as json\r\n\r\nTee is working for two txt files, but can&#39;t get jq to work with tee...\r\n\r\nMy code:\r\n\r\n    logfilename=&quot;log_download_2017&quot;\r\n    echo &quot;start process $(date -u)&quot; | tee -a $logfilename.txt &gt;&gt; jq . $logfilename.json\r\n    echo &quot;logfilename&quot; $logfilename | tee -a $logfilename.txt &gt;&gt; jq . $logfilename.json\r\n\r\n\r\nConsole output:\r\n\r\n`tee: .: Is a directory\r\ntee: .: Is a directory`\r\n\r\nLog files output:\r\n\r\n`start process Mon May 15 03:14:09 UTC 2017\r\nlogfilename log_download_2017`\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/43971184/using-tee-and-jq-to-write-txt-and-json-log-files",
        "title": "Using tee and jq to write txt and json log files"
    },
    {
        "tags": [
            "json",
            "bash",
            "sh",
            "text-processing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1494856793,
                "last_edit_date": 1494856793,
                "creation_date": 1494827932,
                "answer_id": 43972424,
                "question_id": 43972268,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "One approach would be to use `index/1`, e.g. along these lines:\r\n\r\n    jq -R &#39;index(&quot;:&quot;) as $ix | {(.[:$ix]) : .[$ix+1:]}&#39;\r\n\r\nOr, if your jq supports regex, you might like to consider:\r\n\r\n    jq -R &#39;match( &quot;([^:]*):(.*)&quot; ) | .captures | {(.[0].string): .[1].string}&#39;\r\n\r\nor:\r\n\r\n    jq -R &#39;[capture( &quot;(?&lt;key&gt;[^:]*):(?&lt;value&gt;.*)&quot; )] | from_entries&#39;\r\n\r\n",
                "title": "jq to convert two text strings into separate json objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1494990389,
        "creation_date": 1494827133,
        "last_edit_date": 1494990389,
        "question_id": 43972268,
        "body_markdown": "How do I convert these two text strings into separate json objects\r\n\r\nText strings:\r\n\r\n    start process: Mon May 15 03:14:09 UTC 2017\r\n    logfilename: log_download_2017\r\n\r\nJson output:\r\n\r\n    {\r\n    &quot;start process&quot;: &quot;Mon May 15 03:14:09 UTC 2017&quot;,\r\n    }\r\n    {\r\n    &quot;logfilename&quot;: &quot;log_download_2017&quot;,\r\n    }\r\n\r\nShell script:\r\n\r\n    logfilename=&quot;log_download_2017&quot;\r\n    echo &quot;start process: $(date -u)&quot; | tee -a $logfilename.txt | jq -R split(:) &gt;&gt; $logfilename.json\r\n    echo &quot;logfilename:&quot; $logfilename | tee -a $logfilename.txt | jq -R split(:) &gt;&gt; $logfilename.json",
        "link": "https://stackoverflow.com/questions/43972268/jq-to-convert-two-text-strings-into-separate-json-objects",
        "title": "jq to convert two text strings into separate json objects"
    },
    {
        "tags": [
            "linux",
            "bash",
            "shell",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1494878701,
                "post_id": 43987641,
                "comment_id": 75005018,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1494877928,
                "creation_date": 1494877928,
                "answer_id": 43987707,
                "question_id": 43987641,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The shell is interpreting it as a history expansion. Use single quotes instead to prevent that.\r\n\r\n    json=$(jq -n --arg u &quot;user_dev&quot; --arg p &#39;user!&#39; &#39;{username: $u, password: $p}&#39;)\r\n\r\nThat said, `bash` 4.3 includes a fix to prevent that from happening. From the changelog:\r\n\r\n&gt;l.  The history expansion character (!) does not cause history expansion when\r\n    followed by the closing quote in a double-quoted string.",
                "title": "jq not working with exclamation mark as an input"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1494878661,
        "creation_date": 1494877631,
        "last_edit_date": 1494878431,
        "question_id": 43987641,
        "body_markdown": "I am passing username and password to jq the following way:\r\n\r\n    json=$(jq -n --arg u &quot;user_dev&quot; --arg p &quot;user!&quot; &#39;{username: $u, password: $p}&#39;)\r\n\r\nHowever, it is failing and giving the following output:\r\n\r\n    -bash: !&quot;: event not found\r\n\r\nIt seem that it is not liking exclamation mark with the `arg p &quot;user!&quot;`",
        "link": "https://stackoverflow.com/questions/43987641/jq-not-working-with-exclamation-mark-as-an-input",
        "title": "jq not working with exclamation mark as an input"
    },
    {
        "tags": [
            "json",
            "text-processing",
            "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": 1494898007,
                "post_id": 43989072,
                "comment_id": 75011206,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8158942,
                    "reputation": 236,
                    "user_id": 6143547,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/1cbffac5833a5807e65ff0385fe74bde?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gabe",
                    "link": "https://stackoverflow.com/users/6143547/gabe"
                },
                "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": 1494898208,
                "post_id": 43989072,
                "comment_id": 75011258,
                "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": 1494903186,
                "post_id": 43989072,
                "comment_id": 75012377,
                "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": 1494905400,
                "post_id": 43989072,
                "comment_id": 75012825,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8158942,
                    "reputation": 236,
                    "user_id": 6143547,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/1cbffac5833a5807e65ff0385fe74bde?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gabe",
                    "link": "https://stackoverflow.com/users/6143547/gabe"
                },
                "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": 1494905802,
                "post_id": 43989072,
                "comment_id": 75012898,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1494906395,
                "last_edit_date": 1494906395,
                "creation_date": 1494885776,
                "answer_id": 43989490,
                "question_id": 43989072,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a jq-only solution, which produces valid JSON along the lines of your example:\r\n\r\n    foreach (inputs,null) as $line ({};\r\n       if $line == null then .emit = {(.key): .value}\r\n       elif $line[-1:] == &quot;:&quot;\r\n       then (if .key then {emit: {(.key): .value}} else null end)\r\n            + { key : $line[0:-1] }\r\n       else {key, value: (.value + [$line])}\r\n       end;\r\n       .emit // empty )\r\n\r\nInvocation:\r\n\r\n    jq -n -R -f program.jq input.txt\r\n\r\nPlease note the -n option in particular. \r\n\r\n### Caveats\r\nIf the input does not begin with a &quot;key&quot; line, then the above jq program will report an error and terminate.  If more fault-tolerance is required, then the following variant might be of interest:\r\n\r\n    foreach (inputs,null) as $line ({};\r\n       if $line == null then .emit = {(.key|tostring): .value}\r\n       elif $line[-1:] == &quot;:&quot;\r\n       then (if .key then {emit: {(.key): .value}} else null end)\r\n            + { key : $line[0:-1] }\r\n       else {key, value: (.value + [$line])}\r\n       end;\r\n       .emit // empty )\r\n",
                "title": "jq: Convert &quot;header:&quot; &quot;line1&quot; &quot;line2&quot; text file into JSON stream w/ map to lists of strings"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1495026104,
        "creation_date": 1494883595,
        "last_edit_date": 1495026104,
        "question_id": 43989072,
        "body_markdown": "How do I convert these lists of text strings into json\r\n\r\nText strings:\r\n\r\n    start filelist:\r\n    /download/2017/download_2017.sh\r\n    /download/2017/log_download_2017.json\r\n    /download/2017/log_download_2017.txt\r\n    start wget:\r\n    2017-05-15 20:42:00 URL:http://web.site.com/downloads/2017/file_1.zip [1024/1024] -&gt; &quot;file_1.zip&quot; [1]\r\n    2017-05-15 20:43:21 URL:http://web.site.com/downloads/2017/file_2.zip [2048/2048] -&gt; &quot;file_2.zip&quot; [1]\r\n\r\nJSON output:\r\n\r\n    {\r\n    &quot;start filelist&quot;: [\r\n        &quot;download_2017.sh&quot;,\r\n        &quot;log_download_2017.txt&quot;,\r\n        &quot;log_download_2017.json&quot;,\r\n      ],\r\n    }\r\n    {\r\n    &quot;start wget&quot;: [\r\n        &quot;2017-05-15 20:43:01 URL:http://web.site.com/downloads/2017/file_1.zip [1024/1024] -&gt; &quot;file_1.zip&quot; [1]&quot;,\r\n        &quot;2017-05-15 20:43:21 URL:http://web.site.com/downloads/2017/file_2.zip [2048/2048] -&gt; &quot;file_2.zip&quot; [1]&quot;,\r\n      ],\r\n    }\r\n\r\nAppreciate any options and approaches",
        "link": "https://stackoverflow.com/questions/43989072/jq-convert-header-line1-line2-text-file-into-json-stream-w-map-to-lists",
        "title": "jq: Convert &quot;header:&quot; &quot;line1&quot; &quot;line2&quot; text file into JSON stream w/ map to lists of strings"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1481915,
                    "reputation": 13618,
                    "user_id": 1542667,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/bI4tw.jpg?s=256",
                    "display_name": "Yuri Schimke",
                    "link": "https://stackoverflow.com/users/1542667/yuri-schimke"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1494920402,
                "post_id": 43994979,
                "comment_id": 75018993,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4622002,
                    "reputation": 497,
                    "user_id": 3746802,
                    "user_type": "registered",
                    "accept_rate": 27,
                    "profile_image": "https://www.gravatar.com/avatar/82cc4bb0994f5539996c8bdb329816cc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kelly Norton",
                    "link": "https://stackoverflow.com/users/3746802/kelly-norton"
                },
                "reply_to_user": {
                    "account_id": 1481915,
                    "reputation": 13618,
                    "user_id": 1542667,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/bI4tw.jpg?s=256",
                    "display_name": "Yuri Schimke",
                    "link": "https://stackoverflow.com/users/1542667/yuri-schimke"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1494920925,
                "post_id": 43994979,
                "comment_id": 75019322,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1494922404,
                "last_edit_date": 1494922404,
                "creation_date": 1494920798,
                "answer_id": 43995374,
                "question_id": 43994979,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "OK, so I managed to get what I was after. I still have a little tidying up to do as some of the input fields aren&#39;t completely uniform, but it&#39;s close enough to move forward with:\r\n\r\n    aws ec2 describe-reserved-instances-offerings --availability-zone &quot;ap-southeast-2a&quot; --instance-type &quot;c4.xlarge&quot; |\r\n    jq &#39;.ReservedInstancesOfferings[] | [.ProductDescription, .InstanceType, .RecurringCharges[].Amount]&#39;\r\n\r\nOutput:\r\n\r\n    [\r\n      &quot;Linux/UNIX&quot;,\r\n      &quot;c4.xlarge&quot;,\r\n      0.167\r\n    ]\r\n    [\r\n      &quot;Red Hat Enterprise Linux&quot;,\r\n      &quot;c4.xlarge&quot;,\r\n      0.243\r\n    ]\r\n    [\r\n      &quot;Red Hat Enterprise Linux&quot;,\r\n      &quot;c4.xlarge&quot;,\r\n      0.227\r\n    ]\r\n    [\r\n      &quot;Linux/UNIX&quot;,\r\n      &quot;c4.xlarge&quot;,\r\n      0.183\r\n    ]\r\n    [\r\n      &quot;SUSE Linux&quot;,\r\n      &quot;c4.xlarge&quot;,\r\n      0.2\r\n    ]",
                "title": "using jq to return multiple elements?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1494922404,
        "creation_date": 1494919542,
        "last_edit_date": 1494921118,
        "question_id": 43994979,
        "body_markdown": "I&#39;m trying to use jq to return multiple elements from a JSON object. The data is coming from an AWS cli lookup, this is just a tiny section of the output:\r\n\r\n    {\r\n\t&quot;ReservedInstancesOfferings&quot;: [{\r\n\t\t\t&quot;OfferingClass&quot;: &quot;convertible&quot;,\r\n\t\t\t&quot;OfferingType&quot;: &quot;No Upfront&quot;,\r\n\t\t\t&quot;AvailabilityZone&quot;: &quot;ap-southeast-2a&quot;,\r\n\t\t\t&quot;InstanceTenancy&quot;: &quot;default&quot;,\r\n\t\t\t&quot;PricingDetails&quot;: [],\r\n\t\t\t&quot;ProductDescription&quot;: &quot;Linux/UNIX&quot;,\r\n\t\t\t&quot;UsagePrice&quot;: 0.0,\r\n\t\t\t&quot;RecurringCharges&quot;: [{\r\n\t\t\t\t&quot;Amount&quot;: 0.167,\r\n\t\t\t\t&quot;Frequency&quot;: &quot;Hourly&quot;\r\n\t\t\t}],\r\n\t\t\t&quot;Marketplace&quot;: false,\r\n\t\t\t&quot;CurrencyCode&quot;: &quot;USD&quot;,\r\n\t\t\t&quot;FixedPrice&quot;: 0.0,\r\n\t\t\t&quot;Duration&quot;: 94608000,\r\n\t\t\t&quot;Scope&quot;: &quot;Availability Zone&quot;,\r\n\t\t\t&quot;ReservedInstancesOfferingId&quot;: &quot;1fc8c02b-bcc0-42b8-82ef-47c6f6d1c1b5&quot;,\r\n\t\t\t&quot;InstanceType&quot;: &quot;c4.xlarge&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;OfferingClass&quot;: &quot;convertible&quot;,\r\n\t\t\t&quot;OfferingType&quot;: &quot;No Upfront&quot;,\r\n\t\t\t&quot;AvailabilityZone&quot;: &quot;ap-southeast-2a&quot;,\r\n\t\t\t&quot;InstanceTenancy&quot;: &quot;dedicated&quot;,\r\n\t\t\t&quot;PricingDetails&quot;: [],\r\n\t\t\t&quot;ProductDescription&quot;: &quot;Red Hat Enterprise Linux&quot;,\r\n\t\t\t&quot;UsagePrice&quot;: 0.0,\r\n\t\t\t&quot;RecurringCharges&quot;: [{\r\n\t\t\t\t&quot;Amount&quot;: 0.243,\r\n\t\t\t\t&quot;Frequency&quot;: &quot;Hourly&quot;\r\n\t\t\t}],\r\n\t\t\t&quot;Marketplace&quot;: false,\r\n\t\t\t&quot;CurrencyCode&quot;: &quot;USD&quot;,\r\n\t\t\t&quot;FixedPrice&quot;: 0.0,\r\n\t\t\t&quot;Duration&quot;: 94608000,\r\n\t\t\t&quot;Scope&quot;: &quot;Availability Zone&quot;,\r\n\t\t\t&quot;ReservedInstancesOfferingId&quot;: &quot;24aaceee-f54e-4882-aba3-ce710a5036c9&quot;,\r\n\t\t\t&quot;InstanceType&quot;: &quot;c4.xlarge&quot;\r\n\t\t}\r\n\t]\r\n}\r\n\r\nI&#39;m trying to extract the fields:\r\n\r\n    .ReservedInstancesOfferings[].ProductDescription\r\n    .ReservedInstancesOfferings[].InstanceType\r\n    .ReservedInstancesOfferings[].RecurringCharges[].Amount\r\n\r\nI would like to output to appear like this:\r\n\r\n    &quot;Red Hat Enterprise Linux&quot;\r\n    &quot;c4.xlarge&quot;\r\n    0.183\r\n\r\nAs you can see above I understand how to extract all the elements individually, but I can&#39;t work out how to put them all together to attain the desired output. I&#39;ve trued separating the queries with a comma, but that doesn&#39;t provide the desired output.\r\n\r\nAny help would be very much appreciated.\r\n\r\nThank you!\r\n\r\nEDIT: \r\n\r\nOh oh, I got it! Full answer is below. Boy oh boy jq is powerful!\r\n\r\nHopefully this helps someone :)",
        "link": "https://stackoverflow.com/questions/43994979/using-jq-to-return-multiple-elements",
        "title": "using jq to return multiple elements?"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq",
            "args"
        ],
        "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": 1494967265,
                "post_id": 44010890,
                "comment_id": 75050587,
                "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": 1494967385,
                "post_id": 44010890,
                "comment_id": 75050643,
                "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"
                },
                "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": 1494967718,
                "post_id": 44010890,
                "comment_id": 75050805,
                "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": 1494967807,
                "post_id": 44010890,
                "comment_id": 75050858,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 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": 1494967842,
                "post_id": 44010890,
                "comment_id": 75050878,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1494966858,
                "creation_date": 1494966858,
                "answer_id": 44011086,
                "question_id": 44010890,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to use the `[...]` subscripting syntax instead of the `.` syntax if you want to use a variable in the subscript:\r\n\r\n    .pokemon[$v] = &quot;True&quot;",
                "title": "Ubuntu Shell Script - Use jq with args"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1494966858,
        "creation_date": 1494966141,
        "question_id": 44010890,
        "body_markdown": "I&#39;m trying to edit a json file in a shell script with the jq program. The json file has the following format:\r\n\r\n    {\r\n        &quot;bla&quot;: {\r\n            &quot;test1&quot;: &quot;True&quot;,\r\n            &quot;test2&quot;: &quot;False&quot;\r\n        }\r\n    }&#180;\r\n\r\nI want to set a parameter to define which value from &quot;bla&quot; should be changed. I want to start the script for example like this:\r\n\r\n&gt; $ ./myscript.sh test1\r\n\r\nI tried it like this:\r\n\r\n    #!/bin/sh\r\n\r\n    jq --arg v $1 &#39;.pokemon.$v = &quot;True&quot;&#39; filters.json &gt; tmp.$$.json &amp;&amp; mv tmp.$$.json filters.json\r\n\r\nBut it is not working. I&#39;m getting the following error:\r\n\r\n    error: syntax error, unexpected &#39;$&#39;, expecting IDENT\r\n    .pokemon.$v = &quot;True&quot;\r\n             ^\r\n    1 compile error\r\n\r\nSomeone know how to solve this?\r\n",
        "link": "https://stackoverflow.com/questions/44010890/ubuntu-shell-script-use-jq-with-args",
        "title": "Ubuntu Shell Script - Use jq with args"
    },
    {
        "tags": [
            "json",
            "bash",
            "sh",
            "text-processing",
            "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": 1495026260,
                "post_id": 44014822,
                "comment_id": 75077668,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1494992227,
                "last_edit_date": 1495541428,
                "creation_date": 1494991497,
                "answer_id": 44014990,
                "question_id": 44014822,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As mentioned e.g. at https://stackoverflow.com/questions/43729643/use-jq-to-turn-x-y-pairs-into-key-value-pairs, the basic task of converting a key:value string can be accomplished in a number of ways. For example, you could start with:\r\n\r\n    index(&quot;:&quot;) as $ix | {(.[:$ix]) : .[$ix+1:]}\r\n\r\nYou evidently want to trim some spaces, which can be done using `sub/2`.\r\n\r\nTo combine the objects, you could use `add`.  To do this in a single pass, you would use jq -R -s\r\n\r\nPutting it all together, you could do worse than:\r\n\r\n    def trim: sub(&quot;^ +&quot;;&quot;&quot;) | sub(&quot; +$&quot;;&quot;&quot;);\r\n\r\n    def s2o:\r\n      (index(&quot;:&quot;) // empty) as $ix\r\n      | {(.[:$ix]): (.[$ix+1:]|trim)};\r\n\r\n    split(&quot;\\n&quot;) | map(s2o) | add\r\n\r\n",
                "title": "jq to convert two text strings into a single json object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1494992227,
        "creation_date": 1494990272,
        "question_id": 44014822,
        "body_markdown": "How do I convert these two text strings into a single json object\r\n\r\nText strings:\r\n\r\n    start process: Mon May 15 03:14:09 UTC 2017\r\n    logfilename: log_download_2017\r\n\r\nJson output:\r\n\r\n    {\r\n    &quot;start process&quot;: &quot;Mon May 15 03:14:09 UTC 2017&quot;,\r\n    &quot;logfilename&quot;: &quot;log_download_2017&quot;,\r\n    }\r\n\r\nShell script:\r\n\r\n    logfilename=&quot;log_download_2017&quot;\r\n    echo &quot;start process: $(date -u)&quot; | tee -a $logfilename.txt | jq -R . &gt;&gt; $logfilename.json\r\n    echo &quot;logfilename:&quot; $logfilename | tee -a $logfilename.txt | jq -R . &gt;&gt; $logfilename.json",
        "link": "https://stackoverflow.com/questions/44014822/jq-to-convert-two-text-strings-into-a-single-json-object",
        "title": "jq to convert two text strings into a single json object"
    },
    {
        "tags": [
            "bash",
            "shell",
            "unix",
            "exec",
            "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": 1495026848,
                "post_id": 44021118,
                "comment_id": 75078155,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8158942,
                    "reputation": 236,
                    "user_id": 6143547,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/1cbffac5833a5807e65ff0385fe74bde?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gabe",
                    "link": "https://stackoverflow.com/users/6143547/gabe"
                },
                "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": 1495046238,
                "post_id": 44021118,
                "comment_id": 75091425,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8158942,
                    "reputation": 236,
                    "user_id": 6143547,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/1cbffac5833a5807e65ff0385fe74bde?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gabe",
                    "link": "https://stackoverflow.com/users/6143547/gabe"
                },
                "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": 1495046313,
                "post_id": 44021118,
                "comment_id": 75091473,
                "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": 1495051860,
                "post_id": 44021118,
                "comment_id": 75094576,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8158942,
                    "reputation": 236,
                    "user_id": 6143547,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/1cbffac5833a5807e65ff0385fe74bde?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gabe",
                    "link": "https://stackoverflow.com/users/6143547/gabe"
                },
                "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": 1495053722,
                "post_id": 44021118,
                "comment_id": 75095501,
                "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": 1495054357,
                "post_id": 44021118,
                "comment_id": 75095819,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8158942,
                    "reputation": 236,
                    "user_id": 6143547,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/1cbffac5833a5807e65ff0385fe74bde?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gabe",
                    "link": "https://stackoverflow.com/users/6143547/gabe"
                },
                "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": 1495055773,
                "post_id": 44021118,
                "comment_id": 75096474,
                "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": 1495056399,
                "post_id": 44021118,
                "comment_id": 75096740,
                "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": 1495056623,
                "post_id": 44021118,
                "comment_id": 75096837,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8158942,
                    "reputation": 236,
                    "user_id": 6143547,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/1cbffac5833a5807e65ff0385fe74bde?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Gabe",
                    "link": "https://stackoverflow.com/users/6143547/gabe"
                },
                "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": 1495057301,
                "post_id": 44021118,
                "comment_id": 75097154,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1495649186,
                "last_edit_date": 1495649186,
                "creation_date": 1495025195,
                "answer_id": 44025306,
                "question_id": 44021118,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "### The Portable Approach\r\n\r\nThe following is portable to POSIX sh:\r\n\r\n    #!/bin/sh\r\n    die() { rm -rf -- &quot;$tempdir&quot;; [ &quot;$#&quot; -gt 0 ] &amp;&amp; echo &quot;$*&quot; &gt;&amp;2; exit 1; }\r\n    logfilename=&quot;whatever&quot;\r\n\r\n    tempdir=$(mktemp -d &quot;${TMPDIR:-/tmp}&quot;/fifodir.XXXXXX) || exit\r\n    mkfifo &quot;$tempdir/fifo&quot; || die &quot;mkfifo failed&quot;\r\n\r\n    tee -a &quot;$logfilename&quot; &lt;&quot;$tempdir/fifo&quot; \\\r\n      | jq -sRf json_log_s2o.jq \\\r\n      &gt;&gt;&quot;$logfilename.json&quot; &amp; fifo_pid=$!\r\n    exec 3&gt;&quot;$tempdir/fifo&quot; || die &quot;could not open fifo for write&quot;\r\n\r\n    echo &quot;start filelist:&quot; &gt;&amp;3\r\n    printf &#39;%s\\n&#39; &quot;$PWD&quot;/* &gt;&amp;3\r\n\r\n    echo &quot;start wget:&quot; &gt;&amp;3\r\n    wget -nv http://web.site.com/downloads/2017/file_1.zip &gt;&amp;3 2&gt;&amp;1\r\n    wget -nv http://web.site.com/downloads/2017/file_2.zip &gt;&amp;3 2&gt;&amp;1\r\n\r\n    exec 3&gt;&amp;-         # close the write end of the FIFO\r\n    wait &quot;$fifo_pid&quot;  # and wait for the process to exit\r\n    rm -rf &quot;$tempdir&quot; # delete the temporary directory with the FIFO\r\n\r\n---\r\n\r\n### Avoiding FIFO Management (Using Bash)\r\n\r\nWith bash, one can avoid needing to manage the FIFO by using a process substitution:\r\n\r\n    #!/bin/bash\r\n    logfilename=&quot;whatever&quot;\r\n\r\n    exec 3&gt; &gt;(tee -a &quot;$logfilename&quot; | jq -sRf json_log_s2o.jq &gt;&gt;&quot;$logfilename.json&quot;)\r\n\r\n    echo &quot;start filelist:&quot; &gt;&amp;3\r\n    printf &#39;%s\\n&#39; &quot;$PWD/*&quot; &gt;&amp;3\r\n\r\n    echo &quot;start wget:&quot; &gt;&amp;3\r\n    wget -nv http://web.site.com/downloads/2017/file_1.zip &gt;&amp;3 2&gt;&amp;1\r\n    wget -nv http://web.site.com/downloads/2017/file_2.zip &gt;&amp;3 2&gt;&amp;1\r\n\r\n    exec 3&gt;&amp;1\r\n\r\n---\r\n\r\n### Waiting For Exit (Using Linux-y Tools)\r\n\r\nHowever, the thing this *doesn&#39;t* let you do (without bash 4.4) is detect when `jq` failed, or wait for `jq` to finish writing before your script exits. If you want to ensure that `jq` finishes before your script exits, then you might consider using `flock`, like so:\r\n\r\n    writelogs() {\r\n      exec 4&gt;&quot;${1}.json&quot;\r\n      flock -x 4\r\n      tee -a &quot;$1&quot; | jq -sRf json_log_s2o.jq &gt;&amp;4\r\n    }\r\n    exec 3&gt; &gt;(writelogs &quot;$logfilename&quot;)\r\n\r\nand later:\r\n\r\n    exec 3&gt;&amp;-\r\n    flock -s &quot;$logfilename.json&quot; -c :\r\n\r\nBecause the `jq` process inside the `writelogs` function holds a lock on the output file, the final `flock -s` command isn&#39;t able to *also* grab a lock on the output file until `jq` exits.\r\n\r\n---\r\n\r\n### An Aside: Avoiding All The &gt;&amp;3 Redirections\r\n\r\nIn either shell, the below is just as valid:\r\n\r\n    {\r\n      echo &quot;start filelist:&quot;\r\n      printf &#39;%s\\n&#39; &quot;$PWD&quot;/*\r\n\r\n      echo &quot;start wget:&quot;\r\n      wget -nv http://web.site.com/downloads/2017/file_1.zip 2&gt;&amp;1\r\n      wget -nv http://web.site.com/downloads/2017/file_2.zip 2&gt;&amp;1\r\n    } &gt;&amp;3\r\n\r\nIt&#39;s also *possible*, but not advisable, to pipe a code block into a pipeline, thus replacing the FIFO use or process substitution altogether:\r\n\r\n    {\r\n      echo &quot;start filelist:&quot;\r\n      printf &#39;%s\\n&#39; &quot;$PWD&quot;/*\r\n\r\n      echo &quot;start wget:&quot;\r\n      wget -nv http://web.site.com/downloads/2017/file_1.zip 2&gt;&amp;1\r\n      wget -nv http://web.site.com/downloads/2017/file_2.zip 2&gt;&amp;1\r\n    } | tee -a &quot;$logfilename&quot; | jq -sRf json_log_s2o.jq &gt;&gt;&quot;${logfilename}.json&quot;\r\n\r\n...why not advisable? Because there&#39;s no guarantee in POSIX sh as to which components of a pipeline if any run in the same shell interpreter as the rest of your script; and if the above *isn&#39;t* run in the same piece of the script, then variables will be thrown away (and without extensions such as `pipefail`, exit status as well). See [BashFAQ #24](http://mywiki.wooledge.org/BashFAQ/024) for more information.\r\n\r\n---\r\n\r\n### Waiting For Exit On Bash 4.4\r\n\r\nWith bash 4.4, process substitutions export their PIDs in `$!`, and these can be `wait`ed for. Thus, you get an alternate way to wait for the FIFO to exit:\r\n\r\n    exec 3&gt; &gt;(tee -a &quot;$logfilename&quot; | jq -sRf json_log_s2o.jq &gt;&gt;&quot;$logfilename.json&quot;); log_pid=$!\r\n\r\n...and then, later on:\r\n\r\n    wait &quot;$log_pid&quot;\r\n\r\nas an alternative to the `flock` approach given earlier. Obviously, do this only if you have bash 4.4 available.",
                "title": "How can I send multiple commands&#39; output to a single shell pipeline?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1495649186,
        "creation_date": 1495014017,
        "last_edit_date": 1495127953,
        "question_id": 44021118,
        "body_markdown": "I have multiple pipelines, which looks like:\r\n\r\n    tee -a $logfilename.txt | jq string2object.jq &gt;&gt; $logfilename.json\r\n\r\nor\r\n\r\n    tee -a $logfilename.txt | jq array2object.jq &gt;&gt; $logfilename.json\r\n\r\nFor each pipeline, I want to apply to multiple commands. \r\n\r\nEach set of commands looks something like:\r\n\r\n    echo &quot;start filelist:&quot;\r\n    printf &#39;%s\\n&#39; &quot;$PWD&quot;/*\r\n\r\nor\r\n    \r\n    echo &quot;start wget:&quot;\r\n    wget -nv http://web.site.com/downloads/2017/file_1.zip 2&gt;&amp;1\r\n    wget -nv http://web.site.com/downloads/2017/file_2.zip 2&gt;&amp;1\r\n\r\nand the output from those commands should all go through the pipe.\r\n\r\n---\r\n\r\nWhat I&#39;ve tried in the past is putting the pipeline on each command separately:\r\n\r\n    echo &quot;start filelist:&quot; | tee -a $logfilename | jq -sRf array2object.jq &gt;&gt;$logfilename.json\r\n    printf &#39;%s\\n&#39; &quot;$PWD&quot;/* | tee -a $logfilename | jq -sRf array2object.jq &gt;&gt;$logfilename.json\r\n\r\nbut in that case the JSON script can only see one line at a time, so it doesn&#39;t work correctly.",
        "link": "https://stackoverflow.com/questions/44021118/how-can-i-send-multiple-commands-output-to-a-single-shell-pipeline",
        "title": "How can I send multiple commands&#39; output to a single shell pipeline?"
    },
    {
        "tags": [
            "json",
            "bash",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4203120,
                    "reputation": 11256,
                    "user_id": 4923629,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/2abZO.png?s=256",
                    "display_name": "123",
                    "link": "https://stackoverflow.com/users/4923629/123"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1495037354,
                "post_id": 44029906,
                "comment_id": 75086333,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1495413533,
                "last_edit_date": 1495540046,
                "creation_date": 1495038972,
                "answer_id": 44030438,
                "question_id": 44029906,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First your `JSON` needs to be fixed as following:\r\n\r\n    {\r\n      &quot;main&quot;: {\r\n        \r\n      },\r\n      &quot;table&quot;: {\r\n        &quot;All&quot;: [\r\n          {\r\n            &quot;field1&quot;: &quot;a&quot;,\r\n            &quot;field2&quot;: &quot;aa&quot;,\r\n            &quot;field3&quot;: &quot;aaa&quot;,\r\n            &quot;field4&quot;: &quot;0&quot;,\r\n            &quot;active&quot;: &quot;true&quot;,\r\n            &quot;id&quot;: &quot;1&quot;\r\n          },\r\n          {\r\n            &quot;field1&quot;: &quot;b&quot;,\r\n            &quot;field2&quot;: &quot;bb&quot;,\r\n            &quot;field3&quot;: &quot;bbb&quot;,\r\n            &quot;field4&quot;: &quot;0&quot;,\r\n            &quot;active&quot;: &quot;false&quot;,\r\n            &quot;id&quot;: &quot;2&quot;\r\n          },\r\n          {\r\n            &quot;field1&quot;: &quot;c&quot;,\r\n            &quot;field2&quot;: &quot;cc&quot;,\r\n            &quot;field3&quot;: &quot;ccc&quot;,\r\n            &quot;field4&quot;: &quot;0&quot;,\r\n            &quot;active&quot;: &quot;true&quot;,\r\n            &quot;id&quot;: &quot;3&quot;\r\n          },\r\n          {\r\n            &quot;field1&quot;: &quot;d&quot;,\r\n            &quot;field2&quot;: &quot;dd&quot;,\r\n            &quot;field3&quot;: &quot;ddd&quot;,\r\n            &quot;field4&quot;: &quot;0&quot;,\r\n            &quot;active&quot;: &quot;true&quot;,\r\n            &quot;id&quot;: &quot;4&quot;\r\n          }\r\n          \r\n        ]\r\n      },\r\n      &quot;res&quot;: &quot;0&quot;\r\n    }\r\n\r\nSecond using **jq** you can do the following in order to generate the table output using **column**:\r\n\r\n    { echo Field1 Field2 Field3 ID ; cat data.json  | jq -r &#39;.table.All[] | (.field1, .field2, .field3, .id)&#39; | xargs -L4 } | column -t\r\n\r\nOutput:\r\n\r\n    Field1  Field2  Field3  ID\r\n    a       aa      aaa     1\r\n    b       bb      bbb     2\r\n    c       cc      ccc     3\r\n    d       dd      ddd     4\r\n\r\nUsing **sed**:\r\n\r\n    echo &quot;field1,field2,field3,id&quot; ;cat data.json  | jq -r &#39;.table.All[] | (.field1, .field2, .field3, .id)&#39; | xargs -L4 | sed &#39;s/ /,/g&#39;\r\n\r\nOutput:\r\n\r\n    field1,field2,field3,id\r\n    a,aa,aaa,1\r\n    b,bb,bbb,2\r\n    c,cc,ccc,3\r\n    d,dd,ddd,4\r\n\r\nUpdate:\r\n\r\nWithout using **sed** or **xargs** , **jq** has the ability to format the output as csv like the following:\r\n\r\n    cat data.json  | jq -r &#39;.table.All[] | [.field1, .field2, .field3, .id] | @csv&#39;\r\n\r\nOutput:\r\n\r\n    &quot;a&quot;,&quot;aa&quot;,&quot;aaa&quot;,&quot;1&quot;\r\n    &quot;b&quot;,&quot;bb&quot;,&quot;bbb&quot;,&quot;2&quot;\r\n    &quot;c&quot;,&quot;cc&quot;,&quot;ccc&quot;,&quot;3&quot;\r\n    &quot;d&quot;,&quot;dd&quot;,&quot;ddd&quot;,&quot;4&quot;\r\n\r\n\r\nThanks to [chepner](https://stackoverflow.com/users/1126841/chepner) as he mentioned in comments the header can be added using **jq** directly as following:\r\n\r\n    jq -r &#39;(([[&quot;field1&quot;, &quot;field2&quot;, &quot;field3&quot;, &quot;id&quot;]]) + [(.table.All[] | [.field1,.field2,.field3,.id])])[]|@csv&#39; data.json \r\n\r\nOutput:\r\n\r\n    &quot;field1&quot;,&quot;field2&quot;,&quot;field3&quot;,&quot;id&quot;\r\n    &quot;a&quot;,&quot;aa&quot;,&quot;aaa&quot;,&quot;1&quot;\r\n    &quot;b&quot;,&quot;bb&quot;,&quot;bbb&quot;,&quot;2&quot;\r\n    &quot;c&quot;,&quot;cc&quot;,&quot;ccc&quot;,&quot;3&quot;\r\n    &quot;d&quot;,&quot;dd&quot;,&quot;ddd&quot;,&quot;4&quot;\r\n\r\n\r\nThis command should work correctly according to the last JSON data you have provided in your question:\r\n\r\n    jq -r &#39;(([[&quot;field1&quot;, &quot;field2&quot;, &quot;field3&quot;, &quot;id&quot;]]) + [(.main.All[] | [.field1,.field2,.field3,.id])])[]|@csv&#39; data.json\r\n\r\n\r\n&gt; **([[&quot;field1&quot;, &quot;field2&quot;, &quot;field3&quot;, &quot;id&quot;]])** : The first part of the command is for the csv header\r\n&gt; \r\n&gt; **(.main.All[] | [.field1,.field2,.field3,.id])])** : As `main` is the\r\n&gt; parent of your JSON then you can choose it using `.main` which will\r\n&gt; print the array `All` then to print the contents of this array you\r\n&gt; have to add `[]` to the name of this array and the full command will\r\n&gt; be `.main.All[]` which will print multiple dictionries and we can\r\n&gt; specific the needed keys by piping the out put of `.main.All[]` to\r\n&gt; another array with the keys we want as this\r\n&gt; `[.field1,.field2,.field3,.id]`",
                "title": "Struggling with parsing JSON with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1495049523,
                "last_edit_date": 1495049523,
                "creation_date": 1495046206,
                "answer_id": 44032491,
                "question_id": 44029906,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s an only-jq solution that only requires specifying the desired keys  once, e.g. on the command line:\r\n\r\n    jq -r --argjson f &#39;[&quot;field1&quot;, &quot;field2&quot;, &quot;field3&quot;, &quot;id&quot;]&#39; &#39;\r\n      $f, (.table.All[] | [getpath( $f[]|[.])]) | @csv&#39;\r\n\r\nOutput:\r\n\r\n    &quot;field1&quot;,&quot;field2&quot;,&quot;field3&quot;,&quot;id&quot;\r\n    &quot;a&quot;,&quot;aa&quot;,&quot;aaa&quot;,&quot;1&quot;\r\n    &quot;b&quot;,&quot;bb&quot;,&quot;bbb&quot;,&quot;2&quot;\r\n    &quot;c&quot;,&quot;cc&quot;,&quot;ccc&quot;,&quot;3&quot;\r\n    &quot;d&quot;,&quot;dd&quot;,&quot;ddd&quot;,&quot;4&quot;\r\n\r\n### Losing the quotation marks\r\nOne way to avoid quoting the strings would be to pipe into `join(&quot;,&quot;)` (or `join(&quot;, &quot;)`) instead of `@csv`:\r\n\r\n    field1,field2,field3,id\r\n    a,aa,aaa,1\r\n    b,bb,bbb,2\r\n    c,cc,ccc,3\r\n    d,dd,ddd,4\r\n\r\nOf course, this might be unacceptable if the values contain commas. In general, if avoiding the quotation marks around strings is important, a good option to consider is `@tsv`. \r\n",
                "title": "Struggling with parsing JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1495413533,
        "creation_date": 1495037244,
        "last_edit_date": 1495038495,
        "question_id": 44029906,
        "body_markdown": "I&#39;ve read all the posts related to it, I&#39;m playing around with it for hours, and still can&#39;t manage to get a grip of this tool which seems to be exactly what I need if I just find a way to make it work as I need...\r\nSo here&#39;s a sample of my JSON:\r\n\r\n    {\r\n    \t&quot;res&quot;: &quot;0&quot;,\r\n    \t&quot;main&quot;: {\r\n    \t\t&quot;All&quot;: [\r\n    \t  {\r\n            &quot;field1&quot;: &quot;a&quot;,\r\n            &quot;field2&quot;: &quot;aa&quot;,\r\n            &quot;field3&quot;: &quot;aaa&quot;,\r\n            &quot;field4&quot;: &quot;0&quot;,\r\n            &quot;active&quot;: &quot;true&quot;,\r\n            &quot;id&quot;: &quot;1&quot;\r\n          },\r\n    \t  {\r\n            &quot;field1&quot;: &quot;b&quot;,\r\n            &quot;field2&quot;: &quot;bb&quot;,\r\n            &quot;field3&quot;: &quot;bbb&quot;,\r\n            &quot;field4&quot;: &quot;0&quot;,\r\n            &quot;active&quot;: &quot;false&quot;,\r\n            &quot;id&quot;: &quot;2&quot;\r\n          },\r\n    \t  {\r\n            &quot;field1&quot;: &quot;c&quot;,\r\n            &quot;field2&quot;: &quot;cc&quot;,\r\n            &quot;field3&quot;: &quot;ccc&quot;,\r\n            &quot;field4&quot;: &quot;0&quot;,\r\n            &quot;active&quot;: &quot;true&quot;,\r\n            &quot;id&quot;: &quot;3&quot;\r\n          },\r\n    \t  {\r\n            &quot;field1&quot;: &quot;d&quot;,\r\n            &quot;field2&quot;: &quot;dd&quot;,\r\n            &quot;field3&quot;: &quot;ddd&quot;,\r\n            &quot;field4&quot;: &quot;0&quot;,\r\n            &quot;active&quot;: &quot;true&quot;,\r\n            &quot;id&quot;: &quot;4&quot;\r\n          }\r\n    \t\t]\r\n    \t}\r\n    \r\n    }\r\n\r\nI&#39;d like to selectively extract some of the fields and get a csv output like this:\r\n\r\n    field1,field2,field3,id\r\n    a,aa,aaa,1\r\n    b,bb,bbb,2\r\n    c,cc,ccc,3\r\n    d,dd,ddd,4\r\n\r\nPlease notice I&#39;ve skipped some fields and I&#39;m also not interested in the parent arrays and such.\r\nThanks a lot in advance.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/44029906/struggling-with-parsing-json-with-jq",
        "title": "Struggling with parsing JSON with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1495046370,
                "last_edit_date": 1495046370,
                "creation_date": 1495044891,
                "answer_id": 44032133,
                "question_id": 44030810,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A simple `jq` filter like below would be sufficient,\r\n\r\n    command-producing-json | jq &#39;.[] | [ .keyname, .location.locationPackageDetails[].isAvailable ]&#39;\r\n\r\nwould produce below as expected.\r\n\r\n    [\r\n      &quot;AMSTERDAM03&quot;,\r\n      1\r\n    ]\r\n\r\nYou can lose the double-quotes by using the `-r`, `--raw-output` option.",
                "title": "Using jq to print out multiple elements in json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1495046370,
        "creation_date": 1495040181,
        "last_edit_date": 1495043715,
        "question_id": 44030810,
        "body_markdown": "I am trying to get `jq` to return both the keyname as well as the isAvailable value. This offering is currently not available in every region that is being returned by the API so I would ideally like to be able to return something like the following:\r\n\r\n\r\n    [\r\n      &quot;AMSTERDAM03,\r\n      &quot;1&quot;\r\n    ]\r\n\r\n\r\nHere is the json being returned by the API call.\r\n\r\n    [\r\n        {\r\n            &quot;description&quot;: &quot;AMS03 - Amsterdam&quot;,\r\n            &quot;keyname&quot;: &quot;AMSTERDAM03&quot;,\r\n            &quot;location&quot;: {\r\n                &quot;location&quot;: {\r\n                    &quot;id&quot;: 814994,\r\n                    &quot;longName&quot;: &quot;Amsterdam 3&quot;,\r\n                    &quot;name&quot;: &quot;ams03&quot;,\r\n                    &quot;statusId&quot;: 2\r\n                },\r\n                &quot;locationPackageDetails&quot;: [\r\n                    {\r\n                        &quot;isAvailable&quot;: 1,\r\n                        &quot;locationId&quot;: 814994,\r\n                        &quot;packageId&quot;: 737\r\n                    }\r\n                ]\r\n            },\r\n            &quot;sortOrder&quot;: 2\r\n        }\r\n    ]\r\n\r\n\r\nIf I run `jq &#39;.[] | .keyname&#39;` I get back the expected value, but I cannot seem to figure out the syntax for digging in to the lower layers. \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/44030810/using-jq-to-print-out-multiple-elements-in-json",
        "title": "Using jq to print out multiple elements in json"
    }
]