[
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1506441138,
                "creation_date": 1506441138,
                "answer_id": 46430901,
                "question_id": 46429896,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**jq** solution:\r\n\r\n    jq -r &#39;.[] | select(.group==&quot;A&quot;) | .title +&quot; &quot;+ (.eye.four.watcher1[] | select(.name==&quot;cat&quot;)).value&#39; test.json\r\nThe output:\r\n\r\n    ProfileXXX bbbb",
                "title": "jq get multiple values from different [] at once with jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1506441184,
                "creation_date": 1506441184,
                "answer_id": 46430916,
                "question_id": 46429896,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that uses [variable binding](https://stedolan.github.io/jq/manual/#Variable/SymbolicBindingOperator:...as$identifier|...) and [string interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-\\\\\\(foo\\)):\r\n\r\n         select(.group == &quot;A&quot;)\r\n       | .title as $t\r\n       | .eye.four.watcher1[]\r\n       | select(.name == &quot;cat&quot;)\r\n       | &quot;\\($t) \\(.value)&quot;\r\n\r\nWith this filter in `filter.jq` and the sample data in `test.json` \r\n\r\n    $ jq -Mr -f filter.jq test.json\r\n\r\nproduces\r\n\r\n    ProfileXXX bbbb\r\n\r\n\r\n\r\n\r\n[**Try it online!**][TIO-j81rzgj0]\r\n\r\n[TIO-j81rzgj0]: https://tio.run/##bVLBbuIwEL33K6JRDyCFaAFptUXqod0f2CMSRchNJolbE7v2GJal@fVNx0mAIOpL7Hkvz@@N5@2jOQJJUggL@GN1LhUul0uIwYgCFVawmP6IobDaG2Y8MeDkPyZPY8ADf4@gq/BvIYkx2mtY5EI55H1pMSBJkjCSa28Dey8oLdFOYbE6QiW2gZHpghk7oXw4CV5Qx2c0FTRAX3kN0a32Dgd4ygvqdXy6aBYupYMJ2DPz2FTO21lwVZ9Z8wHr94U171mtuGst53J3ievk33Nch7vQrT4uyqKkQV4X9r1qL5pr@/5NOVVtQ1dX9fgUtyQyrs3/Hepc2WY3XimLH@yZbm6ou7cgDG577yFUVzgCt9P2cp12Jp1R4rC5Knovs/NByapL4lDlt4lK2qrbqtgJEvbGHSPeZIIw2@hLO7uZm81nvx7mP2OQbmOsZAEukvV45ades8rdZxOFxY4wpVHSDvDjIw/w@I7Ln1HSDn0kXHRPfYXnOQmtSU4zulp3yEkkdIA1wkD2KvAyuqdx9DJK2hEZQ9P814akrlwzmVT8DBNZGU98sGI/0Z748AU &quot;jq – Try It Online&quot;",
                "title": "jq get multiple values from different [] at once with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1506441184,
        "creation_date": 1506438040,
        "question_id": 46429896,
        "body_markdown": "in [] there are many of below blocks, how to extract .title and &quot;value&quot; of  .eye.four.watcher1[].name==&quot;cat&quot; for blocks having &quot;group&quot;: &quot;A&quot;?\r\n\r\nWhat I tried already is:\r\n\r\n$ jq &#39;. | select(.group==&quot;A&quot;) |  .title +&quot; &quot;+.eye.four.watcher1[].name&#39; test.json\r\n\r\n&quot;ProfileXXX dog&quot;\r\n\r\n&quot;ProfileXXX cat&quot;\r\n\r\n&quot;ProfileXXX mouse&quot;\r\n\r\n\r\nbut how to print only the titte and value of the &quot;cat&quot; of the blocks with &quot;group&quot;: &quot;A&quot;,?\r\n\r\n    {\r\n      &quot;title&quot;: &quot;ProfileXXX&quot;,\r\n      &quot;pagelen&quot;: 10,\r\n      &quot;group&quot;: &quot;A&quot;,\r\n      &quot;size&quot;: 1,\r\n      &quot;eye&quot;: {\r\n        &quot;one&quot;: &quot;git&quot;,\r\n        &quot;two&quot;: false,\r\n        &quot;three&quot;: &quot;...&quot;,\r\n        &quot;four&quot;: {\r\n          &quot;watcher1&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;dog&quot;,\r\n              &quot;value&quot;: &quot;aaaa&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;cat&quot;,\r\n              &quot;value&quot;: &quot;bbbb&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;mouse&quot;,\r\n              &quot;value&quot;: &quot;cccc&quot;\r\n            }\r\n          ],\r\n          &quot;watcher2&quot;: {\r\n            &quot;type&quot;: &quot;B&quot;,\r\n            &quot;href&quot;: &quot;2...&quot;\r\n          },\r\n          &quot;watcher3&quot;: {\r\n            &quot;type&quot;: &quot;C&quot;,\r\n            &quot;href&quot;: &quot;3...&quot;\r\n          },\r\n          &quot;values&quot;: [\r\n            {\r\n              &quot;five&quot;: &quot;git&quot;,\r\n              &quot;six&quot;: false,\r\n              &quot;seven&quot;: &quot;...&quot;,\r\n              &quot;eight&quot;: {\r\n                &quot;watchers&quot;: {\r\n                  &quot;href&quot;: &quot;...&quot;\r\n                },\r\n                &quot;forks&quot;: {\r\n                  &quot;href&quot;: &quot;...&quot;\r\n                },\r\n                &quot;clone&quot;: [\r\n                  {\r\n                    &quot;href&quot;: &quot;...&quot;,\r\n                    &quot;name&quot;: &quot;https&quot;\r\n                  },\r\n                  {\r\n                    &quot;href&quot;: &quot;...&quot;,\r\n                    &quot;name&quot;: &quot;ssh&quot;\r\n                  }\r\n                ],\r\n                &quot;pullrequests&quot;: {\r\n                  &quot;href&quot;: &quot;...&quot;\r\n                }\r\n              },\r\n              &quot;fourteen&quot;: false,\r\n              &quot;fiveteen&quot;: {\r\n                &quot;username&quot;: &quot;...&quot;,\r\n                &quot;display_name&quot;: &quot;...&quot;,\r\n                &quot;uuid&quot;: &quot;...&quot;,\r\n                &quot;links&quot;: {\r\n                  &quot;self&quot;: {\r\n                    &quot;href&quot;: &quot;...&quot;\r\n                  },\r\n                  &quot;html&quot;: {\r\n                    &quot;href&quot;: &quot;...&quot;\r\n                  },\r\n                  &quot;avatar&quot;: {\r\n                    &quot;href&quot;: &quot;...&quot;\r\n                  }\r\n                }\r\n              },\r\n              &quot;updated_on&quot;: &quot;...&quot;,\r\n              &quot;size&quot;: 2328936,\r\n              &quot;is_private&quot;: true,\r\n              &quot;uuid&quot;: &quot;...&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/46429896/jq-get-multiple-values-from-different-at-once-with-jq",
        "title": "jq get multiple values from different [] at once with jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1506444716,
                "post_id": 46430810,
                "comment_id": 79821109,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11856135,
                    "reputation": 61,
                    "user_id": 8676087,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-6nsgck9FD7E/AAAAAAAAAAI/AAAAAAAAABQ/ngxtefbxnkE/s256-rj/photo.jpg",
                    "display_name": "abdullah",
                    "link": "https://stackoverflow.com/users/8676087/abdullah"
                },
                "reply_to_user": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1506457458,
                "post_id": 46430810,
                "comment_id": 79827600,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11856135,
                    "reputation": 61,
                    "user_id": 8676087,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-6nsgck9FD7E/AAAAAAAAAAI/AAAAAAAAABQ/ngxtefbxnkE/s256-rj/photo.jpg",
                    "display_name": "abdullah",
                    "link": "https://stackoverflow.com/users/8676087/abdullah"
                },
                "reply_to_user": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1506458265,
                "post_id": 46430810,
                "comment_id": 79827983,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1506460697,
                "post_id": 46430810,
                "comment_id": 79829113,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11856135,
                    "reputation": 61,
                    "user_id": 8676087,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-6nsgck9FD7E/AAAAAAAAAAI/AAAAAAAAABQ/ngxtefbxnkE/s256-rj/photo.jpg",
                    "display_name": "abdullah",
                    "link": "https://stackoverflow.com/users/8676087/abdullah"
                },
                "reply_to_user": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1506461113,
                "post_id": 46430810,
                "comment_id": 79829293,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1506445833,
        "creation_date": 1506440798,
        "last_edit_date": 1506445833,
        "question_id": 46430810,
        "body_markdown": "hi my people i have problem i use jq command line so i want print the name of array on one title with table so this is it :\r\n\r\n    curl  -s http://cd0a4a.ethosdistro.com/?json=yes  | jq &#39;.rigs&#39;\r\n\r\n \r\n\r\nthis is the main work link :\r\n\r\n    curl  -s http://cd0a4a.ethosdistro.com/?json=yes |jq -c &#39;.rigs|.&quot;0d6b27&quot;,.&quot;50dc35&quot;|[.version,.driver,.miner,&quot;\\(.gpus)/\\(.miner_instance)&quot;]|@    csv&#39;|sed &#39;s/\\\\//g;s/\\&quot;//g&#39; |  gawk &#39;BEGIN{print  &quot;version&quot; &quot;,&quot; &quot;GPU_driver&quot; &quot;,&quot; &quot;miner&quot; &quot;,&quot; &quot;gpu&quot;} {print $0}&#39; | csvlook -I\r\n\r\nthe result it :\r\n\r\n\r\n    | version | GPU_driver | miner    | gpu  |\r\n    | ------- | ---------- | -------- | ---- |\r\n    | 1.2.3   | nvidia     | ethminer | 2/2  |\r\n    | 1.2.4   | amdgpu     | ethminer | 1/1  |\r\n\r\nbut i need it to be like this :\r\n\r\n    | version | GPU_driver | miner    | gpu  |  rigname  |\r\n    | ------- | ---------- | -------- | ---- |-----------|\r\n    | 1.2.3   | nvidia     | ethminer | 2/2  |  0d6b27   |\r\n    | 1.2.4   | amdgpu     | ethminer | 1/1  |  50dc35   |\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/46430810/jq-name-of-title-as-new-column-on-table",
        "title": "jq name of title as new column on table"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 29,
                "is_accepted": true,
                "score": 29,
                "last_activity_date": 1506571307,
                "last_edit_date": 1506571307,
                "creation_date": 1506570840,
                "answer_id": 46460707,
                "question_id": 46460631,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can put the results of the query into a list and get the length of this list:\r\n\r\n    [ .modules[].resources | select (.[]!=null) ] | length",
                "title": "How can I count number of elements after query?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1506575596,
                "last_edit_date": 1506575596,
                "creation_date": 1506572757,
                "answer_id": 46460968,
                "question_id": 46460631,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since you indicated it would be very useful to create an array from the first query output, what you probably want to use here is [map](https://stedolan.github.io/jq/manual/#map(x),map_values(x)).\r\n\r\nLet&#39;s assume your data is something like \r\nthe data from this question: https://stackoverflow.com/questions/46181542/jq-search-by-value-from-another-array-element\r\n\r\n    {\r\n      &quot;modules&quot;: [\r\n        {\r\n          &quot;resources&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;openstack_compute_instance_v2&quot;,\r\n              &quot;primary&quot;: {\r\n                &quot;id&quot;: &quot;5edfe2bf-94df-49d5-8118-3e91fb52946b&quot;,\r\n                &quot;attributes&quot;: {\r\n                  &quot;name&quot;: &quot;jumpbox&quot;\r\n                }\r\n              }\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;openstack_compute_floatingip_associate_v2&quot;,\r\n              &quot;primary&quot;: {\r\n                &quot;attributes&quot;: {\r\n                  &quot;instance_id&quot;: &quot;5edfe2bf-94df-49d5-8118-3e91fb52946b&quot;,\r\n                  &quot;floating_ip&quot;: &quot;10.120.241.21&quot;\r\n                }\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nwith this data your filter\r\n\r\n       .modules[].resources \r\n     | select (.[]!=null)    #&lt; do you really want this `[]` ?\r\n\r\nwould produce two copies of the entire `.resources` array.  What you may want instead is\r\n\r\n       .modules[].resources \r\n     | map(select(.!=null))\r\n     \r\nwhich will give you an array\r\n\r\n    [\r\n      {\r\n        &quot;type&quot;: &quot;openstack_compute_instance_v2&quot;,\r\n        &quot;primary&quot;: {\r\n          &quot;id&quot;: &quot;5edfe2bf-94df-49d5-8118-3e91fb52946b&quot;,\r\n          &quot;attributes&quot;: {\r\n            &quot;name&quot;: &quot;jumpbox&quot;\r\n          }\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;openstack_compute_floatingip_associate_v2&quot;,\r\n        &quot;primary&quot;: {\r\n          &quot;attributes&quot;: {\r\n            &quot;instance_id&quot;: &quot;5edfe2bf-94df-49d5-8118-3e91fb52946b&quot;,\r\n            &quot;floating_ip&quot;: &quot;10.120.241.21&quot;\r\n          }\r\n        }\r\n      }\r\n    ]\r\n\r\nto get the length, just add length:\r\n\r\n      .modules[].resources\r\n    | map(select(.!=null))\r\n    | length\r\n    \r\nin this example giving\r\n\r\n    2\r\n\r\nBecause `map(f)` is defined as `[ .[] | f ]` the above filter is really\r\n\r\n      .modules[].resources\r\n    | [\r\n          .[]\r\n        | select(.!=null)\r\n      ]\r\n    | length\r\n\r\nIn this form you can clearly see the construction of the intermediate array.\r\n\r\nNote also that jq provides a built-in [values](https://stedolan.github.io/jq/manual/#arrays,objects,iterables,booleans,numbers,normals,finites,strings,nulls,values,scalars) filter which is defined as `select(.!=null)` so this example could be further simplified to just\r\n\r\n      .modules[].resources\r\n    | map(values)\r\n    | length",
                "title": "How can I count number of elements after query?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1506580826,
                "last_edit_date": 1506580826,
                "creation_date": 1506575055,
                "answer_id": 46461314,
                "question_id": 46460631,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As mentioned at https://stackoverflow.com/questions/40120333/jq-count-nest-object-values-which-satisfy-condition\r\n\r\nthe best solution (e.g. because it does not involve construction of an intermediate array) would be to use `count`, defined as follows:\r\n\r\n&gt; def count(s): reduce s as $i (0; .+1);\r\n\r\nWith this definition, you should be able simply to wrap `count(...)` around your query since it produces a stream:\r\n\r\n    count(.modules[].resources | select (.[]!=null))\r\n\r\nOr maybe you want something closer to:\r\n\r\n    count(.modules[].resources | objects)",
                "title": "How can I count number of elements after query?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 19,
        "last_activity_date": 1506580826,
        "creation_date": 1506570317,
        "last_edit_date": 1506570621,
        "question_id": 46460631,
        "body_markdown": "I have a query:\r\n\r\n    .modules[].resources | select (.[]!=null)\r\n\r\nand after it I have got:\r\n\r\n    { somestuff } { somestuff } { somestuff }\r\n\r\nwhen I add legth after all:\r\n\r\n    .modules[].resources | select (.[]!=null) | length\r\n\r\nI have got:\r\n\r\n    1 1 1\r\n\r\nbut I need to count elements, so I need 3 in an output. How can I implement it ?\r\n\r\nIn fact it would be very useful to create an array from the first query output to operate with it furthure\r\n\r\n    [ { somestuff } , { somestuff } , { somestuff } ]",
        "link": "https://stackoverflow.com/questions/46460631/how-can-i-count-number-of-elements-after-query",
        "title": "How can I count number of elements after query?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1506697679,
                "post_id": 46490325,
                "comment_id": 79937959,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 301337,
                    "reputation": 13201,
                    "user_id": 608991,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://i.sstatic.net/1L4iV.png?s=256",
                    "display_name": "Tommie C.",
                    "link": "https://stackoverflow.com/users/608991/tommie-c"
                },
                "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": 1506814478,
                "post_id": 46490325,
                "comment_id": 79970202,
                "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": 1506825784,
                "post_id": 46490325,
                "comment_id": 79971771,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1506698941,
                "last_edit_date": 1506698941,
                "creation_date": 1506695687,
                "answer_id": 46491130,
                "question_id": 46490325,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You may want to consider using jq [Streaming](https://stedolan.github.io/jq/manual/#Streaming) for this.  With your sample data the following filter picks out the paths to the &quot;data&quot; attributes:\r\n\r\n      tostream\r\n    | select(length==2) as [$p,$v]\r\n    | select($p[-1]==&quot;data&quot;)\r\n    | [$p,$v]\r\n\r\nIf this is in `filter.jq` and your sample data is in `data.json` the command\r\n\r\n    $ jq -Mc -f filter.jq data.json\r\n\r\nproduces\r\n\r\n    [[0,&quot;text&quot;,0,&quot;data&quot;],&quot; &quot;]\r\n    [[0,&quot;text&quot;,1,&quot;data&quot;],&quot;Company &quot;]\r\n    [[0,&quot;text&quot;,2,&quot;data&quot;],&quot;Name&quot;]\r\n\r\nFrom this you can see your data has information in the paths `.[0].text[0].data`, `.[0].text[1].data` and `.[0].text[2].data`.  \r\n\r\nYou can build on this using [reduce](https://stedolan.github.io/jq/manual/#Reduce) to collect the values into groups based on the presence of the trailing space.  With your data the following filter\r\n\r\n    reduce (\r\n        tostream\r\n      | select(length==2) as [$p,$v]\r\n      | select($p[-1]==&quot;data&quot;)\r\n    ) as [$p,$v] (\r\n        [&quot;&quot;]\r\n      ; .[-1] += $v\r\n      | if $v|endswith(&quot; &quot;)|not then . += [&quot;&quot;] else . end\r\n    )\r\n    | map(select(. != &quot;&quot;))\r\n\r\nproduces\r\n\r\n    [&quot; Company Name&quot;]\r\n\r\nThis example only groups data into a list.  You can use a more sophisticated reduce if you need.\r\n\r\nHere is a [**Try it online!**][TIO-j85zuk42] link you can experiment with.\r\n\r\n\r\n[TIO-j85zuk42]: https://tio.run/##pZHBToNAEIbvPMW44QCxNC2Upmo4efcFCIe1TAsGdlcYWo346uIuRYuKFz0Q9v/4ZvZPeHjsYgvgRT8ATDTlPVbsGpazE1B8j7XOfrgaSIb5PiOj@OtgYMc8pUyjzZU/EMIn48R9@lh/@iKVMYfRHhW4M/J6MWIfK8fsfPUI7qSgb17KiWvEgA3sdfZbjyCYKrKZKPIFnpuEP6uEE1VuZam4eP5ro2UQTlRaLf5T6Y6X@FmnfyeWOSVW21WYNlsEp8cka6qQlzq0UGOBW3IKFHvKosh3gdcQ22pmH5KxYKvYWyZRdLrOtcbesDdmzIzcwNyocBmBfehX5Dt9alGk9TGnzNH/0W2FJKAMBcyNaEYBixp11J7lWi2UXDnD5XO4iIAx1@26N6kol6LuPE80ReHlQjWkQ8WPnmxIh3c &quot;jq – Try It Online&quot;\r\n\r\nTo take this further let&#39;s use the following sample data:\r\n\r\n    [\r\n        { &quot;data&quot;:&quot;Company &quot; },\r\n        { &quot;data&quot;: &quot;Address:&quot; },\r\n        { &quot;data&quot;:&quot;123 Main St. &quot; },\r\n        { &quot;data&quot;:&quot;Smallville &quot; },\r\n        { &quot;data&quot;:&quot;KS &quot; },\r\n        { &quot;data&quot;:&quot;606101&quot; }\r\n    ]\r\n    \r\nThe filter as is will generate\r\n\r\n    [&quot;Company Address:&quot;,&quot;123 Main St. Smallville KS 606101&quot;]\r\n\r\nTo convert that into an object you could add another reduce.  For example this filter\r\n\r\n      reduce (\r\n          tostream\r\n        | select(length==2) as [$p,$v]\r\n        | select($p[-1]==&quot;data&quot;)\r\n      ) as [$p,$v] (\r\n          [&quot;&quot;]\r\n        ; .[-1] += $v\r\n        | if $v|endswith(&quot; &quot;)|not then . += [&quot;&quot;] else . end\r\n      )\r\n    | map(select(. != &quot;&quot;))\r\n    | reduce .[] as $e (\r\n        {k:&quot;&quot;, o:{}}\r\n      ; if $e|endswith(&quot;:&quot;) then .k = $e[:-1] else .o[.k] += $e end\r\n      )\r\n    | .o\r\n\r\nproduces\r\n\r\n    {&quot;Company Address&quot;:&quot;123 Main St. Smallville KS 606101&quot;}\r\n\r\n\r\nOne last thing: at this point the filter is getting pretty large so it would make sense to refactor a bit and break it down into [functions](https://stedolan.github.io/jq/manual/#DefiningFunctions) so that it&#39;s easier to manage and extend.  e.g.\r\n\r\n      def extract:\r\n        [   tostream\r\n          | select(length==2) as [$p,$v]     # collect values for\r\n          | select($p[-1]==&quot;data&quot;)           # paths to &quot;data&quot;\r\n          | $v                               # in an array\r\n        ]\r\n      ;\r\n\r\n      def gather:\r\n        reduce .[] as $v (\r\n            [&quot;&quot;]                             # state: list of grouped values\r\n          ; .[-1] += $v                      # add value to last group\r\n          | if $v|endswith(&quot; &quot;)|not          # if the value ended with &quot; &quot;\r\n            then . += [&quot;&quot;]                   # form a new group\r\n            else .\r\n            end\r\n        )\r\n        | map(select(. != &quot;&quot;))               # produce final result\r\n      ;\r\n\r\n      def combine:\r\n          reduce .[] as $e (\r\n            {k:&quot;&quot;, o:{}}                     # k: current key o: combined object\r\n          ; if $e|endswith(&quot;:&quot;)              # if value ends with a &quot;:&quot;\r\n            then .k = $e[:-1]                #   use it as a new current key\r\n            else .o[.k] += $e                # otherwise add to current key&#39;s value\r\n            end\r\n          )\r\n        | .o                                 # produce the final object\r\n      ;\r\n\r\n        extract                              # extract &quot;data&quot; values\r\n      | gather                               # gather into groups\r\n      | combine                              # combine into an object\r\n      ",
                "title": "How to filter complex JSON using jq toolset and regular expressions into new JSON array of objects"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1506709282,
                "last_edit_date": 1506709282,
                "creation_date": 1506697415,
                "answer_id": 46491701,
                "question_id": 46490325,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "So from what I could tell what you&#39;re trying to do, you&#39;re trying to get all the `&quot;data&quot;` elements and concatenating them into a single string.\r\n\r\nShould be simple enough to do:\r\n\r\n    [.. | .data? | select(. != null) | tostring] | join(&quot;&quot;)\r\n\r\nThere&#39;s not enough example data to know where the start of one &quot;grouping&quot; of data begins and ends.  But assuming every item in the root array is a single phrase, select each item first before performing the search (or map them):\r\n\r\n    map([.. | .data? | select(. != null) | tostring] | join(&quot;&quot;))\r\n\r\nIf ultimately you&#39;d want to parse the data bits to a json object, it&#39;s not too far off:\r\n\r\n    map(\r\n        [.. | .data? | select(. != null) | tostring]\r\n            | join(&quot;&quot;)\r\n            | split(&quot;:&quot;) as [$key,$value]\r\n            | {$key,$value}\r\n    ) | from_entries",
                "title": "How to filter complex JSON using jq toolset and regular expressions into new JSON array of objects"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1506816734,
        "creation_date": 1506693261,
        "last_edit_date": 1506816734,
        "question_id": 46490325,
        "body_markdown": "&gt; First ~ *Thanks* for taking the time to read this. If any further\r\n&gt; information or restatements are needed please comment so that I can improve\r\n&gt; the question. I am new to **jq** and appreciate any assistance provided.\r\n&gt; If there is any confusion in the topic it is due to my lack of\r\n&gt; experience with the **jq** tool. This seems fairly complex so even a partial \r\n&gt; answer is welcome.\r\n\r\n**Background**\r\n\r\nI have some JSON objects within a series of JSON arrays (sample at bottom). The objects have a number of elements but only the values associated with the &quot;data&quot; key are of interest to me. I want to output a single array of JSON objects where the values are translated into key/value pairs based on some regular expression rules.\r\n\r\nI want to essentially combine multiple &quot;data&quot; values to form a key phrase (and then a value-phrase) which I need to output as the array of target objects. I believe I should be able to use a regular expression or a set of known text (for the key-phrase) to compile the text into a single key or value.  \r\n\r\n**Current Logic**\r\n\r\n*Using: jq-1.5, Mac OS 10.12.6, Bash terminal*\r\n\r\nSome things I have examined are by looking at the (:) colon in the value field (it indicates the end of a key-phrase). So for example, below represents the key &quot;Company Address&quot;:\r\n\r\n    &quot;data&quot;:&quot;Company &quot;,\r\n    ...\r\n    &quot;data&quot;: &quot;Address:&quot;\r\n    ...\r\n    {\r\n        &quot;top&quot;: 333,\r\n        &quot;left&quot;: 520,\r\n        &quot;width&quot;: 66,\r\n        &quot;height&quot;: 15,\r\n        &quot;font&quot;: 5,\r\n        &quot;data&quot;:&quot;123 Main St. &quot;\r\n    ...\r\n    &quot;data&quot;:&quot;Smallville &quot;\r\n    ...\r\n    &quot;data&quot;:&quot;KS &quot;\r\n    ...\r\n    &quot;data&quot;:&quot;606101&quot;\r\n\r\nIn this case, the colon in the value indicates that the next value attached to the following useful &quot;data&quot; key is the beginning of an address.\r\n\r\nA space trailing the value indicates that the next data value found is a continuation of the key phrase or the value phrase I am attempting to combine into a new JSON object.\r\n\r\nI have a set of values that I can use to delimit a new JSON object. Essentially the following example would allow me to create a key &quot;Company Name&quot;:\r\n\r\n    ...\r\n    &quot;data&quot;:&quot;Company &quot;\r\n    ...\r\n    &quot;data&quot;:&quot;Name&quot;\r\n\r\n(note that this entry does not have a colon but the pattern will be the start of each new JSON object to be generated)\r\n\r\n**Notes**\r\n\r\nI can determine when the end of a key or value is reached depending on whether or not it&#39;s value ends with a space. (if there is no space then I consider the value to be the end of the value phrase and begin capturing the next key phrase).\r\n\r\n**Things I&#39;ve tried**\r\n\r\nAny assistance with translating this logic into one or more useful jq filter(s) would be greatly appreciated. I&#39;ve taken a look at the [JQ Cookbook][1], the [JQ Manual][2], this [article][3], examined other [SO questions on jq][4], and made an evaluation of an alternate tool ([underscore_cli][5]). I am new to jq and my naive expressions keep failing...\r\n\r\n&gt; I&#39;ve tried some simple tests to attempt to select values of interest.\r\n&gt; (I am not successfully able to walk the json tree to get to the\r\n&gt; information under the text array. Another wrinkle is that I have\r\n&gt; multiple text arrays. Is it possible to have the same algorithm\r\n&gt; performed on each array of objects?)\r\n\r\n    jq -s &#39;.[]  | select(.data | contains(&quot;:&quot;))&#39;\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;data&quot;\r\n\r\n\r\n**Sample**\r\n\r\nA sample of the header JSON\r\n\r\n    [\r\n      {\r\n        &quot;number&quot;: 1,\r\n        &quot;pages&quot;: 254,\r\n        &quot;height&quot;: 1263,\r\n        &quot;width&quot;: 892,\r\n        &quot;fonts&quot;: [\r\n          {\r\n            &quot;fontspec&quot;: &quot;0&quot;,\r\n            &quot;size&quot;: &quot;-1&quot;,\r\n            &quot;family&quot;: &quot;Times&quot;,\r\n            &quot;color&quot;: &quot;#ffffff&quot;\r\n          },\r\n          {\r\n            &quot;fontspec&quot;: &quot;1&quot;,\r\n            &quot;size&quot;: &quot;31&quot;,\r\n            &quot;family&quot;: &quot;Times&quot;,\r\n            &quot;color&quot;: &quot;#000000&quot;\r\n          },\r\n          {\r\n            &quot;fontspec&quot;: &quot;2&quot;,\r\n            &quot;size&quot;: &quot;16&quot;,\r\n            &quot;family&quot;: &quot;Helvetica&quot;,\r\n            &quot;color&quot;: &quot;#000000&quot;\r\n          },\r\n          {\r\n            &quot;fontspec&quot;: &quot;3&quot;,\r\n            &quot;size&quot;: &quot;13&quot;,\r\n            &quot;family&quot;: &quot;Times&quot;,\r\n            &quot;color&quot;: &quot;#237db8&quot;\r\n          },\r\n          {\r\n            &quot;fontspec&quot;: &quot;4&quot;,\r\n            &quot;size&quot;: &quot;17&quot;,\r\n            &quot;family&quot;: &quot;Times&quot;,\r\n            &quot;color&quot;: &quot;#000000&quot;\r\n          },\r\n          {\r\n            &quot;fontspec&quot;: &quot;5&quot;,\r\n            &quot;size&quot;: &quot;13&quot;,\r\n            &quot;family&quot;: &quot;Times&quot;,\r\n            &quot;color&quot;: &quot;#000000&quot;\r\n          },\r\n          {\r\n            &quot;fontspec&quot;: &quot;6&quot;,\r\n            &quot;size&quot;: &quot;8&quot;,\r\n            &quot;family&quot;: &quot;Times&quot;,\r\n            &quot;color&quot;: &quot;#9f97a7&quot;\r\n          },\r\n          {\r\n            &quot;fontspec&quot;: &quot;7&quot;,\r\n            &quot;size&quot;: &quot;10&quot;,\r\n            &quot;family&quot;: &quot;Times&quot;,\r\n            &quot;color&quot;: &quot;#9f97a7&quot;\r\n          }\r\n        ],\r\n        &quot;text&quot;: [\r\n          {\r\n            &quot;top&quot;: 83,\r\n            &quot;left&quot;: 60,\r\n            &quot;width&quot;: 0,\r\n            &quot;height&quot;: 1,\r\n            &quot;font&quot;: 0,\r\n            &quot;data&quot;: &quot; &quot;\r\n          },\r\n          {\r\n            &quot;top&quot;: 333,\r\n            &quot;left&quot;: 68,\r\n            &quot;width&quot;: 68,\r\n            &quot;height&quot;: 15,\r\n            &quot;font&quot;: 5,\r\n            &quot;data&quot;: &quot;Company &quot;\r\n          },\r\n          {\r\n            &quot;top&quot;: 333,\r\n            &quot;left&quot;: 135,\r\n            &quot;width&quot;: 40,\r\n            &quot;height&quot;: 15,\r\n            &quot;font&quot;: 5,\r\n            &quot;data&quot;: &quot;Name&quot;\r\n          },\r\n          ...(more of these objects with data)\r\n         ]\r\n        ]\r\n\r\n&gt; I am looking to output a JSON array of objects whose keys are composed\r\n&gt; of known strings (patterns) for the key/value pair bound by a colon\r\n&gt; (:) indicating the end of a key-phrase and whose next data-value would\r\n&gt; be the start of the value-phrase. The presence of a trailing space\r\n&gt; indicates that the data-value should be appended as part of the\r\n&gt; value-phrase until the trailing space no longer appears in the\r\n&gt; data-value. At that point the next data-value represents the start of\r\n&gt; another key-phrase.\r\n\r\nUPDATE #1:\r\n----------\r\n\r\n&gt; The answers below are very helpful. I&#39;ve gone back to the jq manual\r\n&gt; and incorporated the advice below. I am getting a string but unable to\r\n&gt; separate out the set of data tags into a single string.\r\n\r\n    .[].text |  tostring\r\n\r\n&gt; However, I am seeing the JSON being escaped and the other tags showing\r\n&gt; up in the string `top, left, right` (along with their values). I&#39;d\r\n&gt; like to have the tokens associated only with the data key as a string.\r\n&gt; Then run the regular expressions over that string to parse out a set\r\n&gt; of JSON objects where the keys and values can be defined.\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/Cookbook#filter-objects-based-on-the-contents-of-a-key\r\n  [2]: https://stedolan.github.io/jq/manual/\r\n  [3]: http://www.compciv.org/recipes/cli/jq-for-parsing-json/\r\n  [4]: https://stackoverflow.com/questions/tagged/jq\r\n  [5]: https://github.com/ddopson/underscore-cli",
        "link": "https://stackoverflow.com/questions/46490325/how-to-filter-complex-json-using-jq-toolset-and-regular-expressions-into-new-jso",
        "title": "How to filter complex JSON using jq toolset and regular expressions into new JSON array of objects"
    },
    {
        "tags": [
            "json",
            "geojson",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4636678,
                    "reputation": 960,
                    "user_id": 3757733,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/s5T9b.jpg?s=256",
                    "display_name": "bated",
                    "link": "https://stackoverflow.com/users/3757733/bated"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1506722443,
                "post_id": 46497058,
                "comment_id": 79949718,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1506722578,
                "last_edit_date": 1506722578,
                "creation_date": 1506721886,
                "answer_id": 46497369,
                "question_id": 46497058,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**jq** solution:\r\n\r\n    jq &#39;(.features[0].properties.group = .features[0].properties.activities[0].group)\r\n     | del(.features[0].properties.activities[0].group)&#39; input.json\r\nThe output:\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;geometry&quot;: {\r\n            &quot;type&quot;: &quot;MultiLineString&quot;,\r\n            &quot;coordinates&quot;: [\r\n              [\r\n                [\r\n                  -74,\r\n                  40\r\n                ],\r\n                [\r\n                  -73,\r\n                  40\r\n                ]\r\n              ]\r\n            ]\r\n          },\r\n          &quot;properties&quot;: {\r\n            &quot;startTime&quot;: &quot;20160123T162547-0500&quot;,\r\n            &quot;endTime&quot;: &quot;20160123T164227-0500&quot;,\r\n            &quot;activities&quot;: [\r\n              {\r\n                &quot;activity&quot;: &quot;car&quot;\r\n              }\r\n            ],\r\n            &quot;group&quot;: &quot;car&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "Moving a json nested key-value pair up one level with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1506724297,
                "last_edit_date": 1506724297,
                "creation_date": 1506722357,
                "answer_id": 46497438,
                "question_id": 46497058,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In two steps (first add, then delete):\r\n\r\n    .features[0].properties |= (.group = .activities[0].group)\r\n    | del(.features[0].properties.activities[0].group)\r\n\r\nOr still more succinctly:\r\n\r\n    .features[0].properties |=\r\n      ((.group = .activities[0].group) | del(.activities[0].group))\r\n\r\n",
                "title": "Moving a json nested key-value pair up one level with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1506725055,
                "creation_date": 1506725055,
                "answer_id": 46497812,
                "question_id": 46497058,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The problem doesn&#39;t discuss what should be done if there are no activities or\r\nif there is more than one activity so the following filter encapsulates the\r\nproperty change to a function:\r\n\r\n     def update_activity:\r\n        if .activities|length&lt;1 then .\r\n        else \r\n             .group = .activities[0].group\r\n           | del(.activities[0].group)\r\n        end\r\n     ;\r\n\r\n     .features[].properties |= update_activity\r\n\r\n`.properties` is left unmodified when there are no activities otherwise the group\r\nof the first activity is moved to the property, leaving other activities unmodified.\r\nSo if the sample input (slightly abbreviated) were instead \r\n\r\n    {\r\n      &quot;type&quot; : &quot;FeatureCollection&quot;,\r\n      &quot;features&quot; : [ {\r\n        &quot;properties&quot; : {\r\n          &quot;activities&quot; : [ {\r\n            &quot;activity&quot; : &quot;car&quot;,\r\n            &quot;group&quot; : &quot;car&quot;\r\n          }, {\r\n            &quot;activity&quot; : &quot;bike&quot;,\r\n            &quot;group&quot; : &quot;bike&quot;\r\n          } ]\r\n        }\r\n      } ]\r\n    }\r\n\r\nthe result would be\r\n\r\n    {\r\n      &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n      &quot;features&quot; : [ {\r\n        &quot;properties&quot; : {\r\n          &quot;group&quot;: &quot;car&quot;,\r\n          &quot;activities&quot;: [ {\r\n              &quot;activity&quot;: &quot;car&quot;\r\n          }, {\r\n              &quot;activity&quot;: &quot;bike&quot;,\r\n              &quot;group&quot;: &quot;bike&quot;\r\n          } ]\r\n        }\r\n      } ]\r\n    }\r\n\r\nThis approach offers a specific place to put the logic dealing with other\r\nvariations.  E.g. this version of update_activity removes the `.group` of\r\nall activities:\r\n\r\n     def update_activity:\r\n        if .activities|length&lt;1 then .\r\n        else \r\n             .group = .activities[0].group\r\n           | del(.activities[].group)\r\n        end\r\n     ;\r\n\r\nand this version also assigns `.group` to null in the event there are no activites:\r\n\r\n     def update_activity:\r\n        if .activities|length&lt;1 then\r\n             .group = null\r\n        else \r\n             .group = .activities[0].group\r\n           | del(.activities[].group)\r\n        end\r\n     ;\r\n",
                "title": "Moving a json nested key-value pair up one level with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1506824733,
                "creation_date": 1506824733,
                "answer_id": 46508674,
                "question_id": 46497058,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a generalized solution:\r\n\r\n    # move the key/value specified by apath up to the containing JSON object:\r\n    def up(apath):\r\n      def trim:\r\n        if .[-1] | type == &quot;number&quot; then .[0:-2] | trim\r\n        else .\r\n        end;\r\n\r\n    . as $in\r\n    | (null | path(apath)) as $p\r\n    | ($p|last) as $last\r\n    | $in\r\n    | getpath($p) as $v\r\n    | setpath(($p[0:-1]|trim) + [$last]; $v)\r\n    | del(apath)\r\n    ;\r\n\r\nWith this definition, the solution is simply:\r\n\r\n    up( .features[0].properties.activities[0].group )\r\n\r\n",
                "title": "Moving a json nested key-value pair up one level with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1506824733,
        "creation_date": 1506720035,
        "question_id": 46497058,
        "body_markdown": "I want to use jq to move a nested key:value pair up one level. So given a geojson array of objects like this: \r\n\r\n        {\r\n          &quot;type&quot; : &quot;FeatureCollection&quot;,\r\n          &quot;features&quot; : [ {\r\n            &quot;type&quot; : &quot;Feature&quot;,\r\n            &quot;geometry&quot; : {\r\n              &quot;type&quot; : &quot;MultiLineString&quot;,\r\n              &quot;coordinates&quot; : [ [ [ -74, 40 ], [ -73, 40 ] ] ]\r\n            },\r\n            &quot;properties&quot; : {\r\n              &quot;startTime&quot; : &quot;20160123T162547-0500&quot;,\r\n              &quot;endTime&quot; : &quot;20160123T164227-0500&quot;,\r\n              &quot;activities&quot; : [ {\r\n                &quot;activity&quot; : &quot;car&quot;,\r\n                &quot;group&quot; : &quot;car&quot;\r\n              } ]\r\n            }\r\n          } ]\r\n        }\r\n\r\nI want to return the exact same object, but with `&quot;group&quot;: &quot;car&quot;` in the `features` object. So the result would look something like this:\r\n\r\n        {\r\n          &quot;type&quot; : &quot;FeatureCollection&quot;,\r\n          &quot;features&quot; : [ {\r\n            &quot;type&quot; : &quot;Feature&quot;,\r\n            &quot;geometry&quot; : {\r\n              &quot;type&quot; : &quot;MultiLineString&quot;,\r\n              &quot;coordinates&quot; : [ [ [ -74, 40 ], [ -73, 40 ] ] ]\r\n            },\r\n            &quot;properties&quot; : {\r\n              &quot;type&quot; : &quot;move&quot;,\r\n              &quot;startTime&quot; : &quot;20160123T162547-0500&quot;,\r\n              &quot;endTime&quot; : &quot;20160123T164227-0500&quot;,\r\n              &quot;group&quot; : &quot;car&quot;,\r\n              &quot;activities&quot; : [ {\r\n                &quot;activity&quot; : &quot;car&quot;\r\n              } ]\r\n            }\r\n          } ]\r\n        }\r\n\r\nThis seems simple, but somehow I&#39;m struggling to figure out how to do it with jq. Help appreciated! ",
        "link": "https://stackoverflow.com/questions/46497058/moving-a-json-nested-key-value-pair-up-one-level-with-jq",
        "title": "Moving a json nested key-value pair up one level with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1506969907,
                "post_id": 46530167,
                "comment_id": 80018143,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1506980708,
                "post_id": 46530167,
                "comment_id": 80023102,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 40,
                "is_accepted": true,
                "score": 40,
                "last_activity_date": 1506964138,
                "creation_date": 1506964138,
                "answer_id": 46530324,
                "question_id": 46530167,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this: \r\n\r\n    .[] | select(.id == &quot;3&quot; or .id == &quot;2&quot;) | .name,.value\r\n\r\n[Demo](https://jqplay.org/s/kF2SWNRv84)",
                "title": "JQ select filter with multiple arguments"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 20,
        "last_activity_date": 1506964138,
        "creation_date": 1506963536,
        "question_id": 46530167,
        "body_markdown": "Given then following JSON\r\n\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;1&quot;,\r\n        &quot;name&quot;: &quot;sausage&quot;,\r\n        &quot;value&quot;: 100\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;2&quot;,\r\n        &quot;name&quot;: &quot;spam&quot;,\r\n        &quot;value&quot;: 200\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;3&quot;,\r\n        &quot;name&quot;: &quot;eggs&quot;,\r\n        &quot;value&quot;: 300\r\n      }\r\n    ]\r\n\r\nI can select a single record with `id=3` with:\r\n\r\n&lt;!-- language-all: lang-bash --&gt;\r\n\r\n    jq &#39;.[] | select(.id==&quot;3&quot;) | .name,.value&#39; data.json\r\n    ### &gt; &quot;sausage&quot;\r\n    ### &gt; &quot;100&quot;\r\n\r\nBut how to select several `id`&#39;s, i.e. the items with `id in (1,2)`?\r\n\r\n\r\n    ## this is something I wish I could do\r\n    jq &#39;.[] | select(.id in (&quot;1&quot;, &quot;2&quot;) | .name,.value&#39; data.json \r\n\r\nI tried:\r\n\r\n    jq &#39;.[] | select(.id==&quot;1&quot;) or select(.id==&quot;2&quot;) | .name,.value&#39; data.json\r\n\r\nbut this results in an error.",
        "link": "https://stackoverflow.com/questions/46530167/jq-select-filter-with-multiple-arguments",
        "title": "JQ select filter with multiple arguments"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1507066364,
                "last_edit_date": 1507066364,
                "creation_date": 1507065776,
                "answer_id": 46553656,
                "question_id": 46553593,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Is there a reason you can&#39;t use [--slurpfile or --argfile](https://stedolan.github.io/jq/manual/#Invokingjq) ?\r\n\r\n&gt; --slurpfile variable-name filename:\r\n&gt;\r\nThis option reads all the JSON texts in the named file and binds an array of the parsed JSON values to the given global variable. If you run jq with --argfile foo bar, then $foo is available in the program and has an array whose elements correspond to the texts in the file named bar.\r\n\r\n&gt; --argfile variable-name filename:\r\n&gt;\r\nDo not use. Use --slurpfile instead.\r\n(This option is like --slurpfile, but when the file has just one text, then that is used, else an array of texts is used as in --slurpfile.)\r\n\r\nAssuming you put your mapping into `procedures.json` and you change your filter a bit as so:\r\n\r\n      procedure: $procedures[0][.Procedure],\r\n\r\nthen you can use --slurpfile:\r\n\r\n    $ jq --slurpfile procedures procedures.json -f jq-filter.jq temp.json\r\n\r\nor you use --argfile (although the docs say not to)\r\n\r\n    $ jq --argfile procedures procedures.json -f jq-filter.jq temp.json\r\n\r\nwithout any other change to your code.",
                "title": "Is there a more elegant way to pass a big object variable to jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1507066364,
        "creation_date": 1507065503,
        "question_id": 46553593,
        "body_markdown": "I have the following JSON input to transform (an array of hundreds of similar objects):\r\n\r\n    [{\r\n    \t&quot;Nmarch\\u00e9&quot;: &quot;2013-90006&quot;,\r\n    \t&quot;SIRETMandataire&quot;: null,\r\n    \t&quot;LibelleEntiteMandataire&quot;: &quot;R\\u00e9gion Bretagne&quot;,\r\n    \t&quot;SIRETAcheteur&quot;: null,\r\n    \t&quot;LibelleAcheteur&quot;: null,\r\n    \t&quot;Nature&quot;: null,\r\n    \t&quot;Objet&quot;: &quot;PBF Formation qualifiante 2013 Monteur en construction bois lot 4&quot;,\r\n    \t&quot;CodeCPV&quot;: null,\r\n    \t&quot;Type &quot;: &quot;Services&quot;,\r\n    \t&quot;Procedure&quot;: &quot;MAPA - art 30 - au dessus des seuils&quot;,\r\n    \t&quot;CodePostalCommuneExecution&quot;: 35000.0,\r\n    \t&quot;NomCommuneExecution&quot;: &quot;Rennes&quot;,\r\n    \t&quot;CodeINSEEExecution&quot;: null,\r\n    \t&quot;GranulariteINSEEExecution&quot;: null,\r\n    \t&quot;MillesimeMandatement&quot;: 2013,\r\n    \t&quot;DateNotification&quot;: &quot;2013-10-01&quot;,\r\n    \t&quot;Montant mandate TTC&quot;: 245526,\r\n    \t&quot;Montant mandate HT&quot;: null,\r\n    \t&quot;Montant attribue TTC&quot;: 245526,\r\n    \t&quot;Montant attribue HT&quot;: null,\r\n    \t&quot;Date de cloture&quot;: null,\r\n    \t&quot;Duree&quot;: null,\r\n    \t&quot;SIRETContractant&quot;: 300599123,\r\n    \t&quot;DenominationSociale&quot;: &quot;AFPA DIRECTION REGIONALE BRETAGNE&quot;,\r\n    \t&quot;Role&quot;: &quot;Titulaire&quot;,\r\n    \t&quot;CodePostal&quot;: 35208,\r\n    \t&quot;Dpt ID &quot;: 35,\r\n    \t&quot;D\\u00e9partement&quot;: &quot;Ille-et-Vilaine&quot;,\r\n    \t&quot;Commune&quot;: &quot;RENNES&quot;,\r\n    \t&quot;Taille&quot;: &quot;10 000 et plus&quot;,\r\n    \t&quot;Taille des entreprises par categorie officielle&quot;: &quot;Grande entreprise&quot;,\r\n    \t&quot;Code NAF&quot;: 8559,\r\n    \t&quot;Libelle NAF&quot;: &quot;ENSEIGNEMENT&quot;,\r\n    \t&quot;Libelle SBA&quot;: &quot;Administration publique\\/enseignement&quot;,\r\n    \t&quot;Libelle CCI&quot;: &quot;Tertiaire non marchand&quot;,\r\n    \t&quot;geolocalisation&quot;: null\r\n    }\r\n    ]\r\n\r\n\r\nIn `Procedure`, I have a lot of invalid values that I need to replace through a value mapping. I consequently want to feed a JSON object to my jq transform, with the invalid values as keys and the right values as values:\r\n\r\n\r\n   \r\n\r\n     {\r\n    \t&quot;MAPA - art 28&quot;: &quot;Proc&#233;dure adapt&#233;e&quot;,\r\n    \t&quot;MAPA - art 30 - au dessus des seuils&quot;: &quot;Proc&#233;dure adapt&#233;e&quot;,\r\n    \t&quot;MAPA - art 30 - en dessous des seuils&quot;: &quot;Proc&#233;dure adapt&#233;e&quot;,\r\n    \t&quot;Proc. adapt&#233;e/all&#233;g&#233;e (art.28et30)&quot;: &quot;Proc&#233;dure adapt&#233;e&quot;,\r\n    \t&quot;Proc&#233;dure adapt&#233;e (MAPA)&quot;: &quot;Proc&#233;dure adapt&#233;e&quot;,\r\n    \t&quot;Appel d&#39;offre ouvert&quot;: &quot;Appel d&#39;offres ouvert&quot;,\r\n    \t&quot;appel d&#39;offres ouvert&quot;: &quot;Appel d&#39;offres ouvert&quot;,\r\n    \t&quot;Appel d&#39;offre ouvert (art.33)&quot;: &quot;Appel d&#39;offres ouvert&quot;,\r\n    \t&quot;Appel d&#39;offre restreint&quot;: &quot;Appel d&#39;offres restreint&quot;,\r\n    \t&quot;Achat direct&quot;: &quot;March&#233; n&#233;goci&#233; sans publicit&#233; ni mise en concurrence pr&#233;alable&quot;,\r\n    \t&quot;N&#233;goci&#233; avec pub (art.35I)&quot;: &quot;Proc&#233;dure n&#233;goci&#233;e avec mise en concurrence pr&#233;alable&quot;,\r\n    \t&quot;Proc&#233;dure n&#233;goci&#233;e apr&#232;s pub&quot;: &quot;Proc&#233;dure n&#233;goci&#233;e avec mise en concurrence pr&#233;alable&quot;,\r\n    \t&quot;Proc&#233;dure n&#233;goci&#233;e apr&#232;s pub.&quot;: &quot;Proc&#233;dure n&#233;goci&#233;e avec mise en concurrence pr&#233;alable&quot;,\r\n    \t&quot;Proc&#233;dure n&#233;goci&#233;e sans pub&quot;: &quot;March&#233; n&#233;goci&#233; sans publicit&#233; ni mise en concurrence pr&#233;alable&quot;,\r\n    \t&quot;Proc&#233;dure n&#233;goci&#233;e sans pub.&quot;: &quot;March&#233; n&#233;goci&#233; sans publicit&#233; ni mise en concurrence pr&#233;alable&quot;,\r\n    \t&quot;March&#233; n&#233;goci&#233;&quot;: &quot;March&#233; n&#233;goci&#233; sans publicit&#233; ni mise en concurrence pr&#233;alable&quot;,\r\n    \t&quot;march&#233; n&#233;goci&#233;&quot;: &quot;March&#233; n&#233;goci&#233; sans publicit&#233; ni mise en concurrence pr&#233;alable&quot;,\r\n    \t&quot;March&#233; negoci&#233;&quot;: &quot;March&#233; n&#233;goci&#233; sans publicit&#233; ni mise en concurrence pr&#233;alable&quot;\r\n    }\r\n\r\n\r\nI wanted to declare this object in my jq transform file, but I didn&#39;t see how to use the `bla as var` syntax to declare a variable with foreign data (ideally I&#39;d like to declare it as a file). I consequently ended up using the `--argjson` command line parameter.\r\n\r\nThis works (I get JSON output with replaced values), but I wish I could have a cleaner command and make it more maintainable:\r\n\r\n    cat temp.json | jq --argjson procedures &#39;{&quot;MAPA - art 28&quot;:&quot;Proc&#233;dure adapt&#233;e&quot;,&quot;MAPA - art 30 - au dessus des seuils&quot;:&quot;Proc&#233;dure adapt&#233;e&quot;,&quot;MAPA - art 30 - en dessous des seuils&quot;:&quot;Proc&#233;dure adapt&#233;e&quot;,&quot;Proc. adapt&#233;e/all&#233;g&#233;e (art.28et30)&quot;:&quot;Proc&#233;dure adapt&#233;e&quot;,&quot;Proc&#233;dure adapt&#233;e (MAPA)&quot;:&quot;Proc&#233;dure adapt&#233;e&quot;,&quot;Appel d\\u0027offre ouvert&quot;:&quot;Appel d\\u0027offres ouvert&quot;,&quot;appel d\\u0027offres ouvert&quot;:&quot;Appel d\\u0027offres ouvert&quot;,&quot;Appel d\\u0027offre ouvert (art.33)&quot;:&quot;Appel d\\u0027offres ouvert&quot;,&quot;Appel d\\u0027offre restreint&quot;:&quot;Appel d\\u0027offres restreint&quot;,&quot;Achat direct&quot;:&quot;March&#233; n&#233;goci&#233; sans publicit&#233; ni mise en concurrence pr&#233;alable&quot;,&quot;N&#233;goci&#233; avec pub (art.35I)&quot;:&quot;Proc&#233;dure n&#233;goci&#233;e avec mise en concurrence pr&#233;alable&quot;,&quot;Proc&#233;dure n&#233;goci&#233;e apr&#232;s pub&quot;:&quot;Proc&#233;dure n&#233;goci&#233;e avec mise en concurrence pr&#233;alable&quot;,&quot;Proc&#233;dure n&#233;goci&#233;e apr&#232;s pub.&quot;:&quot;Proc&#233;dure n&#233;goci&#233;e avec mise en concurrence pr&#233;alable&quot;,&quot;Proc&#233;dure n&#233;goci&#233;e sans pub&quot;:&quot;March&#233; n&#233;goci&#233; sans publicit&#233; ni mise en concurrence pr&#233;alable&quot;,&quot;Proc&#233;dure n&#233;goci&#233;e sans pub.&quot;:&quot;March&#233; n&#233;goci&#233; sans publicit&#233; ni mise en concurrence pr&#233;alable&quot;,&quot;March&#233; n&#233;goci&#233;&quot;:&quot;March&#233; n&#233;goci&#233; sans publicit&#233; ni mise en concurrence pr&#233;alable&quot;,&quot;march&#233; n&#233;goci&#233;&quot;:&quot;March&#233; n&#233;goci&#233; sans publicit&#233; ni mise en concurrence pr&#233;alable&quot;,&quot;March&#233; negoci&#233;&quot;:&quot;March&#233; n&#233;goci&#233; sans publicit&#233; ni mise en concurrence pr&#233;alable&quot;}&#39; -f jq-filter.jq\r\n\r\nFor your information, here is jq-filter.jq:\r\n\r\n    {\r\n      &quot;$schema&quot;: &quot;../../sch&#233;mas/json/paquet.json&quot;,\r\n      &quot;marches&quot; : [.[] | {\r\n          id: .&quot;Nmarch&#233;&quot;,\r\n          acheteur: {\r\n              id: .SIRETMandataire,\r\n              nom: .LibelleEntiteMandataire\r\n          },\r\n          nature: .Nature,\r\n          objet: .Objet,\r\n          codeCPV: .CodeCPV,\r\n          procedure: $procedures[.Procedure],\r\n          lieuExecution: {\r\n              code: ( .CodeINSEEExecution //.CodePostalCommuneExecution),\r\n              nom: .NomCommuneExecution,\r\n              typeCode: (if .CodeINSEEExecution != null  then &quot;Code commune&quot; elif .CodePostalCommuneExecution != null then &quot;Code postal&quot; else null end)\r\n          },\r\n          dateNotification: .DateNotification,\r\n          montant: .&quot;Montant Attribue HT&quot;,\r\n          dureeMois: null,\r\n          titulaires: {\r\n              id: .SIRETContractant,\r\n              denominationSociale: .DenominationSociale\r\n          }\r\n      }\r\n      ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/46553593/is-there-a-more-elegant-way-to-pass-a-big-object-variable-to-jq",
        "title": "Is there a more elegant way to pass a big object variable to jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 31,
                "is_accepted": true,
                "score": 30,
                "last_activity_date": 1507123329,
                "last_edit_date": 1507123329,
                "creation_date": 1507122978,
                "answer_id": 46565894,
                "question_id": 46564720,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Short **jq** solution:\r\n\r\n    jq -r &#39;[paths | join(&quot;.&quot;)]&#39;  jsonfile\r\nThe output:\r\n\r\n    [\r\n      &quot;a&quot;,\r\n      &quot;b&quot;,\r\n      &quot;b.c&quot;\r\n    ]\r\n\r\n\r\n----------\r\n- `paths` function outputs the paths to all the elements in its input\r\n\r\n- `join(&quot;.&quot;)` - to concatenate keys within hierarchical paths\r\n\r\n",
                "title": "How to extract all (also nested) key names with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1651133151,
                "creation_date": 1651133151,
                "answer_id": 72040091,
                "question_id": 46564720,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given input `foo.json`\r\n\r\n```json\r\n{&quot;a&quot;:1,&quot;b&quot;:[{&quot;c&quot;:2}]}\r\n```\r\n\r\n```sh\r\njq &#39;[\r\npaths |\r\nmap(select(type!=&quot;number&quot;)) |\r\nselect(length &gt; 0) |\r\njoin(&quot;.&quot;)\r\n] | unique&#39; foo.json\r\n```\r\noutputs\r\n```\r\n[\r\n  &quot;a&quot;,\r\n  &quot;b&quot;,\r\n  &quot;b.c&quot;\r\n]\r\n```",
                "title": "How to extract all (also nested) key names with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 22,
        "last_activity_date": 1651133151,
        "creation_date": 1507119566,
        "question_id": 46564720,
        "body_markdown": "How can I extract all key names, even in nested objects with jq? \r\nFor example,  I have json:\r\n\r\n```\r\n{\r\n &quot;a&quot;: 1,\r\n  &quot;b&quot;: {\r\n      &quot;c&quot;: 2\r\n  }\r\n}\r\n```\r\n\r\nand I want to get list:\r\na, b, b.c\r\n\r\nI know that for top level keys I can get this, with:\r\n`. | to_entries[]  | .key`, but what about keys in nested objects?",
        "link": "https://stackoverflow.com/questions/46564720/how-to-extract-all-also-nested-key-names-with-jq",
        "title": "How to extract all (also nested) key names with jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "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": 1507172583,
                "post_id": 46576926,
                "comment_id": 80107496,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507185947,
                "post_id": 46576926,
                "comment_id": 80111627,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6006601,
                    "reputation": 99,
                    "user_id": 4718345,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/28a95a6d467aa41ae0a3e94be9814b01?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "wasay",
                    "link": "https://stackoverflow.com/users/4718345/wasay"
                },
                "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": 1507225210,
                "post_id": 46576926,
                "comment_id": 80136478,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1507227872,
                "creation_date": 1507227872,
                "answer_id": 46592435,
                "question_id": 46576926,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Thank you for updating your question.  Since in your input `.service` is an object and in your output `.service` is an array, here is a solution which uses a helper function:\r\n\r\n    def as_array:if type==&quot;object&quot; then [.] else . end;\r\n\r\n    .service |= as_array + [\r\n       {\r\n         &quot;name&quot;: &quot;tomcat&quot;,\r\n         &quot;tags&quot;: [\r\n           &quot;contact_points&quot;\r\n         ],\r\n         &quot;check&quot;: {\r\n            &quot;script&quot;: &quot;tmp/status_check.py &gt; /dev/null 2&gt;&amp;1&quot;,\r\n            &quot;interval&quot;: &quot;10s&quot;\r\n         }\r\n       }\r\n    ]\r\n\r\nIf the above filter is in `filter.jq` and your sample data in `status.json`, the command \r\n\r\n    $ jq -M -f filter.jq status.json\r\n\r\nproduces\r\n\r\n    {\r\n      &quot;service&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;web&quot;,\r\n          &quot;tags&quot;: [\r\n            &quot;contact_points&quot;\r\n          ],\r\n          &quot;check&quot;: {\r\n            &quot;script&quot;: &quot;tmp/status_check.py &gt; /dev/null 2&gt;&amp;1&quot;,\r\n            &quot;interval&quot;: &quot;10s&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;tomcat&quot;,\r\n          &quot;tags&quot;: [\r\n            &quot;contact_points&quot;\r\n          ],\r\n          &quot;check&quot;: {\r\n            &quot;script&quot;: &quot;tmp/status_check.py &gt; /dev/null 2&gt;&amp;1&quot;,\r\n            &quot;interval&quot;: &quot;10s&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nIf you want to replace the existing status.json with this output you can use a solution such as [sponge(1)](https://linux.die.net/man/1/sponge) from [moreutils](https://joeyh.name/code/moreutils/) e.g.\r\n\r\n    $ jq -M -f filter.jq status.json | sponge status.json\r\n",
                "title": "How to add a nested key/value in a JSON file using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1507862178,
                "last_edit_date": 1507862178,
                "creation_date": 1507236179,
                "answer_id": 46594484,
                "question_id": 46576926,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If your goal is just to take the single service and duplicate it with a new name, then you could do this:\r\n\r\n    .service |= [., .name = &quot;tomcat&quot;]\r\n\r\nhttps://jqplay.org/s/33L3zA9Fos\r\n\r\nThat is, update the service property (`.service |= ...`) by creating an array with the current item, and another copy where the `name` property is `&quot;tomcat&quot;`.",
                "title": "How to add a nested key/value in a JSON file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1507862178,
        "creation_date": 1507170176,
        "last_edit_date": 1507225457,
        "question_id": 46576926,
        "body_markdown": "I am pretty new to jq command and stuck at a place to edit a JSON file. I have a JSON file in the format below.\r\n\r\n    {\r\n      &quot;service&quot;: {\r\n        &quot;name&quot;: &quot;web&quot;,\r\n        &quot;tags&quot;: [\r\n          &quot;contact_points&quot;\r\n        ],\r\n        &quot;check&quot;: {\r\n          &quot;script&quot;: &quot;tmp/status_check.py &gt; /dev/null 2&gt;&amp;1&quot;,\r\n          &quot;interval&quot;: &quot;10s&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI want to modify this JSON to add a nested key/value as following:\r\n\r\n    {\r\n\t&quot;service&quot;: [{\r\n\t\t\t&quot;name&quot;: &quot;web&quot;,\r\n\t\t\t&quot;tags&quot;: [\r\n\t\t\t\t&quot;contact_points&quot;\r\n\t\t\t],\r\n\t\t\t&quot;check&quot;: {\r\n\t\t\t\t&quot;script&quot;: &quot;tmp/status_check.py &gt; /dev/null 2&gt;&amp;1&quot;,\r\n\t\t\t\t&quot;interval&quot;: &quot;10s&quot;\r\n\t\t\t}\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;name&quot;: &quot;tomcat&quot;,\r\n\t\t\t&quot;tags&quot;: [\r\n\t\t\t\t&quot;contact_points&quot;\r\n\t\t\t],\r\n\t\t\t&quot;check&quot;: {\r\n\t\t\t\t&quot;script&quot;: &quot;tmp/status_check.py &gt; /dev/null 2&gt;&amp;1&quot;,\r\n\t\t\t\t&quot;interval&quot;: &quot;10s&quot;\r\n\t\t\t}\r\n\t\t}\r\n\t]\r\n}\r\n\r\nI tried the below command but it overwrites the contents of the files.\r\n\r\n&gt; jq &#39;. + { &quot;service&quot;: &quot;{&quot;name&quot;:&quot;tomcat&quot;,&quot;tags&quot;:[&quot;contact_points&quot;],&quot;check&quot;:{&quot;script&quot;:&quot;tmp/status_check.py &gt; /dev/null 2&gt;&amp;1&quot;,&quot;interval&quot;:&quot;10s&quot;}}&quot; }&#39; /tmp/status.json &gt; /tmp/file &amp;&amp; mv /tmp/file /tmp/status.json\r\n\r\nand gives the below output\r\n\r\n    {\r\n      &quot;service&quot;: {\r\n        &quot;name&quot;: &quot;tomcat&quot;,\r\n        &quot;tags&quot;: [\r\n          &quot;contact_points&quot;\r\n        ],\r\n        &quot;check&quot;: {\r\n          &quot;script&quot;: &quot;tmp/status_check.py &gt; /dev/null 2&gt;&amp;1&quot;,\r\n          &quot;interval&quot;: &quot;10s&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI tried escaping the special characters but was not able to get the desired output. Is there any other way of achieving this? any help is greatly appreciated.",
        "link": "https://stackoverflow.com/questions/46576926/how-to-add-a-nested-key-value-in-a-json-file-using-jq",
        "title": "How to add a nested key/value in a JSON file using jq"
    },
    {
        "tags": [
            "linux",
            "bash",
            "precision",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4190907,
                    "reputation": 4470,
                    "user_id": 3433538,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/zoihC.jpg?s=256",
                    "display_name": "kevinSpaceyIsKeyserS&#246;ze",
                    "link": "https://stackoverflow.com/users/3433538/kevinspaceyiskeysers%c3%b6ze"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507190946,
                "post_id": 46580748,
                "comment_id": 80114379,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10535450,
                    "reputation": 134,
                    "user_id": 7763491,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/82f6a41aadd199b02a90568dac472a2a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "am1991",
                    "link": "https://stackoverflow.com/users/7763491/am1991"
                },
                "reply_to_user": {
                    "account_id": 4190907,
                    "reputation": 4470,
                    "user_id": 3433538,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/zoihC.jpg?s=256",
                    "display_name": "kevinSpaceyIsKeyserS&#246;ze",
                    "link": "https://stackoverflow.com/users/3433538/kevinspaceyiskeysers%c3%b6ze"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507191126,
                "post_id": 46580748,
                "comment_id": 80114473,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4190907,
                    "reputation": 4470,
                    "user_id": 3433538,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/zoihC.jpg?s=256",
                    "display_name": "kevinSpaceyIsKeyserS&#246;ze",
                    "link": "https://stackoverflow.com/users/3433538/kevinspaceyiskeysers%c3%b6ze"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507191456,
                "post_id": 46580748,
                "comment_id": 80114641,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10535450,
                    "reputation": 134,
                    "user_id": 7763491,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/82f6a41aadd199b02a90568dac472a2a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "am1991",
                    "link": "https://stackoverflow.com/users/7763491/am1991"
                },
                "reply_to_user": {
                    "account_id": 4190907,
                    "reputation": 4470,
                    "user_id": 3433538,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/zoihC.jpg?s=256",
                    "display_name": "kevinSpaceyIsKeyserS&#246;ze",
                    "link": "https://stackoverflow.com/users/3433538/kevinspaceyiskeysers%c3%b6ze"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507191943,
                "post_id": 46580748,
                "comment_id": 80114890,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4190907,
                    "reputation": 4470,
                    "user_id": 3433538,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/zoihC.jpg?s=256",
                    "display_name": "kevinSpaceyIsKeyserS&#246;ze",
                    "link": "https://stackoverflow.com/users/3433538/kevinspaceyiskeysers%c3%b6ze"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507192018,
                "post_id": 46580748,
                "comment_id": 80114930,
                "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": 1507192066,
                "post_id": 46580748,
                "comment_id": 80114954,
                "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": 1507192671,
                "post_id": 46580748,
                "comment_id": 80115298,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "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": 1507196438,
                "post_id": 46580748,
                "comment_id": 80117567,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10535450,
                    "reputation": 134,
                    "user_id": 7763491,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/82f6a41aadd199b02a90568dac472a2a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "am1991",
                    "link": "https://stackoverflow.com/users/7763491/am1991"
                },
                "reply_to_user": {
                    "account_id": 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": 1507197574,
                "post_id": 46580748,
                "comment_id": 80118419,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1507203554,
                "post_id": 46580748,
                "comment_id": 80122196,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1507192787,
                "creation_date": 1507192787,
                "answer_id": 46581285,
                "question_id": 46580748,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; How can I use jq to get latitude and longitude without loosing\r\n&gt; trailing zeros?\r\n&gt; Blockquote\r\n\r\nChange your JSON response value to String\r\n\r\n    {&quot;lat&quot;:34.284606710,&quot;lon&quot;:-12.543774500}\r\n\r\nto\r\n\r\n`{&quot;lat&quot;:&quot;34.284606710&quot;,&quot;lon&quot;:&quot;-12.543774500&quot;}`\r\n\r\nParse with\r\n\r\n&gt; String latitude =object.lat.toString(); \r\n&gt; \r\n&gt; String longitude=object.lon.toString();\r\n\r\nIn this way you&#39;ll never ever loosing anything from your JSON response.\r\n\r\n",
                "title": "How can I use jq to get latitude and longitude without losing trailing zeros?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1507212585,
                "last_edit_date": 1507212585,
                "creation_date": 1507202223,
                "answer_id": 46584314,
                "question_id": 46580748,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In a `bash` script you could use `jq` with string interpolation to get the latitude and longitude values and do zero padding with `printf()`. The `-r` flag in `jq` will strip the double-quotes from the values and feed them to the while-loop.\r\n\r\n    timeout -t 15 gpspipe -w -n 8 gpsd | jq -r &#39;&quot;\\(.lat) \\(.lon)&quot;&#39; | while read -r lat lon; do \r\n        printf -v z_lat &quot;%.9f&quot; &quot;$lat&quot;\r\n        printf -v z_lon &quot;%.9f&quot; &quot;$lon&quot;\r\n        printf &quot;Padded lat: %s Padded lon: %s\\n&quot; &quot;${z_lat}&quot;  &quot;${z_lon}&quot;    \r\n    done\r\n\r\nThe `printf -v` does the required formatting from the variable received from `jq` and applying the trailing zero padding needed and store in variables `z_lat` and `z_lon`.",
                "title": "How can I use jq to get latitude and longitude without losing trailing zeros?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1507224907,
                "last_edit_date": 1507224907,
                "creation_date": 1507224543,
                "answer_id": 46591558,
                "question_id": 46580748,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using a `pad` function:\r\n\r\n    def pad(n):&quot;\\(.)&quot;|(split(&quot;.&quot;)+[&quot;0&quot;])[:2]|.[1]|=(.+&quot;0&quot;*n)[:n]| join(&quot;.&quot;);\r\n    &quot;\\(.lat|pad(9)) \\(.lon|pad(9))&quot;\r\n\r\nExplaination\r\n\r\n    def pad(n):\r\n         &quot;\\(.)&quot;                  # convert to string\r\n       | (split(&quot;.&quot;)+[&quot;0&quot;])[:2]  # split into whole and fractional parts\r\n       | .[1]|=(.+&quot;0&quot;*n)[:n]     # keep first n digits after adding n zeros to fraction\r\n       | join(&quot;.&quot;)               # combine back into a string\r\n       ;\r\n\r\nYou can see how it works at https://jqplay.org/s/e8ZHP1t_K3 \r\n\r\nWith your sample data in `data.json` and the above filter in `filter.jq` the command\r\n\r\n    $ jq -r -f filter.jq data.json \r\n\r\nproduces\r\n\r\n    34.284606710 -12.543774500\r\n",
                "title": "How can I use jq to get latitude and longitude without losing trailing zeros?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1507224907,
        "creation_date": 1507190744,
        "last_edit_date": 1507220174,
        "question_id": 46580748,
        "body_markdown": "I am trying to use the `jq` command inside a `bash` script as \r\n\r\n    #!/bin/bash\r\n\r\n    timeout -t 15 gpspipe -w -n 8 gpsd | jq &#39;{latitude:.lat,longitude:.lon}&#39; |\r\n    {\r\n      # do something\r\n    }\r\n\r\nSo my input from `gpspipe`\r\n\r\n    {\r\n        &quot;lat&quot;:34.284606710,\r\n        &quot;lon&quot;:-12.543774500\r\n    }\r\n\r\nIf I use jq to get lat and lon values the result would be: `&quot;34.28460671&quot;` for latitude and `&quot;-12.5437745&quot;` for longitude.\r\n\r\nWhat I would like is to get the values as strings (with the trailing zeros) i.e. `&quot;34.284606710&quot;` and `&quot;12.543774500&quot;` \r\n\r\nSo basically, my problem is that I can&#39;t get lat and lon as strings (with the trailing zeros), using `jq` in a `bash` script.",
        "link": "https://stackoverflow.com/questions/46580748/how-can-i-use-jq-to-get-latitude-and-longitude-without-losing-trailing-zeros",
        "title": "How can I use jq to get latitude and longitude without losing trailing zeros?"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1507216335,
                "creation_date": 1507216335,
                "answer_id": 46589104,
                "question_id": 46588456,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your expression:\r\n\r\n    .SecurityGroups[].IpPermissions[].IpRanges[] \r\n\r\nis just a stream of CidrIp objects, so that&#39;s not what you want.\r\n\r\nThe following will select the SecurityGroups that meet the criterion:\r\n\r\n    .SecurityGroups[]\r\n    | select(any( .IpPermissions[].IpRanges[]; .CidrIp == &quot;0.0.0.0/0&quot;))\r\n\r\nWhether this is precisely what you want is unclear since you haven&#39;t specified that. Please see http://stackoverflow.com/help/mcve",
                "title": "How do I iterate over CIDR blocks in JQ?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1507223175,
                "creation_date": 1507223175,
                "answer_id": 46591210,
                "question_id": 46588456,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The reason you&#39;re seeing the error\r\n\r\n    Cannot iterate over string (&quot;0.0.0.0/0&quot;)\r\n\r\nis because with your data the first portion of your filter\r\n\r\n    .SecurityGroups[].IpPermissions[].IpRanges[]\r\n\r\ngenerates a sequence of objects\r\n\r\n    {\r\n      &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n    }\r\n    ...\r\n\r\nThe `map` portion of your filter iterates over the values in each of these objects, passing \r\n\r\n    &quot;0.0.0.0/0&quot;\r\n\r\nto the expression `select(any(.CidrIp == &quot;0.0.0.0/0&quot;))` where `any` tries to iterate over all the values within the string and fails with the error you observe.   \r\n\r\nIf you only want to see a sequence of `{&quot;CidrIp&quot;:...}` objects as above you can eliminate the `map` and `any`:\r\n\r\n      .SecurityGroups[].IpPermissions[].IpRanges[] \r\n    | select(.CidrIp == &quot;0.0.0.0/0&quot;)\r\n\r\nIf you would rather collect those objects into an array you could remove the `any` and move some of the iteration into the `map` e.g.\r\n\r\n      .SecurityGroups \r\n    | map(.IpPermissions[].IpRanges[] | select(.CidrIp == &quot;0.0.0.0/0&quot;))\r\n\r\nproducing\r\n\r\n    [\r\n      {\r\n        &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n      },\r\n      ....\r\n\r\nThe explict construction of the result array is easier to see if you replace `map` with its definition.  Since `map(f)` is defined as `[ .[] | f ]` the above filter is the same as this one:\r\n\r\n      .SecurityGroups \r\n    | [ .[] | .IpPermissions[].IpRanges[] | select(.CidrIp == &quot;0.0.0.0/0&quot;) ]\r\n\r\n\r\n",
                "title": "How do I iterate over CIDR blocks in JQ?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1507223175,
        "creation_date": 1507214538,
        "question_id": 46588456,
        "body_markdown": "Basically I&#39;m trying to iterate through my AWS security groups to find any CIDR&#39;s using 0.0.0.0/0.\r\n\r\nHere is my example JSON file:\r\n\r\n    {\r\n        &quot;SecurityGroups&quot;: [\r\n            {\r\n                &quot;IpPermissionsEgress&quot;: [],\r\n                &quot;Description&quot;: &quot;AWS OpsWorks load balancer - do not change or delete&quot;,\r\n                &quot;IpPermissions&quot;: [\r\n                    {\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;FromPort&quot;: 22,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;ToPort&quot;: 22,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;Ipv6Ranges&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;FromPort&quot;: 80,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;ToPort&quot;: 80,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;Ipv6Ranges&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;FromPort&quot;: 443,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;ToPort&quot;: 443,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;Ipv6Ranges&quot;: []\r\n                    }\r\n                ],\r\n                &quot;GroupName&quot;: &quot;AWS-OpsWorks-LB-Server&quot;,\r\n                &quot;OwnerId&quot;: &quot;056146032236&quot;,\r\n                &quot;GroupId&quot;: &quot;sg-7dd13739&quot;\r\n            },\r\n            {\r\n                &quot;IpPermissionsEgress&quot;: [\r\n                    {\r\n                        &quot;IpProtocol&quot;: &quot;-1&quot;,\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;Ipv6Ranges&quot;: []\r\n                    }\r\n                ],\r\n                &quot;Description&quot;: &quot;SG for bastion hosts&quot;,\r\n                &quot;Tags&quot;: [\r\n                    {\r\n                        &quot;Value&quot;: &quot;bastion-host-sg&quot;,\r\n                        &quot;Key&quot;: &quot;Name&quot;\r\n                    }\r\n                ],\r\n                &quot;IpPermissions&quot;: [\r\n                    {\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;FromPort&quot;: 80,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;ToPort&quot;: 80,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;Ipv6Ranges&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;FromPort&quot;: 1991,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;ToPort&quot;: 1991,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;Ipv6Ranges&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;FromPort&quot;: 8080,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;ToPort&quot;: 8080,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;Ipv6Ranges&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;FromPort&quot;: 1194,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;ToPort&quot;: 1194,\r\n                        &quot;IpProtocol&quot;: &quot;udp&quot;,\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;Ipv6Ranges&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;FromPort&quot;: 22,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;ToPort&quot;: 22,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;Ipv6Ranges&quot;: [\r\n                            {\r\n                                &quot;CidrIpv6&quot;: &quot;::/0&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;FromPort&quot;: 30,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;ToPort&quot;: -1,\r\n                        &quot;IpProtocol&quot;: &quot;icmp&quot;,\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;Ipv6Ranges&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;FromPort&quot;: 1194,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;ToPort&quot;: 1194,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;Ipv6Ranges&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;FromPort&quot;: 53,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;ToPort&quot;: 53,\r\n                        &quot;IpProtocol&quot;: &quot;udp&quot;,\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;Ipv6Ranges&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;FromPort&quot;: 53,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;ToPort&quot;: 53,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;Ipv6Ranges&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;FromPort&quot;: 443,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;ToPort&quot;: 443,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;Ipv6Ranges&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;FromPort&quot;: 8,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;ToPort&quot;: -1,\r\n                        &quot;IpProtocol&quot;: &quot;icmp&quot;,\r\n                        &quot;UserIdGroupPairs&quot;: [],\r\n                        &quot;Ipv6Ranges&quot;: []\r\n                    }\r\n                ],\r\n                &quot;GroupName&quot;: &quot;bastion-host-sg&quot;,\r\n                &quot;VpcId&quot;: &quot;vpc-effd0e8a&quot;,\r\n                &quot;OwnerId&quot;: &quot;056146032236&quot;,\r\n                &quot;GroupId&quot;: &quot;sg-0f60196a&quot;\r\n            }\r\n          ]\r\n    }\r\n\r\n\r\nHere is the command I&#39;m trying to run, but get an error:\r\n\r\n    $ cat sg-small.json | jq &#39;.SecurityGroups[].IpPermissions[].IpRanges[] | map(select(any(.CidrIp == &quot;0.0.0.0/0&quot;)))&#39;    \r\n    jq: error (at &lt;stdin&gt;:227): Cannot iterate over string (&quot;0.0.0.0/0&quot;)\r\n\r\n\r\nAny thoughts as to why this is happening.  That method seems to work for other things that aren&#39;t IP addresses.\r\n",
        "link": "https://stackoverflow.com/questions/46588456/how-do-i-iterate-over-cidr-blocks-in-jq",
        "title": "How do I iterate over CIDR blocks in JQ?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1507321237,
                "last_edit_date": 1507321237,
                "creation_date": 1507246955,
                "answer_id": 46596297,
                "question_id": 46595276,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is one approach\r\n\r\n    #!/bin/bash\r\n    \r\n    # usage: update.sh input.json aaa.json bbb.json....\r\n    # updates each of aaa.json bbb.json.... \r\n    \r\n    input_json=&quot;$1&quot;\r\n    shift\r\n    \r\n    for i in &quot;$@&quot;; do\r\n        jq -M --argfile input_json &quot;$input_json&quot; &#39;\r\n    \r\n          # functions to restrict input.json to keys of current xxx.json file\r\n          def prefix:              input_filename | split(&quot;.&quot;)[0];\r\n          def selectprefix:        select(.ID | startswith(prefix));\r\n    \r\n          # functions to build and probe a lookup table\r\n          def pk:                  [.ID, .time_CET];\r\n          def lookup($t;$k):       $t | getpath($k);\r\n          def lookup($t):          lookup($t;pk);\r\n          def organize(s):         reduce s as $r ({}; setpath($r|pk; $r));\r\n    \r\n          # functions to identify objects in input.json missing from xxx.json\r\n          def pks:                 paths | select(length==2);\r\n          def missing($t1;$t2):    [$t1|pks] - [$t2|pks] | .[];\r\n          def getmissing($t1;$t2): [ missing($t1;$t2) as $p | lookup($t1;$p)];\r\n    \r\n          # main routine\r\n            organize(.[]) as $xxx\r\n          | organize($input_json[] | selectprefix) as $inp\r\n          | map(if .FLAG != &quot;?&quot; then . else . += lookup($inp) end)\r\n          | . + getmissing($inp;$xxx)\r\n    \r\n        &#39; &quot;$i&quot; | sponge &quot;$i&quot;\r\n    \r\n    done\r\n\r\nThe script uses jq in a loop to read and update each `aaa.json`... file.\r\n\r\nThe filter creates temporary objects to facilitate looking up values by  `[ID,time_CET]`, updates any values in the `aaa.json` with a FLAG==&quot;?&quot; and finally adds any values from `input.json` that are missing in `aaa.json`.\r\n\r\nThe temporary lookup table for `input.json` uses `input_filename` so that only keys starting with a prefix matching the name of the currently processed file will be included.\r\n\r\nSample Run:\r\n\r\n    $ ./update.sh input.json aaa.json\r\n\r\n`aaa.json` after run:\r\n\r\n    [\r\n      {\r\n        &quot;ID&quot;: &quot;aaa_12301248&quot;,\r\n        &quot;time_CET&quot;: &quot;00:00:00&quot;,\r\n        &quot;VALUE&quot;: 10,\r\n        &quot;FLAG&quot;: &quot;0&quot;\r\n      },\r\n      {\r\n        &quot;ID&quot;: &quot;aaa_12301248&quot;,\r\n        &quot;time_CET&quot;: &quot;00:15:00&quot;,\r\n        &quot;VALUE&quot;: 18,\r\n        &quot;FLAG&quot;: &quot;0&quot;\r\n      },\r\n      {\r\n        &quot;ID&quot;: &quot;aaa_12301248&quot;,\r\n        &quot;time_CET&quot;: &quot;00:55:00&quot;,\r\n        &quot;VALUE&quot;: 45,\r\n        &quot;FLAG&quot;: &quot;0&quot;\r\n      },\r\n      {\r\n        &quot;ID&quot;: &quot;aaa_12301248&quot;,\r\n        &quot;time_CET&quot;: &quot;00:30:00&quot;,\r\n        &quot;VALUE&quot;: 160,\r\n        &quot;FLAG&quot;: &quot;0&quot;\r\n      }\r\n    ]\r\n",
                "title": "jq: Conditionally update/replace/add json elements using an input file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1507321237,
        "creation_date": 1507239976,
        "question_id": 46595276,
        "body_markdown": "I receive the following input file:\r\n\r\n&gt;  - input.json:\r\n\r\n    [\r\n     {&quot;ID&quot;:&quot;aaa_12301248&quot;,&quot;time_CET&quot;:&quot;00:00:00&quot;,&quot;VALUE&quot;:10,&quot;FLAG&quot;:&quot;0&quot;},\r\n     {&quot;ID&quot;:&quot;aaa_12301248&quot;,&quot;time_CET&quot;:&quot;00:15:00&quot;,&quot;VALUE&quot;:18,&quot;FLAG&quot;:&quot;0&quot;},\r\n     {&quot;ID&quot;:&quot;aaa_12301248&quot;,&quot;time_CET&quot;:&quot;00:30:00&quot;,&quot;VALUE&quot;:160,&quot;FLAG&quot;:&quot;0&quot;},\r\n    \r\n     {&quot;ID&quot;:&quot;bbb_0021122&quot;,&quot;time_CET&quot;:&quot;00:00:00&quot;,&quot;VALUE&quot;:null,&quot;FLAG&quot;:&quot;?&quot;},\r\n     {&quot;ID&quot;:&quot;bbb_0021122&quot;,&quot;time_CET&quot;:&quot;00:15:00&quot;,&quot;VALUE&quot;:null,&quot;FLAG&quot;:&quot;?&quot;},\r\n     {&quot;ID&quot;:&quot;bbb_0021122&quot;,&quot;time_CET&quot;:&quot;00:30:00&quot;,&quot;VALUE&quot;:22,&quot;FLAG&quot;:&quot;0&quot;},\r\n    \r\n     {&quot;ID&quot;:&quot;ccc_0021122&quot;,&quot;time_CET&quot;:&quot;00:00:00&quot;,&quot;VALUE&quot;:null,&quot;FLAG&quot;:&quot;?&quot;},\r\n     {&quot;ID&quot;:&quot;ccc_0021122&quot;,&quot;time_CET&quot;:&quot;00:15:00&quot;,&quot;VALUE&quot;:null,&quot;FLAG&quot;:&quot;?&quot;},\r\n     {&quot;ID&quot;:&quot;ccc_0021122&quot;,&quot;time_CET&quot;:&quot;00:30:00&quot;,&quot;VALUE&quot;:20,&quot;FLAG&quot;:&quot;0&quot;},\r\n    \r\n     {&quot;ID&quot;:&quot;ddd_122455&quot;,&quot;time_CET&quot;:&quot;00:00:00&quot;,&quot;VALUE&quot;:null,&quot;FLAG&quot;:&quot;?&quot;},\r\n     {&quot;ID&quot;:&quot;ddd_122455&quot;,&quot;time_CET&quot;:&quot;00:15:00&quot;,&quot;VALUE&quot;:null,&quot;FLAG&quot;:&quot;?&quot;},\r\n     {&quot;ID&quot;:&quot;ddd_122455&quot;,&quot;time_CET&quot;:&quot;00:30:00&quot;,&quot;VALUE&quot;:null,&quot;FLAG&quot;:&quot;?&quot;},\r\n    ]\r\nAs you can see there are some valid values (FLAG: 0) and some invalid values (FLAG: &quot;?&quot;).\r\nNow I got a file looking like this (one for each ID):\r\n\r\n&gt; aaa.json:\r\n\r\n    [\r\n      {&quot;ID&quot;:&quot;aaa_12301248&quot;,&quot;time_CET&quot;:&quot;00:00:00&quot;,&quot;VALUE&quot;:10,&quot;FLAG&quot;:&quot;0&quot;},\r\n      {&quot;ID&quot;:&quot;aaa_12301248&quot;,&quot;time_CET&quot;:&quot;00:15:00&quot;,&quot;VALUE&quot;:null,&quot;FLAG&quot;:&quot;?&quot;},\r\n      {&quot;ID&quot;:&quot;aaa_12301248&quot;,&quot;time_CET&quot;:&quot;00:55:00&quot;,&quot;VALUE&quot;:45,&quot;FLAG&quot;:&quot;0&quot;}\r\n    ]\r\n\r\nAs you can see, object one is the same as in input.json but object two is invalid (FLAG: &quot;?&quot;). That&#39;s why object two has to be replaced by the correct object from input.json (with VALUE:18). \r\nObjects can be identified by &quot;time_CET&quot; and &quot;ID&quot; element. \r\n\r\n\r\nAdditionally, there will be new objects in input.json, that have not been part of aaa.json etc. These objects should be added to the array, and valid objects from aaa.json should be kept.\r\n\r\n&gt; In the end, aaa.json should look like this:\r\n\r\n    [\r\n      {&quot;ID&quot;:&quot;aaa_12301248&quot;,&quot;time_CET&quot;:&quot;00:00:00&quot;,&quot;VALUE&quot;:10,&quot;FLAG&quot;:&quot;0&quot;},\r\n      {&quot;ID&quot;:&quot;aaa_12301248&quot;,&quot;time_CET&quot;:&quot;00:15:00&quot;,&quot;VALUE&quot;:18,&quot;FLAG&quot;:&quot;0&quot;},\r\n      {&quot;ID&quot;:&quot;aaa_12301248&quot;,&quot;time_CET&quot;:&quot;00:30:00&quot;,&quot;VALUE&quot;:160,&quot;FLAG&quot;:&quot;0&quot;},\r\n      {&quot;ID&quot;:&quot;aaa_12301248&quot;,&quot;time_CET&quot;:&quot;00:55:00&quot;,&quot;VALUE&quot;:45,&quot;FLAG&quot;:&quot;0&quot;}\r\n    ]\r\n\r\n\r\nSo, to summarize: \r\n\r\n 1. look for FLAG: &quot;?&quot; in aaa.json\r\n 2. replace this object with matching object from input.json using &quot;ID&quot;\r\n    and &quot;time_CET&quot; for mapping.\r\n 3. Keep exisiting valid objects and add objects from input.json that\r\n    did not exist in aaa.json before (this means only objects starting\r\n    with &quot;aaa&quot; in &quot;ID&quot; field)\r\n 4. repeat this for bbb.json, ccc.json and ddd.json\r\n\r\nI am not sure if it&#39;s possible to get this done all at once with a command like this, because the output has to go to back to the correct id files (aaa, bbb ccc.json):\r\n\r\n    jq --argfile aaa aaa.json --argfile bbb bbb.json .... -f prog.jq input.json\r\n\r\nThe problem is, that the number after the identifier (aaa, bbb, ccc etc.) may change. So to make sure objects are added to the correct file/array, a statement like this would be required:     \r\n `if (.&quot;ID&quot;|contains(&quot;aaa&quot;)) then ....`\r\n\r\nOr is it better to run the program several times with different input parameters? I am not sure..\r\n\r\nThank you in advance!!",
        "link": "https://stackoverflow.com/questions/46595276/jq-conditionally-update-replace-add-json-elements-using-an-input-file",
        "title": "jq: Conditionally update/replace/add json elements using an input file"
    },
    {
        "tags": [
            "json",
            "docker",
            "cmd",
            "jq",
            "conemu"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1500841,
                    "reputation": 10855,
                    "user_id": 1405560,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/89713245814986078240c73bca26916b?s=256&d=identicon&r=PG",
                    "display_name": "Maximus",
                    "link": "https://stackoverflow.com/users/1405560/maximus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507462203,
                "post_id": 46626756,
                "comment_id": 80210689,
                "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": 1507467848,
                "post_id": 46626756,
                "comment_id": 80212165,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 106565,
                    "reputation": 19096,
                    "user_id": 283837,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/b6a1613d264fbc700b317490b59494e0?s=256&d=identicon&r=PG",
                    "display_name": "Simeon Leyzerzon",
                    "link": "https://stackoverflow.com/users/283837/simeon-leyzerzon"
                },
                "reply_to_user": {
                    "account_id": 1500841,
                    "reputation": 10855,
                    "user_id": 1405560,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/89713245814986078240c73bca26916b?s=256&d=identicon&r=PG",
                    "display_name": "Maximus",
                    "link": "https://stackoverflow.com/users/1405560/maximus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507468236,
                "post_id": 46626756,
                "comment_id": 80212287,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1507483665,
                "post_id": 46626756,
                "comment_id": 80217204,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 106565,
                    "reputation": 19096,
                    "user_id": 283837,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/b6a1613d264fbc700b317490b59494e0?s=256&d=identicon&r=PG",
                    "display_name": "Simeon Leyzerzon",
                    "link": "https://stackoverflow.com/users/283837/simeon-leyzerzon"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507484325,
                "post_id": 46626756,
                "comment_id": 80217433,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1507484857,
                "creation_date": 1507484857,
                "answer_id": 46634160,
                "question_id": 46626756,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Apparently, this is an idiosyncrasy of jq Windows implementation, forcing the color output with -C option, as hinted by several commenters above, resolved the issue for me:\r\n\r\n[![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/cfLZe.png",
                "title": "Jq doesn&#39;t highlight Docker inspect output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1507484857,
        "creation_date": 1507426686,
        "last_edit_date": 1507467527,
        "question_id": 46626756,
        "body_markdown": "When executing `docker-machine inspect` command, instead of the expected highlighted version of JSON piped into jq:\r\n\r\n[![enter image description here][1]][1]\r\n\r\nI&#39;m seeing the following plain output (in cmd or ConEmu):\r\n\r\n[![enter image description here][2]][2]\r\n\r\nNot sure what needs to be done to enable proper json highlighting.\r\n\r\nThis happens on Windows 10 machine on which jq ver. 1.5 was installed via Chocolatey:\r\n\r\n[![enter image description here][3]][3]  \r\n\r\n\r\n  [1]: https://i.sstatic.net/UOE1A.png\r\n  [2]: https://i.sstatic.net/Qe5oT.png\r\n  [3]: https://i.sstatic.net/SBIxZ.png",
        "link": "https://stackoverflow.com/questions/46626756/jq-doesnt-highlight-docker-inspect-output",
        "title": "Jq doesn&#39;t highlight Docker inspect output"
    },
    {
        "tags": [
            "json",
            "bioinformatics",
            "hierarchical-data",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4505119,
                    "reputation": 13,
                    "user_id": 3662691,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d58b46f9bd161a7164919f903ea856a4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Pramod",
                    "link": "https://stackoverflow.com/users/3662691/pramod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1509134236,
                "post_id": 46632107,
                "comment_id": 80912453,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1507495408,
                "last_edit_date": 1507495408,
                "creation_date": 1507479999,
                "answer_id": 46633370,
                "question_id": 46632107,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that (a) assumes there is no header row, in accordance with the comment about the headers (but see below); (b) does not &quot;slurp&quot; the file (i.e.,\r\n does not read the entire file into memory); and (c) assumes a version of jq with `inputs`. (If your jq does not have `inputs`, it would be very easy to modify the following accordingly.)\r\n\r\n    def parse_row:\r\n      split(&quot;,&quot;) \r\n      | length as $length\r\n      | .[1: $length - 3] as $exons\r\n      | { metric : .[0],\r\n          value: [ { metric: &quot;Exons&quot;,\r\n                     value: $exons,\r\n    \t\t type: &quot;set&quot; },\r\n    \t\t{ metric: &quot;Fraction of bases&quot;,\r\n                      value: (.[$length - 1] | tonumber),\r\n    \t\t  type: &quot;simple&quot;\r\n    \t\t},\r\n                    { metric: &quot;Total_bases&quot;,\r\n                      value: (.[$length - 3] | tonumber),\r\n                      type: &quot;simple&quot;\r\n    \t\t}\r\n    \t\t],\r\n    \t    type: &quot;set&quot; \r\n        } ;\r\n    \r\n    [inputs | parse_row]\r\n    | { &quot;Exome regions&quot;: .}\r\n\r\nThe appropriate invocation of jq would be along the following lines:\r\n\r\n    jq -n -R -f program.jq input.txt\r\n\r\nThis produces the required JSON.\r\n\r\n(The -R is for &quot;raw input&quot;.)\r\n\r\nIf the input file does have a header row, the above solution will still work provided only that you drop the &quot;-n&quot; command-line option.\r\n\r\nPlease note that although the input file has comma-separated values, it is not really a CSV file.\r\n",
                "title": "Converting comma separated file to nested objects json in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1509467679,
                "last_edit_date": 1509467679,
                "creation_date": 1507482963,
                "answer_id": 46633861,
                "question_id": 46632107,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses functions for parsing and assembly of the output:\r\n\r\n    def parse:\r\n      [\r\n          inputs                     # read lines\r\n        | split(&quot;,&quot;)                 # split into columns\r\n        | select(length&gt;0)           # eliminate blanks\r\n        | .[:1] + [.[1:-3]] + .[-3:] # normalize columns\r\n      ]\r\n    ;\r\n    def simple(n;v): {metric:n, value:v|tonumber, type:&quot;simple&quot;};\r\n    def set(n;v):    {metric:n, value:v,          type:&quot;set&quot;};\r\n    def region:\r\n      set(.[0]; [\r\n          set(&quot;Exons&quot;; .[1]),\r\n          simple(&quot;Fraction of bases&quot;; .[2]),\r\n          simple(&quot;Total_bases&quot;; .[3])\r\n        ]\r\n      )\r\n    ;\r\n    {\r\n       &quot;Exome regions&quot;: parse | map(region)\r\n    }\r\n\r\nSample Run (assumes filter is in `filter.jq` and data in `data.json`)\r\n\r\n    $ jq -M -Rnr -f filter.jq data.json\r\n    {\r\n      &quot;Exome regions&quot;: [\r\n        {\r\n          &quot;metric&quot;: &quot;PIK3CA&quot;,\r\n          &quot;value&quot;: [\r\n            {\r\n              &quot;metric&quot;: &quot;Exons&quot;,\r\n              &quot;value&quot;: [\r\n                &quot;PIK3CA_Exon10&quot;,\r\n                &quot;PIK3CA_Exon13&quot;,\r\n                &quot;PIK3CA_Exon14&quot;\r\n              ],\r\n              &quot;type&quot;: &quot;set&quot;\r\n            },\r\n            {\r\n              &quot;metric&quot;: &quot;Fraction of bases&quot;,\r\n              &quot;value&quot;: 1927879,\r\n              &quot;type&quot;: &quot;simple&quot;\r\n            },\r\n            {\r\n              &quot;metric&quot;: &quot;Total_bases&quot;,\r\n              &quot;value&quot;: 12993042,\r\n              &quot;type&quot;: &quot;simple&quot;\r\n            }\r\n          ],\r\n          &quot;type&quot;: &quot;set&quot;\r\n        },\r\n        {\r\n          &quot;metric&quot;: &quot;NRAS&quot;,\r\n          &quot;value&quot;: [\r\n            {\r\n              &quot;metric&quot;: &quot;Exons&quot;,\r\n              &quot;value&quot;: [\r\n                &quot;NRAS_Exon4&quot;,\r\n                &quot;NRAS_Amp_369&quot;,\r\n                &quot;NRAS_Amp_371&quot;,\r\n                &quot;NRAS_Amp_374&quot;,\r\n                &quot;NRAS_Amp_379&quot;\r\n              ],\r\n              &quot;type&quot;: &quot;set&quot;\r\n            },\r\n            {\r\n              &quot;metric&quot;: &quot;Fraction of bases&quot;,\r\n              &quot;value&quot;: 884111,\r\n              &quot;type&quot;: &quot;simple&quot;\r\n            },\r\n            {\r\n              &quot;metric&quot;: &quot;Total_bases&quot;,\r\n              &quot;value&quot;: 8062107,\r\n              &quot;type&quot;: &quot;simple&quot;\r\n            }\r\n          ],\r\n          &quot;type&quot;: &quot;set&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n[Try it online!](https://tio.run/##bVLfb9MwEH7fX2F5L41wojgpa@NISBUCCSEhBLxlUeV2txFw7BA75ce6f53MjtMtgd6Dfef7vs939n370d/ALapk0xnNEP747n36ekP8tn3zS0kaz6J0Fi0JzZLVepURmmRZGi8TEkf05bX88GnzmbhlwC29u6mbbXqVTYIVnQZTmJVcr5eUUrKOrxIar5wwvZb4qBtRmQW2blCUeY@suRYa3mpgF2iwYtyd@d7QObtELfAbJCoJ@olxROMNBAdnGEPSihqF9kp0tZwxQcDeLATIO/P1VRzMmCCqupLcANoJLr9PeVHBaIleoCIqKAvT0vlREaastDyp2pqL6g/8c2E57PnF6QV0VTcCFjI/BAzd12Daas8kQQcuOmCHo1Gyq3fQEmR@N8Cwx@OHiQKYkW7tfwXy3M2oAGZKb@GuUvL0B04sKuIyn/2GO8VuJjTObYu0DMg061vAb1u@N1YLqVu04xo8ODkP/qIMF9tnWFoGT6hy9ILJW92fsq6OGsayNWZ@hux31LxZ@FPPexjWvv@rGleV7sNQdkKEw2jZoOU/Q9UZGzwC &quot;jq – Try It Online&quot;)\r\n\r\n___\r\n\r\nHere is a solution to the revised problem:\r\n\r\n    def parse:\r\n      [\r\n          inputs                     # read lines\r\n        | split(&quot;,&quot;)                 # split into columns\r\n        | select(length&gt;0)           # eliminate blanks\r\n        | .[:1] + [.[1:-3]] + .[-3:] # normalize columns\r\n      ]\r\n    ;\r\n    def simple(n;v): {metric:n, value:v|tonumber, type:&quot;simple&quot;};\r\n    def set(n;v):    {metric:n, value:v,          type:&quot;set&quot;};\r\n    def exons(v):    [ v[] | split(&quot;;&quot;) | .[0], {&quot;chromosome&quot;:.[1], &quot;start&quot;:.[2], &quot;end&quot;:.[3]} ];\r\n    def region:\r\n      set(.[0]; [\r\n          set(&quot;Exons&quot;; exons(.[1])),\r\n          simple(&quot;Fraction of bases&quot;; .[2]),\r\n          simple(&quot;Total_bases&quot;; .[3])\r\n        ]\r\n      )\r\n    ;\r\n    \r\n    { &quot;Exome regions&quot;: parse | map(region) }\r\n\r\n[Try it online!](https://tio.run/##fVLfb9owEH7vX2F5L0RLkE1oAUeahKZNmiZN07a31EIGrm02/8hih20F/vUxO0kLFMY92He@@7473933n7sl3KFCl7WzDOHPHz6mb6dxe83e/TaakmzxUNGMEkIyek3IkTO95By@dNLJYDQeTWI6mExSMhzEpE@vb/WnL9OvcTga2Amq8UxVOUtvJv/3jegF3wXO0QnneDyklMZjcjOgZBRqpLcab2wpC9fDXo1ynu2Ql9C6UlQW2BVqJO/uIG1P0Tl5hSoQSyQLDfYZsUFdhhhHZxCN05M6gxZG1kofIUHCwvUk6Hv38IZER0iQhSq0cIDmUugfh7h@zihHr1HezylLUh70fp6kjHucNpUSsniEFwl5c2dXTx2whSol9HS2ihhaK3BVsWA6Risha2CrjTO6VnOoYuT@lMBwG4@3BwzgOriXU4Z4/5uOAdwhHPzW2F4Hz9Eq5/tmZr6Z4Z@Ex2iN/aSNMtYowMx/2b9h60TlgjUIFuhl0FO@RXyfoIL7wuinIYdqA2F2NO7wisP@Wpx1FYUMURQfBrWtwu8rsXCeEpk7NBcWAiZUcDb4m3FCzvZhKY@eo3inRQczaY41CsUo6Gq3mLWb6puhRNlrXyO0vdrt/poy1GJ3SaJrKZNmcb1RiV@JqZ03/gE &quot;jq – Try It Online&quot;)",
                "title": "Converting comma separated file to nested objects json in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1509467679,
        "creation_date": 1507472412,
        "last_edit_date": 1509374770,
        "question_id": 46632107,
        "body_markdown": "I have a CSV file which I would like to parse and obtain a Nested JSON  using jq. I have started to use JQ recently and I really like the tool. I understand basic functionalities, but parsing a csv file seems  a little difficult especially to print nested objects.\r\n\r\nSample Input\r\n------------\r\nGene, Exon,Total,Exon Bases, Total Bases, Fraction of Exon bases\r\nPIK3CA,PIK3CA_Exon10;chr1;1000;1500,PIK3CA_Exon13;chr1;1000;1500,PIK3CA_Exon14;chr1;1000;1500,1927879,12993042,0.15\r\nNRAS,NRAS_Exon4;chr1;1000;1500,NRAS_Amp_369;chr1;1000;1500,NRAS_Amp_371;chr1;1000;1500,NRAS_Amp_374;chr1;1000;1500,NRAS_Amp_379;chr1;1000;1500,884111,8062107,0.11\r\n\r\nHeader and Input data explanation\r\n---------------------------\r\nThe first column will have one value always. The second column can have multiple exons (1 or more). You can see that it has 3 values in 2nd row and 5 in 3rd row. Exon bases will be the second last column always, Total bases will be last but one and Fraction of exon bases will be the last column.\r\n\r\nNote\r\n-----\r\nI have added the header for explanation purposes, it can be removed or modified for processing\r\n\r\nExpected output\r\n-------\r\n\r\n\r\n    {  \r\n       &quot;Exome regions&quot;:[  \r\n          {  \r\n             &quot;metric&quot;:&quot;PIK3CA&quot;,\r\n             &quot;value&quot;:[  \r\n                {  \r\n                   &quot;metric&quot;:&quot;Exons&quot;,\r\n                   &quot;value&quot;:[  \r\n                      &quot;PIK3CA_Exon10&quot;,\r\n                      {\r\n                       &quot;chromosome&quot;:&quot;chr1&quot;,\r\n                       &quot;start&quot;:1000,\r\n                       &quot;end&quot;:1500\r\n                      },\r\n                      &quot;PIK3CA_Exon13&quot;,\r\n                     {\r\n                       &quot;chromosome&quot;:&quot;chr1&quot;,\r\n                       &quot;start&quot;:1000,\r\n                       &quot;end&quot;:1500\r\n                      },\r\n                      &quot;PIK3CA_Exon14&quot;,\r\n                      {\r\n                       &quot;chromosome&quot;:&quot;chr1&quot;,\r\n                       &quot;start&quot;:1000,\r\n                       &quot;end&quot;:1500\r\n                      }\r\n                   ],\r\n                   &quot;type&quot;:&quot;set&quot;\r\n                },\r\n                {  \r\n                   &quot;metric&quot;:&quot;Fraction of bases&quot;,\r\n                   &quot;value&quot;:0.15,\r\n                   &quot;type&quot;:&quot;simple&quot;\r\n                },\r\n                {  \r\n                   &quot;metric&quot;:&quot;Total_bases&quot;,\r\n                   &quot;value&quot;:1927879,\r\n                   &quot;type&quot;:&quot;simple&quot;\r\n                }\r\n             ],\r\n             &quot;type&quot;:&quot;set&quot;\r\n          },\r\n    \r\n          {  \r\n             &quot;metric&quot;:&quot;NRAS&quot;,\r\n             &quot;value&quot;:[  \r\n                {  \r\n                   &quot;metric&quot;:&quot;Exons&quot;,\r\n                   &quot;value&quot;:[  \r\n                      &quot;NRAS_Exon4&quot;,\r\n                      {\r\n                       &quot;chromosome&quot;:&quot;chr1&quot;,\r\n                       &quot;start&quot;:1000,\r\n                       &quot;end&quot;:1500\r\n                      },\r\n                      &quot;NRAS_Amp_369&quot;,\r\n                     {\r\n                       &quot;chromosome&quot;:&quot;chr1&quot;,\r\n                       &quot;start&quot;:1000,\r\n                       &quot;end&quot;:1500\r\n                      },\r\n                      &quot;NRAS_Amp_371&quot;,\r\n                     {\r\n                       &quot;chromosome&quot;:&quot;chr1&quot;,\r\n                       &quot;start&quot;:1000,\r\n                       &quot;end&quot;:1500\r\n                      },\r\n                      &quot;NRAS_Amp_374&quot;,\r\n                     {\r\n                       &quot;chromosome&quot;:&quot;chr1&quot;,\r\n                       &quot;start&quot;:1000,\r\n                       &quot;end&quot;:1500\r\n                      },\r\n                      &quot;NRAS_Amp_379&quot;,\r\n                     {\r\n                       &quot;chromosome&quot;:&quot;chr1&quot;,\r\n                       &quot;start&quot;:1000,\r\n                       &quot;end&quot;:1500\r\n                      }\r\n                   ],\r\n                   &quot;type&quot;:&quot;set&quot;\r\n                },\r\n                {  \r\n                   &quot;metric&quot;:&quot;Fraction of bases&quot;,\r\n                   &quot;value&quot;:0.11,\r\n                   &quot;type&quot;:&quot;simple&quot;\r\n                },\r\n                {  \r\n                   &quot;metric&quot;:&quot;Total_bases&quot;,\r\n                   &quot;value&quot;:884111,\r\n                   &quot;type&quot;:&quot;simple&quot;\r\n                }\r\n             ],\r\n             &quot;type&quot;:&quot;set&quot;\r\n          }\r\n       ]\r\n    }\r\n\r\n\r\nThanks for your help in advance!!\r\n\r\nPS: - I need to add more information, I have to edit the Exon fields and add &quot;Chromosomes&quot;, &quot;Start&quot; and &quot;End&quot; to each Exon. Here i have given same start and end, but in actual scenario it varies for each Exon. Can you please help me with this.\r\nAlso, the input for these Exons can be separated by any other character too.Right now I separate it by &quot;;&quot;",
        "link": "https://stackoverflow.com/questions/46632107/converting-comma-separated-file-to-nested-objects-json-in-jq",
        "title": "Converting comma separated file to nested objects json in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1507505703,
                "last_edit_date": 1507505703,
                "creation_date": 1507498909,
                "answer_id": 46636353,
                "question_id": 46634409,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is an approach which builds a &quot;table&quot; object from `id_array.json`.  This function creates the table:\r\n\r\n    def maketable:\r\n      reduce $id_array[] as $i (\r\n        {}\r\n      ; .[$i.ID_EXT] = ($i | {ID_WEB,ID_ACC})\r\n      )\r\n    ;\r\n\r\nWith the sample `id_array.json` in `$id_array` this returns an object like\r\n\r\n    {\r\n      &quot;aaa&quot;: {\r\n        &quot;ID_WEB&quot;: 30,\r\n        &quot;ID_ACC&quot;: &quot;one&quot;\r\n      },\r\n      &quot;bbb&quot;: {\r\n        &quot;ID_WEB&quot;: 40,\r\n        &quot;ID_ACC&quot;: &quot;two&quot;\r\n      },\r\n      &quot;ccc&quot;: {\r\n        &quot;ID_WEB&quot;: 50,\r\n        &quot;ID_ACC&quot;: &quot;three&quot;\r\n      }\r\n    }\r\n\r\nThis function takes an object from `data.json` and returns the corresponding lookup key for the table:\r\n\r\n    def getkey: .ID_EXT_LARGE | split(&quot;_&quot;)[0] ;\r\n\r\ne.g. given \r\n\r\n    {&quot;ID_EXT_LARGE&quot;:&quot;aaa_1234411&quot;,&quot;xy&quot;:&quot;xyz&quot;}\r\n\r\nit returns\r\n\r\n    &quot;aaa&quot;\r\n\r\nWith these two functions the result output can be generated with:\r\n\r\n      maketable as $idtable\r\n    | map( . + $idtable[ getkey ] )\r\n\r\nHere is a script which puts everything together and uses `sponge` to update `data.json`:\r\n\r\n    #!/bin/bash\r\n    jq -M --argfile id_array id_array.json &#39;\r\n    \r\n        def maketable:\r\n          reduce $id_array[] as $i (\r\n            {}\r\n          ; .[$i.ID_EXT] = ($i | {ID_WEB,ID_ACC})\r\n          )\r\n        ;\r\n        def getkey: .ID_EXT_LARGE | split(&quot;_&quot;)[0] ;\r\n    \r\n          maketable as $idtable\r\n        | map( . + $idtable[ getkey ] )\r\n    \r\n    &#39; data.json | sponge data.json\r\n\r\nHere is `data.json` after a sample run:\r\n\r\n    [\r\n      {\r\n        &quot;ID_EXT_LARGE&quot;: &quot;aaa_1234411&quot;,\r\n        &quot;xy&quot;: &quot;xyz&quot;,\r\n        &quot;ID_WEB&quot;: 30,\r\n        &quot;ID_ACC&quot;: &quot;one&quot;\r\n      },\r\n      {\r\n        &quot;ID_EXT_LARGE&quot;: &quot;bbb_1474411&quot;,\r\n        &quot;xy&quot;: &quot;cfg&quot;,\r\n        &quot;ID_WEB&quot;: 40,\r\n        &quot;ID_ACC&quot;: &quot;two&quot;\r\n      },\r\n      {\r\n        &quot;ID_EXT_LARGE&quot;: &quot;ccc_8944411&quot;,\r\n        &quot;xy&quot;: &quot;drt&quot;,\r\n        &quot;ID_WEB&quot;: 50,\r\n        &quot;ID_ACC&quot;: &quot;three&quot;\r\n      },\r\n      {\r\n        &quot;ID_EXT_LARGE&quot;: &quot;aaa_1234411&quot;,\r\n        &quot;xy&quot;: &quot;kai&quot;,\r\n        &quot;ID_WEB&quot;: 30,\r\n        &quot;ID_ACC&quot;: &quot;one&quot;\r\n      }\r\n    ]\r\n\r\n___\r\nNote that as [peak](https://stackoverflow.com/users/997358/peak) points out `maketable` could be replaced with\r\n\r\n    def maketable: INDEX($id_array[]; .ID_EXT) | map_values(del(.ID_EXT)) ;\r\n\r\nif the more general [INDEX](https://stedolan.github.io/jq/manual/#SQL-StyleOperators) builtin (definition below) is available.\r\n\r\n    def INDEX(stream; idx_expr):  \r\n      reduce stream as $row (\r\n        {}\r\n      ; .[$row|idx_expr| if type != &quot;string&quot; then tojson else . end] |= $row\r\n      )\r\n    ;\r\n",
                "title": "jq - Map Object values using startswith()"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1507505703,
        "creation_date": 1507486249,
        "question_id": 46634409,
        "body_markdown": "I got two .json files, the first one contains the data:\r\n\r\n&gt; data.json\r\n\r\n    [\r\n     {&quot;ID_EXT_LARGE&quot;:&quot;aaa_1234411&quot;,&quot;xy&quot;:&quot;xyz&quot;},\r\n     {&quot;ID_EXT_LARGE&quot;:&quot;bbb_1474411&quot;,&quot;xy&quot;:&quot;cfg&quot;},\r\n     {&quot;ID_EXT_LARGE&quot;:&quot;ccc_8944411&quot;,&quot;xy&quot;:&quot;drt&quot;},\r\n     {&quot;ID_EXT_LARGE&quot;:&quot;aaa_1234411&quot;,&quot;xy&quot;:&quot;kai&quot;}\r\n    ]\r\n\r\nThe other one contains the IDs:\r\n\r\n&gt; id_array.json\r\n\r\n    [\r\n     {&quot;ID_EXT&quot;:&quot;aaa&quot;,&quot;ID_WEB&quot;:30,&quot;ID_ACC&quot;:&quot;one&quot;},\r\n     {&quot;ID_EXT&quot;:&quot;bbb&quot;,&quot;ID_WEB&quot;:40,&quot;ID_ACC&quot;:&quot;two&quot;},\r\n     {&quot;ID_EXT&quot;:&quot;ccc&quot;,&quot;ID_WEB&quot;:50,&quot;ID_ACC&quot;:&quot;three&quot;}\r\n    ]\r\n\r\nNow I try to get the &quot;ID_WEB&quot; and &quot;ID_ACC&quot; propertie into the objects of data.json, using the mapping of ID_EXT_LARGE and ID_EXT.\r\n\r\nThe problem is, that ID_EXT only contains the first characters of ID_EXT_LARGE.\r\nExpected result - (should be the extended data.json file):\r\n\r\n&gt; data.json\r\n\r\n    [\r\n     {&quot;ID_EXT_LARGE&quot;:&quot;aaa_1234411&quot;,&quot;ID_WEB&quot;:30,&quot;ID_ACC&quot;:&quot;one&quot;,&quot;xy&quot;:&quot;xyz&quot;},\r\n     {&quot;ID_EXT_LARGE&quot;:&quot;bbb_1474411&quot;,&quot;ID_WEB&quot;:40,&quot;ID_ACC&quot;:&quot;two&quot;,&quot;xy&quot;:&quot;cfg&quot;},\r\n     {&quot;ID_EXT_LARGE&quot;:&quot;ccc_8944411&quot;,&quot;ID_WEB&quot;:50,&quot;ID_ACC&quot;:&quot;three&quot;,&quot;xy&quot;:&quot;drt&quot;},\r\n     {&quot;ID_EXT_LARGE&quot;:&quot;aaa_1234411&quot;,&quot;ID_WEB&quot;:30,&quot;ID_ACC&quot;:&quot;one&quot;,&quot;xy&quot;:&quot;kai&quot;}\r\n    ]\r\n\r\nI tried it for ID_WEB and was thinking of something like this, (the for loop was just an idea):\r\n\r\n&gt; script.jq\r\n\r\n      def getIDWEB(id_array);\r\n            for i ....\r\n              if .&quot;ID_EXT_LARGE&quot;|startswith(id_array[i].ID_EXT) then id_array[i].ID_WEB  end\r\n            end  \r\n        ;\r\n    \r\n      def setIDWEB(id_array):\r\n         .ID_WEB = getIDWEB(id_array)\r\n        ;\r\n    \r\n      ($id_array) as $id_array\r\n      | map(setIDWEB($id_array))\r\n\r\n\r\nProbably I am thinking too complicated and this is actually a one-liner?",
        "link": "https://stackoverflow.com/questions/46634409/jq-map-object-values-using-startswith",
        "title": "jq - Map Object values using startswith()"
    },
    {
        "tags": [
            "arrays",
            "json",
            "operators",
            "jq",
            "cartesian-product"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1507559672,
                "last_edit_date": 1507559672,
                "creation_date": 1507525857,
                "answer_id": 46639195,
                "question_id": 46638584,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It sounds like you&#39;re interested in outer-products.  In any case, here is a definition of `outer/2` for forming an outer-product of two arrays:\r\n    \r\n    def outer(a; b): [a[] as $x | b[] as $y | [$x, $y]];\r\n\r\nExample:\r\n\r\n    outer([1,2]; [3,4])\r\n\r\nyields:\r\n\r\n     [[[1,3],[1,4]],[[2,3],[2,4]]]\r\n\r\n### outer(a;b;f)\r\nYou might want to use this variant (which is similar to outer(A, B, f) in R, for example):\r\n\r\n    def outer(a; b; f):\r\n      [a[] as $x | b[] as $y | [$x, $y] | f];\r\n     \r\n\r\nFor example:\r\n\r\n    def times: reduce .[] as $x (1;.*$x);\r\n\r\n    outer([1,2];[3,4]; times)\r\n\r\nyields the ordinary outer-product:\r\n\r\n    [[3,4],[6,8]]\r\n",
                "title": "Is there some way I can achieve the distributive property for arrays in `jq`?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1507537489,
                "last_edit_date": 1507537489,
                "creation_date": 1507537110,
                "answer_id": 46641732,
                "question_id": 46638584,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Perhaps the implicit cartesian product formed when using multiple `[]` iterators will help you express your problem.  For example, the following filter computes the product of `a1` and `a2` without explicit loops:\r\n  \r\n    def a1: [1,2];\r\n    def a2: [3,4];  \r\n    [ a1[] * a2[] ] | add\r\n\r\ngiving the result `21`.  Using string interpolation shows the operations more clearly.  With the above `a1` and `a2`\r\n \r\n    [ &quot;(\\(a1[]) * \\(a2[]))&quot; ] | join(&quot;+&quot;)\r\n\r\nproduces \r\n\r\n    (1 * 3)+(2 * 3)+(1 * 4)+(2 * 4)\r\n\r\nYou can also form a collection of objects with object constructors. E.g.\r\n\r\n    [ {x:a1[], y:a2[]} ]\r\n\r\nproduces\r\n\r\n    [\r\n      { &quot;x&quot;: 1, &quot;y&quot;: 3 },\r\n      { &quot;x&quot;: 1, &quot;y&quot;: 4 },\r\n      { &quot;x&quot;: 2, &quot;y&quot;: 3 },\r\n      { &quot;x&quot;: 2, &quot;y&quot;: 4 }\r\n    ]\r\n\r\nwith this approach you will need to decide how the objects should be combined.",
                "title": "Is there some way I can achieve the distributive property for arrays in `jq`?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1507558547,
                "last_edit_date": 1507558547,
                "creation_date": 1507558221,
                "answer_id": 46648490,
                "question_id": 46638584,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I just had a weirdly-timed morning epiphany that I just tried and gives me an acceptable result.\r\n\r\nI see there are other answers already, and I will probably accept one of those based solely on the content since they seem to be more concise and descriptive, especially with math and programming background.  I wish I could accept more than one!\r\n\r\nI will still add my `jq` expression into the mix as it does display slightly different terms, that may represent the algorithm I wanted but did not know clearly earlier, and does so in a complete `jq` command invocation:\r\n\r\n    ⋊&gt; ~ jq -cn &#39;[&quot;one&quot;, &quot;two&quot;] as $num | [&quot;a&quot;, &quot;b&quot;] as $let | [($num[] | [.]) + ($let[] | [.])]&#39;                                                                                                       10:01:42\r\n    [[&quot;one&quot;,&quot;a&quot;],[&quot;two&quot;,&quot;a&quot;],[&quot;one&quot;,&quot;b&quot;],[&quot;two&quot;,&quot;b&quot;]]",
                "title": "Is there some way I can achieve the distributive property for arrays in `jq`?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1507573015,
        "creation_date": 1507520975,
        "last_edit_date": 1507573015,
        "question_id": 46638584,
        "body_markdown": "I want to multiply 2 arrays to produce a mixed reduce.  I compare this to using the FOIL method expanding and distributing parenthesized terms between polynomials into a resulting, combined expression in algebra.\r\n\r\nI was hoping to avoid having to write a `foreach` loop, even if it automatically works for any array length, and doing that for every array mixture I want to create.\r\n\r\nI also want to avoid creating some resultant array through iterating the first array, combining the terms from the second array, and then somehow performing a total composition in this filter segment, possibly requiring a `flatten` directive at the end.  This seems like too many steps for what I need, and could be more concisely represented.  A `*` operator perhaps?\r\n\r\nI&#39;m starting to think the second method is what I need to do since I may not want to &#39;multiply&#39; the terms, but instead create a new array or object to use while working with the rest of my task.\r\n\r\nMy question is starting to sound like essentially asking how to enter a double `foreach` loop in `jq` using filters and only the data elements, not that actual `foreach` loop?\r\n\r\nIn my example I essentially want to use 2 arrays, each containing a pair of terms to be used in an enumeration of states, to create a resulting array that allows me to iterate through 4 total cases.  This is similar to how combinations are calculated.\r\n\r\nDoes anybody know what I am talking about? :)",
        "link": "https://stackoverflow.com/questions/46638584/is-there-some-way-i-can-achieve-the-distributive-property-for-arrays-in-jq",
        "title": "Is there some way I can achieve the distributive property for arrays in `jq`?"
    },
    {
        "tags": [
            "json",
            "bash",
            "if-statement",
            "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": 1507572540,
                "post_id": 46652354,
                "comment_id": 80254011,
                "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": 1507572775,
                "post_id": 46652354,
                "comment_id": 80254140,
                "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": 1507573092,
                "post_id": 46652354,
                "comment_id": 80254321,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1507573513,
                "last_edit_date": 1507573513,
                "creation_date": 1507572188,
                "answer_id": 46652449,
                "question_id": 46652354,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Let&#39;s go over this from the top so you understand what&#39;s happening.\r\n\r\n&gt;     ~$ err=$(jq &quot;.errMsg&quot; $input)\r\n&gt;     ~$ echo $err\r\n&gt;     &quot;&quot;\r\n\r\nThis output indicates that `err` contains `&quot;&quot;` (it may also have some spaces before and after the `&quot;&quot;`).\r\nThis is not the same thing as an empty string.\r\nIt&#39;s literally two double-quote characters.\r\n\r\n&gt;     ~$ if [ $err = &quot;&quot; ]; then echo EMPTY; else echo CONTENT; fi \r\n&gt;     CONTENT\r\n&gt;\r\n&gt; I excpected the EMPTY as $err just showed &quot;&quot;.\r\n\r\nAs mentioned earlier, `$err` is not empty, it contains two double-quotes.\r\nOn the other hand, in the Bash statement `[ ... = &quot;&quot; ]` the `&quot;&quot;` does really mean an empty value.\r\n\r\nThe Bash statement `[ $err = &quot;&quot; ]` is problematic,\r\nbecause it will result in a syntax error if the value of `$err` is empty,\r\nor if it contains whitespace (assuming you haven&#39;t customized `IFS`).\r\n\r\nThe correct way to write this statement to enclose `$err` in double-quotes:\r\n\r\n    if [ &quot;$err&quot; = &quot;&quot; ]; then echo EMPTY; else echo CONTENT; fi\r\n\r\nThe same goes for the `$input` variable in your first command, it should be written as:\r\n\r\n    err=$(jq &quot;.errMsg&quot; &quot;$input&quot;)\r\n\r\n---\r\n\r\nIf you want to check for empty `.errMsg` value in the object,\r\nyou have at least two options.\r\n\r\nOption 1: check that the value is `&quot;&quot;`.\r\n\r\n    if [ &quot;$err&quot; = &#39;&quot;&quot;&#39; ]; then echo EMPTY; else echo CONTENT; fi\r\n\r\nOption 2: make `jq` output in raw mode, so it doesn&#39;t include the enclosing double-quotes around string values.\r\n\r\n    err=$(jq -r &quot;.errMsg&quot; &quot;$input&quot;)\r\n    if [ &quot;$err&quot; = &quot;&quot; ]; then echo EMPTY; else echo CONTENT; fi\r\n\r\nI recommend this latter option, so that the value of `err` will be the real value. The enclosing double-quotes seem just noise for your purpose.\r\n",
                "title": "bash JSON with jq - how to check for empty JSON members?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1507573527,
                "creation_date": 1507573527,
                "answer_id": 46652762,
                "question_id": 46652354,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can read your entire structure into a native bash associative array as follows:\r\n\r\n    declare -A data=( )\r\n    while IFS=$&#39;\\t&#39; read -r key value; do\r\n      data[$key]=$value\r\n    done &lt; &lt;(jq -r &#39;to_entries[] | [.key, .value] | @tsv&#39; &quot;$input&quot;)\r\n\r\nFrom there, you have several options: You can check items individually...\r\n\r\n    [[ ${data[errMsg]} ]] || echo &quot;ERROR: errMsg is not set!&quot;\r\n\r\n...or you can loop over all of them:\r\n\r\n    for key in &quot;${!data[@]}&quot;; do\r\n        [[ ${data[$key]} ]] || echo &quot;ERROR: ${key} is not set!&quot;\r\n    done",
                "title": "bash JSON with jq - how to check for empty JSON members?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1507573527,
        "creation_date": 1507571872,
        "question_id": 46652354,
        "body_markdown": "I want to detect an error depending on an error message JSON field being empty or non-empty . I am using jq to slice out the member, but then have massive trouble evaluating it in my bash &quot;if&quot;. \r\n\r\nI have a json file referenced by my variable $input which does have an errMsg member, but as an empty string (note that my CLI prompt is ~$) : \r\n\r\n    ~$ echo $(jq &quot;.&quot; $input)\r\n    { &quot;projectCode&quot;: &quot;145&quot;, &quot;fullCode&quot;: &quot;1&quot;, &quot;errMsg&quot;: &quot;&quot; }\r\n\r\n\r\nretrieving the errMsg field in this case properly yields an empty string: \r\n\r\n    ~$ err=$(jq &quot;.errMsg&quot; $input)\r\n    ~$ echo $err\r\n    &quot;&quot;\r\n\r\nProblem : testing that variable seems impossible :\r\n\r\n    ~$ if [ $err = &quot;&quot; ]; then echo EMPTY; else echo CONTENT; fi \r\n    CONTENT\r\n\r\nI excpected the EMPTY as $err just showed &quot;&quot;. Checking other way around: \r\n\r\n    ~$ if [ $err != &quot;&quot; ]; then echo EMPTY; else echo CONTENT; fi\r\n    EMPTY \r\n\r\nso $err is apparently not &quot;&quot;, even though echo $err yields &quot;&quot; ? \r\nHow can that be ? What bash feature  am I missing here ? \r\n\r\nAnyway, lets try that with a non-empty json (after changing the $input content):\r\n\r\n    ~$ echo $(jq &quot;.&quot; $input)\r\n    { &quot;projectCode&quot;: &quot;145&quot;, &quot;fullCode&quot;: &quot;1&quot;, &quot;errMsg&quot;: &quot;not empty&quot; }\r\n    ~$ echo $err\r\n    &quot;not empty&quot;\r\n\r\n    ~$ if [ $err != &quot;&quot; ]; then echo EMPTY; else echo CONTENT; fi\r\n    bash: syntax error near unexpected token `then&#39;\r\n\r\nokay, then masking like this : \r\n\r\n    ~$ if [ &quot;$err&quot; != &quot;&quot; ]; then echo EMPTY; else echo CONTENT; fi\r\n    bash: syntax error near unexpected token `then&#39;\r\n\r\nI guess it finds a second token after &quot;not&quot; and doesnt like it. \r\nAfter much research i find this truly unreadable solution that seems to work: \r\n\r\n    ~$ val=$(sed &quot;s/^\\(\\&quot;\\)\\(.*\\)\\1\\$/\\2/g&quot; &lt;&lt;&lt;&quot;$err&quot; | sed -e &#39;s/\\s.*$//&#39;)\r\n    ~$ if [ &quot;$val&quot; = &quot;&quot; ]; then echo &quot;NO ERROR&quot;; else echo &quot;ERROR&quot;; fi\r\n    NO ERROR\r\n\r\nit also works for non-empty errMsg members. Please, there MUST be a simple and elegant solution to this.",
        "link": "https://stackoverflow.com/questions/46652354/bash-json-with-jq-how-to-check-for-empty-json-members",
        "title": "bash JSON with jq - how to check for empty JSON members?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1507659873,
                "creation_date": 1507659873,
                "answer_id": 46673453,
                "question_id": 46671563,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This filter produces the desired output.\r\n\r\n    def parse: capture(&quot;(?&lt;key&gt;\\\\w+)\\\\s*:\\\\s*(?&lt;value&gt;\\\\w+)&quot;) ;\r\n    def print: &quot;[\\(.key) : \\(.value)]&quot;;\r\n    def norm:   [.[][][] | parse | select(.key==&quot;property_A&quot;) | print][0];\r\n\r\n      .Items\r\n    | map({id:.ID.S, old:.oldProperties|norm, new:.newProperties|norm})[]\r\n\r\n    \r\nSample Run (assumes filter in `filter.jq` and data in `data.json`)\r\n\r\n    $ jq -M -f filter.jq data.json\r\n    {\r\n      &quot;id&quot;: &quot;ID_Complete&quot;,\r\n      &quot;old&quot;: &quot;[property_A : value_A_old]&quot;,\r\n      &quot;new&quot;: &quot;[property_A : value_A_new]&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;ID_Incomplete&quot;,\r\n      &quot;old&quot;: null,\r\n      &quot;new&quot;: &quot;[property_A : value_A_new]&quot;\r\n    }\r\n\r\n\r\n[Try it online!][TIO-j8lxnwrl]\r\n\r\n[TIO-j8lxnwrl]: https://tio.run/##xZJBS8MwFMfv/RSPnFpdg@fMKZu7DDwIO6ahlO0J1TaJaeoYa7@69TUVZV5kJwkkL8nv/395j7y8DSe28Vg3TEiK1kyc2JYJivIHU9sKPbJ@xky1f3LGovMlNiPzGPiRlHa6OOZLEPBeVC3my5wEioS/kdU3svpCFLlrPFzmToK/3CdE9SN1VtZG7y4t7B9erfpu2OMz2MI1KGBXWN86jFl8f/uKx7ssO1wnWdZciXGiw2AwHbME5lHQulJ7AUxmMSdRQnkoCmSi2MRo42oBAJJLNQ7oppS0NljhzgfpYsF@KiL/bvJW8kbNowiAhy8UdVAXNj6Ve8E3a76dATVL8LMWd2PCGVCdgp81MFz0iVRkBxBFw/BhrC@NboY01W1VpaW2raeNKw6paT1tPgE &quot;jq – Try It Online&quot;",
                "title": "Using jq to parse keys present in two lists (even though it might not exist in one of those)"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1507902794,
                "last_edit_date": 1507902794,
                "creation_date": 1507693505,
                "answer_id": 46679458,
                "question_id": 46671563,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your list of properties appear to be values of some object. You could map them out into an object to then diff the objects, then report on the results.\r\n\r\nYou could do something like this:\r\n\r\n    def make_object_from_properties:\r\n          [.L[].S | capture(&quot;\\\\[(?&lt;key&gt;\\\\w+) : (?&lt;value&gt;\\\\w+)\\\\]&quot;)]\r\n        | from_entries\r\n        ;\r\n    def diff_objects($old; $new):\r\n          def _prop($key): select(has($key))[$key];\r\n          ([($old | keys[]), ($new | keys[])] | unique) as $keys\r\n        | [   $keys[] as $k\r\n            | ({ value: $old | _prop($k) } // { none: true }) as $o\r\n            | ({ value: $new | _prop($k) } // { none: true }) as $n\r\n            | (if   $o.none                 then &quot;add&quot;\r\n              elif  $n.none                 then &quot;remove&quot;\r\n              elif  $o.value != $n.value    then &quot;change&quot;\r\n                                            else &quot;same&quot;\r\n              end) as $s\r\n            | { key: $k, status: $s, old: $o.value, new: $n.value }\r\n          ]\r\n      ;\r\n    def diff_properties:\r\n          (.oldProperties | make_object_from_properties) as $old\r\n        | (.newProperties | make_object_from_properties) as $new\r\n        | diff_objects($old; $new) as $diff\r\n        | foreach $diff[] as $d ({ id: .ID.S };\r\n              select($d.status != &quot;same&quot;)\r\n            | .old = ((select(any(&quot;remove&quot;, &quot;change&quot;; . == $d.status)) | &quot;[\\($d.key) : \\($d.old)]&quot;) // null)\r\n            | .new = ((select(any(&quot;add&quot;, &quot;change&quot;;    . == $d.status)) | &quot;[\\($d.key) : \\($d.new)]&quot;) // null)\r\n          )\r\n        ;\r\n    [.Items[] | diff_properties]\r\n\r\nThis yields the following output:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;ID_Complete&quot;,\r\n        &quot;old&quot;: &quot;[property_A : value_A_old]&quot;,\r\n        &quot;new&quot;: &quot;[property_A : value_A_new]&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;ID_Complete&quot;,\r\n        &quot;old&quot;: &quot;[property_B : value_B_old]&quot;,\r\n        &quot;new&quot;: &quot;[property_B : value_B_new]&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;ID_Incomplete&quot;,\r\n        &quot;old&quot;: null,\r\n        &quot;new&quot;: &quot;[property_A : value_A_new]&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;ID_Incomplete&quot;,\r\n        &quot;old&quot;: &quot;[property_B : value_B_old]&quot;,\r\n        &quot;new&quot;: &quot;[property_B : value_B_new]&quot;\r\n      }\r\n    ]\r\n\r\nIt seems like your data is in some kind of encoded format too. For a more robust solution, you should consider defining some functions to decode them.  Consider approaches found [here](https://stackoverflow.com/questions/28593471/how-to-simplify-aws-dynamodb-query-json-output-from-the-command-line) on how you could do that.\r\n",
                "title": "Using jq to parse keys present in two lists (even though it might not exist in one of those)"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1507902794,
        "creation_date": 1507652869,
        "question_id": 46671563,
        "body_markdown": "*(It was hard to come up with a title that summarizes the issue, so feel free to improve it).*\r\n  \r\nI have a JSON file with the following content:\r\n\r\n    {\r\n        &quot;Items&quot;: [\r\n            {\r\n                &quot;ID&quot;: {\r\n                    &quot;S&quot;: &quot;ID_Complete&quot;\r\n                }, \r\n                &quot;oldProperties&quot;: {\r\n                    &quot;L&quot;: [\r\n                        {\r\n                            &quot;S&quot;: &quot;[property_A : value_A_old]&quot;\r\n                        }, \r\n                        {\r\n                            &quot;S&quot;: &quot;[property_B : value_B_old]&quot;\r\n                        }\r\n                    ]\r\n                },\r\n                &quot;newProperties&quot;: {\r\n                    &quot;L&quot;: [\r\n                        {\r\n                            &quot;S&quot;: &quot;[property_A : value_A_new]&quot;\r\n                        }, \r\n                        {\r\n                            &quot;S&quot;: &quot;[property_B : value_B_new]&quot;\r\n                        }\r\n                    ]\r\n                }\r\n            }, \r\n            {\r\n                &quot;ID&quot;: {\r\n                    &quot;S&quot;: &quot;ID_Incomplete&quot;\r\n                }, \r\n                &quot;oldProperties&quot;: {\r\n                    &quot;L&quot;: [\r\n                        {\r\n                            &quot;S&quot;: &quot;[property_B : value_B_old]&quot;\r\n                        }\r\n                    ]\r\n                },\r\n                &quot;newProperties&quot;: {\r\n                    &quot;L&quot;: [\r\n                        {\r\n                            &quot;S&quot;: &quot;[property_A : value_A_new]&quot;\r\n                        }, \r\n                        {\r\n                            &quot;S&quot;: &quot;[property_B : value_B_new]&quot;\r\n                        }\r\n                    ]\r\n                }\r\n            }\r\n        ]\r\n    }\r\n\r\nI would like to manipulate the data using `jq` in such a way that for each item in `Items[]` that has a ***new*** value for *property_A* (under ***newProperties*** list) generate an output with the corresponding *id*, *old* and *new* (see desired output below) fields regardless of the value that property has in the ***oldProperties*** list. Moreover, if *property_A* does not exist in the ***oldProperties***, I still need the *old* field to be populated with a `null` (or any fixed string for what it&#39;s worth).  \r\n\r\nDesired output:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;id_Complete&quot;,\r\n      &quot;old&quot;: &quot;[property_A : value_A_old]&quot;,\r\n      &quot;new&quot;: &quot;[property_A : value_A_new]&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;ID_Incomplete&quot;,\r\n      &quot;old&quot;: null,\r\n      &quot;new&quot;: &quot;[property_A : value_A_new]&quot;\r\n    }\r\n\r\n**Note:** Even though *property_A* doesn&#39;t exist in the ***oldProperties*** list, other properties may (and will) exist.\r\n\r\n\r\nThe problem I am facing is that I am not able to get an output when the desired property does not exist in the ***oldProperties*** list. My current `jq` command looks like this:\r\n\r\n    jq -r &#39;.Items[] | \r\n        { id:.ID.S, \r\n          old:.oldProperties.L[].S | select(. | contains(&quot;property_A&quot;)),\r\n          new:.newProperties.L[].S | select(. | contains(&quot;property_A&quot;)) }&#39;\r\n\r\nWhich renders only the *ID_Complete* case, while I need the other as well.\r\n\r\nIs there any way to achieve this using this tool?\r\n\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/46671563/using-jq-to-parse-keys-present-in-two-lists-even-though-it-might-not-exist-in-o",
        "title": "Using jq to parse keys present in two lists (even though it might not exist in one of those)"
    },
    {
        "tags": [
            "json",
            "path",
            "key",
            "sublimetext3",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507725360,
                "post_id": 46687961,
                "comment_id": 80324205,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1163881,
                    "reputation": 14429,
                    "user_id": 1142881,
                    "user_type": "registered",
                    "accept_rate": 99,
                    "profile_image": "https://www.gravatar.com/avatar/d53533db57e68fc5b6671b5499c0433e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "SkyWalker",
                    "link": "https://stackoverflow.com/users/1142881/skywalker"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507725713,
                "post_id": 46687961,
                "comment_id": 80324434,
                "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": 1507726016,
                "post_id": 46687961,
                "comment_id": 80324662,
                "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": 1507729399,
                "post_id": 46687961,
                "comment_id": 80327331,
                "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": 1507730706,
                "post_id": 46687961,
                "comment_id": 80328365,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1163881,
                    "reputation": 14429,
                    "user_id": 1142881,
                    "user_type": "registered",
                    "accept_rate": 99,
                    "profile_image": "https://www.gravatar.com/avatar/d53533db57e68fc5b6671b5499c0433e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "SkyWalker",
                    "link": "https://stackoverflow.com/users/1142881/skywalker"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507732538,
                "post_id": 46687961,
                "comment_id": 80329714,
                "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": 1507736076,
                "post_id": 46687961,
                "comment_id": 80332177,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1039648,
                    "reputation": 12683,
                    "user_id": 1046007,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c1c27f58af84eeaad72231f198e7c369?s=256&d=identicon&r=PG",
                    "display_name": "Walter Tross",
                    "link": "https://stackoverflow.com/users/1046007/walter-tross"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507739211,
                "post_id": 46687961,
                "comment_id": 80334114,
                "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": 2,
                "creation_date": 1507747058,
                "post_id": 46687961,
                "comment_id": 80338386,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1507734117,
                "last_edit_date": 1592644375,
                "creation_date": 1507733688,
                "answer_id": 46691444,
                "question_id": 46687961,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It would be easier to answer more precisely if you can provide a small sample of your data and the desired output but in any event the [--stream](https://stedolan.github.io/jq/manual/#Streaming) option may be what you want.  From the documentation:\n\n&gt; ### Streaming\n&gt;\n&gt; With the --stream option jq can parse input texts in a streaming fashion, allowing jq programs to start processing large JSON texts immediately rather than after the parse completes. If you have a single JSON text that is 1GB in size, streaming it will allow you to process it much more quickly.\n&gt;\n&gt; However, streaming isn’t easy to deal with as the jq program will have `[&lt;path&gt;, &lt;leaf-value&gt;]` (and a few other forms) as inputs.\n\nHere are some existing answers you may want to review.\n\n* https://stackoverflow.com/questions/39232060/process-large-json-stream-with-jq\n\n* https://stackoverflow.com/questions/32182087/processing-huge-json-array-files-with-jq\n\n* https://stackoverflow.com/questions/43469103/process-huge-geojson-file-with-jq\n\n* https://stackoverflow.com/questions/30982175/load-a-large-json-file-using-multi-threading/45851860#45851860\n\nThe [JQ Cookbook](https://github.com/stedolan/jq/wiki/Cookbook) also has an example:\n\n* [Processing a huge JSON array of items](https://github.com/stedolan/jq/wiki/Cookbook#processing-a-huge-json-array-of-items)",
                "title": "How to show the path to a given key in a big JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1507756437,
        "creation_date": 1507724044,
        "last_edit_date": 1507756437,
        "question_id": 46687961,
        "body_markdown": "I have a very very big JSON and I&#39;d like to check the path to some keys. Pretty printing doesn&#39;t help if the JSON is very large and lot of hierarchies. I&#39;m using [Sublime 3][1] and [jq][2] together with the [Pretty JSON plugin][3]. Is there a way to know the full path(s) to a given key using the jq tool or any other way? I could write a JSON parser in some language and do it but I need just to figure out quickly where things are.\r\n\r\n  [1]: https://www.sublimetext.com/3\r\n  [2]: https://stedolan.github.io/jq/\r\n  [3]: https://github.com/dzhibas/SublimePrettyJson",
        "link": "https://stackoverflow.com/questions/46687961/how-to-show-the-path-to-a-given-key-in-a-big-json",
        "title": "How to show the path to a given key in a big JSON?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507785238,
                "post_id": 46701330,
                "comment_id": 80350773,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5028364,
                    "reputation": 32494,
                    "user_id": 4039431,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://www.gravatar.com/avatar/11cbc250ef94644843c0bf53bc752d74?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Amit",
                    "link": "https://stackoverflow.com/users/4039431/amit"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507785744,
                "post_id": 46701330,
                "comment_id": 80350965,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "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": 1507785839,
                "post_id": 46701330,
                "comment_id": 80350998,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5028364,
                    "reputation": 32494,
                    "user_id": 4039431,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://www.gravatar.com/avatar/11cbc250ef94644843c0bf53bc752d74?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Amit",
                    "link": "https://stackoverflow.com/users/4039431/amit"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507785935,
                "post_id": 46701330,
                "comment_id": 80351032,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5028364,
                    "reputation": 32494,
                    "user_id": 4039431,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://www.gravatar.com/avatar/11cbc250ef94644843c0bf53bc752d74?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Amit",
                    "link": "https://stackoverflow.com/users/4039431/amit"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507786240,
                "post_id": 46701330,
                "comment_id": 80351161,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1507787691,
                "last_edit_date": 1507787691,
                "creation_date": 1507784058,
                "answer_id": 46701669,
                "question_id": 46701330,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Perhaps this would help you:\r\n\r\n    map(select(.product.type == &quot;mobile&quot;)) | .[] | {id: .product.id, service: .product.service}\r\n\r\nhttps://jqplay.org/s/6zMyKjTehN",
                "title": "How to filter a JSON object based on a condition and then just select few keys from the filtered object using the JQ parser"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1507789431,
                "creation_date": 1507789431,
                "answer_id": 46702785,
                "question_id": 46701330,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The data as currently shown in the question is not strictly JSON, but since the OP mentions the input is supposed to be an array, the following assumes the data is a JSON array of the objects.\r\n\r\nA succinct solution is then:\r\n\r\n    data[] | .product | select(.type == &quot;mobile&quot;) | {service, id}\r\n\r\nWith the input data adjusted as described above, the output would be as shown, namely:\r\n\r\n    {&quot;service&quot;:&quot;pricing&quot;,&quot;id&quot;:1}\r\n",
                "title": "How to filter a JSON object based on a condition and then just select few keys from the filtered object using the JQ parser"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1507789431,
        "creation_date": 1507781782,
        "last_edit_date": 1507786423,
        "question_id": 46701330,
        "body_markdown": "I am having a below JSON structure,which has an array of objects.\r\n\r\n   \r\n\r\n     {\r\n      &quot;payload&quot;: {\r\n        &quot;location&quot;: {\r\n          &quot;uid&quot;: 1,\r\n          &quot;type&quot;: &quot;foo&quot;\r\n        },\r\n        &quot;name&quot;: &quot;foo&quot;,\r\n        &quot;maxResults&quot;: 10\r\n      },\r\n      &quot;product&quot;: {\r\n        &quot;uid&quot;: &quot;1232323&quot;,\r\n        &quot;source&quot;: &quot;foo&quot;,\r\n        &quot;service&quot;: &quot;pricing&quot;,\r\n        &quot;version&quot;: &quot;0.1&quot;,\r\n        &quot;time&quot;: 1507602150899,\r\n        &quot;type&quot;: &quot;mobile&quot;,\r\n        &quot;id&quot;: 1\r\n      }\r\n    }\r\n    {\r\n      &quot;payload&quot;: {\r\n        &quot;location&quot;: {\r\n          &quot;uid&quot;: 2,\r\n          &quot;type&quot;: &quot;bar&quot;\r\n        },\r\n        &quot;name&quot;: &quot;bar&quot;,\r\n        &quot;maxResults&quot;: 10\r\n      },\r\n      &quot;product&quot;: {\r\n        &quot;uid&quot;: &quot;244434242&quot;,\r\n        &quot;source&quot;: &quot;bar&quot;,\r\n        &quot;service&quot;: &quot;pricing&quot;,\r\n        &quot;version&quot;: &quot;0.2&quot;,\r\n        &quot;time&quot;: &quot;1507602ds0899&quot;,\r\n        &quot;type&quot;: &quot;phone&quot;,\r\n        &quot;id&quot;: 2\r\n      }\r\n    }\r\n\r\nI want to filter the object based on condition, where `product.type == mobile` and then in matching objects, I just want to the `id` and `service` fields. So in above example, below would be the O/P.\r\n\r\n    {\r\n      &quot;service&quot; : &quot;pricing&quot;,\r\n      &quot;id&quot; : 1\r\n    }\r\n\r\nI am able to extract the matching objects using the \r\n\r\n    cat myjson.json | jq &#39;select(.product.type == &quot;moble&quot;)&#39; \r\n\r\nbut after that how can I filter only the `service` and `id` field of object ?\r\n",
        "link": "https://stackoverflow.com/questions/46701330/how-to-filter-a-json-object-based-on-a-condition-and-then-just-select-few-keys-f",
        "title": "How to filter a JSON object based on a condition and then just select few keys from the filtered object using the JQ parser"
    },
    {
        "tags": [
            "shell",
            "windows-installer",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4242095,
                    "reputation": 920,
                    "user_id": 3471694,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/VvTrb.png?s=256",
                    "display_name": "Bui Anh Tuan",
                    "link": "https://stackoverflow.com/users/3471694/bui-anh-tuan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507789672,
                "post_id": 46702550,
                "comment_id": 80352600,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1042873,
                    "reputation": 4936,
                    "user_id": 2072269,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/xNPjb.png?s=256",
                    "display_name": "muru",
                    "link": "https://stackoverflow.com/users/2072269/muru"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1507795064,
                "post_id": 46702550,
                "comment_id": 80355398,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 17751969,
                    "reputation": 1415,
                    "user_id": 14335655,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-EMeW4PvQZ-Y/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rf6kW0De2vjqiJI3dJB40kl-jtlWA/s256-rj/photo.jpg",
                    "display_name": "Karolina Hageg&#229;rd",
                    "link": "https://stackoverflow.com/users/14335655/karolina-hageg%c3%a5rd"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1628775767,
                "post_id": 46702550,
                "comment_id": 121516080,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1507794784,
                "creation_date": 1507794784,
                "answer_id": 46704271,
                "question_id": 46702550,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "After obtaining jq.exe (by whatever means), you would normally run it from a batch script or from the Windows command line.  See for example https://en.wikipedia.org/wiki/Win32_console\r\n\r\nYou may find it easier to use `jq` if you let &quot;choco&quot; install it for you (`choco install jq`). \r\n\r\nTo install `choco` is quite straightforward: https://chocolatey.org/install\r\n\r\n\r\n",
                "title": "Jq installation error"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1507794784,
        "creation_date": 1507788547,
        "question_id": 46702550,
        "body_markdown": "I am using windows 10 home. I tried to install jq from [https://stedolan.github.io/jq/download/][1].\r\n\r\nDownloaded `jq-win64.exe` file, but when i open it, it just opens and closes instantly . I want to run a `.sh` file which requires jq installed . Any help here.\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/download/",
        "link": "https://stackoverflow.com/questions/46702550/jq-installation-error",
        "title": "Jq installation error"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8566752,
                    "reputation": 54493,
                    "user_id": 6419007,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/CwqtX.jpg?s=256",
                    "display_name": "Eric Duminil",
                    "link": "https://stackoverflow.com/users/6419007/eric-duminil"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507883892,
                "post_id": 46725770,
                "comment_id": 80397668,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1225693,
                    "reputation": 51,
                    "user_id": 1191273,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/deee2805c2848550b4cd4a2e2c1f2138?s=256&d=identicon&r=PG",
                    "display_name": "user1191273",
                    "link": "https://stackoverflow.com/users/1191273/user1191273"
                },
                "reply_to_user": {
                    "account_id": 8566752,
                    "reputation": 54493,
                    "user_id": 6419007,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/CwqtX.jpg?s=256",
                    "display_name": "Eric Duminil",
                    "link": "https://stackoverflow.com/users/6419007/eric-duminil"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507902971,
                "post_id": 46725770,
                "comment_id": 80409322,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1507892202,
                "creation_date": 1507892202,
                "answer_id": 46728303,
                "question_id": 46725770,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**jq** solution:\r\n\r\n    jq &#39;[.mc[0].rc[] | .id as $id | reduce .atb[] as $i \r\n        ({&quot;atb_price&quot;:[], &quot;atb_amount&quot;:[], &quot;atb_id&quot;: []}; \r\n         .atb_price += [$i[0]] | .atb_amount += [$i[1]] | .atb_id += [$id])]&#39; jsonfile\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;atb_price&quot;: [\r\n          7.6,\r\n          7.2\r\n        ],\r\n        &quot;atb_amount&quot;: [\r\n          35,\r\n          25\r\n        ],\r\n        &quot;atb_id&quot;: [\r\n          11111,\r\n          11111\r\n        ]\r\n      },\r\n      {\r\n        &quot;atb_price&quot;: [\r\n          1.04,\r\n          1.02\r\n        ],\r\n        &quot;atb_amount&quot;: [\r\n          100,\r\n          200\r\n        ],\r\n        &quot;atb_id&quot;: [\r\n          22222,\r\n          22222\r\n        ]\r\n      }\r\n    ]\r\n\r\n",
                "title": "In Jq how to expand a json array of tuples into multiple elements"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1507893239,
                "creation_date": 1507893239,
                "answer_id": 46728615,
                "question_id": 46725770,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "A succinct and straightforward solution:\r\n\r\n    .mc[].rc[]\r\n    | .id as $id\r\n    | .atb\r\n    | { atb_price:   map(.[0]),\r\n        atb_amount:  map(.[1]),\r\n        atb_id:      map($id) }",
                "title": "In Jq how to expand a json array of tuples into multiple elements"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1508330896,
        "creation_date": 1507883723,
        "last_edit_date": 1508330896,
        "question_id": 46725770,
        "body_markdown": "I have this json string  \r\n\r\n    {&quot;op&quot;:&quot;mcm&quot;,&quot;clk&quot;:&quot;1147179697&quot;,&quot;pt&quot;:1439869512969,\r\n       &quot;mc&quot;:[ {&quot;id&quot;:&quot;1.120040663&quot;,\r\n               &quot;rc&quot;:[\r\n                      {&quot;atb&quot;:[[7.6,35],[7.2,25]],&quot;id&quot;:11111},\r\n                      {&quot;atb&quot;:[[1.04,100],[1.02,200]],&quot;id&quot;:22222}\r\n                    ],\r\n               &quot;con&quot;:true,\r\n               &quot;img&quot;:false}\r\n            ]}\r\n\r\nand need to extract the atb elements into prices and amounts together with the id:\r\n\r\n    [{\r\n    &quot;atb_price&quot;: [7.6, 7.2]\r\n    &quot;atb_amount&quot;: [35, 25]\r\n    &quot;atb_id&quot;: [11111, 11111]\r\n    },\r\n    {\r\n    &quot;atb_price&quot;: [1.04, 1.02]\r\n    &quot;atb_amount&quot;: [100, 200]\r\n    &quot;atb_id&quot;: [22222, 22222]\r\n    }]\r\n\r\nSo far I have these filter which gets me some of the way there but not quite.  \r\n1. Gives a combination of all prices/amounts/ids.\r\n\r\n    (.mc[].rc | map({&quot;prices&quot;:.atb[][0], &quot;vol&quot;:.atb[][1], &quot;id&quot;:.id}))  \r\n2. The id element remains outside the array.  \r\n\r\n    .mc[].rc | map( {&quot;id&quot;:.id, &quot;atb&quot;: ( .atb | map({ &quot;amount&quot;:  .[1],  &quot;price&quot;:.[0] }) )[] } )\r\n\r\nAny help greatly appreciated.\r\n\r\n**EDIT**\r\nEventually, I modified one of the answers slightly because my json string was more complex than first thought, in some cases, there are _trd_ elements to deal with.\r\n\r\n    {&quot;op&quot;:&quot;mcm&quot;,&quot;clk&quot;:&quot;1147179697&quot;,&quot;pt&quot;:1439869512969,\r\n       &quot;mc&quot;:[ {&quot;id&quot;:&quot;1.120040663&quot;,\r\n               &quot;rc&quot;:[\r\n                      {&quot;atb&quot;:[[7.6,35],[7.2,25]],&quot;id&quot;:11111},\r\n                      {&quot;atb&quot;:[[1.04,100],[1.02,200]],&quot;id&quot;:22222}\r\n                      {&quot;trd&quot;:[[1.04,100],[1.02,200]],&quot;id&quot;:22222}\r\n                    ],\r\n               &quot;con&quot;:true,\r\n               &quot;img&quot;:false}\r\n            ]}\r\n\r\nThe solution,\r\n\r\n    (. | del(.mc))\r\n    + (.mc[] | del(.rc))\r\n    + (.mc[].rc[] \r\n    | .id as $id | .ltp as $ltp | .tv as $rtv\r\n    | (select(.atl) | (.atl | {&quot;atl.price&quot;: map(.[0]), &quot;atl.volume&quot;: map(.[1]), &quot;runner.id&quot;: map($id)})),\r\n      (select(.atb) | (.atb | {&quot;atb.price&quot;: map(.[0]), &quot;atb.volume&quot;: map(.[1]), &quot;runner.id&quot;: map($id)})),\r\n      (select(.trd) | (.trd | {&quot;trd.price&quot;: map(.[0]), &quot;trd.volume&quot;: map(.[1]), &quot;runner.id&quot;: map($id)}))\r\n      )",
        "link": "https://stackoverflow.com/questions/46725770/in-jq-how-to-expand-a-json-array-of-tuples-into-multiple-elements",
        "title": "In Jq how to expand a json array of tuples into multiple elements"
    },
    {
        "tags": [
            "json",
            "elasticsearch",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1507892997,
                "creation_date": 1507892997,
                "answer_id": 46728543,
                "question_id": 46727645,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**jq** solution:\r\n\r\n    jq -r &#39;.[] | .key_as_string as $ks | .agg1.buckets[] | .key as $key \r\n               | .agg2.buckets[] | [$ks,$key,.key,.doc_count] | @csv&#39; jsonfile\r\n\r\nThe output (for your current input):\r\n\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value3&quot;,&quot;10367.xxx&quot;,1\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value3&quot;,&quot;10997.xxx&quot;,1\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value3&quot;,&quot;12055.xxx&quot;,1\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value3&quot;,&quot;12157.xxx&quot;,1\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value3&quot;,&quot;12435.xxx&quot;,1\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value3&quot;,&quot;12volt.xxx&quot;,1\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value3&quot;,&quot;13158.xxx&quot;,1\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value3&quot;,&quot;13507.xxx&quot;,1\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value3&quot;,&quot;13597.xxx&quot;,1\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value3&quot;,&quot;137.xxx&quot;,1\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value2&quot;,&quot;saasf.xxx&quot;,7\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value2&quot;,&quot;asfasf.xxx&quot;,5\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value2&quot;,&quot;sasfsd.xxx&quot;,3\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value2&quot;,&quot;werwer.xxx&quot;,3\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value2&quot;,&quot;werwre.xxx&quot;,3\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value2&quot;,&quot;a-werwr.xxx&quot;,2\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value2&quot;,&quot;aef.xxx&quot;,2\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value2&quot;,&quot;sadhdhh.xxx&quot;,2\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value2&quot;,&quot;dhsdfsdg.xxx&quot;,2\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value2&quot;,&quot;ertetrt.xxx&quot;,2\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value1&quot;,&quot;fhshfg.xxx&quot;,3\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value1&quot;,&quot;sgh.xxx&quot;,3\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value1&quot;,&quot;12.xxx&quot;,2\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value1&quot;,&quot;sbgs.xxx&quot;,2\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value1&quot;,&quot;dp-eca.xxx&quot;,2\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value1&quot;,&quot;ztuhfb.xxx&quot;,2\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value1&quot;,&quot;javascript.xxx&quot;,2\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value1&quot;,&quot;koi-fdhfh.xxx&quot;,2\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value1&quot;,&quot;sdfh.xxx&quot;,2\r\n    &quot;2017-09-01T00:00:00.000+02:00&quot;,&quot;value1&quot;,&quot;etz5.xxx&quot;,2\r\n\r\n",
                "title": "JQ: Create CSV out of aggregated json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1507894677,
        "creation_date": 1507889951,
        "last_edit_date": 1507894677,
        "question_id": 46727645,
        "body_markdown": "I&#39;m trying to parse an aggregated search result of elasticsearch with jq to create a CSV. But it&#39;s really hard to get the result i need - hope someone can help. I have the following json:\r\n\r\n    [\r\n      {\r\n        &quot;key_as_string&quot;: &quot;2017-09-01T00:00:00.000+02:00&quot;,\r\n        &quot;key&quot;: 1506808800000,\r\n        &quot;doc_count&quot;: 5628,\r\n        &quot;agg1&quot;: {\r\n          &quot;doc_count_error_upper_bound&quot;: 5,\r\n          &quot;sum_other_doc_count&quot;: 1193,\r\n          &quot;buckets&quot;: [\r\n            {\r\n              &quot;key&quot;: &quot;value3&quot;,\r\n              &quot;doc_count&quot;: 3469,\r\n              &quot;agg2&quot;: {\r\n                &quot;doc_count_error_upper_bound&quot;: 1,\r\n                &quot;sum_other_doc_count&quot;: 3459,\r\n                &quot;buckets&quot;: [\r\n                  {\r\n                    &quot;key&quot;: &quot;10367.xxx&quot;,\r\n                    &quot;doc_count&quot;: 1\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;10997.xxx&quot;,\r\n                    &quot;doc_count&quot;: 1\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;12055.xxx&quot;,\r\n                    &quot;doc_count&quot;: 1\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;12157.xxx&quot;,\r\n                    &quot;doc_count&quot;: 1\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;12435.xxx&quot;,\r\n                    &quot;doc_count&quot;: 1\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;12volt.xxx&quot;,\r\n                    &quot;doc_count&quot;: 1\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;13158.xxx&quot;,\r\n                    &quot;doc_count&quot;: 1\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;13507.xxx&quot;,\r\n                    &quot;doc_count&quot;: 1\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;13597.xxx&quot;,\r\n                    &quot;doc_count&quot;: 1\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;137.xxx&quot;,\r\n                    &quot;doc_count&quot;: 1\r\n                  }\r\n                ]\r\n              }\r\n            },\r\n            {\r\n              &quot;key&quot;: &quot;value2&quot;,\r\n              &quot;doc_count&quot;: 608,\r\n              &quot;agg2&quot;: {\r\n                &quot;doc_count_error_upper_bound&quot;: 0,\r\n                &quot;sum_other_doc_count&quot;: 577,\r\n                &quot;buckets&quot;: [\r\n                  {\r\n                    &quot;key&quot;: &quot;saasf.xxx&quot;,\r\n                    &quot;doc_count&quot;: 7\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;asfasf.xxx&quot;,\r\n                    &quot;doc_count&quot;: 5\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;sasfsd.xxx&quot;,\r\n                    &quot;doc_count&quot;: 3\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;werwer.xxx&quot;,\r\n                    &quot;doc_count&quot;: 3\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;werwre.xxx&quot;,\r\n                    &quot;doc_count&quot;: 3\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;a-werwr.xxx&quot;,\r\n                    &quot;doc_count&quot;: 2\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;aef.xxx&quot;,\r\n                    &quot;doc_count&quot;: 2\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;sadhdhh.xxx&quot;,\r\n                    &quot;doc_count&quot;: 2\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;dhsdfsdg.xxx&quot;,\r\n                    &quot;doc_count&quot;: 2\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;ertetrt.xxx&quot;,\r\n                    &quot;doc_count&quot;: 2\r\n                  }\r\n                ]\r\n              }\r\n            },\r\n            {\r\n              &quot;key&quot;: &quot;value1&quot;,\r\n              &quot;doc_count&quot;: 358,\r\n              &quot;agg2&quot;: {\r\n                &quot;doc_count_error_upper_bound&quot;: 0,\r\n                &quot;sum_other_doc_count&quot;: 336,\r\n                &quot;buckets&quot;: [\r\n                  {\r\n                    &quot;key&quot;: &quot;fhshfg.xxx&quot;,\r\n                    &quot;doc_count&quot;: 3\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;sgh.xxx&quot;,\r\n                    &quot;doc_count&quot;: 3\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;12.xxx&quot;,\r\n                    &quot;doc_count&quot;: 2\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;sbgs.xxx&quot;,\r\n                    &quot;doc_count&quot;: 2\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;dp-eca.xxx&quot;,\r\n                    &quot;doc_count&quot;: 2\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;ztuhfb.xxx&quot;,\r\n                    &quot;doc_count&quot;: 2\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;javascript.xxx&quot;,\r\n                    &quot;doc_count&quot;: 2\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;koi-fdhfh.xxx&quot;,\r\n                    &quot;doc_count&quot;: 2\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;sdfh.xxx&quot;,\r\n                    &quot;doc_count&quot;: 2\r\n                  },\r\n                  {\r\n                    &quot;key&quot;: &quot;etz5.xxx&quot;,\r\n                    &quot;doc_count&quot;: 2\r\n                  }\r\n                ]\r\n              }\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n\r\n\r\nThis is just a little snipped, in reality i have these result for every single day (-&gt; timestamp is located in &#39;key_as_string&#39;). However, i need a csv which give me the following result:\r\n\r\n\r\n    2017-09-01T00:00:00.000+02:00,value3,10367.xxx,1\r\n    2017-09-01T00:00:00.000+02:00,value3,10997.xxx,1\r\n    ...\r\n    2017-09-01T00:00:00.000+02:00,value2,saasf.xxx,7\r\n    2017-09-01T00:00:00.000+02:00,value2,asfasf.xxx,5\r\n    ...\r\n    2017-09-01T00:00:00.000+02:00,value1,fhshfg.xxx,3\r\n    2017-09-01T00:00:00.000+02:00,value1,sgh.xxx,3\r\n    ..\r\n\r\n",
        "link": "https://stackoverflow.com/questions/46727645/jq-create-csv-out-of-aggregated-json",
        "title": "JQ: Create CSV out of aggregated json"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1507925951,
                "last_edit_date": 1507925951,
                "creation_date": 1507899072,
                "answer_id": 46730389,
                "question_id": 46729401,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a succinct and straightforward solution, based on the fact that in jq, if X and Y are two JSON objects, the expression `X + Y` gives precedence to keys in Y.\r\n\r\nFirst, suppose the following is in combine.jq:\r\n\r\n    def lookup($t):\r\n      $A[] | select(.type==$t) // {tag:&quot;NEW&quot;};\r\n\r\n    map( lookup(.type) + . )\r\n\r\nThe following invocation will then yield the desired result:\r\n\r\n    jq --argfile A A.json  -f combine.jq  B.json\r\n\r\n### One-liner\r\n\r\nIf you want a &quot;one-liner&quot;:\r\n\r\n    jq --argfile A A.json &#39;map((.type as $t|$A[]|select(.type==$t)//{tag:&quot;NEW&quot;}) + .)&#39; B.json",
                "title": "Updating nested values from 2 files using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1507899217,
                "creation_date": 1507899217,
                "answer_id": 46730431,
                "question_id": 46729401,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Another **jq** solution (grouping by `.type` key):\r\n\r\n    jq --slurpfile f2 fileB &#39;[$f2[0] + . | group_by(.type)[] \r\n         | if .[1] then .[1] + .[0] else .[0] end]&#39; fileA\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;type&quot;: &quot;admin-properties&quot;,\r\n        &quot;tag&quot;: 1507894175,\r\n        &quot;properties&quot;: {\r\n          &quot;fieldA&quot;: &quot;valueA&quot;,\r\n          &quot;fieldB&quot;: &quot;valueB&quot;,\r\n          &quot;fieldC&quot;: &quot;valueC&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;hive-site&quot;,\r\n        &quot;tag&quot;: 1507894175,\r\n        &quot;properties&quot;: {\r\n          &quot;javax.jdo.option.ConnectionPassword&quot;: &quot;hortonworks2&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;other-type&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;newFieldA&quot;: &quot;valueA&quot;,\r\n          &quot;newFieldB&quot;: &quot;valueB&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\n",
                "title": "Updating nested values from 2 files using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1508305716,
                "last_edit_date": 1508305716,
                "creation_date": 1507922355,
                "answer_id": 46736698,
                "question_id": 46729401,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using [reduce](https://stedolan.github.io/jq/manual/#Reduce) to create a temporary lookup table from File A along with a [map](https://stedolan.github.io/jq/manual/#map\\(x\\),map_values\\(x\\)) to produce the requested output including the &quot;NEW&quot; tag on items in File B not present in File A.\r\n\r\n&lt;!-- language: lang-none --&gt;\r\n\r\n      (reduce $A[] as $a({};.[$a.type]=$a)) as $t\r\n    | map(if $t[.type]==null then {tag:&quot;NEW&quot;}+. else $t[.type]*. end)\r\n\r\n[Try it online!](https://tio.run/##rVLBTgIxEL3zFZOGAyjdiJGgazgA0aPx5mHDoWEH6bq0a9tlNbC/7joLC26CEGI8tOm815m@mdfovQgaACtaAMx9Jsh8YHO5RG6lQ9apCPFKeLd31b@9u@n2exWcGJ2gcRItA78qQnAkluLDi0Lt6cRJrbyxVgqn5fFZWJtpE5b32VwbpxWFb7bLNsk57XnnUJAIF1Lx2nNn66rJmkmMw2FZbiniFIdVkR0z2jOjmpjGBISF5rCxhnMG9X8Tuf7bRH5p/Vjjh23X8fEeH59Wot0cDd9EJ8evMHs86sCOPGbCugBoGQzTKZIZwdYU0Vrl917QFF75@mTQFO32hnDk1kIkLTmjc1CxA5XGMZBYBSv6Nz57enhh@aUHGFv8uXdBgArbRfG1tcoWnJeZXKokdRQYkXGdOgq@AQ &quot;jq – Try It Online&quot;)\r\n\r\nThis can be made more concise by eliminating the `if` in the map and using the [// Alternative operator](https://stedolan.github.io/jq/manual/#Alternativeoperator://) instead.  e.g. \r\n\r\n&lt;!-- language: lang-none --&gt;\r\n\r\n      (reduce $A[] as $a({};.[$a.type]=$a)) as $t | map( ($t[.type]//{tag:&quot;NEW&quot;})*. )\r\n\r\n[Try it online!](https://tio.run/##rVI9T8MwEN3zK05WhgTVKUFUhSKGtoIRsTFEHazGEIfUDrbTgJL8dYLz0SpSaVUhBlu@9@y7d/ccf9SBBVCYBYD0V0rRDFDEthQrpika9QR5M7g/uZze3F7700kPp1KkVGpGFYJZn8TAMdmSTy8OhSdSzQT3loJzum6Oz0SpXMiwuY8iIbXgJnxXPmofV2avRoeCSLhhHA/Kna1rIOuV0SScN@m2JMnovE@yYxZ7ZjEQY62AKLDnVgnnDOr/JnL1t4n80vqxxg/bHuLLPb48rUToiErcRifHz2n@eNSBHXnMhLJ2JA2zNTVWBJ0lxCmqOy@widfUXt3bxHVbQkMJG5I64Ng66MjxuDBfZYaeHl5Q5V544Nb1d2eFqjHmWZJgxtNMm0CSHItMm@AH &quot;jq – Try It Online&quot;)\r\n\r\nSample Run (assumes filter in `filter.jq` and data in `FileA.json` and `FileB.json`):\r\n\r\n&lt;!-- language: lang-none --&gt;\r\n\r\n    $ jq -M -f filter.jq --argfile A FileA.json FileB.json\r\n    [\r\n      {\r\n        &quot;type&quot;: &quot;hive-site&quot;,\r\n        &quot;tag&quot;: 1507894175,\r\n        &quot;properties&quot;: {\r\n          &quot;javax.jdo.option.ConnectionPassword&quot;: &quot;hortonworks2&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;admin-properties&quot;,\r\n        &quot;tag&quot;: 1507894175,\r\n        &quot;properties&quot;: {\r\n          &quot;fieldA&quot;: &quot;valueA&quot;,\r\n          &quot;fieldB&quot;: &quot;valueB&quot;,\r\n          &quot;fieldC&quot;: &quot;valueC&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;tag&quot;: &quot;NEW&quot;,\r\n        &quot;type&quot;: &quot;other-type&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;newFieldA&quot;: &quot;valueA&quot;,\r\n          &quot;newFieldB&quot;: &quot;valueB&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\nThe following filter will also include any keys in File A not in File B (as requested in comments).\r\n\r\n&lt;!-- language: lang-none --&gt;\r\n\r\n      (reduce $A[] as $a({};.[$a.type]=$a)) as $t  # build lookup table\r\n    | map( ($t[.type]//{tag:&quot;NEW&quot;})*. )            # apply A to B\r\n    | (($t|keys_unsorted)-map(.type)) as $o        # find keys in A not in B\r\n    | [$t[$o[]]] + .                               # add back those objects\r\n\r\n[Try it online!](https://tio.run/##rZBBT8IwFMfvfIqXucOmbIjRqBgPYLwabx6WxZS1SGH01bUFCfDVnV03ZcbEEGOTLX39t7/3y5u9lkkHYGM/AE@vJfMG4Bmh0WRTRqMMxYS/eN0mJy827l@cXl5dn/cvL5pjWaBkheZMeTBoWPZY4YJNOMtpdeqqJckN81y@s/9d92frKV@ySHHN/tZzRpbkLZ5RjFFqjiK@QyFYVm0fiVIrLGqbKRYahS3nqt90@qsxoQsuopbPweItb9d1WOFcx@HeySWjr2TUkumkQBT4w84WkgMm@X8jO/smsS1rUlAwajJmhZJajASb3U2c@CSunNJbn4ShCzTAEYwNzynkiHMjQZNxzhx0CwsiAwh8ndTPer2NHeXAe7h/8nbhcQwhtNYRECnzNQxBI4waQmBfb@dsrZ6NUFab0TCqqA7YOOCeMOGCQnUduLAggbrafMISa@JjkqYpnEAMvy@rQymMSTYHPUXFHLYs3@vRqjKKhMnziAtptC0KsorQaFt8AA &quot;jq – Try It Online&quot;)",
                "title": "Updating nested values from 2 files using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1508660020,
        "creation_date": 1507895806,
        "last_edit_date": 1508660020,
        "question_id": 46729401,
        "body_markdown": "I&#39;ve used jq for a few parsing tasks, just got started with it a couple of days ago and am enjoying its versatility, but the one task I&#39;ve outlined below is a bit more complicated and I&#39;m stuck wresting with jq over this one.\r\n\r\nI have 2 files, both with similar schema for data.  Files A and B, and what I&#39;m hoping to get as output, looks like the following:\r\n\r\nFile A:\r\n\r\n    [\r\n      {\r\n        &quot;type&quot;: &quot;hive-site&quot;,\r\n        &quot;tag&quot;: 1507894175,\r\n        &quot;properties&quot; : {\r\n          &quot;javax.jdo.option.ConnectionPassword&quot; : &quot;hortonworks1&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;admin-properties&quot;,\r\n        &quot;tag&quot;: 1507894175,\r\n        &quot;properties&quot;: {\r\n          &quot;fieldA&quot;: &quot;valueA&quot;,\r\n    \t  &quot;fieldB&quot;: &quot;valueB&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\n\r\nFile B:\r\n\r\n    [\r\n      {\r\n        &quot;type&quot;: &quot;hive-site&quot;,\r\n        &quot;properties&quot; : {\r\n          &quot;javax.jdo.option.ConnectionPassword&quot; : &quot;hortonworks2&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;admin-properties&quot;,\r\n        &quot;properties&quot;: {\r\n        &quot;fieldA&quot;: &quot;valueA&quot;,\r\n        &quot;fieldB&quot;: &quot;valueB&quot;,\r\n        &quot;fieldC&quot;: &quot;valueC&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;other-type&quot;,\r\n        &quot;properties&quot;: {\r\n          &quot;newFieldA&quot;: &quot;valueA&quot;,\r\n          &quot;newFieldB&quot;: &quot;valueB&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\n\r\nResult: File C (File A as base, with modifications from File B)\r\n\r\n    [\r\n      {\r\n        &quot;type&quot;: &quot;hive-site&quot;,\r\n        &quot;tag&quot;: 1507894175,\r\n        &quot;properties&quot; : {\r\n          &quot;javax.jdo.option.ConnectionPassword&quot; : &quot;hortonworks2&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;admin-properties&quot;,\r\n        &quot;tag&quot;: 1507894175,\r\n        &quot;properties&quot;: {\r\n          &quot;fieldA&quot;: &quot;valueA&quot;,\r\n          &quot;fieldB&quot;: &quot;valueB&quot;,\r\n          &quot;fieldC&quot;: &quot;valueC&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;other-type&quot;,\r\n        &quot;tag&quot;: NEW,\r\n        &quot;properties&quot;: {\r\n          &quot;newFieldA&quot;: &quot;valueA&quot;,\r\n          &quot;newFieldB&quot;: &quot;valueB&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\n\r\nI&#39;d like to take all of the pairs under &quot;properties&quot; from File B and push those to File A, updating existing property pairs if they exist, or adding them as their own block (with a &quot;NEW&quot; tag as shown) if they do not.\r\n\r\nI&#39;ve found similar answers ([here][1] and [here][2]), but none are close enough to be able to modify for my purposes.\r\n\r\nThank you!!\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/29772676/update-one-value-in-array-of-dicts-using-jq\r\n  [2]: https://stackoverflow.com/questions/19529688/how-to-merge-2-json-file-using-jq",
        "link": "https://stackoverflow.com/questions/46729401/updating-nested-values-from-2-files-using-jq",
        "title": "Updating nested values from 2 files using jq"
    },
    {
        "tags": [
            "json",
            "sorting",
            "jq",
            "jmespath"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1507926656,
                "last_edit_date": 1507926656,
                "creation_date": 1507899559,
                "answer_id": 46730534,
                "question_id": 46730446,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It&#39;s a good job for **jq** processor:\r\n\r\n    jq &#39;.Statement[0].Principal.AWS |= sort&#39; file\r\n\r\n- `.Statement[0].Principal.AWS` - selected item\r\n\r\n- `|=` - *update* statement/action (to update the selected item)\r\n\r\n\r\n----------\r\n\r\n\r\nThe output:\r\n\r\n    {\r\n      &quot;Version&quot;: &quot;2012-10-17&quot;,\r\n      &quot;Statement&quot;: [\r\n        {\r\n          &quot;Sid&quot;: &quot;BLAHBLAHBLAH&quot;,\r\n          &quot;Effect&quot;: &quot;Allow&quot;,\r\n          &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: [\r\n              &quot;arn:aws:iam::293576423935:root&quot;,\r\n              &quot;arn:aws:iam::339659563489:root&quot;,\r\n              &quot;arn:aws:iam::346654243625:root&quot;,\r\n              &quot;arn:aws:iam::349855857558:root&quot;,\r\n              &quot;arn:aws:iam::398259495958:root&quot;,\r\n              &quot;arn:aws:iam::577836285792:root&quot;,\r\n              &quot;arn:aws:iam::636877599363:root&quot;,\r\n              &quot;arn:aws:iam::652379234777:root&quot;,\r\n              &quot;arn:aws:iam::682354689262:root&quot;,\r\n              &quot;arn:aws:iam::735277384553:root&quot;,\r\n              &quot;arn:aws:iam::836666644595:root&quot;,\r\n              &quot;arn:aws:iam::984895836564:root&quot;\r\n            ]\r\n          },\r\n          &quot;Action&quot;: &quot;s3:*&quot;,\r\n          &quot;Resource&quot;: [\r\n            &quot;arn:aws:s3:::blah-blah-blah&quot;,\r\n            &quot;arn:aws:s3:::blah-blah-blah/*&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n----------\r\nTo sort multiple arrays use:\r\n\r\n    jq &#39;.Statement[].Principal.AWS |= sort&#39; file\r\n\r\n",
                "title": "Output entire JSON document with sorted content"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1507926656,
        "creation_date": 1507899283,
        "last_edit_date": 1507903267,
        "question_id": 46730446,
        "body_markdown": "Is it possible to sort a particular array of a json document and output the entire document with the sorted content otherwise untouched?\r\n\r\nFor example, if I have something like this:\r\n\r\n    {\r\n      &quot;Version&quot;: &quot;2012-10-17&quot;,\r\n      &quot;Statement&quot;: [\r\n        {\r\n          &quot;Sid&quot;: &quot;BLAHBLAHBLAH&quot;,\r\n          &quot;Effect&quot;: &quot;Allow&quot;,\r\n          &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: [\r\n              &quot;arn:aws:iam::346654243625:root&quot;,\r\n              &quot;arn:aws:iam::984895836564:root&quot;,\r\n              &quot;arn:aws:iam::636877599363:root&quot;,\r\n              &quot;arn:aws:iam::577836285792:root&quot;,\r\n              &quot;arn:aws:iam::836666644595:root&quot;,\r\n              &quot;arn:aws:iam::652379234777:root&quot;,\r\n              &quot;arn:aws:iam::339659563489:root&quot;,\r\n              &quot;arn:aws:iam::293576423935:root&quot;,\r\n              &quot;arn:aws:iam::682354689262:root&quot;,\r\n              &quot;arn:aws:iam::349855857558:root&quot;,\r\n              &quot;arn:aws:iam::398259495958:root&quot;,\r\n              &quot;arn:aws:iam::735277384553:root&quot;\r\n            ]\r\n          },\r\n          &quot;Action&quot;: &quot;s3:*&quot;,\r\n          &quot;Resource&quot;: [\r\n            &quot;arn:aws:s3:::blah-blah-blah&quot;,\r\n            &quot;arn:aws:s3:::blah-blah-blah/*&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nI&#39;d like to get back this:\r\n\r\n    {\r\n      &quot;Version&quot;: &quot;2012-10-17&quot;,\r\n      &quot;Statement&quot;: [\r\n        {\r\n          &quot;Sid&quot;: &quot;BLAHBLAHBLAH&quot;,\r\n          &quot;Effect&quot;: &quot;Allow&quot;,\r\n          &quot;Principal&quot;: {\r\n            &quot;AWS&quot;: [\r\n              &quot;arn:aws:iam::293576423935:root&quot;,\r\n              &quot;arn:aws:iam::339659563489:root&quot;,\r\n              &quot;arn:aws:iam::346654243625:root&quot;,\r\n              &quot;arn:aws:iam::349855857558:root&quot;,\r\n              &quot;arn:aws:iam::398259495958:root&quot;,\r\n              &quot;arn:aws:iam::577836285792:root&quot;,\r\n              &quot;arn:aws:iam::636877599363:root&quot;,\r\n              &quot;arn:aws:iam::652379234777:root&quot;,\r\n              &quot;arn:aws:iam::682354689262:root&quot;,\r\n              &quot;arn:aws:iam::735277384553:root&quot;,\r\n              &quot;arn:aws:iam::836666644595:root&quot;,\r\n              &quot;arn:aws:iam::984895836564:root&quot;\r\n            ]\r\n          },\r\n          &quot;Action&quot;: &quot;s3:*&quot;,\r\n          &quot;Resource&quot;: [\r\n            &quot;arn:aws:s3:::blah-blah-blah&quot;,\r\n            &quot;arn:aws:s3:::blah-blah-blah/*&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nI have seen sorting examples using `jq` and `JMESPath` but only ever seen them output the section being sorted and not the entire document with the sorted section. Looking for guidance in the matter and would be happy with any working solution. \r\n\r\nThis is what I have used to sort the array `| jq &#39;.Statement[].Principal.AWS|sort&#39;` which works, but I&#39;d like to get back into the context of the entire document formatted as it was.",
        "link": "https://stackoverflow.com/questions/46730446/output-entire-json-document-with-sorted-content",
        "title": "Output entire JSON document with sorted content"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq",
            "data-extraction"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1281728,
                    "reputation": 75703,
                    "user_id": 1235698,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/90fd9ad4efef8eb93209f42183c48f3e?s=256&d=identicon&r=PG",
                    "display_name": "Marcin Orlowski",
                    "link": "https://stackoverflow.com/users/1235698/marcin-orlowski"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1507900422,
                "post_id": 46730755,
                "comment_id": 80407626,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1507900590,
                "creation_date": 1507900590,
                "answer_id": 46730887,
                "question_id": 46730755,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq &#39;.data[] | .smallphoto&#39; input.json\r\n\r\nyields:\r\n\r\n    &quot;https://images-eu.ssl-images-amazon.com/images/I/51b5iaLTjgL._SL160_.jpg&quot;\r\n    &quot;https://images-eu.ssl-images-amazon.com/images/I/51CVLqsSNkL._SL160_.jpg&quot;\r\n    &quot;https://images-eu.ssl-images-amazon.com/images/I/41OHDP2rAeL._SL160_.jpg&quot;\r\n\r\nThe key point here is that `.[]` (`.data[]` being an abbreviated form of `.data|.[]`) can be used with JSON objects, not just arrays.",
                "title": "Bash script to filter JSON text"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1507920912,
                "creation_date": 1507920912,
                "answer_id": 46736390,
                "question_id": 46730755,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another filter which will find `.smallphoto` no matter how deeply nested:\r\n\r\n    .. | .smallphoto?//empty\r\n\r\n[Try it online!](https://tio.run/##tZBBS8MwGIbv@xWh5zVNtZ3rLiJ6UCizMPE6Yhvb1DTJkhRRt79uTbZpB@oOUg@BPN8b3nw89ap7GwHgEaWE8mYAjR0V2GALLrGEvq4WhCqIooUdeRFC6GyCkDf@DKWiOXFRApOkHzOqDeUlx802pFklOAHT/oFuMGOyEka4vDJG6lkQ0AaXRPukhVozf0@4wa@Cw1w0@zy4CeLwIaY4vavLFC4XaThBS1jL8mCvQapd5bZxsyv2wmNi4mT6VzEgY60e0M7lfbrSi/nTP9jpq7/ZiY7biX@0c/q7nTkuCHtkWOcV4YPZicLb66vsRF2Qwe0cVvd2Ru5s1h2EYA375c9BEJBGmpeuexfSUMF15/u8ZfYLLltjQeFnX7TGwgc &quot;jq – Try It Online&quot;)\r\n\r\nSample Run (assumes corrected sample data in `data.json`)\r\n\r\n    $ jq -M &#39;.. | .smallphoto?//empty&#39; data.json\r\n    &quot;https://images-eu.ssl-images-amazon.com/images/I/51b5iaLTjgL._SL160_.jpg&quot;\r\n    &quot;https://images-eu.ssl-images-amazon.com/images/I/51CVLqsSNkL._SL160_.jpg&quot;\r\n    &quot;https://images-eu.ssl-images-amazon.com/images/I/41OHDP2rAeL._SL160_.jpg&quot;\r\n",
                "title": "Bash script to filter JSON text"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1508231437,
        "creation_date": 1507900172,
        "last_edit_date": 1508231437,
        "question_id": 46730755,
        "body_markdown": "I have the following JSON File:\r\n\r\n    {\r\n      &quot;error&quot;: 0,\r\n      &quot;data&quot;: {\r\n        &quot;0&quot;: {\r\n          &quot;orderid&quot;: &quot;40007600&quot;,\r\n          &quot;price&quot;: &quot;9.99&quot;,\r\n          &quot;listingname&quot;: &quot;iPhone 8&quot;,\r\n          &quot;smallphoto&quot;: &quot;https://images-eu.ssl-images-amazon.com/images/I/51b5iaLTjgL._SL160_.jpg&quot;,\r\n          &quot;photo&quot;: &quot;https://images-eu.ssl-images-amazon.com/images/I/51b5iaLTjgL.jpg&quot;\r\n        },\r\n        &quot;1&quot;: {\r\n          &quot;orderid&quot;: &quot;40007598&quot;,\r\n          &quot;price&quot;: &quot;9.99&quot;,\r\n          &quot;listingname&quot;: &quot;iPhone 8 Plus&quot;,\r\n          &quot;smallphoto&quot;: &quot;https://images-eu.ssl-images-amazon.com/images/I/51CVLqsSNkL._SL160_.jpg&quot;,\r\n          &quot;photo&quot;: &quot;https://images-eu.ssl-images-amazon.com/images/I/51CVLqsSNkL.jpg&quot;\r\n        },\r\n        &quot;4&quot;: {\r\n          &quot;orderid&quot;: &quot;40007595&quot;,\r\n          &quot;price&quot;: &quot;9.39&quot;,\r\n          &quot;listingname&quot;: &quot;Nadelflaschen&quot;,\r\n          &quot;smallphoto&quot;: &quot;https://images-eu.ssl-images-amazon.com/images/I/41OHDP2rAeL._SL160_.jpg&quot;,\r\n          &quot;photo&quot;: &quot;https://images-eu.ssl-images-amazon.com/images/I/41OHDP2rAeL.jpg&quot;\r\n        },\r\n      }\r\n    }\r\n\r\nHow can I filter everything with a bash script, so I get all image URLs of &quot;smallphoto&quot; into a text file?\r\n\r\nf.e. https://images-eu.ssl-images-amazon.com/images/I/41OHDP2rAeL._SL160_.jpg from &quot;Nadelflaschen&quot;\r\n\r\nI tried awk and jq commands. But I am just to dump to understand the jq syntax. \r\n\r\nawk is possible, but I only get unfiltered links with backslashes, which do not work.",
        "link": "https://stackoverflow.com/questions/46730755/bash-script-to-filter-json-text",
        "title": "Bash script to filter JSON text"
    },
    {
        "tags": [
            "arrays",
            "bash",
            "shell",
            "stream",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1508034899,
                "last_edit_date": 1508034899,
                "creation_date": 1508034479,
                "answer_id": 46751125,
                "question_id": 46751099,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Instead of\r\n\r\n    jq &#39;.[].Checks[1].ServiceTags[]&#39; \r\n\r\nTry\r\n\r\n    jq &#39;[.[].Checks[1].ServiceTags[]]&#39; \r\n\r\nThe extra `[]` instruct jq to collect the values into an array.   \r\nSee [Array construction: \\[\\]](https://stedolan.github.io/jq/manual/#Arrayconstruction:[]) in the jq Manual.",
                "title": "Retrieving jq results as one list object, vs a stream of members"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1508153794,
        "creation_date": 1508034005,
        "last_edit_date": 1508153794,
        "question_id": 46751099,
        "body_markdown": "Hi i am trying in shell script to get a list of consul service tags for myApp passing nodes, using jq.\r\n\r\nwhen i have something like this..\r\n     \r\n    curl &#39;http://127.0.0.1:8500/v1/health/service/myApp?dc=a&amp;passing=true&#39; \\\r\n      | jq &#39;.[].Checks[1].ServiceTags[]&#39; \r\n\r\noutput is..\r\n\r\n    &quot;a&quot;\r\n    &quot;b&quot;\r\n    &quot;c&quot;\r\n    &quot;d&quot;\r\n\r\nI want to know if i could get it as a list. I want the output in this way..\r\n\r\n     [&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;]\r\n\r\ncan you please suggest options..",
        "link": "https://stackoverflow.com/questions/46751099/retrieving-jq-results-as-one-list-object-vs-a-stream-of-members",
        "title": "Retrieving jq results as one list object, vs a stream of members"
    },
    {
        "tags": [
            "select",
            "jq",
            "consul"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1508083091,
                "last_edit_date": 1508083091,
                "creation_date": 1508043263,
                "answer_id": 46751842,
                "question_id": 46751641,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Unfortunately the given data, the given problem description, and the given answer do not quite agree with each other, perhaps because of a typo.  \r\n\r\nHowever, the problem description corresponds to a query of the form:\r\n\r\n   .[].Checks[] | select(.Node == $NODE) | .ServiceTags[]\r\n\r\nFor example, with your data, and letting $NODE have the value &quot;my-ap-1-2-3-4&quot;, the jq query:\r\n\r\n    .[].Checks[] | select(.Node == &quot;my-ap-1-2-3-4&quot;) | .ServiceTags[]\r\n\r\n yields:\r\n\r\n    &quot;my-app-tag&quot;",
                "title": "Retrieve service tags for a given node from consul API with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1508111317,
        "creation_date": 1508041159,
        "last_edit_date": 1508111317,
        "question_id": 46751641,
        "body_markdown": "I am trying to retrieve ServiceTag(s) for a given Node from consul API. I need through jq filtering.\r\n\r\nHere is jq play query for Node &amp; Service tag, but i want ServiceTag for a given Node..\r\n\r\nWith service tag - https://jqplay.org/s/iaSIPnkxFm\r\n\r\nWith node - https://jqplay.org/s/ea-LyKhhpy\r\n\r\nCan anyone please help me with jq query to combine both to give the service tag &quot;my-app-tag&quot; for the node &quot;my-app-1-2-3-4&quot; in the above the example.\r\n",
        "link": "https://stackoverflow.com/questions/46751641/retrieve-service-tags-for-a-given-node-from-consul-api-with-jq",
        "title": "Retrieve service tags for a given node from consul API with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1508177218,
                "last_edit_date": 1508177218,
                "creation_date": 1508097258,
                "answer_id": 46759364,
                "question_id": 46759294,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following could easily be modified to truncate the array if it is initially too long, if that is required:\r\n\r\n    def expand(n; value): . + [range(length;n) | value];\r\n      \r\n    map(.VALUE |= expand(10;0))\r\n\r\n## One-liner\r\n\r\n    jq &#39;map(.VALUE|=.+[range(length;10)|0])&#39; data.json | sponge data.json",
                "title": "Populate array up to a certain number of values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1508177218,
        "creation_date": 1508096786,
        "last_edit_date": 1508097324,
        "question_id": 46759294,
        "body_markdown": "I wonder if this is possible.\r\nThere is an object like this:\r\n\r\n&gt; data.json:\r\n\r\n    [\r\n     {&quot;DATE&quot;:&quot;September&quot;,&quot;VALUE&quot;:[5,17,8,9]}\r\n    ]\r\n\r\nAs you can see, the array &quot;VALUE&quot; consists of 4 numbers at the moment. (This may vary). However, I would like it to contain always - let&#39;s say 10 - numbers.\r\n\r\nTherefore the array should be populated with zeroes. \r\n\r\nThe result should look like this:\r\n\r\n&gt; data.json:\r\n\r\n    [\r\n     {&quot;DATE&quot;:&quot;September&quot;,&quot;VALUE&quot;:[5,17,8,9,0,0,0,0,0,0]}\r\n    ]\r\n\r\nOf course, the initial array could already contain the expected count of ten values. Then, nothing should be changed.",
        "link": "https://stackoverflow.com/questions/46759294/populate-array-up-to-a-certain-number-of-values",
        "title": "Populate array up to a certain number of values"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "containment",
            "elaboration"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1508252129,
                "last_edit_date": 1508252129,
                "creation_date": 1508241828,
                "answer_id": 46789697,
                "question_id": 46788536,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following definition of `extends/1` uses a purely object-based definition of extension (in particular, it does not sort arrays).  The OP requirements regarding arrays are unclear to me, but a variant definition is offered in the following section.\r\n\r\n    # Usage: $in | extends($b) iff $in contains $b in an object-based sense\r\n    def extends($b):\r\n      # Handle the case that both are objects:\r\n      def objextends($x):\r\n        . as $in | all($x|keys[]; . as $k | $in[$k] | extends($x[$k]));\r\n      # Handle the case that both are arrays:\r\n      def arrayextends($x):\r\n        . as $in\r\n        | length == ($x|length) and\r\n            all( range(0;length); . as $i | $in[$i] | extends($x[$i]));\r\n\r\n      if . == $b then true\r\n      else . as $in\r\n      | type as $intype\r\n      | ($intype == ($b|type)) and\r\n          (($intype == &quot;object&quot; and objextends($b)) or\r\n           ($intype == &quot;array&quot; and arrayextends($b)))\r\n  end;\r\n\r\nExamples:\r\n\r\n    {a:{a:1,b:2}, b:2} | extends({a:{a:1}}) # true\r\n\r\n    {a:{a:1,b:2}, b:2} | extends({a:{a:2}}) # false\r\n\r\n    {a:{a:1,b:2}, b:[{x:1,y:2}]} | extends({a:{a:2}, b:[{x:1}]}) # true\r\n\r\n### Alternative definition\r\n\r\nThe following definition sorts arrays and is sufficiently generous to handle the given example:\r\n\r\n    # Usage: $in | extends2($b) iff $in contains $b in a way which ignores the order of array elements\r\n    def extends2($b):\r\n      # Both are objects\r\n      def objextends($x):\r\n        . as $in | all($x|keys[]; . as $k | $in[$k] | extends($x[$k]));\r\n    \r\n      def arrayextends($x): ($x|sort) - sort == [];\r\n     \r\n      if . == $b then true\r\n      else . as $in\r\n      | type as $intype\r\n      | ($intype == ($b|type)) and\r\n          (($intype == &quot;object&quot; and objextends($b)) or\r\n           ($intype == &quot;array&quot;  and arrayextends($b)))\r\n      end;\r\n\r\nWith $P1 and $P2 as shown:\r\n\r\n      $P1 | extends2($P2) # yields true\r\n",
                "title": "Compare two json files using jq or any other tools in bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1508266243,
                "creation_date": 1508266243,
                "answer_id": 46797231,
                "question_id": 46788536,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you know there are no duplicates in any subarrays then you could use this approach which computes the difference between sets of `[path,value]` pairs returned from [tostream](https://stedolan.github.io/jq/manual/#tostream) replacing array indices with `null`:\r\n \r\n    def details:[\r\n         tostream\r\n       | select(length==2) as [$p,$v]\r\n       | [$p|map(if type==&quot;number&quot; then null else . end),$v]\r\n    ];\r\n \r\n    def extends(a;b): (b|details) - (a|details) == [];\r\n\r\nIf `P1` and `P2` are functions returning the sample data \r\n\r\n    def P1: {\r\n        &quot;id&quot;: 12,\r\n        &quot;keys&quot;: [&quot;key1&quot;,&quot;key2&quot;],\r\n        &quot;body&quot;: {\r\n          &quot;height&quot;: &quot;180cm&quot;,\r\n          &quot;wight&quot;: &quot;70kg&quot;\r\n        },\r\n        &quot;name&quot;: &quot;Alex&quot;\r\n      }\r\n    ;\r\n\r\n    def P2: {\r\n        &quot;id&quot;: 12,\r\n        &quot;keys&quot;: [&quot;key2&quot;,&quot;key1&quot;],\r\n        &quot;body&quot;: {\r\n          &quot;height&quot;: &quot;180cm&quot;\r\n        }\r\n      }\r\n    ;\r\n\r\nthen \r\n\r\n      extends(P1;P2)  # returns true\r\n    , extends(P2;P1)  # returns false\r\n\r\nIn the presence of duplicates the result is less clear. e.g.\r\n\r\n      extends([&quot;a&quot;,&quot;b&quot;,&quot;b&quot;];[&quot;a&quot;,&quot;a&quot;,&quot;b&quot;])  # returns true\r\n\r\n\r\n\r\n[**Try it online!**](https://tio.run/##lVFNb4MwDL3zK6ysB5BgarhsAnHYP@COOITiFtYQGDFr0ehfHwvd@DjsUkuR4/eerZf4/WMcwUSOR3NIlFIHiQVzUK2pRVHNyAAaJR7IlqhOVESR74DQkOwad/eZrioDDJVo7PII1DcYRUx1VYYtAypQgeqkBJQa4RlQ5c7SnIYWWLMfvJIhtS3CzAnAzoY/gw54YIu1iiJIlsalO@YBfC0vYWXOAuC@uyJn7LXBkunCmTsln6UbQVbnPdsOMViB5akggzL@uj9UzN2Sl5l72Z9PbGFum5lKVDgp3iReZ8XtnkNrte4/YN3/tc4ftr76@88HLN8f8zA2a4YnoLbDO@mupB/G/E4ehdnnOH7XDZW10qPnTVv2StV0ZIpWXLy6I1P8AA &quot;jq – Try It Online&quot;)",
                "title": "Compare two json files using jq or any other tools in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1508266243,
        "creation_date": 1508237985,
        "last_edit_date": 1508248342,
        "question_id": 46788536,
        "body_markdown": "I want to compare two json files to see if one can be extracted from the other one.&lt;br&gt;\r\n&lt;br&gt;**P1 (p1.json)**\r\n\r\n    {\r\n      &quot;id&quot;: 12,\r\n      &quot;keys&quot;: [&quot;key1&quot;,&quot;key2&quot;],\r\n      &quot;body&quot;: {\r\n        &quot;height&quot;: &quot;180cm&quot;,\r\n        &quot;wight&quot;: &quot;70kg&quot;\r\n      },\r\n      &quot;name&quot;: &quot;Alex&quot;\r\n    }\r\n**P2 (p2.json)**\r\n\r\n    {\r\n      &quot;id&quot;: 12,\r\n      &quot;keys&quot;: [&quot;key2&quot;,&quot;key1&quot;],\r\n      &quot;body&quot;: {\r\n        &quot;height&quot;: &quot;180cm&quot;\r\n      }\r\n    }\r\n\r\nAs it can be seen **P2** is not completely equal to **P1** but it can be extracted from **P1** (It provides less data about the same person but the data is correct).\r\n&lt;br&gt;&lt;br&gt;\r\n**Expected behavior:**\r\n\r\n    p1 extends p2 --&gt; true\r\n    p2 extends p1 --&gt; false\r\n&lt;br&gt;\r\n**Notes**&lt;br&gt;\r\n- An array cannot be extracted from the same array with some additional elements&lt;br&gt;",
        "link": "https://stackoverflow.com/questions/46788536/compare-two-json-files-using-jq-or-any-other-tools-in-bash",
        "title": "Compare two json files using jq or any other tools in bash"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1508258570,
                "creation_date": 1508258570,
                "answer_id": 46795159,
                "question_id": 46794676,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a filter which uses [map_values](https://stedolan.github.io/jq/manual/#map\\(x\\),map_values\\(x\\)) to produce the specified output:\r\n\r\n    map( map_values(._metadata.timestamp) )\r\n\r\nSample Run (assuming data in `data.json`)\r\n\r\n    $ jq -M &#39;map( map_values(._metadata.timestamp) )&#39; data.json\r\n    [\r\n      {\r\n        &quot;Something&quot;: &quot;2016-02-18T12:32:50.276Z&quot;\r\n      },\r\n      {\r\n        &quot;OtherThing&quot;: &quot;2016-03-18T12:32:50.276Z&quot;\r\n      },\r\n      {\r\n        &quot;ThirdThing&quot;: &quot;2016-04-18T12:32:50.276Z&quot;\r\n      }\r\n    ]\r\n\r\n\r\n[**Try it online!**](https://tio.run/##pY29DoIwFIV3nqLpBIklUBQNL@Egk8aQJjRSQ3@EVgfl1a13QHT0Z7gnOV9O7nc8@V2A0BUOIbzRkttGqAMuRgSwAsZqZtkbBGyF5L1l0gDGNElzklCSrsqUFhktFklMl/kWj/sheOYwe@nWtuFd@bsv@9IHqq7@wzf/xBfsb14yEyKI6sxax/swnhzx9DZCkfd3bazQqveEKNe2RCjjLJSOXYh2FsoD &quot;jq – Try It Online&quot;)",
                "title": "JQ: print dictionary key names in correct order together with enclosed attributes"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1508297066,
        "creation_date": 1508256903,
        "last_edit_date": 1508297066,
        "question_id": 46794676,
        "body_markdown": "I&#39;m trying to use jq to extract the toplevel Attribute names together with the enclosed timestamps.\r\n\r\njson input:\r\n\r\n    [\r\n      {\r\n        &quot;Something&quot;: {\r\n          &quot;_metadata&quot;: {\r\n            &quot;timestamp&quot;: &quot;2016-02-18T12:32:50.276Z&quot;\r\n          }\r\n        }\r\n      },\r\n      {\r\n        &quot;OtherThing&quot;: {\r\n          &quot;_metadata&quot;: {\r\n            &quot;timestamp&quot;: &quot;2016-03-18T12:32:50.276Z&quot;\r\n          }\r\n        }\r\n      },\r\n      {\r\n        &quot;ThirdThing&quot;: {\r\n          &quot;_metadata&quot;: {\r\n            &quot;timestamp&quot;: &quot;2016-04-18T12:32:50.276Z&quot;\r\n          }\r\n        }\r\n      }\r\n    ]\r\n\r\ndesired output:\r\n\r\n    [\r\n      {\r\n        &quot;Something&quot;: &quot;2016-02-18T12:32:50.276Z&quot;\r\n      },\r\n      {\r\n        &quot;OtherThing&quot;: &quot;2016-03-18T12:32:50.276Z&quot;\r\n      },\r\n      {\r\n        &quot;ThirdThing&quot;: &quot;2016-04-18T12:32:50.276Z&quot;\r\n      }\r\n    ]\r\n\r\n\r\nTried `jq &#39;.[] | keys&#39;` which gives me only the toplevel dictionary names.\r\n\r\n    [\r\n      &quot;Something&quot;\r\n    ]\r\n    [\r\n      &quot;OtherThing&quot;\r\n    ]\r\n    [\r\n      &quot;ThirdThing&quot;\r\n    ]\r\n\r\nWhich filter would achieve this?",
        "link": "https://stackoverflow.com/questions/46794676/jq-print-dictionary-key-names-in-correct-order-together-with-enclosed-attribute",
        "title": "JQ: print dictionary key names in correct order together with enclosed attributes"
    },
    {
        "tags": [
            "json",
            "elasticsearch",
            "jq",
            "elasticsearch-bulk-api"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10565624,
                    "reputation": 1261,
                    "user_id": 7783957,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/x87uK.jpg?s=256",
                    "display_name": "Hatim Stovewala",
                    "link": "https://stackoverflow.com/users/7783957/hatim-stovewala"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508261392,
                "post_id": 46794935,
                "comment_id": 80538360,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 12003312,
                    "reputation": 87,
                    "user_id": 8782384,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9357d8264ee90103e21f4b2f260fc2fb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ESLearner",
                    "link": "https://stackoverflow.com/users/8782384/eslearner"
                },
                "reply_to_user": {
                    "account_id": 10565624,
                    "reputation": 1261,
                    "user_id": 7783957,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/x87uK.jpg?s=256",
                    "display_name": "Hatim Stovewala",
                    "link": "https://stackoverflow.com/users/7783957/hatim-stovewala"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508264002,
                "post_id": 46794935,
                "comment_id": 80539883,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10565624,
                    "reputation": 1261,
                    "user_id": 7783957,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/x87uK.jpg?s=256",
                    "display_name": "Hatim Stovewala",
                    "link": "https://stackoverflow.com/users/7783957/hatim-stovewala"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508264516,
                "post_id": 46794935,
                "comment_id": 80540158,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 12003312,
                    "reputation": 87,
                    "user_id": 8782384,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9357d8264ee90103e21f4b2f260fc2fb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ESLearner",
                    "link": "https://stackoverflow.com/users/8782384/eslearner"
                },
                "reply_to_user": {
                    "account_id": 10565624,
                    "reputation": 1261,
                    "user_id": 7783957,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/x87uK.jpg?s=256",
                    "display_name": "Hatim Stovewala",
                    "link": "https://stackoverflow.com/users/7783957/hatim-stovewala"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508268001,
                "post_id": 46794935,
                "comment_id": 80542060,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8164473,
                    "reputation": 4329,
                    "user_id": 6147374,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/fd752594fbf823094bb87549a0784bff?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ibo",
                    "link": "https://stackoverflow.com/users/6147374/ibo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508270130,
                "post_id": 46794935,
                "comment_id": 80543184,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 10565624,
                    "reputation": 1261,
                    "user_id": 7783957,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/x87uK.jpg?s=256",
                    "display_name": "Hatim Stovewala",
                    "link": "https://stackoverflow.com/users/7783957/hatim-stovewala"
                },
                "reply_to_user": {
                    "account_id": 8164473,
                    "reputation": 4329,
                    "user_id": 6147374,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/fd752594fbf823094bb87549a0784bff?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ibo",
                    "link": "https://stackoverflow.com/users/6147374/ibo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508270481,
                "post_id": 46794935,
                "comment_id": 80543377,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1508270237,
                "creation_date": 1508270237,
                "answer_id": 46798213,
                "question_id": 46794935,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here you go. This worked for me. Let me know if this helps.\r\n\r\n    cat data.json | jq -c &#39;. | {&quot;index&quot;: {&quot;_index&quot;: &quot;json&quot;, &quot;_type&quot;: &quot;json&quot;}}, .&#39;  | curl -XPOST localhost:9200/_bulk --data-binary @-\r\n\r\nLearn more about [jq : a lightweight and flexible command-line JSON processor][1].\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/",
                "title": "How to bulk change JSON format for Elastic Search"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1540219974,
                "creation_date": 1540219974,
                "answer_id": 52932198,
                "question_id": 46794935,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "We&#39;re found it is necessary to specify `Content-Type` in the curl header; the suggested solution should be of the form: \r\n\r\n```\r\ncat data.json | jq -c &#39;. | {&quot;index&quot;: {&quot;_index&quot;: &quot;json&quot;, &quot;_type&quot;: &quot;json&quot;}}, .&#39;  | \r\n curl -H &quot;Content-Type: application/json&quot; -XPOST localhost:9200/_bulk --data-binary @-\r\n```",
                "title": "How to bulk change JSON format for Elastic Search"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1540219974,
        "creation_date": 1508257718,
        "last_edit_date": 1508313465,
        "question_id": 46794935,
        "body_markdown": "I have the below format and was hoping to pre-process in bulk using elasticsearch. \r\n\r\n    {&quot;title&quot;:&quot;April&quot;,&quot;url&quot;:&quot;https://simple.wikipedia.org/wiki/April&quot;, &quot;abstract&quot;:&quot;April is the 4th month of the year, and comes between March and May. It is one of four months to have 30 days.&quot;,&quot;sections&quot;:[&quot;The Month&quot;,&quot;April in poetry&quot;,&quot;Events in April&quot;,&quot;Fixed Events&quot;,&quot;Moveable Events&quot;,&quot;Selection of Historical Events&quot;,&quot;Trivia&quot;,&quot;References&quot;]}\r\n    {&quot;title&quot;:&quot;August&quot;,&quot;url&quot;:&quot;https://simple.wikipedia.org/wiki/August&quot;, &quot;abstract&quot;:&quot;August (Aug.) is the 8th month of the year in the Gregorian calendar, coming between July and September.&quot;,&quot;sections&quot;:[&quot;The Month&quot;,&quot;August observances&quot;,&quot;Fixed observances and events&quot;,&quot;Moveable and Monthlong events&quot;,&quot;Selection of Historical Events&quot;,&quot;Trivia&quot;,&quot;References&quot;]}\r\nI am trying to add the index,type line before each of my line.\r\n\r\n    {&quot;index&quot;:{&quot;_index&quot;:&quot;myindex&quot;,&quot;_type&quot;:&quot;wiki&quot;,&quot;_id&quot;:&quot;1&quot;}}\r\n\r\n   On reading prior posts I am using [Kevin Marsh&#39;s post][1] like below:\r\n\r\n    cat file.json jq -c &#39;.[] | {&quot;index&quot;: {&quot;_index&quot;: &quot;myindex&quot;, &quot;_type&quot;: &quot;wiki&quot;, &quot;_id&quot;: .id}}, .&#39; \r\n\r\nI am not using the pipe as I am trying to figure out the error that precedes that.I get an error jq:no such file or directory. I then used `jq --version and get jq-1.5-1-a5b5cbe`. \r\n\r\nAny help is much appreciated.\r\n\r\n\r\n  [1]: http://kevinmarsh.com/2014/10/23/using-jq-to-import-json-into-elasticsearch.html",
        "link": "https://stackoverflow.com/questions/46794935/how-to-bulk-change-json-format-for-elastic-search",
        "title": "How to bulk change JSON format for Elastic Search"
    },
    {
        "tags": [
            "json",
            "sorting",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1508278514,
                "last_edit_date": 1508278514,
                "creation_date": 1508268721,
                "answer_id": 46797833,
                "question_id": 46796701,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a filter (derived from [walk/1](https://stedolan.github.io/jq/manual/#walk\\(f\\)) [[source](https://github.com/stedolan/jq/blob/master/src/builtin.jq#L284)]) which will reorder the keys of subobjects using a function:\r\n\r\n    def reorder(order):\r\n        . as $in\r\n      | if type == &quot;object&quot; then\r\n          reduce (keys_unsorted|order)[] as $key(\r\n            {}; . + { ($key):  ($in[$key] | reorder(order)) }\r\n          )\r\n        elif type == &quot;array&quot; then map( reorder(order) )\r\n        else .\r\n        end;\r\n    \r\nthe order function is expected to return the set of keys in whatever order is desired.  e.g. the following function moves &quot;shouldbeFirstKey&quot; to the first position\r\n\r\n    def neworder:\r\n        &quot;shouldbeFirstKey&quot; as $s\r\n      | index($s) as $i\r\n      | if $i==null then . else [$s] + .[:$i] + .[$i+1:] end\r\n    ;    \r\nso that\r\n    \r\n      {key1:&quot;value&quot;, shouldbeFirstKey:&quot;value2&quot;, other:{key3:&quot;value3&quot;, shouldbeFirstKey:&quot;value4&quot;}}\r\n    | reorder(neworder)\r\n    \r\nproduces the output\r\n\r\n    {\r\n      &quot;shouldbeFirstKey&quot;: &quot;value2&quot;,\r\n      &quot;key1&quot;: &quot;value&quot;,\r\n      &quot;other&quot;: {\r\n        &quot;shouldbeFirstKey&quot;: &quot;value4&quot;,\r\n        &quot;key3&quot;: &quot;value3&quot;\r\n      }\r\n    }\r\n\r\n\r\n[**Try it online!**](https://tio.run/##dVDLboMwELznK1aIAygFKU1PRFx76ScgVJF4ozilNvWjaUT49dI1poFEig@rfXhmZ@f41fdAb@ECwz0olIqhioYYZ0PfvRQqDSEXY@MCfA/m3CDkOQRye8SdCcAcUFwRQFzM7hCiDzzrdyu0VAbZxTMX5UBIo2iGAGi7De1aQguRG8YZUMJF4YqS1t7qi6GboeNrjvVcXqVUdfbq4LNqojuSG5xGSKdSsM3ixh6BpwE0GRPog7Q12@IrV9q8IS1yh@nJKMHwJwp17B2cGxjyPBe2rr201K8vQl2SAWmRhdwnIV@ustKpGcAzSSNZS@assuC7qi0GT3CvaJw800jSJpW5/@uxu34MeAk6b@9k@//93rK@/5WN4VLoPkncIQkXjTVUqOqUSGuo@AM &quot;jq – Try It Online&quot;)",
                "title": "JQ sorting key by arbitrary order"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1508751554,
                "last_edit_date": 1508751554,
                "creation_date": 1508443548,
                "answer_id": 46838094,
                "question_id": 46796701,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Suppose we have an object with a bunch of keys, and want some of those keys to appear in a certain order, while leaving the others as-is.  Then the technique illustrated by the following example can be used:\r\n\r\n    $ jq -n &#39;{a:2,b:3,first:0,second:1} | . as $in | {first,second} + $in&#39;\r\n\r\nThe result:\r\n\r\n    {\r\n      &quot;first&quot;: 0,\r\n      &quot;second&quot;: 1,\r\n      &quot;a&quot;: 2,\r\n      &quot;b&quot;: 3\r\n    }\r\n\r\n\r\n### rekey\r\n\r\nLet&#39;s call the object defining the key ordering as the &quot;template object&quot; ({first,second} above).  Notice that using the technique described above, the keys in the &quot;template object&quot; always appear in the result.  If we only want the template object keys to appear in the result if they appear in the input, we can modify the above approach using the following function:\r\n\r\n    def rekey(obj):\r\n      . as $in\r\n      | reduce (obj|keys_unsorted)[] as $k ({};\r\n          if $in|has($k) then . + {($k): $in[$k]} else . end)\r\n      | . + $in ;\r\n\r\nFor example:\r\n\r\n    {a:2,b:3,first:0,second:1} | rekey({first,second,third})\r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;first&quot;: 0,\r\n      &quot;second&quot;: 1,\r\n      &quot;a&quot;: 2,\r\n      &quot;b&quot;: 3\r\n    }\r\n\r\n### With `walk/1`\r\n\r\nIf one wants to reorder keys recursively, one can use `walk/1` (defined as at https://github.com/stedolan/jq/blob/master/src/builtin.jq), \r\nas illustrated here using the above definition of `rekey`:\r\n\r\n    walk(if type == &quot;object&quot; then rekey($template) else . end)\r\n\r\nwhere $template represents the &quot;template object&quot;.\r\n\r\nThere is no need to define a special variant of `walk/1`. Simply define a function that takes as input an arbitrary object, and that produces the desired reordering. \r\n\r\n(If your jq comes with the version of `walk/1` that uses `keys`, then you should consider updating your jq, or redefine `walk/1` to use `keys_unsorted`.)",
                "title": "JQ sorting key by arbitrary order"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1623737900,
                "last_edit_date": 1623737900,
                "creation_date": 1623734844,
                "answer_id": 67980482,
                "question_id": 46796701,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "idea from @jq170727 &#39;s answer:\r\n```jq\r\njq &#39;\r\ndef reorder(a; n):\r\n    def order(a; n):\r\n        a as $a |\r\n        n as $n |\r\n        index($a) as $i |\r\n        if $i == null then .\r\n        else\r\n            if $i&lt;$n then .[:$i] + .[$i+1:$n+1] + [$a] + .[$n+1:]\r\n            elif $n&lt;$i then .[:$n] + [$a] + .[$n:]\r\n            else .\r\n            end\r\n        end;\r\n\r\n    . as $in\r\n  | if type == &quot;object&quot; then\r\n      reduce (keys_unsorted|order(a;n))[] as $key(\r\n        {}; . + { ($key):  ($in[$key] | reorder(a; n)) }\r\n      )\r\n    elif type == &quot;array&quot; then map( reorder(a; n) )\r\n    else .\r\n    end;\r\n\r\n[.[]  | reorder(&quot;id&quot;; 0)| reorder(&quot;size&quot;; 3) | reorder(&quot;name&quot;; 1)]&#39;\r\ndata.json\r\n\r\n```",
                "title": "JQ sorting key by arbitrary order"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 5,
        "last_activity_date": 1623737900,
        "creation_date": 1508264373,
        "last_edit_date": 1508287298,
        "question_id": 46796701,
        "body_markdown": "I am trying to sort by key in an arbitrary format (key &#39;event&#39; should be the first)\r\n\r\nI know this one sort the key by alphabetical order:\r\njq -S &#39;.&#39; file.json\r\n\r\nbut is there a function to sort key so that the first one is always the same and not by alphabetical order?\r\n\r\nIt is to make them more human readable and have the most significant key first\r\n\r\nCurrently have: \r\n{key1:value, shouldbeFirstKey:value2, ...}\r\nWould like\r\n{shouldbeFirstKey:value2, key1:value, ...}\r\n",
        "link": "https://stackoverflow.com/questions/46796701/jq-sorting-key-by-arbitrary-order",
        "title": "JQ sorting key by arbitrary order"
    },
    {
        "tags": [
            "json",
            "formatting",
            "jq",
            "pretty-print"
        ],
        "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": 3,
                "creation_date": 1508316635,
                "post_id": 46805833,
                "comment_id": 80559378,
                "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": 1508362944,
                "post_id": 46805833,
                "comment_id": 80586923,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1915048,
                    "reputation": 1132,
                    "user_id": 1727782,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/08e470ad31aa3368aecbc40df03c15e4?s=256&d=identicon&r=PG",
                    "display_name": "Alex Summers",
                    "link": "https://stackoverflow.com/users/1727782/alex-summers"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508718385,
                "post_id": 46805833,
                "comment_id": 80708088,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1508318577,
                "creation_date": 1508318577,
                "answer_id": 46806801,
                "question_id": 46805833,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "While it is probably best to use a tool like the one [peak](https://stackoverflow.com/users/997358/peak) suggested if your json isn&#39;t too complex you could use a second jq invocation to postprocess the output of the first.  For example if your data is in `data.json`\r\n\r\n&lt;!-- language: lang-none --&gt;\r\n\r\n    $ jq -M . data.json | jq -MRsr &#39;gsub(&quot;\\n      +&quot;;&quot;&quot;)|gsub(&quot;\\n    ]&quot;;&quot;]&quot;)&#39;\r\n\r\nproduces\r\n\r\n    {\r\n      &quot;frameGrid&quot;: {\r\n        &quot;size&quot;: [24,24],\r\n        &quot;dimensions&quot;: [1,1],\r\n        &quot;names&quot;: [[&quot;default&quot;]]\r\n      }\r\n    }",
                "title": "How to pretty print using jq, so that multiple values are on the same line?"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1508396548,
                "last_edit_date": 1508396548,
                "creation_date": 1508359867,
                "answer_id": 46819029,
                "question_id": 46805833,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "As @jq170727 mentioned, postprocessing after a pretty-printing run of jq (e.g. `jq .`) is worth considering.  In that vein, here is an awk script that might suffice:\r\n\r\n    #!/bin/bash\r\n    \r\n    awk &#39;\r\n      function ltrim(x) { sub(/^[ \\t]*/, &quot;&quot;, x); return x; }\r\n      s &amp;&amp; NF &gt; 1 &amp;&amp; $NF == &quot;[&quot;  { s=s $0;               next}\r\n      s &amp;&amp; NF == 1 &amp;&amp; $1 == &quot;],&quot; { print s &quot;],&quot;;   s=&quot;&quot;; next}\r\n      s &amp;&amp; NF == 1 &amp;&amp; $1 == &quot;[&quot;  { print s;        s=$0; next}\r\n      s &amp;&amp; NF == 1 &amp;&amp; $1 == &quot;{&quot;  { print s; print; s=&quot;&quot;; next}\r\n      s &amp;&amp; NF == 1 &amp;&amp; $1 == &quot;]&quot;  { print s $1;     s=&quot;&quot;; next}\r\n      s &amp;&amp; NF == 1 &amp;&amp; $1 == &quot;}&quot;  { print s;        s=$0; next}\r\n      s                          { s=s ltrim($0);        next}\r\n      $NF == &quot;[&quot;                 { s=$0;                 next}\r\n      {print}\r\n    &#39;\r\n\r\n### Examples\r\n\r\nWith the example input, the invocation:\r\n\r\n     jq . example.json | ./pp\r\n\r\nproduces:\r\n\r\n\r\n    {\r\n      &quot;frameGrid&quot;: {\r\n        &quot;size&quot;: [24,24],\r\n        &quot;dimensions&quot;: [1,1],\r\n        &quot;names&quot;: [\r\n          [&quot;default&quot;]\r\n        ]\r\n      }\r\n    }\r\n\r\n---\r\n\r\nThe invocation:\r\n\r\n    jq -n &#39;{a:[1,2,3,[1,2,3,4]],b:2,c:{d:[1,2,{e:[3,4]}]}}&#39; | ./pp\r\n\r\nproduces:\r\n\r\n    {\r\n      &quot;a&quot;: [1,2,3,\r\n        [1,2,3,4]\r\n      ],\r\n      &quot;b&quot;: 2,\r\n      &quot;c&quot;: {\r\n        &quot;d&quot;: [1,2,\r\n          {\r\n            &quot;e&quot;: [3,4]\r\n          }\r\n        ]\r\n      }\r\n    }",
                "title": "How to pretty print using jq, so that multiple values are on the same line?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1604807762,
                "last_edit_date": 1604807762,
                "creation_date": 1604806041,
                "answer_id": 64734539,
                "question_id": 46805833,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re not married to jq, take a look at [FracturedJson](https://j-brooke.github.io/FracturedJson/).  There&#39;s a web-based formatter, a commandline app, and a couple libraries.\r\n\r\nFracturedJson inlines arrays/objects as long as they&#39;re neither too long nor too complex (according to your settings).  It can also do arrays as multiple lines with multiple items per line, again, if they&#39;re not too complex.  Otherwise it breaks things out in the classic indented form.\r\n\r\nHere&#39;s the data from the original question using the default settings:\r\n\r\n```\r\n{\r\n    &quot;frameGrid&quot;: {\r\n        &quot;size&quot;: [24, 24],\r\n        &quot;dimensions&quot;: [1, 1],\r\n        &quot;names&quot;: [ [&quot;default&quot;] ]\r\n    }\r\n}\r\n```\r\n\r\nDisclosure: I&#39;m the author of FracturedJson.  It&#39;s open source under an MIT license.",
                "title": "How to pretty print using jq, so that multiple values are on the same line?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 8,
        "last_activity_date": 1604807762,
        "creation_date": 1508315347,
        "last_edit_date": 1508348123,
        "question_id": 46805833,
        "body_markdown": "What I get from jq is:\r\n\r\n\r\n    {\r\n      &quot;frameGrid&quot;: {\r\n        &quot;size&quot;: [\r\n          24,\r\n          24\r\n        ],\r\n        &quot;dimensions&quot;: [\r\n          1,\r\n          1\r\n        ],\r\n        &quot;names&quot;: [\r\n          [\r\n            &quot;default&quot;\r\n          ]\r\n        ]\r\n      }\r\n    }\r\n\r\nWhat I would like to see is something more like this: \r\n\r\n    {\r\n      &quot;frameGrid&quot;: {\r\n        &quot;size&quot;: [24,24], \r\n        &quot;dimensions&quot;: [1,1],\r\n        &quot;names&quot;: [[&quot;default&quot;]]\r\n      }\r\n    }\r\n\r\nI know both forms are valid, and that jq has a compact/pretty print mode. But is there something in-between? I&#39;m looking to somehow format a larger json file that has many more array values than this, so that it&#39;s easily readable and printable. Maybe I&#39;m just using the wrong tool for this job?\r\n\r\n(please excuse the horrid formating choice. Seems code-sample doesn&#39;t like json formats much)\r\n\r\n",
        "link": "https://stackoverflow.com/questions/46805833/how-to-pretty-print-using-jq-so-that-multiple-values-are-on-the-same-line",
        "title": "How to pretty print using jq, so that multiple values are on the same line?"
    },
    {
        "tags": [
            "json",
            "stream",
            "unique",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508342717,
                "post_id": 46814476,
                "comment_id": 80576437,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 8011176,
                    "reputation": 4161,
                    "user_id": 6042824,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://i.sstatic.net/YoO5z.jpg?s=256",
                    "display_name": "Bilesh Ganguly",
                    "link": "https://stackoverflow.com/users/6042824/bilesh-ganguly"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508347175,
                "post_id": 46814476,
                "comment_id": 80578807,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1508348558,
                "last_edit_date": 1508348558,
                "creation_date": 1508342964,
                "answer_id": 46814619,
                "question_id": 46814476,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**jq** processor itself has **`unique`** function:\r\n\r\nLet&#39;s assume the following `input.json`:\r\n\r\n    [\r\n      &quot;a-b-c-v001&quot;,\r\n      &quot;a-b-c-v002&quot;,\r\n      &quot;a-b-c-v001&quot;,\r\n      &quot;a-b-c-v003&quot;,\r\n      &quot;a-b-c-v002&quot;\r\n    ]\r\n\r\n\r\n----------\r\n\r\n    jq &#39;unique&#39; input.json\r\nThe output:\r\n\r\n    [\r\n      &quot;a-b-c-v001&quot;,\r\n      &quot;a-b-c-v002&quot;,\r\n      &quot;a-b-c-v003&quot;\r\n    ]\r\n\r\n\r\n",
                "title": "Get unique strings from group of strings using JQ"
            },
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1667314391,
                "last_edit_date": 1667314391,
                "creation_date": 1508347087,
                "answer_id": 46815776,
                "question_id": 46814476,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Make sure your jq expression produces an array. For example, if your jq expression (the one producing a stream of strings) is E, then you could modify it to:\r\n\r\n    [E] | unique | .[]\r\n\r\nor just:\r\n\r\n    [E] | unique[]\r\n\r\n### Avoiding a sort\r\n\r\n`unique` involves a sort, which can easily be avoided if E as above produces a stream of strings:\r\n\r\n    INDEX(E;.)[]\r\n\r\nSo, in answer to a Q in a comment, a sort-free way to get the count of distinct strings would be:\r\n\r\n    def count(s): reduce s as $x (0;.+1);\r\n    count( INDEX(E;.)[] )\r\n\r\n\r\n\r\n    ",
                "title": "Get unique strings from group of strings using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1667314391,
        "creation_date": 1508342469,
        "last_edit_date": 1508403888,
        "question_id": 46814476,
        "body_markdown": "I have strings extracted from jq , from which I just want to get unique values.\r\n\r\n    &quot;a-b-c-v001&quot;\r\n    &quot;a-b-c-v002&quot;\r\n    &quot;a-b-c-v001&quot;\r\n    &quot;a-b-c-v003&quot;\r\n    &quot;a-b-c-v002&quot;  \r\n\r\nI just need 3 results, unique\r\n\r\n    &quot;a-b-c-v001&quot;\r\n    &quot;a-b-c-v002&quot;\r\n    &quot;a-b-c-v003&quot;  \r\n\r\nI have tried unique &amp; sort did not work - https://jqplay.org/s/xjND6Iv60T",
        "link": "https://stackoverflow.com/questions/46814476/get-unique-strings-from-group-of-strings-using-jq",
        "title": "Get unique strings from group of strings using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1508410422,
                "creation_date": 1508410422,
                "answer_id": 46828275,
                "question_id": 46827655,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use the `map()` function:\r\n\r\n    jq -r &#39;.Parameters | map(\r\n               if .ParameterKey == &quot;career&quot; then (.ParameterValue = &quot;foo&quot;) else . end)\r\n           [] |  .ParameterKey + &quot;=&quot; + .ParameterValue&#39;",
                "title": "Bash and jq - Find a key contained in a variable and change it&#39;s value"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1508410869,
                "last_edit_date": 1508410869,
                "creation_date": 1508410434,
                "answer_id": 46828278,
                "question_id": 46827655,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**jq** solution:\r\n\r\n    echo $my_json | jq -r --arg career &quot;consultation&quot; &#39;.Parameters[] \r\n         | [.ParameterKey, if (.ParameterKey == &quot;career&quot;) then $career else .ParameterValue end] \r\n         | join(&quot;=&quot;)&#39; &gt; outputfile\r\n\r\n\r\n- `--arg career &quot;consultation&quot;` - passing value `&quot;consultation&quot;` into *jq* script as a predefined variable named `$career`\r\n\r\n- `join(&quot;=&quot;)` - join/implode *key* and *value* using `=` as separator\r\n\r\n----------\r\n\r\n\r\nThe `outputfile` contents:\r\n\r\n    name=james\r\n    age=22\r\n    city=belfast\r\n    career=consultation\r\n\r\n",
                "title": "Bash and jq - Find a key contained in a variable and change it&#39;s value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1508424004,
                "last_edit_date": 1508424004,
                "creation_date": 1508422414,
                "answer_id": 46832003,
                "question_id": 46827655,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses a generalization of [from_entries](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries)\r\nto convert the data to an intermediate object, [object multiplication with *](https://stedolan.github.io/jq/manual/#Multiplication,division,modulo:*,/,and%) to update the desired keys and a function to format the output taking into account blank values.\r\n\r\nFirst we assume jq will be invoked with the [--argjson](https://stedolan.github.io/jq/manual/#Invokingjq) parameter as follows to specify the key to be replaced:\r\n\r\n    $ jq -Mr --argjson replace &#39;{&quot;career&quot;:&quot;consultation&quot;}&#39; -f filter.jq data.json\r\n\r\nwhere `data.json` contains the sample data and `filter.jq` contains the following filter:\r\n    \r\n    def from_entries(k;v): map({(k):v})|add;\r\n    def format_output:     keys[] as $k | if .[$k]!=&quot;&quot; then &quot;\\($k)=\\(.[$k])&quot; else &quot;#\\($k)=&quot; end;\r\n    \r\n      .Parameters\r\n    | from_entries(.ParameterKey;.ParameterValue)\r\n    | . * $replace\r\n    | format_output\r\n\r\nSample output:\r\n\r\n    age=22\r\n    career=consultation\r\n    city=belfast\r\n    name=james\r\n\r\nIf instead we run it as \r\n\r\n    $ jq -Mr --argjson replace &#39;{&quot;career&quot;:&quot;&quot;}&#39; -f filter.jq data.json\r\n\r\nThe output is\r\n\r\n    age=22\r\n    #career=\r\n    city=belfast\r\n    name=james\r\n\r\n[**Try it online!**][TIO-j8yje0dh]\r\n\r\n[TIO-j8yje0dh]: https://tio.run/##nZKxboMwEIZ3nuJ6ZYAKGJJOoDxBl05dCIrccLQEMNQ2iRDw6qUOqA1IDFU83f336/N/lk9fQ2uAPlhLEmmM/nb77EzKKxOsIEVCog8hjOL1tH/V0vbG8pq0FU@6l@jMRi/UXAdcd3gD9c7/mZvNGpB93Mt7pzxhUq1Bj6lq7qTKMlEXJmgVq3USc/BYRUZvdINm/xp8xB6YBFNQlbMjGR0YRkwJJKIsDsSVSElaWXC2fShYZbVWZvvn3u5YHAeTsRQFU4eyVlWt/PGujBoZRiM2gw7SBLzQzKKHHSKoT@KAe8vM7N3eGnUbgXJJgI@TrFuu4Tqwd/sVOtgikjffOPCWr2NrtwdP860WMYfhu6xUWnI5uC6v89xN@VV2XcEu7uT5AQ &quot;jq – Try It Online&quot;",
                "title": "Bash and jq - Find a key contained in a variable and change it&#39;s value"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1508424004,
        "creation_date": 1508408279,
        "last_edit_date": 1508409902,
        "question_id": 46827655,
        "body_markdown": "Let&#39;s say I have the following json.\r\n\r\n    {\r\n        &quot;userid&quot;:334,\r\n    \r\n    \t&quot;Parameters&quot;: [ \r\n    \t    {\r\n    \t        &quot;ParameterValue&quot;: &quot;james&quot;, &quot;ParameterKey&quot;: &quot;name&quot; \r\n    \t    },\r\n    \t    {\r\n    \t        &quot;ParameterValue&quot;: &quot;22&quot;, &quot;ParameterKey&quot;: &quot;age&quot; \r\n    \t    },\r\n    \t    {\r\n    \t        &quot;ParameterValue&quot;: &quot;belfast&quot;, &quot;ParameterKey&quot;: &quot;city&quot; \r\n    \t    },\r\n    \t    {\r\n    \t        &quot;ParameterValue&quot;: &quot;software&quot;, &quot;ParameterKey&quot;: &quot;career&quot; \r\n    \t    }\r\n    \t]\r\n    }\r\n\r\nI have some code which takes the JSON and extracts all of the keys and their values.\r\n\r\n    echo $my_json | jq -r &#39;.Parameters[] | .ParameterKey + &quot;=&quot; + .ParameterValue&#39; &gt;&gt; $OUTPUT_FILE \r\n           \r\nIf I look in my output file I have something similar to this:\r\n\r\n    name=james\r\n    age=22\r\n    city=belfast\r\n    career=software\r\n\r\nHow can I find, say &quot;career&quot; and change it&#39;s value before it is placed in the $OUTPUT_FILE? Example below:\r\n\r\n    name=james\r\n    age=22\r\n    city=belfast\r\n    career=consultation\r\n",
        "link": "https://stackoverflow.com/questions/46827655/bash-and-jq-find-a-key-contained-in-a-variable-and-change-its-value",
        "title": "Bash and jq - Find a key contained in a variable and change it&#39;s value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1508445402,
                "last_edit_date": 1508445402,
                "creation_date": 1508413587,
                "answer_id": 46829145,
                "question_id": 46829008,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You can use the following command based on `group_by`:\r\n\r\n    group_by(.foo,.bar)\r\n    | map(.[]+{&quot;count&quot;:length})\r\n    | unique_by(.foo,.bar)\r\n\r\nOutput:\r\n\r\n    [\r\n      {\r\n        &quot;foo&quot;: 1,\r\n        &quot;bar&quot;: &quot;a&quot;,\r\n        &quot;baz&quot;: &quot;whatever&quot;,\r\n        &quot;count&quot;: 2\r\n      },\r\n      {\r\n        &quot;foo&quot;: 1,\r\n        &quot;bar&quot;: &quot;b&quot;,\r\n        &quot;baz&quot;: &quot;world&quot;,\r\n        &quot;count&quot;: 1\r\n      }\r\n    ]\r\n\r\nThe other output you mentioned can be achieved with this command:\r\n\r\n    group_by(.foo,.bar)\r\n    | map({&quot;count&quot;:length,&quot;data&quot;:(unique_by(.foo,.bar)[])})\r\n\r\nOutput:\r\n\r\n    [\r\n      {\r\n        &quot;count&quot;: 2,\r\n        &quot;data&quot;: {\r\n          &quot;foo&quot;: 1,\r\n          &quot;bar&quot;: &quot;a&quot;,\r\n          &quot;baz&quot;: &quot;whatever&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;count&quot;: 1,\r\n        &quot;data&quot;: {\r\n          &quot;foo&quot;: 1,\r\n          &quot;bar&quot;: &quot;b&quot;,\r\n          &quot;baz&quot;: &quot;world&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\n",
                "title": "Count and remove duplicates in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1508427911,
                "creation_date": 1508427911,
                "answer_id": 46833843,
                "question_id": 46829008,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses [peak](https://stackoverflow.com/users/997358/peak)&#39;s [GROUPS_BY](https://stackoverflow.com/a/45715729/8379597) instead of [group_by/1](https://stedolan.github.io/jq/manual/#group_by(path_expression)) to avoid sorting:\r\n\r\n    def GROUPS_BY(stream; f): reduce stream as $x ({}; .[$x|f] += [$x] ) | .[] ;\r\n \r\n      GROUPS_BY(.[]; {foo,bar}|tostring)\r\n    | .[0].count = length\r\n    | .[0]\r\n ",
                "title": "Count and remove duplicates in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1508445402,
        "creation_date": 1508413076,
        "question_id": 46829008,
        "body_markdown": "I have an array of objects and I want to remove some duplicates in this array, I want to keep the count of the duplicates though.\r\n\r\nMy input is:\r\n\r\n    [\r\n        {\r\n            &quot;foo&quot;: 1,\r\n            &quot;bar&quot;: &quot;a&quot;,\r\n            &quot;baz&quot;: &quot;whatever&quot;\r\n        },\r\n        {\r\n            &quot;foo&quot;: 1,\r\n            &quot;bar&quot;: &quot;a&quot;,\r\n            &quot;baz&quot;: &quot;hello&quot;\r\n        },\r\n        {\r\n            &quot;foo&quot;: 1,\r\n            &quot;bar&quot;: &quot;b&quot;,\r\n            &quot;baz&quot;: &quot;world&quot;\r\n        }\r\n    ]\r\n\r\n(not sure if it&#39;s important but the uniqueness of an object is based on `foo` and `bar`, not `baz`.\r\n\r\nAn example of desired output would then be:\r\n\r\n    [\r\n        {\r\n            &quot;foo&quot;: 1,\r\n            &quot;bar&quot;: &quot;a&quot;,\r\n            &quot;baz&quot;: &quot;whatever&quot;,\r\n            &quot;count&quot;: 2\r\n        },\r\n        {\r\n            &quot;foo&quot;: 1,\r\n            &quot;bar&quot;: &quot;b&quot;,\r\n            &quot;baz&quot;: &quot;world&quot;,\r\n            &quot;count&quot;: 1\r\n        }\r\n    ]\r\n\r\nor even: \r\n\r\n    [\r\n        {\r\n            &quot;count&quot;: 2,\r\n            &quot;data&quot;: {\r\n                &quot;foo&quot;: 1,\r\n                &quot;bar&quot;: &quot;a&quot;,\r\n                &quot;baz&quot;: &quot;whatever&quot;\r\n            }\r\n        },\r\n        ...\r\n    ]\r\n\r\nI know how to do the uniqueness part (with `unique_by([.foo, .bar])`) but not the counting part.",
        "link": "https://stackoverflow.com/questions/46829008/count-and-remove-duplicates-in-jq",
        "title": "Count and remove duplicates in jq"
    },
    {
        "tags": [
            "aws-cli",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1508427424,
                "last_edit_date": 1508427424,
                "creation_date": 1508425484,
                "answer_id": 46833048,
                "question_id": 46832763,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With **jq** **`match`** function:\r\n\r\n    aws ecs list-task-definitions --region eu-west-1 \\\r\n    | jq -r &#39;.taskDefinitionArns[] | match(&quot;.*/([^:]+):[0-9]+$&quot;).captures[0].string&#39;\r\n\r\n\r\n- `&quot;.*/([^:]+):[0-9]+$&quot;` - regex pattern to match the sequence between `/` and the last `:` characters\r\n\r\n----------\r\n\r\nThe output:\r\n\r\n    audience-view-dev-api\r\n    audience-view-dev-groups\r\n    audience-view-dev-groups\r\n    audience-view-dev-mock-api\r\n    audience-view-dev-mock-responder\r\n\r\nhttps://stedolan.github.io/jq/manual/v1.5/#match(val),match(regex;flags)\r\n\r\n",
                "title": "parse JSON to jq to get a list from AWS CLI"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1508426132,
                "creation_date": 1508426132,
                "answer_id": 46833279,
                "question_id": 46832763,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Try this:\r\n\r\n    $ aws ecs list-task-definitions --region eu-west-1 \\\r\n      | jq -Mr &#39;.taskDefinitionArns[] | split(&quot;:&quot;)[5] | split(&quot;/&quot;)[1]&#39;\r\n\r\nExpanded:\r\n\r\n      .taskDefinitionArns[]     # for each taskDefinitionArns\r\n    | split(&quot;:&quot;)[5]             # take entry [5] after splitting by :\r\n    | split(&quot;/&quot;)[1]             # take entry [1] after splitting by /\r\n  ",
                "title": "parse JSON to jq to get a list from AWS CLI"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1532104264,
                "last_edit_date": 1532104264,
                "creation_date": 1532104173,
                "answer_id": 51446866,
                "question_id": 46832763,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get unique values:\r\n\r\n    aws ecs list-task-definitions | jq -r &#39;.taskDefinitionArns[] | match(&quot;.*/([^:]+):[0-9]+$&quot;).captures[0].string&#39; | sort | uniq",
                "title": "parse JSON to jq to get a list from AWS CLI"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 5,
        "last_activity_date": 1532104264,
        "creation_date": 1508424686,
        "question_id": 46832763,
        "body_markdown": "I would like to get a list of task definitions I can create a list from via AWS CLI. Here is a partial list from the command;\r\n\r\n`aws ecs list-task-definitions --region eu-west-1`\r\n\r\n    {\r\n        &quot;taskDefinitionArns&quot;: [\r\n            &quot;arn:aws:ecs:eu-west-1:543573289192:task-definition/audience-view-dev-api:4&quot;, \r\n            &quot;arn:aws:ecs:eu-west-1:543573289192:task-definition/audience-view-dev-groups:4&quot;, \r\n            &quot;arn:aws:ecs:eu-west-1:543573289192:task-definition/audience-view-dev-groups:5&quot;, \r\n            &quot;arn:aws:ecs:eu-west-1:543573289192:task-definition/audience-view-dev-mock-api:1&quot;, \r\n            &quot;arn:aws:ecs:eu-west-1:543573289192:task-definition/audience-view-dev-mock-responder:1&quot;\r\n        ]\r\n    }\r\n\r\nFrom this I would like to only show;\r\n\r\n    audience-view-dev-api\r\n    audience-view-dev-groups\r\n    audience-view-dev-groups\r\n    audience-view-dev-mock-api\r\n    audience-view-dev-mock-responder\r\n\r\nI believe if I pipe this to `jq` then I can get what I&#39;m after? I am trying various combinations of;  `aws ecs list-task-definitions --region eu-west-1 | jq -r &#39;.taskDefinitionArns[].&lt;something_here&gt;&#39;` to no avail",
        "link": "https://stackoverflow.com/questions/46832763/parse-json-to-jq-to-get-a-list-from-aws-cli",
        "title": "parse JSON to jq to get a list from AWS CLI"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1508446237,
                "creation_date": 1508446237,
                "answer_id": 46838691,
                "question_id": 46838417,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you simply want to print out the objects for which .state is NOT &quot;STARTED&quot;, just use negation:\r\n\r\n    .rows[] | select(.state != &quot;STARTED&quot;)\r\n\r\nIf the &quot;started&quot; state is associated with multiple values, please give further details. There might not be any need to use regular expressions.  If you really do need to use regular expressions, then you will probably want to use `test`. ",
                "title": "jq only show when object doesnt match"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1508491089,
        "creation_date": 1508445108,
        "last_edit_date": 1508491089,
        "question_id": 46838417,
        "body_markdown": "I&#39;m trying to set up an alert for when the following JSON object state says anything but started. I&#39;m beginning to play around with conditional jq but I&#39;m unsure how to implement regex into this.\r\n\r\n    {\r\n      &quot;page&quot;: 0,\r\n      &quot;page_size&quot;: 100,\r\n      &quot;total_pages&quot;: 10,\r\n      &quot;total_rows&quot;: 929,\r\n      &quot;headers&quot;: [\r\n        &quot;*&quot;\r\n      ],\r\n      &quot;rows&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;168&quot;,\r\n          &quot;state&quot;: &quot;STARTED&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;169&quot;,\r\n          &quot;state&quot;: &quot;FAILED&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;170&quot;,\r\n          &quot;state&quot;: &quot;STARTED&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nI only want to display the id and state of the failed object, this is what I tried\r\n    \r\n    jq &#39;.rows[] | .id, select(.state | contains(&quot;!STARTED&quot;))&#39; test.json\r\n\r\nI&#39;d like my output to be something like\r\n\r\n    {\r\n     &quot;id&quot;: &quot;169&quot;,\r\n     &quot;state&quot;: &quot;FAILED&quot;\r\n    }\r\n",
        "link": "https://stackoverflow.com/questions/46838417/jq-only-show-when-object-doesnt-match",
        "title": "jq only show when object doesnt match"
    },
    {
        "tags": [
            "json",
            "count",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1508466186,
                "last_edit_date": 1508466186,
                "creation_date": 1508450294,
                "answer_id": 46839523,
                "question_id": 46839374,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The given description of the problem is very confusing.  For example, there are actually three occurrences of the JSON string &quot;1.2.3.46:8983_emo&quot; in the given JSON:\r\n \r\n\r\n    .. | strings | select(. == &quot;1.2.3.46:8983_emo&quot;)\r\n\r\nshows there are three occurrences.\r\n\r\nIf you just want to look in .myApp and .myApp_shadow, then consider:\r\n\r\n    .cluster.collections\r\n    | [(.myApp, .myApp_shadow) | .. | strings | select(.==&quot;1.2.3.46:8983_emo&quot;)]\r\n    | length\r\n\r\n\r\nThis yields the answer you said you expect (i.e. 2).\r\n\r\nHopefully the above will provide sufficient guidance for you to do whatever it is you want; if not, then please see http://stackoverflow.com/help/mcve and provide a minimal example that clarifies the issue you&#39;re having.\r\n\r\n### count/1\r\n\r\nA more efficient and perhaps better approach is to use `count/1`:\r\n\r\n    def count(s): reduce s as $x (0; .+1);\r\n\r\nThis counts the number of items in the stream, s, without constructing an array. So you could for example write:\r\n\r\n    .cluster.collections\r\n    | &quot;1.2.3.46:8983_emo&quot; as $s\r\n    | count((.myApp, .myApp_shadow) | .. | strings | select(.==$s))\r\n\r\nOr if you only want to check the values of the &quot;node_name&quot; key:\r\n\r\n    count(.. | select(.node_name? == &quot;1.2.3.46:8983_emo&quot;))\r\n\r\n\r\n",
                "title": "Get total number of occurrences of a string in json using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1508470590,
                "creation_date": 1508470590,
                "answer_id": 46842040,
                "question_id": 46839374,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another solution which uses [tostream](https://stedolan.github.io/jq/manual/#tostream)\r\n\r\n    reduce (\r\n        tostream\r\n      | select(length==2) as [$p,$v]\r\n      | select($p[-1]==&quot;node_name&quot; and $v==&quot;1.2.3.46:8983_emo&quot;)\r\n    ) as $n (0;.+1)",
                "title": "Get total number of occurrences of a string in json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1508470590,
        "creation_date": 1508449476,
        "last_edit_date": 1508465721,
        "question_id": 46839374,
        "body_markdown": "I want to get count of number of occurrences of &quot;1.2.3.46:8983_emo&quot; in this json string using jq.\r\n\r\n1.2.3.46:8983_emo is present under myApp &amp; myApp_shadow. So the count will be 2\r\n\r\nusing below jq filter     \r\n\r\n\r\n    .cluster.collections.myApp.shards.shard1.replicas[].node_name \r\n\r\nI am able to get node_names but I need something like this, which is not working. I don&#39;t know how to look under &#39;myApp&#39; &amp; &#39;myApp_shadow&#39;. Can you please help\r\n\r\n    .cluster.collections | select (.myApp.shards.shard1.replicas[].node_name==&quot;1.2.3.46:8983_emo&quot;)\r\n\r\nHere is the snippet...https://jqplay.org/s/VvdATQ6bAr\r\n\r\nFYI..when i try just adding &quot;| length&quot; did not work for me. It gave wrong counts",
        "link": "https://stackoverflow.com/questions/46839374/get-total-number-of-occurrences-of-a-string-in-json-using-jq",
        "title": "Get total number of occurrences of a string in json using jq"
    },
    {
        "tags": [
            "node.js",
            "linux",
            "jq",
            "child-process"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 174911,
                    "reputation": 18753,
                    "user_id": 404556,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/39lHi.jpg?s=256",
                    "display_name": "randomir",
                    "link": "https://stackoverflow.com/users/404556/randomir"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508513628,
                "post_id": 46852418,
                "comment_id": 80652335,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 404757,
                    "reputation": 23037,
                    "user_id": 773263,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/e2581b53db32340d7e1b5be6b99c2bb1?s=256&d=identicon&r=PG",
                    "display_name": "Philip Kirkbride",
                    "link": "https://stackoverflow.com/users/773263/philip-kirkbride"
                },
                "reply_to_user": {
                    "account_id": 174911,
                    "reputation": 18753,
                    "user_id": 404556,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/39lHi.jpg?s=256",
                    "display_name": "randomir",
                    "link": "https://stackoverflow.com/users/404556/randomir"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508513894,
                "post_id": 46852418,
                "comment_id": 80652502,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 174911,
                    "reputation": 18753,
                    "user_id": 404556,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/39lHi.jpg?s=256",
                    "display_name": "randomir",
                    "link": "https://stackoverflow.com/users/404556/randomir"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1508514046,
                "post_id": 46852418,
                "comment_id": 80652596,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 404757,
                    "reputation": 23037,
                    "user_id": 773263,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/e2581b53db32340d7e1b5be6b99c2bb1?s=256&d=identicon&r=PG",
                    "display_name": "Philip Kirkbride",
                    "link": "https://stackoverflow.com/users/773263/philip-kirkbride"
                },
                "reply_to_user": {
                    "account_id": 174911,
                    "reputation": 18753,
                    "user_id": 404556,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/39lHi.jpg?s=256",
                    "display_name": "randomir",
                    "link": "https://stackoverflow.com/users/404556/randomir"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508514136,
                "post_id": 46852418,
                "comment_id": 80652638,
                "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": 1508514184,
                "post_id": 46852418,
                "comment_id": 80652667,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 174911,
                    "reputation": 18753,
                    "user_id": 404556,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/39lHi.jpg?s=256",
                    "display_name": "randomir",
                    "link": "https://stackoverflow.com/users/404556/randomir"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1508514920,
                "post_id": 46852418,
                "comment_id": 80653098,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "reply_to_user": {
                    "account_id": 174911,
                    "reputation": 18753,
                    "user_id": 404556,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/39lHi.jpg?s=256",
                    "display_name": "randomir",
                    "link": "https://stackoverflow.com/users/404556/randomir"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508515050,
                "post_id": 46852418,
                "comment_id": 80653193,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 174911,
                    "reputation": 18753,
                    "user_id": 404556,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/39lHi.jpg?s=256",
                    "display_name": "randomir",
                    "link": "https://stackoverflow.com/users/404556/randomir"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1508515254,
                "post_id": 46852418,
                "comment_id": 80653330,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1508515649,
                "last_edit_date": 1508515649,
                "creation_date": 1508514605,
                "answer_id": 46852764,
                "question_id": 46852418,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The catch is in `jq`&#39;s [attempts to intelligently infer the default filter](https://github.com/stedolan/jq/issues/1110), if the filter was omitted.\r\n\r\nNamely, when output goes to a **terminal** (TTY), the **filter may be omitted**, and it defaults to `.` (pretty print). That&#39;s why in terminal you can write:\r\n\r\n    cat file | jq           # or:  jq &lt; file\r\n\r\ninstead of:\r\n\r\n    cat file | jq .         # or:  jq . file\r\n\r\nWhen invoked from `node`, however, with `stdin` and **`stdout` redirected**, `jq` **requires the filter** argument. That&#39;s why you have to specify it explicitly:\r\n\r\n    var command = &quot;cat /tmp/gen_json | jq .&quot;;\r\n\r\nor, even better (to avoid the feline abuse):\r\n\r\n    var command = &quot;jq . /tmp/gen_json&quot;;\r\n",
                "title": "Weird pipe behavior in node&#39;s child_process?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1508612598,
        "creation_date": 1508513306,
        "last_edit_date": 1508612598,
        "question_id": 46852418,
        "body_markdown": "I have a shell command that works fine in terminal yet when executed by node&#39;s `child_process` it errors.\r\n\r\nHere is the command as used in terminal *([file.json][1] is a json file)*:\r\n\r\n    cat /tmp/file.json | jq\r\n\r\nHere is running the same command from `child_process`:\r\n\r\n    var cp = require(&quot;child_process&quot;);\r\n    \r\n    var command = &quot;cat /tmp/gen_json | jq&quot;;\r\n    cp.exec(command, function(err, stdout, stderr) {\r\n      stderr ? console.log(stderr) : console.log(stdout);\r\n    });\r\n\r\nWhich produces:\r\n\r\n    jq - commandline JSON processor [version 1.5-1-a5b5cbe]\r\n    Usage: jq [options] &lt;jq filter&gt; [file...]\r\n    \r\n    \tjq is a tool for processing JSON inputs, applying the\r\n    \tgiven filter to its JSON text inputs and producing the\r\n        ...\r\n\r\nThis is the default message that is displayed when just running `jq`. It&#39;s as if I just ran `jq` without the preceding pipe.\r\n\r\n\r\n  [1]: https://pastebin.com/njvSHztP",
        "link": "https://stackoverflow.com/questions/46852418/weird-pipe-behavior-in-nodes-child-process",
        "title": "Weird pipe behavior in node&#39;s child_process?"
    },
    {
        "tags": [
            "json",
            "parsing",
            "key",
            "jq",
            "extract"
        ],
        "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": 1508600172,
                "post_id": 46864773,
                "comment_id": 80677294,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 925874,
                    "reputation": 142,
                    "user_id": 956674,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/fc2709c22be539720928733982f20df0?s=256&d=identicon&r=PG",
                    "display_name": "peterRepeater",
                    "link": "https://stackoverflow.com/users/956674/peterrepeater"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508600695,
                "post_id": 46864773,
                "comment_id": 80677472,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1508604459,
                "creation_date": 1508604459,
                "answer_id": 46865627,
                "question_id": 46864773,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s one way you could achieve the desired output.\r\n\r\nprogram.jq:\r\n\r\n    [&quot;project&quot;,&quot;name&quot;,&quot;net_tier&quot;,&quot;vcpu&quot;,&quot;mem&quot;,&quot;disk001&quot;,&quot;disk002&quot;],\r\n      [.project]\r\n    + (.nodes[] | .networks[] as $n |\r\n        [\r\n          .name,\r\n          $n.net_tier,\r\n          (.hardware |\r\n            .vcpu,\r\n            .mem,\r\n            (.disks | add[&quot;disk001&quot;,&quot;disk002&quot;])\r\n          )\r\n        ]\r\n      )\r\n    | @csv\r\n\r\n&lt;!-- --&gt;\r\n\r\n    $ jq -r -f program.jq input.json\r\n    &quot;project&quot;,&quot;name&quot;,&quot;net_tier&quot;,&quot;vcpu&quot;,&quot;mem&quot;,&quot;disk001&quot;,&quot;disk002&quot;\r\n    &quot;Project X&quot;,&quot;server001&quot;,&quot;network_tier_001&quot;,1,1024,40,20\r\n\r\nBasically, you&#39;ll want to project the fields that you want into arrays so you may convert those arrays to csv rows. Your input makes it seem like there could potentially be multiple networks for a given node. So if you wanted to output all combinations, that would have to be flattened out.",
                "title": "Parsing multiple key/values in json tree with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1508633922,
                "last_edit_date": 1508633922,
                "creation_date": 1508616223,
                "answer_id": 46867546,
                "question_id": 46864773,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s another approach, that is short enough to speak for itself:\r\n\r\n\r\n    def s(f): first(.. | f? // empty) // null;\r\n\r\n    [s(.project), s(.name), s(.net_tier), s(.vcpu), s(.mem), s(.disk001), s(.disk002)]\r\n    | @csv\r\n\r\nInvocation:\r\n\r\n    $ jq -r -f value-pairs.jq input.json\r\n\r\nResult:\r\n\r\n    &quot;Project X&quot;,&quot;server001&quot;,&quot;network_tier_001&quot;,1,1024,40,20\r\n\r\n## With headers\r\n\r\nUsing the same `s/1` as above:\r\n\r\n    . as $d\r\n    | [&quot;project&quot;, &quot;name&quot;, &quot;net_tier&quot;, &quot;vcpu&quot;, &quot;mem&quot;, &quot;disk001&quot;,&quot;disk002&quot;]\r\n    | (., map( . as $v | $d | s(.[$v])))\r\n    | @csv\r\n\r\n\r\n### With multiple nodes\r\n\r\nAgain with `s/1` as above:\r\n\r\n\r\n    .project as $p\r\n    | [&quot;project&quot;, &quot;name&quot;, &quot;net_tier&quot;, &quot;vcpu&quot;, &quot;mem&quot;, &quot;disk001&quot;,&quot;disk002&quot;] as $h\r\n    | ($h,\r\n       (.nodes[] as $d\r\n       | $h\r\n       | map( . as $v | $d | s(.[$v]) )\r\n       | .[0] = $p)\r\n       ) | @csv\r\n\r\nOutput with the illustrative multi-node data:\r\n\r\n    &quot;project&quot;,&quot;name&quot;,&quot;net_tier&quot;,&quot;vcpu&quot;,&quot;mem&quot;,&quot;disk001&quot;,&quot;disk002&quot;\r\n    &quot;Project X&quot;,&quot;server001&quot;,&quot;network_tier_001&quot;,1,1024,40,20\r\n    &quot;Project X&quot;,&quot;server002&quot;,&quot;network_tier_002&quot;,1,1024,,40",
                "title": "Parsing multiple key/values in json tree with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1508635103,
                "last_edit_date": 1508635103,
                "creation_date": 1508631529,
                "answer_id": 46869347,
                "question_id": 46864773,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a different filter which computes the unique set of network tier and disk names and then generates a result with columns appropriate to the data.\r\n\r\n      {\r\n        tiers: [ .nodes[].networks[].net_tier ] | unique\r\n      , disks: [ .nodes[].hardware.disks[] | keys[] | select(startswith(&quot;disk&quot;)) ] | unique\r\n      } as $n\r\n\r\n    | def column_names($n): [ &quot;project&quot;, &quot;name&quot; ] + $n.tiers + [&quot;vcpu&quot;, &quot;mem&quot;] + $n.disks ;\r\n      def tiers($n):        [ $n.tiers[] as $t | .networks[] | if .net_tier==$t then $t else null end ] ;\r\n      def disks($n):        [ $n.disks[] as $d | map(select(.[$d]!=null)|.[$d])[0] ] ;\r\n      def rows($n):\r\n          .project as $project\r\n        | .nodes[]\r\n        | .name as $name\r\n        | tiers($n) as $tier_values\r\n        | .hardware\r\n        | .vcpu as $vcpu\r\n        | .mem as $mem\r\n        | .disks\r\n        | disks($n) as $disk_values\r\n        | [$project, $name] + $tier_values + [$vcpu, $mem] + $disk_values\r\n      ;\r\n      column_names($n), rows($n)\r\n\r\n    | @csv\r\n\r\nThe benfit of this approach becomes apparent if we add another node to the sample data:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;server002&quot;,\r\n      &quot;networks&quot;: [\r\n        {\r\n          &quot;net_tier&quot;: &quot;network_tier_002&quot;\r\n        }\r\n      ],\r\n      &quot;hardware&quot;: {\r\n        &quot;vcpu&quot;: 1,\r\n        &quot;mem&quot;: 1024,\r\n        &quot;disks&quot;: [\r\n          {\r\n            &quot;disk002&quot;: 40,\r\n            &quot;detail001&quot;: &quot;foo&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nSample Run (assuming filter in `filter.jq` and amended data in `data.json`)\r\n\r\n    $ jq -Mr -f filter.jq data.json\r\n    &quot;project&quot;,&quot;name&quot;,&quot;network_tier_001&quot;,&quot;network_tier_002&quot;,&quot;vcpu&quot;,&quot;mem&quot;,&quot;disk001&quot;,&quot;disk002&quot;\r\n    &quot;Project X&quot;,&quot;server001&quot;,&quot;network_tier_001&quot;,&quot;&quot;,1,1024,40,20\r\n    &quot;Project X&quot;,&quot;server002&quot;,,&quot;network_tier_002&quot;,1,1024,,40\r\n\r\n[Try it online!](https://tio.run/##nVRRa9swEH7vr9BEHxLqGMdrYXgU9gcGg@1hYExQbKVxa0upJMd0Sf76sruTbdSEwZiS4NOd7vvuvpPz/Ho@8J3Rz7J0POPfvMV@8ohX0pam3rlaK4j82NaWwVewwM/0hoUpSkOQZ/mBK9FKyLLS7KVJkiXhOVE3aGd8o3XgScGzFgYBpOu1eRkwpFu5WhqIDn7arjxcvVuJqjLSwmG@TOIlfhIIPAkne/EWeMFpuzXCtcK@QCB9eIjHH6a0ogzAkiRbLrM0zYTI1uusLPmpiPhWmKoXBro68H2563i2hETZwjNJ76GZ2g51o0Vt3ifXXZ@i8QB0nV4cQBFOxSniGuuo5LoW6hO2JDXSGvnkh@EVKHWnnMFGv/eykgoVFU6UErwo/lfRtEg4UXwkil9Uw8WA0n8XP/0vOdK/yFGcEO3KfTwzWocbNixktxnLWUy3LC/isV5vUnmsYEfWqfq1k0NixKiSd4lj7TGFcsx5kW/esLKB2zyzThhn@9ptZ9QAn8@vsU9MWHarbmh7hBdjw0rddK1aobp2dqvmyDu9XxHzsgPSHeTF1BKYuVcQwijgEKTa2OeBCrHpuAcdVj6hQO1Yi4MyAl1gV2/YpM7jIxxwW6nwoGysZKprGiZVBRWFTMR9zTTKhUwVYLdiNxv0ivPbqvjwiHjzI23meVJcwBrde9RpqIzFgzgEOthT@DjN7J0LNPTKgxEEJn28FHhb96LppA2Tx9mHPlSfctAIAzAO8sMzdJMOgWOSyysDu2vifGwu8nXTlIMa8RoQf0R0FL5GGtW8vGbRpO14Gb@Udn9zPv/W9Edtz4sFzmZRq13nYGNEv9Cdg80f &quot;jq – Try It Online&quot;)",
                "title": "Parsing multiple key/values in json tree with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1508639233,
        "creation_date": 1508599110,
        "last_edit_date": 1508639233,
        "question_id": 46864773,
        "body_markdown": "Using jq, I&#39;d like to cherry-pick key/value pairs from the following json:\r\n\r\n    {\r\n      &quot;project&quot;: &quot;Project X&quot;,\r\n      &quot;description&quot;: &quot;This is a description of Project X&quot;,\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;server001&quot;,\r\n          &quot;detail001&quot;: &quot;foo&quot;,\r\n          &quot;detail002&quot;: &quot;bar&quot;,\r\n          &quot;networks&quot;: [\r\n            {\r\n              &quot;net_tier&quot;: &quot;network_tier_001&quot;,\r\n              &quot;ip_address&quot;: &quot;10.1.1.10&quot;,\r\n              &quot;gateway&quot;: &quot;10.1.1.1&quot;,\r\n              &quot;subnet_mask&quot;: &quot;255.255.255.0&quot;,\r\n              &quot;mac_address&quot;: &quot;00:11:22:aa:bb:cc&quot;\r\n            }\r\n          ],\r\n          &quot;hardware&quot;: {\r\n            &quot;vcpu&quot;: 1,\r\n            &quot;mem&quot;: 1024,\r\n            &quot;disks&quot;: [\r\n              {\r\n                &quot;disk001&quot;: 40,\r\n                &quot;detail001&quot;: &quot;foo&quot;\r\n              },\r\n              {\r\n                &quot;disk002&quot;: 20,\r\n                &quot;detail001&quot;: &quot;bar&quot;\r\n              }\r\n            ]\r\n          },\r\n          &quot;os&quot;: &quot;debian8&quot;,\r\n          &quot;geo&quot;: {\r\n            &quot;region&quot;: &quot;001&quot;,\r\n            &quot;country&quot;: &quot;Sweden&quot;,\r\n            &quot;datacentre&quot;: &quot;Malmo&quot;\r\n          },\r\n          &quot;detail003&quot;: &quot;baz&quot;\r\n        }\r\n      ],\r\n      &quot;detail001&quot;: &quot;foo&quot;\r\n    }\r\n\r\nFor the sake of an example, I&#39;d like to parse the following keys and their values: &quot;Project&quot;, &quot;name&quot;, &quot;net_tier&quot;, &quot;vcpu&quot;, &quot;mem&quot;, &quot;disk001&quot;, &quot;disk002&quot;.\r\n\r\nI&#39;m able to parse individual elements without much issue, but due to the hierarchical nature of the full parse, I&#39;ve not had much luck parsing down different branches (i.e. both networks and hardware &gt; disks).\r\n\r\nAny help appreciated.\r\n\r\n**Edit:**\r\n\r\nFor clarity, the output I&#39;m going for is a comma-separated CSV. In terms of parsing all combinations, covering the sample data in the example will do for now. I will hopefully be able to expand on any suggestions.",
        "link": "https://stackoverflow.com/questions/46864773/parsing-multiple-key-values-in-json-tree-with-jq",
        "title": "Parsing multiple key/values in json tree with jq"
    },
    {
        "tags": [
            "json",
            "nested",
            "edit",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1508692953,
                "creation_date": 1508692953,
                "answer_id": 46877045,
                "question_id": 46876940,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Another way using [tag:nodejs] and [tag:shell] :\r\n\r\n## Code :\r\n\r\n    $ node&lt;&lt;EOF\r\n    var obj = $(&lt;/tmp/file.json);\r\n    delete obj.results.a;\r\n    delete obj.results.c;\r\n    console.log(JSON.stringify(obj));\r\n    EOF\r\n\r\n## OUTPUT : \r\n\r\n    {&quot;success&quot;:true,&quot;results&quot;:{&quot;b&quot;:&quot;bbb&quot;}}",
                "title": "jq: selecting subset of keys from nested object"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1508695333,
                "creation_date": 1508695333,
                "answer_id": 46877456,
                "question_id": 46876940,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is one solution:\r\n\r\n    .results |= {b}\r\n\r\nSample Run\r\n\r\n    $ jq -M &#39;.results |= {b}&#39; &lt;&lt;&lt; &#39;{&quot;success&quot;:true, &quot;results&quot;:{&quot;a&quot;: &quot;…&quot;, &quot;b&quot;: &quot;…&quot;, &quot;c&quot;: &quot;…&quot;}}&#39;\r\n    {\r\n      &quot;success&quot;: true,\r\n      &quot;results&quot;: {\r\n        &quot;b&quot;: &quot;…&quot;\r\n      }\r\n    }\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/FvpCrYiFMg)",
                "title": "jq: selecting subset of keys from nested object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1508696656,
        "creation_date": 1508692389,
        "last_edit_date": 1508696656,
        "question_id": 46876940,
        "body_markdown": "Input:\r\n\r\n    {&quot;success&quot;: true, &quot;results&quot;: {&quot;a&quot;: …, &quot;b&quot;: …, &quot;c&quot;: …}}\r\n\r\nDesired output, given I want to keep `b`:\r\n\r\n    {&quot;success&quot;: true, &quot;results&quot;: {&quot;b&quot;: …}}\r\n\r\nThings I tried:\r\n\r\n    $ jq &#39;del(select(.results.b | not))&#39;\r\n    {&quot;success&quot;: true, &quot;results&quot;: {&quot;a&quot;: …, &quot;b&quot;: …, &quot;c&quot;: …}}\r\n    # removes nothing from &quot;results&quot;\r\n\r\n    $ jq &#39;with_entries(select(.key == &quot;success&quot; or .key == &quot;results.b&quot;))&#39;\r\n    {&quot;success&quot;: true}\r\n    # nested comparison not understood; returns only &quot;success&quot;\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/46876940/jq-selecting-subset-of-keys-from-nested-object",
        "title": "jq: selecting subset of keys from nested object"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "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": 1,
                "creation_date": 1508763643,
                "post_id": 46889790,
                "comment_id": 80727126,
                "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": 0,
                "creation_date": 1508764049,
                "post_id": 46889790,
                "comment_id": 80727379,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1508763276,
                "creation_date": 1508763276,
                "answer_id": 46889891,
                "question_id": 46889790,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You declared the variable: result but never used it.",
                "title": "Working with Bash and cURL"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1508763955,
                "creation_date": 1508763955,
                "answer_id": 46890108,
                "question_id": 46889790,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You should process the results in jq inside the subshell.  \r\n\r\n    result=$(curl GET https://jsonplaceholder.typicode.com/posts/2 | jq &#39;.body&#39;)\r\n    echo &quot;$result&quot;\r\n\r\nfirst pointed out by @123 in a comment",
                "title": "Working with Bash and cURL"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1508763955,
        "creation_date": 1508762890,
        "last_edit_date": 1508763494,
        "question_id": 46889790,
        "body_markdown": "I posted [a question][1] here and got an answer that gave me what I needed.\r\n\r\nI have a similar problem, but one that I can&#39;t find answer for so I&#39;m asking another :/\r\n\r\nWhen I run the following command directly in the terminal, I get the correct response when piped into jq.\r\n\r\n    curl GET &quot;https://jsonplaceholder.typicode.com/posts/2&quot; | jq &#39;.body&#39;\r\n\r\n    RESPONSE: &quot;*est rerum tempore vitae\\nsequi sint nihil reprehenderit dolor beatae ea dolores neque\\nfugiat blanditiis voluptate porro vel nihil molestiae ut reiciendis\\nqui aperiam non debitis possimus qui neque nisi nulla*&quot;\r\n\r\nHowever, when I run the same command inside an executable bash script, I see no response?\r\n\r\n    result=&quot;$(curl GET https://jsonplaceholder.typicode.com/posts/2)&quot; | jq &#39;.body&#39;\r\n    echo &quot;$result&quot;\r\n    \r\nThe echoed result is an empty string.\r\n\r\nWould someone be able to point me in the right direction please, and possibly highlight some of the nuances with double/single quotations etc? I&#39;m assuming I&#39;ve making a syntax error?\r\n\r\nThanks\r\n\r\n  [1]: https://stackoverflow.com/questions/46853407/how-to-get-correct-response-from-curl-in-executable-bash-script",
        "link": "https://stackoverflow.com/questions/46889790/working-with-bash-and-curl",
        "title": "Working with Bash and cURL"
    },
    {
        "tags": [
            "json",
            "csv",
            "recursion",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1508788197,
                "creation_date": 1508788197,
                "answer_id": 46897394,
                "question_id": 46896564,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The key here is to define a recursive function, like so:\r\n\r\n    def children($parent_id):\r\n      .id as $id\r\n      | [$id, $parent_id, .text],\r\n        (.children[] | children($id)) ;\r\n\r\nWith your data, the filter:\r\n\r\n    .[]\r\n    | children(&quot;NULL&quot;)\r\n    | @tsv\r\n\r\nproduces the tab-separated values shown below.  It is now easy to add headers, convert to fixed-width format if desired, etc.\r\n\r\n    1\tNULL\tengine\r\n    2\t1\texhaust\r\n    3\t1\tcooling\r\n    4\t3\tcooling fan\r\n    5\t3\twater pump\r\n    6\tNULL\tframe\r\n    7\t6\twheels\r\n    8\t6\tbrakes\r\n    9\t8\tbrake calipers\r\n    10\t6\tcables\r\n\r\n\r\n",
                "title": "Convert JSON categories tree to database table"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1508788212,
                "creation_date": 1508788212,
                "answer_id": 46897399,
                "question_id": 46896564,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses a recursive function:\r\n\r\n    def details($parent):\r\n       [.id, $parent, .text],                   # details for current node\r\n       (.id as $p | .children[] | details($p))  # details for children\r\n    ;\r\n    \r\n      [&quot;id&quot;,&quot;parent_id&quot;,&quot;text&quot;]                 # header\r\n    , (.[] | details(null))                     # details\r\n    | @tsv                                      # convert to tsv\r\n\r\nSample Run (assumes filter in `filter.jq` and sample data in `data.json`)\r\n\r\n    $ jq -Mr -f filter.jq data.json \r\n    id\tparent_id\ttext\r\n    1\t\tengine\r\n    2\t1\texhaust\r\n    3\t1\tcooling\r\n    4\t3\tcooling fan\r\n    5\t3\twater pump\r\n    6\t\tframe\r\n    7\t6\twheels\r\n    8\t6\tbrakes\r\n    9\t8\tbrake calipers\r\n    10\t6\tcables\r\n\r\n\r\n[Try it online!][TIO-j94lhhbr]\r\n\r\n[jq]: https://stedolan.github.io/jq/\r\n[TIO-j94lhhbr]: https://tio.run/##jZDfToMwFIfveYqTzostKYtT559543sQYjp6GNWuxbZsS5yvLrZzBDaYsdz0wHe@3zm8fdTJJxGcLMiMUOJw5/wV1Uoo9HVWCMkNKrJoqJsOtStYZd0pln7RI3nbkpnWUqjVoPCuh0HO1CXpvKW3zKGBslqX53B4mob7tiE3bD281EPHWiBKeyn@sQWXhr2jHdQ9nVGQMSlKNLY/aCOeXXd@A1tKHGDTfc0xB46OCWnHVyXz39xkEQFAMhWcwvEVhWlQpRT6Z9T0Q64NZJUJDaA0x6AZew0w60Wwh2mTn6S@amMnk57mCEbPkbckYSVKfmd5PdwPm6UDwxTIOJqI@uSTFFVJGXL@2iDaw4uzG/jXGUGm1QaNA6fBd9X1ty6d0MrWcRzSYqHKyvnCsG2sK@eLHw &quot;jq – Try It Online&quot;",
                "title": "Convert JSON categories tree to database table"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1508789582,
                "creation_date": 1508789582,
                "answer_id": 46897718,
                "question_id": 46896564,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another solution which uses jq&#39;s [recurse](https://stedolan.github.io/jq/manual/#recurse\\(f\\),recurse,recurse\\(f;condition\\),recurse_down) builtin:\r\n\r\n      [&quot;id&quot;,&quot;parent_id&quot;,&quot;text&quot;]\r\n    , (\r\n          .[]\r\n        | recurse(.id as $p| .children[] | .parent=$p )\r\n        | [.id, .parent, .text]\r\n      )\r\n    | @tsv \r\n\r\nSample Run (assumes filter in `filter.jq` and sample data in `data.json`)\r\n\r\n    $ jq -Mr -f filter.jq data.json\r\n    id\tparent_id\ttext\r\n    1\t\tengine\r\n    2\t1\texhaust\r\n    3\t1\tcooling\r\n    4\t3\tcooling fan\r\n    5\t3\twater pump\r\n    6\t\tframe\r\n    7\t6\twheels\r\n    8\t6\tbrakes\r\n    9\t8\tbrake calipers\r\n    10\t6\tcables\r\n\r\n[Try it online!](https://tio.run/##dZDLbsIwEEX3fMXIYkGlJCp9F6lS/yOyKpMMxK1xXD8KUtNfr@uEmgQI481czbl3bL9/@vyb8JIsyJwkxOLOhhblmksMuqi4KDVKsojUzYDaVcwZe4zRn@SfvO3Joq4Fl@vRwLszDFZMXgq97@kts6hBuY06hdsTDQ@9YaXZZvxRj4PUClGYS@ufenCp2Qea0bjnEwoKJrhCbc4vGoPn14NvYEuBIyxtPHSVt56EKBZm9q3rOyudtNMEZhM4VJbTg2pAY@G0wVnGS2AGpqqBLG7JaQCyfejLVMHVwJcHQxKHoWnXxdw918CrNV/g/W@tLK@l8WkqnRApl8rZIDTbprWzQfwB &quot;jq – Try It Online&quot;)",
                "title": "Convert JSON categories tree to database table"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1607377116,
        "creation_date": 1508784960,
        "last_edit_date": 1508790483,
        "question_id": 46896564,
        "body_markdown": "Imagine I have a categories tree like this JSON file:\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;1&quot;,\r\n        &quot;text&quot;: &quot;engine&quot;,\r\n        &quot;children&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;2&quot;,\r\n            &quot;text&quot;: &quot;exhaust&quot;,\r\n            &quot;children&quot;: []\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;3&quot;,\r\n            &quot;text&quot;: &quot;cooling&quot;,\r\n            &quot;children&quot;: [\r\n              {\r\n                &quot;id&quot;: &quot;4&quot;,\r\n                &quot;text&quot;: &quot;cooling fan&quot;,\r\n                &quot;children&quot;: []\r\n              },\r\n              {\r\n                &quot;id&quot;: &quot;5&quot;,\r\n                &quot;text&quot;: &quot;water pump&quot;,\r\n                &quot;children&quot;: []\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;6&quot;,\r\n        &quot;text&quot;: &quot;frame&quot;,\r\n        &quot;children&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;7&quot;,\r\n            &quot;text&quot;: &quot;wheels&quot;,\r\n            &quot;children&quot;: []\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;8&quot;,\r\n            &quot;text&quot;: &quot;brakes&quot;,\r\n            &quot;children&quot;: [\r\n              {\r\n                &quot;id&quot;: &quot;9&quot;,\r\n                &quot;text&quot;: &quot;brake calipers&quot;,\r\n                &quot;children&quot;: []\r\n              }\r\n            ]\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;10&quot;,\r\n            &quot;text&quot;: &quot;cables&quot;,\r\n            &quot;children&quot;: []\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nHow can I convert it to this flat table?\r\n\r\n    id\tparent_id\ttext\r\n    1\tNULL\t    engine\r\n    2\t1\t        exhaust\r\n    3\t1\t        cooling\r\n    4\t3\t        cooling fan\r\n    5\t3\t        water pump\r\n    6\tNULL\t    frame\r\n    7\t6\t        wheels\r\n    8\t6\t        brakes\r\n    9\t8\t        brake calipers\r\n    10\t6\t        cables\r\n\r\nI found similar questions and inverted questions (from table to JSON) but I can&#39;t figure it out with jq and its @tsv filter. Also I noticed the &quot;flatten&quot; filter is not often referenced in the answers (while it looks to be the exact tool I need) but it might be because it was introduced recently in the latests versions of jq.",
        "link": "https://stackoverflow.com/questions/46896564/convert-json-categories-tree-to-database-table",
        "title": "Convert JSON categories tree to database table"
    },
    {
        "tags": [
            "json",
            "jq",
            "string-literals"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508827250,
                "post_id": 46903037,
                "comment_id": 80754085,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 5275501,
                    "reputation": 770,
                    "user_id": 4212430,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://lh4.googleusercontent.com/-GVNLcRjg1oY/AAAAAAAAAAI/AAAAAAAAAAA/-RDrCON4sHQ/s256-rj/photo.jpg",
                    "display_name": "Balajee Addanki",
                    "link": "https://stackoverflow.com/users/4212430/balajee-addanki"
                },
                "reply_to_user": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508827999,
                "post_id": 46903037,
                "comment_id": 80754537,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508828509,
                "post_id": 46903037,
                "comment_id": 80754852,
                "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": 1508846269,
                "post_id": 46903037,
                "comment_id": 80766427,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1508829386,
                "last_edit_date": 1508829386,
                "creation_date": 1508826784,
                "answer_id": 46903634,
                "question_id": 46903037,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your input &quot;JSON&quot; is not valid JSON, as indicated by the error message.  \r\n\r\nThe first error is that a comma is missing after the key/value pair: &quot;delivery_format&quot;: &quot;csv&quot;, but there are others -- notably, JSON strings cannot be split across lines.  Once you fix the key/value pair problem and the JSON strings that are split incorrectly, `jq .` will work with your text. (Note that once your input is corrected, the longest JSON string is quite short -- 50 characters or so -- whereas jq has no problems processing strings of length 10^8 quite speedily ...)\r\n\r\nGenerally, jq is rather permissive when it comes to JSON-like input, but if you&#39;re ever in doubt, it would make sense to use a validator such as the online validator at jsonlint.com\r\n\r\nBy the way, the jq FAQ does suggest various ways for handling input that isn&#39;t strictly JSON -- see https://github.com/stedolan/jq/wiki/FAQ#processing-not-quite-valid-json",
                "title": "jq construct with value strings spanning multiple lines"
            },
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1508846565,
                "creation_date": 1508846565,
                "answer_id": 46910083,
                "question_id": 46903037,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use `jq` itself:\r\n\r\n    my_formatted_json=$(jq -n &#39;{\r\n      &quot;api_key&quot;: &quot;XXXXXXXXXX-7AC9-D655F83B4825&quot;,\r\n      &quot;app_guid&quot;: &quot;XXXXXXXXXXXXXX&quot;,\r\n      &quot;time_start&quot;: 1508677200,\r\n      &quot;time_end&quot;: 1508763600,\r\n      &quot;traffic&quot;: [&quot;event&quot;],\r\n      &quot;traffic_including&quot;: [&quot;unattributed_traffic&quot;],\r\n      &quot;time_zone&quot;: &quot;Australia/NSW&quot;,\r\n      &quot;delivery_format&quot;: &quot;csv&quot;,\r\n      &quot;columns_order&quot;: [\r\n        &quot;attribution_attribution_action&quot;,\r\n        &quot;attribution_campaign&quot;,\r\n        ...,\r\n        &quot;timestamp_utc&quot;\r\n      ]\r\n    }&#39;)",
                "title": "jq construct with value strings spanning multiple lines"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1508871104,
                "creation_date": 1508871104,
                "answer_id": 46917988,
                "question_id": 46903037,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Along the lines of [chepner](https://stackoverflow.com/a/46910083/8379597)&#39;s suggestion since jq can read raw text data you could just use a jq filter to generate a legal json object from your script variables.  For example:\r\n\r\n&lt;!-- language-all: lang-bash --&gt;\r\n\r\n    #!/bin/bash\r\n    \r\n    # whatever logic you have to obtain bash variables goes here\r\n    key=XXXXXXXXXX-7AC9-D655F83B4825\r\n    guid=XXXXXXXXXXXXXX\r\n    \r\n    # now use jq filter to read raw text and construct legal json object\r\n    json_construct=$(jq -MRn &#39;[inputs]|map(split(&quot; &quot;)|{(.[0]):.[1]})|add&#39; &lt;&lt;EOF\r\n    api_key $key\r\n    app_guid $guid\r\n    EOF)\r\n    \r\n    echo $json_construct\r\n\r\nSample Run (assumes executable script is in `script.sh`)\r\n\r\n    $ ./script.sh\r\n    { &quot;api_key&quot;: &quot;XXXXXXXXXX-7AC9-D655F83B4825&quot;, &quot;app_guid&quot;: &quot;XXXXXXXXXXXXXX&quot; }\r\n\r\n[Try it online!][TIO-j95yrahz]\r\n\r\n[Bash]: https://www.gnu.org/software/bash/\r\n[TIO-j95yrahz]: https://tio.run/##VU9NT4NAEL3vrxhbksKB1i@0mvbgV2@NiScTQsgAIyziLu4uYCP@dty9NPoOL/MyL/PeZKiraZqfrDIuVpkVjM1hqNBQTwoaWfIcDrKDCnsCI0FmBrkA54QeFcesIQ2ltFSRIvZOh@3rEeH13cNN@HgVRbv1xf3l@jxiZceLPw4HFynkAJ0mqD/hjTfGZtswRViAwgEMfRlAUUAuhTaqyw00VGIDtZbCdqopN8zN6dGw9Xx7K9y/CFjEXLSd0cn4ga2v24YbfwazYPz2l/FpEtwu47PkJxixKBaw2Tw97xi2PLWvgGfJijZ1tcFzzOw@YIzySoL3P3OafgE &quot;Bash – Try It Online&quot;",
                "title": "jq construct with value strings spanning multiple lines"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1508871104,
        "creation_date": 1508824140,
        "question_id": 46903037,
        "body_markdown": "I am trying to form a JSON construct using `jq` that should ideally look like below:-\r\n\r\n    {\r\n      &quot;api_key&quot;: &quot;XXXXXXXXXX-7AC9-D655F83B4825&quot;,\r\n      &quot;app_guid&quot;: &quot;XXXXXXXXXXXXXX&quot;,\r\n      &quot;time_start&quot;: 1508677200,\r\n      &quot;time_end&quot;: 1508763600,\r\n      &quot;traffic&quot;: [\r\n        &quot;event&quot;\r\n      ],\r\n      &quot;traffic_including&quot;: [\r\n        &quot;unattributed_traffic&quot;\r\n      ],\r\n      &quot;time_zone&quot;: &quot;Australia/NSW&quot;,\r\n      &quot;delivery_format&quot;: &quot;csv&quot;,\r\n      &quot;columns_order&quot;: [\r\n    \t&quot;attribution_attribution_action&quot;,\r\n    \t&quot;attribution_campaign&quot;,\r\n    \t&quot;attribution_campaign_id&quot;,\r\n    \t&quot;attribution_creative&quot;,\r\n    \t&quot;attribution_date_adjusted&quot;,\r\n    \t&quot;attribution_date_utc&quot;,\r\n    \t&quot;attribution_matched_by&quot;,\r\n    \t&quot;attribution_matched_to&quot;,\r\n    \t&quot;attribution_network&quot;,\r\n    \t&quot;attribution_network_id&quot;,\r\n    \t&quot;attribution_seconds_since&quot;,\r\n    \t&quot;attribution_site_id&quot;,\r\n    \t&quot;attribution_site_id&quot;,\r\n    \t&quot;attribution_tier&quot;,\r\n    \t&quot;attribution_timestamp&quot;,\r\n    \t&quot;attribution_timestamp_adjusted&quot;,\r\n    \t&quot;attribution_tracker&quot;,\r\n    \t&quot;attribution_tracker_id&quot;,\r\n    \t&quot;attribution_tracker_name&quot;,\r\n    \t&quot;count&quot;,\r\n    \t&quot;custom_dimensions&quot;,\r\n    \t&quot;device_id_adid&quot;,\r\n    \t&quot;device_id_android_id&quot;,\r\n    \t&quot;device_id_custom&quot;,\r\n    \t&quot;device_id_idfa&quot;,\r\n    \t&quot;device_id_idfv&quot;,\r\n    \t&quot;device_id_kochava&quot;,\r\n    \t&quot;device_os&quot;,\r\n    \t&quot;device_type&quot;,\r\n    \t&quot;device_version&quot;,\r\n    \t&quot;dimension_count&quot;,\r\n    \t&quot;dimension_data&quot;,\r\n    \t&quot;dimension_sum&quot;,\r\n    \t&quot;event_name&quot;,\r\n    \t&quot;event_time_registered&quot;,\r\n    \t&quot;geo_city&quot;,\r\n    \t&quot;geo_country&quot;,\r\n    \t&quot;geo_lat&quot;,\r\n    \t&quot;geo_lon&quot;,\r\n    \t&quot;geo_region&quot;,\r\n    \t&quot;identity_link&quot;,\r\n    \t&quot;install_date_adjusted&quot;,\r\n    \t&quot;install_date_utc&quot;,\r\n    \t&quot;install_device_version&quot;,\r\n    \t&quot;install_devices_adid&quot;,\r\n    \t&quot;install_devices_android_id&quot;,\r\n    \t&quot;install_devices_custom&quot;,\r\n    \t&quot;install_devices_email_0&quot;,\r\n    \t&quot;install_devices_email_1&quot;,\r\n    \t&quot;install_devices_idfa&quot;,\r\n    \t&quot;install_devices_ids&quot;,\r\n    \t&quot;install_devices_ip&quot;,\r\n    \t&quot;install_devices_waid&quot;,\r\n    \t&quot;install_matched_by&quot;,\r\n    \t&quot;install_matched_on&quot;,\r\n    \t&quot;install_receipt_status&quot;,\r\n    \t&quot;install_san_original&quot;,\r\n    \t&quot;install_status&quot;,\r\n    \t&quot;request_ip&quot;,\r\n    \t&quot;request_ua&quot;,\r\n    \t&quot;timestamp_adjusted&quot;,\r\n    \t&quot;timestamp_utc&quot;\r\n      ]\r\n    }\r\n\r\nWhat I have tried unsuccessfully thus far is below:-\r\n\r\n    json_construct=$(cat &lt;&lt;EOF\r\n    {\r\n    &quot;api_key&quot;: &quot;6AEC90B5-4169-59AF-7AC9-D655F83B4825&quot;,\r\n    &quot;app_guid&quot;: &quot;komacca-s-rewards-app-au-ios-production-cv8tx71&quot;,\r\n    &quot;time_start&quot;: 1508677200,\r\n    &quot;time_end&quot;: 1508763600,\r\n    &quot;traffic&quot;: [&quot;event&quot;],\r\n    &quot;traffic_including&quot;: [&quot;unattributed_traffic&quot;],\r\n    &quot;time_zone&quot;: &quot;Australia/NSW&quot;,\r\n    &quot;delivery_format&quot;: &quot;csv&quot;\r\n    &quot;columns_order&quot;: [&quot;attribution_attribution_action&quot;,&quot;attribution_campaign&quot;,&quot;attribution_campaign_id&quot;,&quot;attribution_creative&quot;,&quot;attribution_date_adjusted&quot;,&quot;attribution_date_utc&quot;,&quot;attribution_matched_by&quot;,&quot;attribution_matched_to&quot;,&quot;attributio\r\n    network&quot;,&quot;attribution_network_id&quot;,&quot;attribution_seconds_since&quot;,&quot;attribution_site_id&quot;,&quot;attribution_tier&quot;,&quot;attribution_timestamp&quot;,&quot;attribution_timestamp_adjusted&quot;,&quot;attribution_tracker&quot;,&quot;attribution_tracker_id&quot;,&quot;attribution_tracker_name&quot;,&quot;\r\n    unt&quot;,&quot;custom_dimensions&quot;,&quot;device_id_adid&quot;,&quot;device_id_android_id&quot;,&quot;device_id_custom&quot;,&quot;device_id_idfa&quot;,&quot;device_id_idfv&quot;,&quot;device_id_kochava&quot;,&quot;device_os&quot;,&quot;device_type&quot;,&quot;device_version&quot;,&quot;dimension_count&quot;,&quot;dimension_data&quot;,&quot;dimension_sum&quot;,&quot;ev\r\n    t_name&quot;,&quot;event_time_registered&quot;,&quot;geo_city&quot;,&quot;geo_country&quot;,&quot;geo_lat&quot;,&quot;geo_lon&quot;,&quot;geo_region&quot;,&quot;identity_link&quot;,&quot;install_date_adjusted&quot;,&quot;install_date_utc&quot;,&quot;install_device_version&quot;,&quot;install_devices_adid&quot;,&quot;install_devices_android_id&quot;,&quot;install_\r\n    vices_custom&quot;,&quot;install_devices_email_0&quot;,&quot;install_devices_email_1&quot;,&quot;install_devices_idfa&quot;,&quot;install_devices_ids&quot;,&quot;install_devices_ip&quot;,&quot;install_devices_waid&quot;,&quot;install_matched_by&quot;,&quot;install_matched_on&quot;,&quot;install_receipt_status&quot;,&quot;install_san_\r\n    iginal&quot;,&quot;install_status&quot;,&quot;request_ip&quot;,&quot;request_ua&quot;,&quot;timestamp_adjusted&quot;,&quot;timestamp_utc&quot;]\r\n    }\r\n    EOF)\r\n\r\nfollowed by:- \r\n\r\n    echo &quot;$json_construct&quot; | jq &#39;.&#39;\r\n\r\nI get the following error:- \r\n\r\n&gt; parse error: Expected separator between values at line 10, column 15\r\n\r\nI am guessing it is because of the string literal which spans to multiple lines that `jq` is unable to parse it.",
        "link": "https://stackoverflow.com/questions/46903037/jq-construct-with-value-strings-spanning-multiple-lines",
        "title": "jq construct with value strings spanning multiple lines"
    },
    {
        "tags": [
            "json",
            "jq",
            "weaviate"
        ],
        "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": 1508851638,
                "post_id": 46910840,
                "comment_id": 80770506,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1508851752,
                "post_id": 46910840,
                "comment_id": 80770602,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1625671,
                    "reputation": 7668,
                    "user_id": 1501285,
                    "user_type": "registered",
                    "accept_rate": 66,
                    "profile_image": "https://www.gravatar.com/avatar/b742182dd480420da7e0e9fe357b2c04?s=256&d=identicon&r=PG",
                    "display_name": "Bob van Luijt",
                    "link": "https://stackoverflow.com/users/1501285/bob-van-luijt"
                },
                "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": 1508864825,
                "post_id": 46910840,
                "comment_id": 80779766,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1508851918,
                "creation_date": 1508851918,
                "answer_id": 46911892,
                "question_id": 46910840,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Simple adjustment:\r\n\r\n    jq --arg dgraphip &quot;1.2.3.4&quot; &#39;{&quot;environments&quot; : .environments \r\n     | map(select(.name | contains(&quot;docker&quot;)) \r\n     | .database.database_config.host = $dgraphip)}&#39; weaviate.conf.json\r\n\r\nThe output:\r\n\r\n    {\r\n      &quot;environments&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;docker&quot;,\r\n          &quot;database&quot;: {\r\n            &quot;name&quot;: &quot;dgraph&quot;,\r\n            &quot;database_config&quot;: {\r\n              &quot;host&quot;: &quot;1.2.3.4&quot;,\r\n              &quot;port&quot;: 9080\r\n            }\r\n          },\r\n          &quot;schemas&quot;: {\r\n            &quot;Thing&quot;: &quot;https://raw.githubusercontent.com/weaviate/weaviate-semantic-schemas/master/weaviate-Thing-ontology-schema_org.min.json&quot;,\r\n            &quot;Action&quot;: &quot;https://raw.githubusercontent.com/weaviate/weaviate-semantic-schemas/master/weaviate-Action-ontology-schema_org.min.json&quot;\r\n          },\r\n          &quot;mqttEnabled&quot;: false\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "How to get the complete object / array with jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1508872028,
                "creation_date": 1508872028,
                "answer_id": 46918231,
                "question_id": 46910840,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another approach which uses [update assignment `|=`](https://stedolan.github.io/jq/manual/#Update-assignment:|=) with [map](https://stedolan.github.io/jq/manual/#map\\(x\\),map_values\\(x\\))\r\n\r\n    .environments |= map(      \r\n         select(.name | contains(&quot;docker&quot;))\r\n       | .database.database_config.host = &quot;1.2.3.4&quot;\r\n    ) \r\n\r\nSample Run (assumes data in `data.json`)\r\n\r\n    $ jq -M &#39;.environments |= map(select(.name | contains(&quot;docker&quot;)) | .database.database_config.host = &quot;1.2.3.4&quot;)&#39; data.json\r\n    {\r\n      &quot;environments&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;docker&quot;,\r\n          &quot;database&quot;: {\r\n            &quot;name&quot;: &quot;dgraph&quot;,\r\n            &quot;database_config&quot;: {\r\n              &quot;host&quot;: &quot;1.2.3.4&quot;,\r\n              &quot;port&quot;: 9080\r\n            }\r\n          },\r\n          &quot;schemas&quot;: {\r\n            &quot;Thing&quot;: &quot;https://raw.githubusercontent.com/weaviate/weaviate-semantic-schemas/master/weaviate-Thing-ontology-schema_org.min.json&quot;,\r\n            &quot;Action&quot;: &quot;https://raw.githubusercontent.com/weaviate/weaviate-semantic-schemas/master/weaviate-Action-ontology-schema_org.min.json&quot;\r\n          },\r\n          &quot;mqttEnabled&quot;: false\r\n        }\r\n      ]\r\n    }\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/d9K97QJKHK)",
                "title": "How to get the complete object / array with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1551182140,
        "creation_date": 1508848697,
        "last_edit_date": 1551182140,
        "question_id": 46910840,
        "body_markdown": "I&#39;m running: \r\n\r\n    $ jq &quot;.environments[] | select(.name | contains(\\&quot;docker\\&quot;)) | .database.database_config.host = \\&quot;${DGRAPHIP}\\&quot;&quot; weaviate.conf.json\r\n\r\non this file: https://github.com/weaviate/weaviate/blob/develop/weaviate.conf.json\r\n\r\nThe output of this is (if `DGRAPHIP = 1.2.3.4`):\r\n\r\n    {\r\n      &quot;name&quot;: &quot;docker&quot;,\r\n      &quot;database&quot;: {\r\n        &quot;name&quot;: &quot;dgraph&quot;,\r\n        &quot;database_config&quot;: {\r\n          &quot;host&quot;: &quot;1.2.3.4&quot;, &lt;== THIS IS GOOD!\r\n          &quot;port&quot;: 9080\r\n        }\r\n      },\r\n      &quot;schemas&quot;: {\r\n        &quot;Thing&quot;: &quot;https://raw.githubusercontent.com/weaviate/weaviate-semantic-schemas/master/weaviate-Thing-ontology-s\r\n    chema_org.min.json&quot;,\r\n        &quot;Action&quot;: &quot;https://raw.githubusercontent.com/weaviate/weaviate-semantic-schemas/master/weaviate-Action-ontology\r\n    -schema_org.min.json&quot;\r\n      },\r\n      &quot;mqttEnabled&quot;: false\r\n    }\r\n\r\nThis is not the desired outcome, I would like the outcome to be encapsulated like:\r\n\r\n    {\r\n        &quot;environments&quot;: [{\r\n            RESULTS\r\n        }]\r\n    }",
        "link": "https://stackoverflow.com/questions/46910840/how-to-get-the-complete-object-array-with-jq",
        "title": "How to get the complete object / array with jq?"
    },
    {
        "tags": [
            "type-conversion",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 412243,
                    "reputation": 3776,
                    "user_id": 785213,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4afc5a37218ad4f1d104492e4b4d3657?s=256&d=identicon&r=PG",
                    "display_name": "Kevin E",
                    "link": "https://stackoverflow.com/users/785213/kevin-e"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1598443468,
                "post_id": 46911763,
                "comment_id": 112459695,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 24,
                "is_accepted": false,
                "score": 24,
                "last_activity_date": 1508875810,
                "last_edit_date": 1508875810,
                "creation_date": 1508852408,
                "answer_id": 46912064,
                "question_id": 46911763,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Convert number to string with `tostring` function:\r\n\r\n    jq -r &#39;.[] | select(.name==&quot;AAA&quot;) | (.members|tostring) +&quot; &quot;+ .id test&#39;",
                "title": "jq: error: number and string cannot be added"
            },
            {
                "up_vote_count": 26,
                "is_accepted": true,
                "score": 26,
                "last_activity_date": 1508854867,
                "last_edit_date": 1508854867,
                "creation_date": 1508854541,
                "answer_id": 46912879,
                "question_id": 46911763,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I recommend to use [*string interpolation*][1]. It will automatically cast input to a string if necessary:\r\n\r\n    jq -r &#39;.[]|select(.name==&quot;AAA&quot;)|&quot;\\(.members) \\(.id)&quot;&#39; file.json\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Stringinterpolation-%5C(foo)",
                "title": "jq: error: number and string cannot be added"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1508857748,
                "last_edit_date": 1508857748,
                "creation_date": 1508855940,
                "answer_id": 46913441,
                "question_id": 46911763,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You have not specified precisely how you want the two values to appear, so it is worth pointing out that you could write:\r\n\r\n    .... | (.members, .id)\r\n\r\nor\r\n\r\n     .... | [.members, .id]\r\n\r\nor\r\n\r\n    .... | [.members, .id] | E\r\n\r\nwhere E could be @csv or @tsv or etc. In jq 1.5, `join/1` will also do the type conversion.\r\n\r\n",
                "title": "jq: error: number and string cannot be added"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1508869785,
                "creation_date": 1508869785,
                "answer_id": 46917621,
                "question_id": 46911763,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could start by just projecting the members of interest. e.g\r\n\r\n    $ jq -Mc &#39;.[] | select(.name==&quot;AAA&quot;) | {members,id}&#39; data.json\r\n    {&quot;members&quot;:10,&quot;id&quot;:&quot;20&quot;}\r\n\r\nNow you can see `.members` is a number and `.id` is a string.  You can&#39;t add them directly with `+` but you can choose any of the options explained in the other answers.  ",
                "title": "jq: error: number and string cannot be added"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 29,
        "last_activity_date": 1508903292,
        "creation_date": 1508851456,
        "last_edit_date": 1508903292,
        "question_id": 46911763,
        "body_markdown": "I&#39;d like to print the value of members and id from below jq output:\r\n\r\n    $ cat test_|jq -r &#39;.[] | select(.name==&quot;AAA&quot;) | .&#39;\r\n    {\r\n      &quot;name&quot;: &quot;AAA&quot;,\r\n      &quot;members&quot;: 10,\r\n      &quot;profiles&quot;: 0,\r\n      &quot;templates&quot;: 0,\r\n      &quot;ldapGroups&quot;: 0,\r\n      &quot;ldapMembers&quot;: 0,\r\n      &quot;id&quot;: &quot;20&quot;\r\n    }\r\n\r\nUnfortunately it works for one of each only:\r\n\r\n    $ cat test_|jq -r &#39;.[] | select(.name==&quot;AAA&quot;) | .members&#39;\r\n    10\r\n\r\nwith +&quot; &quot;+ I get error:\r\n\r\n\r\n    $ cat test_|jq -r &#39;.[] | select(.name==&quot;AAA&quot;) | .members+&quot; &quot;+.id&#39;\r\n    jq: error: number and string cannot be added\r\n\r\n",
        "link": "https://stackoverflow.com/questions/46911763/jq-error-number-and-string-cannot-be-added",
        "title": "jq: error: number and string cannot be added"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1508879333,
                "last_edit_date": 1508879333,
                "creation_date": 1508861253,
                "answer_id": 46915233,
                "question_id": 46915043,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With **jq** **`sub()`** function:\r\n\r\n    jq &#39;.records[].time |= sub(&quot;[0-9]{3}$&quot;;&quot;&quot;)&#39; file\r\nThe output:\r\n\r\n    {\r\n      &quot;records&quot;: [\r\n        {\r\n          &quot;time&quot;: &quot;123456789&quot;\r\n        },\r\n        {\r\n          &quot;time&quot;: &quot;123456789&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n----------\r\nOr even simpler: via dividing the `time` value by `1000`:\r\n\r\n    jq &#39;.records[].time |= (tonumber / 1000 | tostring)&#39; file\r\n\r\n",
                "title": "Perform string manipulation on a value and return the original JSON document with jq"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1508866987,
                "creation_date": 1508866987,
                "answer_id": 46916847,
                "question_id": 46915043,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using `|=` and [string slicing](https://stedolan.github.io/jq/manual/#Array/StringSlice:.[10:15])\r\n\r\n    .records[].time |= .[:-3]\r\n\r\nSample Run (assuming data in `data.json`)\r\n\r\n    $ jq -M &#39;.records[].time |= .[:-3]&#39; data.json\r\n    {\r\n      &quot;records&quot;: [\r\n        {\r\n          &quot;time&quot;: &quot;123456789&quot;\r\n        },\r\n        {\r\n          &quot;time&quot;: &quot;123456789&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/VzYkL1HfnY)",
                "title": "Perform string manipulation on a value and return the original JSON document with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1508879712,
                "last_edit_date": 1508879712,
                "creation_date": 1508873381,
                "answer_id": 46918593,
                "question_id": 46915043,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following works with jq version 1.4 or later:\r\n\r\n    jq &#39;.records[].time |= .[:-3]&#39; file.json\r\n\r\n(The expression `.[:-3]` is short for `.[0:-3]`; the negative integer here counts from the right.)\r\n\r\nWith jq 1.3, the following filter would work in your particular case:\r\n\r\n    .records[].time |= (tonumber | ./1000 | tostring)",
                "title": "Perform string manipulation on a value and return the original JSON document with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1705685650,
        "creation_date": 1508860650,
        "last_edit_date": 1705685650,
        "question_id": 46915043,
        "body_markdown": "In my JSON document I have a string that I need manipulated and then have the entire document returned with the &#39;fixed&#39; values.\r\n\r\nThe input document is:\r\n\r\n    {\r\n        &quot;records&quot; : [\r\n                {\r\n                    &quot;time&quot;: &quot;123456789000&quot;\r\n                    \r\n                },\r\n                {\r\n                    &quot;time&quot;: &quot;123456789000&quot;\r\n                }\r\n            \r\n        ]\r\n    }\r\n\r\nI want to find the &quot;time&quot; key and replace the string by dropping off the last 3 chars. The resulting document would be:\r\n\r\n    {\r\n        &quot;records&quot; : [\r\n                {\r\n                    &quot;time&quot;: &quot;123456789&quot;\r\n    \r\n                },\r\n                {\r\n                    &quot;time&quot;: &quot;123456789&quot;\r\n                }\r\n    \r\n        ]\r\n    }\r\n\r\nI&#39;ve been trying to understand the jq query syntax but I&#39;m not coming right. I&#39;m still struggling to return the whole document when filtering on a specific value. All I have so far is:\r\n\r\n    .records[] | select(.time | contains(&quot;123456789000&quot;))\r\n\r\n",
        "link": "https://stackoverflow.com/questions/46915043/perform-string-manipulation-on-a-value-and-return-the-original-json-document-wit",
        "title": "Perform string manipulation on a value and return the original JSON document with jq"
    },
    {
        "tags": [
            "amazon-web-services",
            "amazon-ec2",
            "aws-cli",
            "jq",
            "jmespath"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1471109,
                    "reputation": 2459,
                    "user_id": 3182139,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/bf4b21b5fc705c9484d71281b6a4986d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "LHWizard",
                    "link": "https://stackoverflow.com/users/3182139/lhwizard"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1510178311,
                "post_id": 46938368,
                "comment_id": 81330173,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1907209,
                    "reputation": 1869,
                    "user_id": 1734032,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xFnWL1Ci.jpg?s=256",
                    "display_name": "mckenzm",
                    "link": "https://stackoverflow.com/users/1734032/mckenzm"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1738199337,
                "post_id": 46938368,
                "comment_id": 140022193,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1515735060,
                "last_edit_date": 1515735060,
                "creation_date": 1508955877,
                "answer_id": 46939584,
                "question_id": 46938368,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You need to use advanced *JMESPath* conditions. See if the below cli command satisfies what you are asking.\r\n\r\n    aws ec2 describe-security-groups \\\r\n        --filters &quot;Name=ip-permission.to-port,Values=22&quot; \\\r\n        --query &#39;SecurityGroups[?IpPermissions[?ToPort==`22` &amp;&amp; contains(IpRanges[].CidrIp, `0.0.0.0/0`)]].{GroupId: GroupId, GroupName: GroupName}&#39; \\\r\n        --output json \\\r\n        --region us-east-1\r\n\r\n",
                "title": "Filtering AWS CLI output for security groups that have specific port and IP ACLs"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1508958342,
                "creation_date": 1508958342,
                "answer_id": 46940244,
                "question_id": 46938368,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**jq** solution to filter out *security groups* with empty nested data:\r\n\r\n    aws ec2 describe-security-groups --output json --query &#39;SecurityGroups[*].[GroupName,GroupId,IpPermissions[?ToPort==`22`]\r\n    .[IpRanges[?CidrIp==`0.0.0.0/0`]]]&#39; | jq &#39;map(select(.[2] | flatten | length &gt; 0))&#39;\r\nThe output:\r\n\r\n    [\r\n      [\r\n        &quot;SG 1&quot;,\r\n        &quot;sg-11111111&quot;,\r\n        [\r\n          [\r\n            [\r\n              {\r\n                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n              }\r\n            ]\r\n          ]\r\n        ]\r\n      ]\r\n    ]\r\n\r\n",
                "title": "Filtering AWS CLI output for security groups that have specific port and IP ACLs"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1508958596,
                "creation_date": 1508958596,
                "answer_id": 46940312,
                "question_id": 46938368,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a jq filter which will return only SecurityGroups with an IpPermission with FromPort=22 and an IpRange CidrIp of &quot;0.0.0.0/0&quot;:\r\n\r\n      .SecurityGroups[]\r\n    | select(.IpPermissions[] | .FromPort == 22 and .IpRanges[].CidrIp == &quot;0.0.0.0/0&quot;)\r\n\r\nSample Run (assuming filter in `filter.jq` and data in `data.json`)\r\n\r\n    $ jq -M -f filter.jq data.json\r\n    {\r\n      &quot;Description&quot;: &quot;SG 1&quot;,\r\n      &quot;IpPermissions&quot;: [\r\n        {\r\n          &quot;PrefixListIds&quot;: [],\r\n          &quot;FromPort&quot;: 22,\r\n          &quot;IpRanges&quot;: [\r\n            {\r\n              &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n            }\r\n          ],\r\n          &quot;ToPort&quot;: 22,\r\n          &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n          &quot;UserIdGroupPairs&quot;: [],\r\n          &quot;Ipv6Ranges&quot;: []\r\n        }\r\n      ],\r\n      &quot;GroupName&quot;: &quot;SG 1&quot;,\r\n      &quot;VpcId&quot;: &quot;vpc-12345678&quot;,\r\n      &quot;OwnerId&quot;: &quot;1234567890&quot;,\r\n      &quot;GroupId&quot;: &quot;sg-11111111&quot;\r\n    }\r\n\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/GxsLPIvgX5)",
                "title": "Filtering AWS CLI output for security groups that have specific port and IP ACLs"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 4,
        "last_activity_date": 1515735060,
        "creation_date": 1508951657,
        "last_edit_date": 1508969951,
        "question_id": 46938368,
        "body_markdown": "I&#39;m having difficulty filtering AWS CLI describe-security-groups output\r\n\r\nGoal: Find all SGs with ingress rules on port 22 with cidr 0.0.0.0/0\r\n\r\nAmazons&#39; own docs provide an example, but state there&#39;s a limitation with their query in that it will first filter the entire data set for port 22 then filter that entire data set for 0.0.0.0/0.  What this means is that SGs with the following rules will still trigger:\r\n\r\n    ingress 22 sg-12345678\r\n    ingress 443 0.0.0.0/0\r\n\r\nThis completely defeats the purpose of the filtering, and I&#39;m not even sure why Amazon provides that example with a heading of &quot;To describe security groups that have specific rules&quot;\r\n\r\n**Route 1: aws cli query first then jq**\r\n\r\nThis route is based off what I found here: https://github.com/aws/aws-cli/issues/971\r\n\r\n    aws ec2 describe-security-groups --output json --query &#39;SecurityGroups[*].[GroupName,GroupId,IpPermissions[?ToPort==`22`].[IpRanges[?CidrIp==`0.0.0.0/0`]]]&#39;\r\n\r\nWhich provides a list of *all security groups*, but showing nested data for any SGs with 22 0.0.0.0/0 (and successfully ignoring any 0.0.0.0/0 ACLs for other ports)  In the output below, SG1 is what I&#39;m interested, and SG2/SG3 needs to be filtered out.\r\n\r\n\r\n    [\r\n        [\r\n            &quot;SG 1&quot;, \r\n            &quot;sg-11111111&quot;, \r\n            [\r\n                [\r\n                    [\r\n                        {\r\n                            &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                        }\r\n                    ]\r\n                ]\r\n            ]\r\n        ],\r\n        [\r\n            &quot;SG 2&quot;,\r\n            &quot;sg-22222222&quot;,\r\n            [\r\n                [\r\n                    []\r\n                ]\r\n            ]\r\n        ],\r\n        [\r\n            &quot;SG 3&quot;, \r\n            &quot;sg-33333333&quot;, \r\n            []\r\n        ]\r\n    ]\r\n\r\nThis is a great first step as I&#39;ve eliminated 0.0.0.0/0 ACLs that aren&#39;t associated with port 22.  But as I try to run jq to simply remove entries that have empty data sets, I&#39;m having difficulty cause all the keys have been stripped.  \r\n\r\n - As I try to select deeper into the nested sections, I end up with errors like cannot iterate over null\r\n - If I try to use contains, I just get back nothing, so I&#39;m not even sure where I&#39;m going wrong there\r\n\r\n**Route 2: jq un-queried CLI output**\r\n\r\nI&#39;ve been unable to get away from the pitfall of the original AWS example by using jq from the start, where I can first query for all SGs that contain port 22, then query for any ACLs of 0.0.0.0/0, which of course gives me false positives.\r\nDue to the stream nature of jq, I haven&#39;t figured out how to check condition A (port 22) then check condition B (0.0.0.0/0) only on items related to condition A.\r\n\r\nHere&#39;s some sanitized raw CLI output of 2 SGs, again, I need to get the first one without triggering a false positive on the 2nd\r\n\r\n    {\r\n        &quot;SecurityGroups&quot;: [\r\n            {\r\n                &quot;Description&quot;: &quot;SG 1&quot;, \r\n                &quot;IpPermissions&quot;: [\r\n                    {\r\n                        &quot;PrefixListIds&quot;: [], \r\n                        &quot;FromPort&quot;: 22, \r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ], \r\n                        &quot;ToPort&quot;: 22, \r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;, \r\n                        &quot;UserIdGroupPairs&quot;: [], \r\n                        &quot;Ipv6Ranges&quot;: []\r\n                    }\r\n                ], \r\n                &quot;GroupName&quot;: &quot;SG 1&quot;,\r\n                &quot;VpcId&quot;: &quot;vpc-12345678&quot;, \r\n                &quot;OwnerId&quot;: &quot;1234567890&quot;, \r\n                &quot;GroupId&quot;: &quot;sg-11111111&quot;\r\n            }, \r\n            {\r\n                &quot;Description&quot;: &quot;SG 2&quot;, \r\n                &quot;IpPermissions&quot;: [\r\n                    {\r\n                        &quot;PrefixListIds&quot;: [], \r\n                        &quot;FromPort&quot;: 22, \r\n                        &quot;IpRanges&quot;: [], \r\n                        &quot;ToPort&quot;: 22, \r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;, \r\n                        &quot;UserIdGroupPairs&quot;: [\r\n                            {\r\n                                &quot;UserId&quot;: &quot;1234567890&quot;, \r\n                                &quot;GroupId&quot;: &quot;sg-abcdefab&quot;\r\n                            }\r\n                        ], \r\n                        &quot;Ipv6Ranges&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;PrefixListIds&quot;: [], \r\n                        &quot;FromPort&quot;: 443, \r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ], \r\n                        &quot;ToPort&quot;: 443, \r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;, \r\n                        &quot;UserIdGroupPairs&quot;: [], \r\n                        &quot;Ipv6Ranges&quot;: []\r\n                    }\r\n                ], \r\n                &quot;GroupName&quot;: &quot;SG 2&quot;, \r\n                &quot;VpcId&quot;: &quot;vpc-12345678&quot;, \r\n                &quot;OwnerId&quot;: &quot;1234567890&quot;, \r\n                &quot;GroupId&quot;: &quot;sg-22222222&quot;\r\n            } \r\n        ]\r\n    }",
        "link": "https://stackoverflow.com/questions/46938368/filtering-aws-cli-output-for-security-groups-that-have-specific-port-and-ip-acls",
        "title": "Filtering AWS CLI output for security groups that have specific port and IP ACLs"
    },
    {
        "tags": [
            "unique",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11424519,
                    "reputation": 129,
                    "user_id": 8833708,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/181018fda6bd34f5c4a9e852889353e1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "DonJ",
                    "link": "https://stackoverflow.com/users/8833708/donj"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1508960787,
                "post_id": 46940636,
                "comment_id": 80828988,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1508969655,
                "last_edit_date": 1508969655,
                "creation_date": 1508960802,
                "answer_id": 46940915,
                "question_id": 46940636,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You&#39;re on the right track ...\r\n\r\n    .[].node.stops[] | select(.stopDesc == &quot;Big Wall&quot;)\r\n\r\n### unique\r\n\r\nRegarding the supplementary question:\r\n\r\n1) `sort` and `unique` both expect arrays as input\r\n\r\n2) calling `unique` obviates the need to call `sort`\r\n\r\n3) `unique` produces an array, so you might want to use `unique[]`\r\n\r\n4) One way to convert a stream of (JSON) values to an array is to wrap the expression producing the stream in square brackets.\r\n\r\nHere is an example:\r\n\r\n    [.[].node.stops[] | select(.stopDesc == &quot;Big Wall&quot;) | .zoneName]\r\n    | unique\r\n",
                "title": "jq, search for a &#39;sections&#39; basing on a value of an attribute"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1508986221,
        "creation_date": 1508959735,
        "last_edit_date": 1508986221,
        "question_id": 46940636,
        "body_markdown": "I am new in this stuff,\r\nI have input json:\r\n\r\n    {\r\n      &quot;2017-09-15&quot;: {\r\n        &quot;key&quot;: &quot;stops&quot;,\r\n        &quot;node&quot;: {\r\n          &quot;lastUpdate&quot;: &quot;2017-09-15 05:15:26&quot;,\r\n          &quot;stops&quot;: [\r\n            {\r\n              &quot;stopId&quot;: 11000,\r\n              &quot;stopCode&quot;: null,\r\n              &quot;stopName&quot;: null,\r\n              &quot;stopShortName&quot;: &quot;1000&quot;,\r\n              &quot;stopDesc&quot;: &quot;Tom Tail&quot;,\r\n              &quot;subName&quot;: &quot;1000&quot;,\r\n              &quot;zoneId&quot;: null,\r\n              &quot;zoneName&quot;: null,\r\n              &quot;stopUrl&quot;: &quot;&quot;,\r\n              &quot;locationType&quot;: null,\r\n              &quot;parentStation&quot;: null,\r\n              &quot;stopTimezone&quot;: &quot;&quot;,\r\n              &quot;wheelchairBoarding&quot;: null,\r\n              &quot;virtual&quot;: null,\r\n              &quot;nonpassenger&quot;: null,\r\n              &quot;depot&quot;: null,\r\n              &quot;ticketZoneBorder&quot;: null,\r\n              &quot;onDemand&quot;: null,\r\n              &quot;activationDate&quot;: &quot;2017-09-14&quot;\r\n            },\r\n            {\r\n              &quot;stopId&quot;: 1100,\r\n              &quot;stopCode&quot;: &quot;04&quot;,\r\n              &quot;stopName&quot;: &quot;One Three&quot;,\r\n              &quot;stopShortName&quot;: &quot;1100&quot;,\r\n              &quot;stopDesc&quot;: &quot;Big Wall&quot;,\r\n              &quot;subName&quot;: &quot;04&quot;,\r\n              &quot;zoneId&quot;: 1,\r\n              &quot;zoneName&quot;: &quot;Demo2&quot;,\r\n              &quot;stopUrl&quot;: &quot;&quot;,\r\n              &quot;locationType&quot;: null,\r\n              &quot;parentStation&quot;: null,\r\n              &quot;stopTimezone&quot;: &quot;&quot;,\r\n              &quot;wheelchairBoarding&quot;: null,\r\n              &quot;virtual&quot;: 0,\r\n              &quot;nonpassenger&quot;: 0,\r\n              &quot;depot&quot;: 0,\r\n              &quot;ticketZoneBorder&quot;: 0,\r\n              &quot;onDemand&quot;: 0,\r\n              &quot;activationDate&quot;: &quot;2017-09-24&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\n\r\nI can get all stops by filter:\r\njq -r &#39;.[].node.stops&#39; json\r\n\r\nbut how to search for a specific stop, for example basing on stopDescr - exact name or containing a string?\r\n\r\nthx.\r\n",
        "link": "https://stackoverflow.com/questions/46940636/jq-search-for-a-sections-basing-on-a-value-of-an-attribute",
        "title": "jq, search for a &#39;sections&#39; basing on a value of an attribute"
    },
    {
        "tags": [
            "json",
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1509001718,
                "last_edit_date": 1509001718,
                "creation_date": 1509001219,
                "answer_id": 46947746,
                "question_id": 46947523,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "So you&#39;re essentially taking an object and selecting properties to keep (or properties to remove).  Just select them.\r\n\r\nWe&#39;re making an update to the `properties` object so update and select (keep) the desired properties. Once filtered, map out the properties you want to keep in the result:\r\n\r\n    $ jq &#39;.properties |=\r\n    with_entries(select(.value.configurable)\r\n      | .value |= {configurable,value,optional}\r\n    )&#39; input.json",
                "title": "filter an object based on properties of its values"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1509004604,
                "last_edit_date": 1509004604,
                "creation_date": 1509001555,
                "answer_id": 46947822,
                "question_id": 46947523,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This filter will give you the properties with `&quot;configurable&quot;: true`\r\n\r\n     .properties |= reduce keys[] as $k (.; \r\n         if .[$k].configurable \r\n         then . \r\n         else delpaths([[$k]]) end\r\n      ) \r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/AFsCRkNJDk)\r\n\r\nThis filter demonstrates how you can further refine the properties to subset of keys:\r\n\r\n     .properties |= reduce keys[] as $k (.; \r\n         if   .[$k].configurable \r\n         then .[$k] |= {configurable,value,optional} \r\n         else delpaths([[$k]]) end\r\n     )\r\n\r\nSample Output\r\n \r\n    {\r\n      &quot;properties&quot;: {\r\n        &quot;.properties.backup_options&quot;: {\r\n          &quot;configurable&quot;: true,\r\n          &quot;value&quot;: &quot;disable&quot;,\r\n          &quot;optional&quot;: false\r\n        },\r\n        &quot;.properties.backup_options.enable.cron_schedule&quot;: {\r\n          &quot;configurable&quot;: true,\r\n          &quot;value&quot;: null,\r\n          &quot;optional&quot;: false\r\n        },\r\n        &quot;.properties.backup_options.enable.backup_all_masters&quot;: {\r\n          &quot;configurable&quot;: true,\r\n          &quot;value&quot;: true,\r\n          &quot;optional&quot;: false\r\n        }\r\n      }\r\n    }\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/DKBq6T83U2)\r\n\r\nWith a helper function such as\r\n\r\n    def objmap(cond;update): reduce keys[] as $k (.; \r\n       if .[$k]|cond then .[$k]|=update else delpaths([[$k]]) end\r\n    );\r\n\r\nThe filters can be written as\r\n\r\n    .properties |= objmap(.configurable; .)\r\n\r\nand\r\n\r\n    .properties |= objmap(.configurable; {configurable,value,optional})\r\n",
                "title": "filter an object based on properties of its values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1509004604,
        "creation_date": 1509000406,
        "last_edit_date": 1509001539,
        "question_id": 46947523,
        "body_markdown": "I&#39;m trying to use jq to filter a json block. I need to keep the full structure but filter out the &quot;non-configurable&quot; child json blocks.\r\n\r\n    {\r\n      &quot;properties&quot;: {\r\n        &quot;.properties.backup_options&quot;: {\r\n          &quot;type&quot;: &quot;selector&quot;,\r\n          &quot;configurable&quot;: true,\r\n          &quot;credential&quot;: false,\r\n          &quot;value&quot;: &quot;disable&quot;,\r\n          &quot;optional&quot;: false\r\n        },\r\n        &quot;.properties.backup_options.enable.cron_schedule&quot;: {\r\n          &quot;type&quot;: &quot;string&quot;,\r\n          &quot;configurable&quot;: true,\r\n          &quot;credential&quot;: false,\r\n          &quot;value&quot;: null,\r\n          &quot;optional&quot;: false\r\n        },\r\n        &quot;.properties.backup_options.enable.backup_all_masters&quot;: {\r\n          &quot;type&quot;: &quot;boolean&quot;,\r\n          &quot;configurable&quot;: true,\r\n          &quot;credential&quot;: false,\r\n          &quot;value&quot;: true,\r\n          &quot;optional&quot;: false\r\n        },\r\n        &quot;.properties.backups&quot;: {\r\n          &quot;type&quot;: &quot;selector&quot;,\r\n          &quot;configurable&quot;: false,\r\n          &quot;credential&quot;: false,\r\n          &quot;value&quot;: &quot;disable&quot;,\r\n          &quot;optional&quot;: false\r\n        },\r\n        &quot;.properties.backups.enable.endpoint_url&quot;: {\r\n          &quot;type&quot;: &quot;string&quot;,\r\n          &quot;configurable&quot;: false,\r\n          &quot;credential&quot;: false,\r\n          &quot;value&quot;: null,\r\n          &quot;optional&quot;: true\r\n        }\r\n    }\r\n\r\n\r\nI&#39;ve been able to filter down `cat input.json | jq &#39;.properties[] |  select(.configurable==true)&#39;`, however this looses the original structure.\r\n\r\nBonus marks to also filter out some of the fields in the sub-blocks, ie remove the credential and type lines. \r\n\r\nSo desired output is:\r\n\r\n    {\r\n      &quot;properties&quot;: {\r\n        &quot;.properties.backup_options&quot;: {\r\n          &quot;configurable&quot;: true,\r\n          &quot;value&quot;: &quot;disable&quot;,\r\n          &quot;optional&quot;: false\r\n        },\r\n        &quot;.properties.backup_options.enable.cron_schedule&quot;: {\r\n          &quot;configurable&quot;: true,\r\n          &quot;value&quot;: null,\r\n          &quot;optional&quot;: false\r\n        },\r\n        &quot;.properties.backup_options.enable.backup_all_masters&quot;: {\r\n\r\n          &quot;configurable&quot;: true,\r\n          &quot;value&quot;: true,\r\n          &quot;optional&quot;: false\r\n        }       \r\n    }\r\n\r\nDo I need to nest multiple jq statements to achieve this? break it down and rebuild? Help (this has already used up too many hours trying different combinations and tutorials).",
        "link": "https://stackoverflow.com/questions/46947523/filter-an-object-based-on-properties-of-its-values",
        "title": "filter an object based on properties of its values"
    },
    {
        "tags": [
            "json",
            "bash",
            "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": 1509022121,
                "post_id": 46954692,
                "comment_id": 80856552,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 1533859,
                    "reputation": 7477,
                    "user_id": 1430394,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://i.sstatic.net/k0jEL.jpg?s=256",
                    "display_name": "Milkncookiez",
                    "link": "https://stackoverflow.com/users/1430394/milkncookiez"
                },
                "reply_to_user": {
                    "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": 1,
                "creation_date": 1509022502,
                "post_id": 46954692,
                "comment_id": 80856853,
                "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": 1509022538,
                "post_id": 46954692,
                "comment_id": 80856879,
                "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": 1509052252,
                "post_id": 46954692,
                "comment_id": 80875544,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 81,
                "is_accepted": true,
                "score": 81,
                "last_activity_date": 1509023097,
                "last_edit_date": 1592644375,
                "creation_date": 1509022731,
                "answer_id": 46955018,
                "question_id": 46954692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From the manual:\n\n&gt;-e / --exit-status:\n&gt;\n&gt;Sets  the  exit  status of jq to 0 if the last output values was neither false nor null, 1 if the last output value was either false or null, or 4 if no valid result was ever produced. Normally jq exits with 2 if there was any usage problem or system error, 3 if there was a jq program compile error, or 0 if the jq program ran.\n\nSo you can use:\n\n    if jq -e . &gt;/dev/null 2&gt;&amp;1 &lt;&lt;&lt;&quot;$json_string&quot;; then\n        echo &quot;Parsed JSON successfully and got something other than false/null&quot;\n    else\n        echo &quot;Failed to parse JSON, or got false/null&quot;\n    fi\nIn fact, if you don&#39;t care about distinguishing between the different types of error, then you can just lose the `-e` switch. In this case, anything considered to be valid JSON (including false/null) will be parsed successfully by the filter `.` and the program will terminate successfully, so the `if` branch will be followed.",
                "title": "Check if string is a valid JSON with jq"
            },
            {
                "up_vote_count": 20,
                "is_accepted": false,
                "score": 20,
                "last_activity_date": 1580935742,
                "last_edit_date": 1580935742,
                "creation_date": 1518683351,
                "answer_id": 48802853,
                "question_id": 46954692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is working for me\r\n\r\n    echo $json_string | jq -e . &gt;/dev/null 2&gt;&amp;1  | echo ${PIPESTATUS[1]}\r\n\r\nthat returns return code:\r\n\r\n - 0 - Success\r\n - 1 - Failed\r\n - 4 - Invalid\r\n\r\nThen you can evaluate the return code by further code.",
                "title": "Check if string is a valid JSON with jq"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1623726190,
                "creation_date": 1623726190,
                "answer_id": 67979464,
                "question_id": 46954692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The commands and explanations below attempt to use `jq` in the least expensive way, just as means to validate JSON. In my opinion, there are tools better suited for this (Like JSONLint), but if the only thing you have at hand is `jq` then this is my contribution.\r\n\r\nTo validate a JSON file and still get the errors in `STDERR` output using `jq` you can use the following bash one-liner\r\n\r\n```sh\r\njq -reM &#39;&quot;&quot;&#39; &lt;&lt;&lt;&#39;&lt;MAYBE_INVALID_JSON&gt;&#39; 1&gt;/dev/null\r\n```\r\n\r\nWhich reads as:\r\n\r\n- Execute `jq` with flags:\r\n    - `-r` to output a raw value (No processing or formatting)\r\n    - `-e` to exit with a code greater than `0` if there was an error\r\n    - `-M` do not colorize JSON\r\n- The first `jq` argument is `&#39;&quot;&quot;&#39;` which outputs an empty string, effectively preventing `jq` from making any processing of the JSON for printing\r\n- `&lt;&lt;&lt;` followed by a string is called a &quot;Here String&quot;, and is basically telling bash to treat the string as if it was a file and pass it to `STDIN` (As input to the command).\r\n\r\n    Note that you can replace `&lt;&lt;&lt;&#39;&lt;MAYBE_INVALID_JSON&gt;&#39;` with the path of a file you want to validate and it would still work\r\n- Then redirect any `STDOUT` output (Which normally will contain the JSON) to `/dev/null`, effectively discarding it\r\n\r\nYou can also get fancier and output a custom message below the errors by using the following:\r\n\r\n```sh\r\njq -reM &#39;&quot;&quot;&#39; &lt;&lt;&lt;&#39;&lt;MAYBE_INVALID_JSON&gt;&#39; 1&gt;/dev/null || ( exit_code=&quot;$?&quot;; echo &#39;ERROR: Invalid JSON file. See errors above&#39; 1&gt;&amp;2; exit &quot;$exit_code&quot; )\r\n```\r\n\r\nWhere the added portion reads as follows:\r\n\r\n- `||` means: If the previous command failed with a non-zero exit code then run the following command\r\n- Open a sub-shell with `(`. This is actually needed since we want to exit with the original command&#39;s exit code\r\n    - Set the `exit_code` environment variable to the exit code of the last command `$?`\r\n    - Print custom error message using `echo`\r\n    - `exit` the sub-shell with the exit code from the original command `$exit_code`\r\n- Close the sub-shell",
                "title": "Check if string is a valid JSON with jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1674668967,
                "creation_date": 1674668967,
                "answer_id": 75237888,
                "question_id": 46954692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For a **variable** content like for a line, that&#39;s been working for me\r\n\r\n    echo &quot;$my_potential_json&quot;|jq empty &gt; /dev/null 2&gt;&amp;1                                                                                                                                                \r\n    if [ $? -eq 0 ]; then\r\n        echo &quot;found valid json:$my_potential_json&quot;\r\n        do_whatever....",
                "title": "Check if string is a valid JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 68,
        "last_activity_date": 1674668967,
        "creation_date": 1509021814,
        "last_edit_date": 1509025246,
        "question_id": 46954692,
        "body_markdown": "I need to catch an error when lifting a service. The response can be `null`, a string error message like\r\n\r\n `error services-migration/foobar: Not found: services-migration/foobar` \r\n\r\nor a valid JSON when everything is fine. I was wondering if there is a way with `jq` to simply check if the provided string is a valid JSON. I could ofc check the string for some keywords like `error` f.e., but I&#39;m looking for a more robust option, where eg. I get a `true/false` or `1/0` from jq.\r\nI was looking through the docs of `jq` and also some questions here on SO but everything was about finding and picking out key-values from a JSON, but nothing about simply validating a string.\r\n\r\nUPDATE:\r\n\r\nI&#39;ve got this:\r\n\r\n     result=$(some command)\r\n\r\nfrom which the result is the string `error services-migration/foobar: Not found: services-migration/foobar`\r\n\r\nAnd then the if statement:\r\n\r\n     if jq -e . &gt;/dev/null 2&gt;&amp;1 &lt;&lt;&lt;&quot;$result&quot;; then\r\n        echo &quot;it catches it&quot;\r\n     else\r\n        echo &quot;it doesn&#39;t catch it&quot;\r\n     fi\r\n\r\nAnd it always ends up in the `else` clause.",
        "link": "https://stackoverflow.com/questions/46954692/check-if-string-is-a-valid-json-with-jq",
        "title": "Check if string is a valid JSON with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12034035,
                    "reputation": 2289,
                    "user_id": 8803266,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/0PJdh.png?s=256",
                    "display_name": "Oliver Baumann",
                    "link": "https://stackoverflow.com/users/8803266/oliver-baumann"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1509026000,
                "post_id": 46956201,
                "comment_id": 80859637,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6813994,
                    "reputation": 2144,
                    "user_id": 5243291,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://lh3.googleusercontent.com/-PGScbJu5bNM/AAAAAAAAAAI/AAAAAAAAAGA/mlPoagrrqR8/s256-rj/photo.jpg",
                    "display_name": "Vini",
                    "link": "https://stackoverflow.com/users/5243291/vini"
                },
                "reply_to_user": {
                    "account_id": 12034035,
                    "reputation": 2289,
                    "user_id": 8803266,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/0PJdh.png?s=256",
                    "display_name": "Oliver Baumann",
                    "link": "https://stackoverflow.com/users/8803266/oliver-baumann"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1509026062,
                "post_id": 46956201,
                "comment_id": 80859685,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1642596420,
                "post_id": 46956201,
                "comment_id": 125111764,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 15,
                "is_accepted": true,
                "score": 15,
                "last_activity_date": 1509034386,
                "last_edit_date": 1509034386,
                "creation_date": 1509027960,
                "answer_id": 46956950,
                "question_id": 46956201,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I must say, I&#39;m not terribly good at `jq`, so probably all those array iterations could be shorthanded somehow, but this yields the values you mentioned:\r\n\r\n    cat foo.json | jq &quot;.[] | .images | .[] | .classifiers | .[] | .classes | .[] | .[]&quot;\r\n\r\nIf you want the keys, too, just omit that last `.[]`.`\r\n\r\n**Edit**\r\nAs @chepner pointed out in the comments, this can indeed be shortened to\r\n\r\n    cat foo.json | jq &quot;.images[].classifiers[].classes[] | [.class, .score] | @csv &quot;",
                "title": "Parsing nested json with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1509030538,
                "creation_date": 1509030538,
                "answer_id": 46957893,
                "question_id": 46956201,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "**jq** solution to obtain a prepared *csv* record:\r\n\r\n    jq -r &#39;.images[0].classifiers[0].classes[0] | [.class, .score] | @csv&#39; input.json\r\nThe output:\r\n\r\n    &quot;football&quot;,0.867376",
                "title": "Parsing nested json with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1509039540,
                "last_edit_date": 1509039540,
                "creation_date": 1509038208,
                "answer_id": 46960200,
                "question_id": 46956201,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Depending on the data this filter which uses [Recursive Descent: ..](https://stedolan.github.io/jq/manual/#RecursiveDescent:..), [objects](https://stedolan.github.io/jq/manual/#arrays,objects,iterables,booleans,numbers,normals,finites,strings,nulls,values,scalars) and [has](https://stedolan.github.io/jq/manual/#has\\(key\\)) may work:\r\n\r\n    .. | objects | select(has(&quot;class&quot;)) | [.class,.score] | @csv\r\n\r\nSample Run (assuming data in `data.json`)\r\n\r\n    $ jq -Mr &#39;.. | objects | select(has(&quot;class&quot;)) | [.class,.score] | @csv&#39; data.json\r\n    &quot;football&quot;,0.867376\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/0qDy0fI_fZ)\r\n\r\nHere is another variation which uses [paths](https://stedolan.github.io/jq/manual/#paths,paths\\(node_filter\\),leaf_paths) and [getpath](https://stedolan.github.io/jq/manual/#getpath\\(PATHS\\))\r\n\r\n    getpath( paths(has(&quot;class&quot;)?) ) | [.class,.score] | @csv\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/cLAeCsoIY9)\r\n\r\n",
                "title": "Parsing nested json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 8,
        "last_activity_date": 1509039540,
        "creation_date": 1509025869,
        "last_edit_date": 1509026384,
        "question_id": 46956201,
        "body_markdown": "I am parsing a nested json to get specific values from the json response. The json response is as follows:\r\n\r\n    { \r\n\t&quot;custom_classes&quot;: 2,\r\n\t&quot;images&quot;: \r\n\t\t[ \r\n\t\t  { \r\n\t\t\t&quot;classifiers&quot;: \r\n\t\t\t[ \r\n\t\t\t  { \r\n\t\t\t\t&quot;classes&quot;: \r\n\t\t\t\t[ \r\n\t\t\t\t  { \r\n\t\t\t\t\t&quot;class&quot;: &quot;football&quot;,\r\n\t\t\t\t\t&quot;score&quot;: 0.867376 \r\n\t\t\t\t  } \r\n\t\t\t\t], \r\n\t\t\t\t&quot;classifier_id&quot;: &quot;players_367677167&quot;,\r\n\t\t\t\t&quot;name&quot;: &quot;players&quot; \r\n\t\t\t  } \r\n\t\t\t], \r\n\t\t\t&quot;image&quot;: &quot;1496A400EDC351FD.jpg&quot; \r\n\t\t  } \r\n\t\t], \r\n\t&quot;images_processed&quot;: 1 \r\n    }\r\n\r\nFrom the class images=&gt;classifiers=&gt;classes:&quot;class&quot; &amp; &quot;score&quot; are the values that I want to save in a csv file. I have found how to save the result in a csv file. But I am unable to parse the `images` alone. I can get `custom_classes` and `image_processed`.\r\n\r\nI am using `jq-1.5`. \r\n\r\nThe different commands I have tried :\r\n\r\n    curl &quot;Some address&quot;| jq &#39;.[&quot;images&quot;]&#39;\r\n    curl &quot;Some address&quot;| jq &#39;.[.images]&#39;\r\n    curl &quot;Some address&quot;| jq &#39;.[.images[&quot;image&quot;]]&#39;\r\n\r\nMost of the times the error is about not being able to index the array `images`.\r\n\r\nAny hints?",
        "link": "https://stackoverflow.com/questions/46956201/parsing-nested-json-with-jq",
        "title": "Parsing nested json with jq"
    },
    {
        "tags": [
            "json",
            "grep",
            "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": 1509064860,
                "post_id": 46965781,
                "comment_id": 80879271,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6608813,
                    "reputation": 1016,
                    "user_id": 5104758,
                    "user_type": "registered",
                    "accept_rate": 93,
                    "profile_image": "https://i.sstatic.net/Wwwke.png?s=256",
                    "display_name": "lft93ryt",
                    "link": "https://stackoverflow.com/users/5104758/lft93ryt"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1509066286,
                "post_id": 46965781,
                "comment_id": 80879547,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1509067526,
                "creation_date": 1509067526,
                "answer_id": 46966131,
                "question_id": 46965781,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Issue 1: Format&lt;br /&gt;\r\nhttps://shapeshed.com/jq-json/ &lt;br&gt;\r\nThe second input to jq is the file you wish to read from. If this value is - the program will read from the instream.\r\n\r\nIssue 2: Selection&lt;br /&gt;\r\nhttps://stedolan.github.io/jq/manual/#select(boolean_expression) &lt;br&gt;\r\nTo select an element by value you should/could use a select statement&lt;br /&gt;\r\n`select(.GroupName == &quot;MY1SG-PUBLIC-80&quot;)`&lt;Br /&gt;\r\n`jq &#39;SCOPE | select(.GroupName == &quot;MY1SG-PUBLIC-80&quot;) | .GroupId[]&#39; -`&lt;br /&gt;\r\nwhere SCOPE is the group you wish to look in. if SCOPE is `.[]`, it will scan every json entry. &lt;br /&gt;Following this, it pipes this group into a select filter, and trims it down to only ones that have GroupName set to the given value. &lt;br&gt;This result set is then piped into a key filter, where it only returns the array of matching GroupID&#39;s.\r\n\r\n",
                "title": "Searching for object with jQ in command line"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1509080779,
                "last_edit_date": 1509080779,
                "creation_date": 1509069346,
                "answer_id": 46966371,
                "question_id": 46965781,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; I am trying to fetch the Group Id using the Group Name. \r\n\r\nAssuming the input has been tweaked to make it valid JSON (*), the filter:\r\n\r\n    .SecurityGroups[] | select(.GroupName==&quot;MY1SG-PUBLIC-80&quot;) | .GroupId\r\n\r\nproduces:\r\n \r\n    &quot;sg-ee0c979c&quot;\r\n\r\nIt might be worthwhile considering this alternative filter:\r\n\r\n    .[][]|select(.GroupName==&quot;MY1SG-PUBLIC-80&quot;)|.GroupId\r\n\r\n(*) The input as originally shown has an extraneous comma.\r\n",
                "title": "Searching for object with jQ in command line"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1521707416,
        "creation_date": 1509064272,
        "last_edit_date": 1521707416,
        "question_id": 46965781,
        "body_markdown": "I have a JSON file of AWS security groups list. I am trying to fetch the Group Id using the Group Name. The object looks like the following: \r\n\r\n    {\r\n        &quot;SecurityGroups&quot;: [{\r\n            &quot;IpPermissionsEgress&quot;: [\r\n                {\r\n                    &quot;IpProtocol&quot;: &quot;-1&quot;,\r\n                }\r\n            ],\r\n            &quot;Description&quot;: &quot;launch-wizard-2 created 2017-10-21T09:19:40.007-04:00&quot;,\r\n            &quot;GroupName&quot;: &quot;MY1SG-PUBLIC-80&quot;,\r\n            &quot;VpcId&quot;: &quot;vpc-ceed12b7&quot;,\r\n            &quot;OwnerId&quot;: &quot;712503525534&quot;,\r\n            &quot;GroupId&quot;: &quot;sg-ee0c979c&quot;\r\n        }]\r\n    }\r\nWith jQ my attempt is as follows:\r\n\r\n    aws ec2 describe-security-groups | jq &#39;.GroupId&#39; [&quot;GroupName&quot;: &quot;MY1SG-PUBLIC-80&quot;]\r\n\r\nError:\r\n```jq: error: Could not open file [GroupName:: No such file or directory\r\njq: error: Could not open file MY1SG-PUBLIC-80]: No such file or directory```\r\n",
        "link": "https://stackoverflow.com/questions/46965781/searching-for-object-with-jq-in-command-line",
        "title": "Searching for object with jQ in command line"
    },
    {
        "tags": [
            "json",
            "schema",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1509265144,
                "last_edit_date": 1509265144,
                "creation_date": 1509104104,
                "answer_id": 46974099,
                "question_id": 46973467,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; I would be more than happy to have a better approach ...\r\n\r\nIf I were you, I&#39;d start with (and maybe end with) the following:\r\n\r\n    [paths(scalars) | map(if type == &quot;number&quot; then 0 else . end)]\r\n    | unique\r\n    | .[]\r\n\r\nWith your example, using the -cr command-line options, this produces:\r\n\r\n    [&quot;issues&quot;,0,&quot;fields&quot;,&quot;assignee&quot;,&quot;id&quot;]\r\n    [&quot;issues&quot;,0,&quot;fields&quot;,&quot;assignee&quot;,&quot;name&quot;]\r\n    [&quot;issues&quot;,0,&quot;fields&quot;,&quot;fixVersions&quot;,0,&quot;id&quot;]\r\n    [&quot;issues&quot;,0,&quot;fields&quot;,&quot;fixVersions&quot;,0,&quot;releaseDate&quot;]\r\n    [&quot;issues&quot;,0,&quot;fields&quot;,&quot;status&quot;,&quot;id&quot;]\r\n    [&quot;issues&quot;,0,&quot;fields&quot;,&quot;status&quot;,&quot;statusCategory&quot;,&quot;id&quot;]\r\n    [&quot;issues&quot;,0,&quot;fields&quot;,&quot;status&quot;,&quot;statusCategory&quot;,&quot;name&quot;]\r\n    [&quot;issues&quot;,0,&quot;id&quot;]\r\n    [&quot;issues&quot;,0,&quot;key&quot;]\r\n    [&quot;issues&quot;,0,&quot;name&quot;]\r\n    [&quot;startAt&quot;]\r\n    [&quot;total&quot;]\r\n\r\nYou could get even closer to what you&#39;ve indicated you want my mapping the numeric 0s to a string, but then you have to be careful about potential conflicts between that string and key names.  To illustrate:\r\n\r\n    [paths(scalars) | map(if type == &quot;number&quot; then &quot;[]&quot; else . end)]\r\n    | unique\r\n    | .[]\r\n    | join(&quot;:&quot;)\r\n\r\nproduces:\r\n\r\n    issues:[]:fields:assignee:id\r\n    issues:[]:fields:assignee:name\r\n    issues:[]:fields:fixVersions:[]:id\r\n    issues:[]:fields:fixVersions:[]:releaseDate\r\n    issues:[]:fields:status:id\r\n    issues:[]:fields:status:statusCategory:id\r\n    issues:[]:fields:status:statusCategory:name\r\n    issues:[]:id\r\n    issues:[]:key\r\n    issues:[]:name\r\n    startAt\r\n    total\r\n\r\nNotice that this approach yields essentially the same results as the schema-inference-based approach. That is a Good Thing.\r\n\r\n### Using INDEX/2\r\n\r\nUsing `unique/0` as above has two potential disadvantages: (1) the ordering of the output does not reflect the ordering in the data; (2) efficiency (though in practice that is unlikely to be a real issue except maybe for JSON texts with a huge number of leaf paths).\r\n\r\nIn any case, `INDEX/2` could be used instead of `unique`. In case your jq does not have `INDEX/2`, its def is given here. \r\n\r\nIn short:\r\n\r\n    def INDEX(stream; idx_expr):\r\n      reduce stream as $row ({};\r\n        .[$row|idx_expr|\r\n          if type != &quot;string&quot; then tojson\r\n          else .\r\n          end] |= $row);\r\n\r\n    INDEX(paths(scalars)\r\n          | map(if type == &quot;number&quot; then &quot;[]&quot; else . end); .)\r\n    | .[]\r\n    | join(&quot;:&quot;)\r\n\r\nyields:\r\n\r\n    startAt\r\n    total\r\n    issues:[]:id\r\n    issues:[]:name\r\n    issues:[]:fields:fixVersions:[]:id\r\n    issues:[]:fields:fixVersions:[]:releaseDate\r\n    issues:[]:fields:status:id\r\n    issues:[]:fields:status:statusCategory:id\r\n    issues:[]:fields:status:statusCategory:name\r\n    issues:[]:key\r\n    issues:[]:fields:assignee:id\r\n    issues:[]:fields:assignee:name\r\n\r\n### Paths to empty arrays\r\n\r\nIf you want paths to empty arrays to be reported as well, you could (for example) simply change &quot;paths(scalars)&quot; to &quot;(paths(scalars), paths(arrays))&quot;.\r\n\r\n\r\n",
                "title": "How to get nested keys of a json stream using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1509111444,
                "last_edit_date": 1509111444,
                "creation_date": 1509105060,
                "answer_id": 46974358,
                "question_id": 46973467,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you want a schematic representation of your data, you might like to consider an approach based on *schema inference*.  \r\n\r\nFor example, using the `schema` function as defined at https://gist.github.com/pkoppstein/a5abb4ebef3b0f72a6ed, your input results in the following inferred schema:\r\n\r\n\r\n    {\r\n      &quot;startAt&quot;: &quot;number&quot;,\r\n      &quot;total&quot;: &quot;number&quot;,\r\n      &quot;issues&quot;: [\r\n        {\r\n          &quot;fields&quot;: {\r\n            &quot;assignee&quot;: {\r\n              &quot;id&quot;: &quot;string&quot;,\r\n              &quot;name&quot;: &quot;string&quot;\r\n            },\r\n            &quot;fixVersions&quot;: [\r\n              {\r\n                &quot;id&quot;: &quot;string&quot;,\r\n                &quot;releaseDate&quot;: &quot;string&quot;\r\n              }\r\n            ],\r\n            &quot;status&quot;: {\r\n              &quot;id&quot;: &quot;string&quot;,\r\n              &quot;statusCategory&quot;: {\r\n                &quot;id&quot;: &quot;number&quot;,\r\n                &quot;name&quot;: &quot;string&quot;\r\n              }\r\n            }\r\n          },\r\n          &quot;id&quot;: &quot;string&quot;,\r\n          &quot;key&quot;: &quot;string&quot;,\r\n          &quot;name&quot;: &quot;string&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nIf you filter that through `paths(scalars)`, you get:\r\n\r\n\r\n    [&quot;startAt&quot;]\r\n    [&quot;total&quot;]\r\n    [&quot;issues&quot;,0,&quot;fields&quot;,&quot;assignee&quot;,&quot;id&quot;]\r\n    [&quot;issues&quot;,0,&quot;fields&quot;,&quot;assignee&quot;,&quot;name&quot;]\r\n    [&quot;issues&quot;,0,&quot;fields&quot;,&quot;fixVersions&quot;,0,&quot;id&quot;]\r\n    [&quot;issues&quot;,0,&quot;fields&quot;,&quot;fixVersions&quot;,0,&quot;releaseDate&quot;]\r\n    [&quot;issues&quot;,0,&quot;fields&quot;,&quot;status&quot;,&quot;id&quot;]\r\n    [&quot;issues&quot;,0,&quot;fields&quot;,&quot;status&quot;,&quot;statusCategory&quot;,&quot;id&quot;]\r\n    [&quot;issues&quot;,0,&quot;fields&quot;,&quot;status&quot;,&quot;statusCategory&quot;,&quot;name&quot;]\r\n    [&quot;issues&quot;,0,&quot;id&quot;]\r\n    [&quot;issues&quot;,0,&quot;key&quot;]\r\n    [&quot;issues&quot;,0,&quot;name&quot;]\r\n\r\nExcept for the ordering, these results are the same as obtained using the more direct approach; this I would suggest validates both approaches.",
                "title": "How to get nested keys of a json stream using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1509128637,
                "last_edit_date": 1509128637,
                "creation_date": 1509125323,
                "answer_id": 46980553,
                "question_id": 46973467,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`paths` is definitely the right approach but getting the exact output requested is a little cumbersome.  Here is a filter which does this except for the precise ordering:\r\n\r\n    def normalize:    # convert paths to requested structure\r\n        if .[-1]|type==&quot;number&quot; then .[-1]=&quot;[]&quot; else . end\r\n      | map(select(type!=&quot;number&quot;));\r\n    \r\n    def collect:      # collect unique normalized paths into an object\r\n      reduce (paths|normalize) as $p (\r\n         {}\r\n       ; if getpath($p)==null then setpath($p;null) else . end\r\n      );\r\n    \r\n    def colonize($p): # convert object back into : separated paths\r\n        keys_unsorted[] as $k\r\n      | (if $p==&quot;&quot; then $k else &quot;\\($p):\\($k)&quot; end) as $n\r\n      | $n, (.[$k] | if type==&quot;object&quot; then colonize($n) else empty end);\r\n    \r\n    def summary:      # final output without redundant foo: if foo:[] is present \r\n        [ collect | colonize(&quot;&quot;) ]\r\n      | map(select(endswith(&quot;:[]&quot;))|.[:-3]) as $remove\r\n      | map(select($remove[[.]]==[]));\r\n    \r\n    summary[]\r\n\r\nSample Run (assuming filter in `filter.jq` and data in `data.json`)\r\n\r\n    $ jq -Mcr -f filter.jq data.json\r\n    startAt\r\n    total\r\n    issues:[]\r\n    issues:id\r\n    issues:name\r\n    issues:fields\r\n    issues:fields:fixVersions:[]\r\n    issues:fields:fixVersions:id\r\n    issues:fields:fixVersions:releaseDate\r\n    issues:fields:status\r\n    issues:fields:status:id\r\n    issues:fields:status:statusCategory\r\n    issues:fields:status:statusCategory:id\r\n    issues:fields:status:statusCategory:name\r\n    issues:fields:assignee\r\n    issues:fields:assignee:id\r\n    issues:fields:assignee:name\r\n    issues:key\r\n\r\n[Try it online!](https://tio.run/##lZPBjpswEIbveQp3xAEkiCDZ3WqJOKya3qqqp6oStSpvmGTZgE1t022a5NWbjoGwyd7qA3js@f/5PIbnn6c9GCu0fbCQxiFYZUUF6e08uQ2hNKZFA2m@h7KAFG5uZnf3EIIUNVJoVI2f3TSEdYlVQZl7mv3@itqUSl4Ik@QmTihNY4XC4FJYp5/FyV0U30fzGI48dBi27Tx6TZwkMZyXP5Bko/TuvD0fKZZKIhxphK@U751wi5QNnz4@LKNvNK4ohTHlRiJeVUvg0hSO/4k0G9Wl/KLVRqMxHRg/Hk4FrplUuhZV@QdTNmE0yjWb5lHCD3bXYJaBbOtH1MDsE8p@J4OcA8PKIJsylAXJDqwWjW@okSvrO@G7URgEi8nEFVqpym2nlK6xaFfI/EbYJ3MYCQImDPMa5ncgbH9074Uj2qB1ub7XBFkm26rqccy4vHCLwTXURWElyd6p086aLsH8aKVR2mKR867stjuGT8W8ho49HNjb9p7wvVPTcxuA8@9ZZSfyZMj8ae5tOQVkMHROPT7TeQejVwg5YGLd2F1nNXCatq6F3vWI@blfZDlqAQLG37abHMxLSV2gL5tTuw/TPI3mvAfUWKtf@FYyLOf5lPMsy3l3R0P5nJ9Of1Vj3b9yiiLX16iUTWsp0OIlUq2l4B8 &quot;jq – Try It Online&quot;)\r\n\r\nNote that there is a problem here with empty arrays.  If there are empty arrays in your data this filter will report them as ordinary fields because the corresponding path returned by `paths` won&#39;t end in a number.  The easiest way to compensate for this is to map the empty arrays to something non-empty like `[{}]` first.  e.g. \r\n\r\n    def walk(f):  # defined here in case your jq doesn&#39;t have it\r\n        . as $in\r\n      | if type == &quot;object&quot; then reduce keys_unsorted[] as $key (\r\n            {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n        elif type == &quot;array&quot; then map( walk(f) ) | f\r\n        else f\r\n        end;\r\n\r\n      walk(if .==[] then [{}] else . end)\r\n    | summary[]\r\n",
                "title": "How to get nested keys of a json stream using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1509159204,
                "creation_date": 1509159204,
                "answer_id": 46985771,
                "question_id": 46973467,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Just to be clear -- it is quite easy to write a jq filter that produces the output in the format originally envisioned, though that format is unlikely to be of general use.  \r\n\r\nThe following approach obviates the need to use `walk/1` to handle the special case of empty arrays.  It uses `unique` only because `INDEX/2` is not included in jq release 1.5 (*).\r\n\r\nWith the example input and the `-r` command-line option, the following:\r\n\r\n     [paths as $p\r\n      | if (getpath($p)|type) == &quot;array&quot; then $p + [&quot; []&quot;]\r\n        elif ($p[-1]|type) == &quot;number&quot; then empty\r\n        else $p\r\n        end\r\n        | map(select(type != &quot;number&quot;))]\r\n     | unique\r\n     | .[]\r\n     | join(&quot;:&quot;)\r\n\r\nproduces:\r\n\r\n    issues: []\r\n    issues:fields\r\n    issues:fields:assignee\r\n    issues:fields:assignee:id\r\n    issues:fields:assignee:name\r\n    issues:fields:fixVersions: []\r\n    issues:fields:fixVersions:id\r\n    issues:fields:fixVersions:releaseDate\r\n    issues:fields:status\r\n    issues:fields:status:id\r\n    issues:fields:status:statusCategory\r\n    issues:fields:status:statusCategory:id\r\n    issues:fields:status:statusCategory:name\r\n    issues:id\r\n    issues:key\r\n    issues:name\r\n    startAt\r\n    total\r\n\r\n(*) `unique` can easily be avoided here by using `INDEX/2`, as described elsewhere on this page.\r\n\r\n",
                "title": "How to get nested keys of a json stream using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 4,
        "last_activity_date": 1509265144,
        "creation_date": 1509101830,
        "last_edit_date": 1509109710,
        "question_id": 46973467,
        "body_markdown": "I am trying to design a number of relational tables to hold parsed output of various json streams. The data streams have quite complex structure and to facilitate the table design, I need to know every level of nested keys for every stream. And I am lost about how to get every nested keys out of the stream using jq. The following is a simplified representative json stream.\r\n\r\n    {\r\n      &quot;startAt&quot;: 0,\r\n      &quot;total&quot;: 5315,\r\n      &quot;issues&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;44269&quot;,\r\n          &quot;name&quot;: &quot;someName&quot;,\r\n          &quot;fields&quot;: {\r\n            &quot;fixVersions&quot;: [\r\n              {\r\n                &quot;id&quot;: &quot;11401&quot;,\r\n                &quot;releaseDate&quot;: &quot;2016-09-30&quot;\r\n              }\r\n            ],\r\n            &quot;status&quot;: {\r\n              &quot;id&quot;: &quot;10110&quot;,\r\n              &quot;statusCategory&quot;: {\r\n                &quot;id&quot;: 3,\r\n                &quot;name&quot;: &quot;Done&quot;\r\n              }\r\n            }\r\n          }\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;44270&quot;,\r\n          &quot;key&quot;: &quot;LEAD-XXXX&quot;,\r\n          &quot;fields&quot;: {\r\n            &quot;assignee&quot;: {\r\n              &quot;id&quot;: &quot;10111&quot;,\r\n              &quot;name&quot;: &quot;Don&quot;\r\n            },\r\n            &quot;status&quot;: {\r\n              &quot;id&quot;: &quot;10110&quot;,\r\n              &quot;statusCategory&quot;: {\r\n                &quot;id&quot;: 2,\r\n                &quot;name&quot;: &quot;inProgress&quot;\r\n              }\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nAnd I am expecting the following output. I would be more than happy to have a better approach helping me with the table design.\r\n\r\n    startAt\r\n    total\r\n    issues: []\r\n    issues:id\r\n    issues:name\r\n    issues:key\r\n    issues:fields\r\n    issues:fields:fixVersions: []\r\n    issues:fields:fixVersions:id\r\n    issues:fields:fixVersions:releaseDate\r\n    issues:fields:status\r\n    issues:fields:status:id\r\n    issues:fields:status:statusCategory\r\n    issues:fields:status:statusCategory:id\r\n    issues:fields:status:statusCategory:name\r\n    issues:fields:assignee\r\n    issues:fields:assignee:id\r\n    issues:fields:assignee:name\r\n\r\nHow can I get the nested keys for the above stream using jq. Appreciate the help very much.",
        "link": "https://stackoverflow.com/questions/46973467/how-to-get-nested-keys-of-a-json-stream-using-jq",
        "title": "How to get nested keys of a json stream using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "templates",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1509128569,
                "post_id": 46981141,
                "comment_id": 80909966,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "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": 1509129023,
                "post_id": 46981141,
                "comment_id": 80910182,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 9982288,
                    "reputation": 93,
                    "user_id": 7384800,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/34fae1464249024137ef7f3e42ca8033?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordan Little",
                    "link": "https://stackoverflow.com/users/7384800/jordan-little"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1509129227,
                "post_id": 46981141,
                "comment_id": 80910275,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1509153316,
                "last_edit_date": 1509153316,
                "creation_date": 1509130475,
                "answer_id": 46981701,
                "question_id": 46981141,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses jq to build a legal json array from bash variables and then uses that array with a second jq invocation to substitute the variables into the template at corresponding positions:\r\n\r\n&lt;!-- language-all: lang-bash --&gt;\r\n\r\n    #!/bin/bash\r\n    \r\n    # example template\r\n    template=&#39;{\r\n      &quot;sections&quot;: [\r\n        { &quot;title&quot;: &quot;x&quot; },\r\n        { &quot;title&quot;: &quot;y&quot; }\r\n      ]\r\n    }&#39;\r\n    \r\n    # bash variables \r\n    section0_section_uuid=&quot;Section_0&quot;\r\n    section1_section_uuid=&quot;Section_1&quot;\r\n    \r\n    # put into json array with jq\r\n    uuids=$(jq -MRn &#39;[inputs]&#39; &lt;&lt;EOF\r\n    $section0_section_uuid\r\n    $section1_section_uuid\r\n    EOF)\r\n    \r\n    # substitute json array into template\r\n    jq -M --argjson uuids &quot;$uuids&quot; &#39;\r\n      reduce ($uuids|keys[]) as $k (.; .sections[$k].title = $uuids[$k])\r\n    &#39; &lt;&lt;&lt; &quot;$template&quot;\r\n\r\nSample Output\r\n\r\n    {\r\n      &quot;sections&quot;: [\r\n        {\r\n          &quot;title&quot;: &quot;Section_0&quot;\r\n        },\r\n        {\r\n          &quot;title&quot;: &quot;Section_1&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n[Try it online!][TIO-j9a97wl7]\r\n\r\n[TIO-j9a97wl7]: https://tio.run/##dZBRT4MwFIXf@yuOHQmQCNteFR71zZjoIyFL2RpXwLLRoiNzvx3bDpYZ9an3npze795TMLUdhtnNvBByXpiGkBn4gb3vag7NzcM0J1OR@kcCUMXXWjRS0TtkpgeOoFromhuBHihOt7/U3qhGzMnJtwRLwgdrBStqrkDGiYvVWKy6TmxS@jp2Czo5lv84ltSO3XUaQuoGpWokWNuyHp9Cb1HuifWr1AvKPaKnFwk/E9L4Ve4jSR6eH4n35xIX@SeZmB@hRaquUObKTvNrqFviEp9DIopY@@Y8bhVQz70Uvgmm5ZtuzRGcta@K9yrLQzAFr0IQ3yOeQs@8Ko9drkhxtlspJPaOxEydsHQYvgE &quot;Bash – Try It Online&quot;\r\n\r\n___\r\nHere is a solution to a portion of the revised problem which works by replacing leaf values in the template with corresponding values from an object constructed from bash variables and passed to jq via `--argjson`.  It should be straightforward to generalize to the complete template assuming more suitable names are chosen for replacement values then `[CHANGE_ME]` and `[CHANGE_ME_LETTERS]`\r\n\r\n&lt;!-- language-all: lang-bash --&gt;\r\n\r\n    #!/bin/bash\r\n    \r\n    # example template\r\n    template=&#39;{\r\n      &quot;fields&quot;: [],\r\n      &quot;sections&quot;: [ {\r\n          &quot;fields&quot;: [ {\r\n              &quot;k&quot;: &quot;concealed&quot;,\r\n              &quot;n&quot;: &quot;[SSH_ROOT_USER_N]&quot;,\r\n              &quot;t&quot;: &quot;ROOT_USER_PASS&quot;,\r\n              &quot;v&quot;: &quot;[SSH_ROOT_USER_V]&quot;\r\n          } ]\r\n      } ]\r\n    }&#39;\r\n    \r\n    # bash variables \r\n    SSH_ROOT_USER_N=&quot;abcd&quot;\r\n    SSH_ROOT_USER_V=&quot;efgh&quot;\r\n    \r\n    # put into json object with jq\r\n    vars=$(jq -M . &lt;&lt;EOF\r\n    {\r\n     &quot;[SSH_ROOT_USER_N]&quot;: &quot;$SSH_ROOT_USER_N&quot;,\r\n     &quot;[SSH_ROOT_USER_V]&quot;: &quot;$SSH_ROOT_USER_V&quot;\r\n    }\r\n    EOF)\r\n    \r\n    # substitute variables into template\r\n    jq -M --argjson vars &quot;$vars&quot; &#39;\r\n    reduce (tostream|select(length==2)) as [$p,$v] (\r\n        {}\r\n      ; setpath($p;if $v|type!=&quot;string&quot; then . else $vars[$v]//$v end)\r\n    )\r\n    &#39; &lt;&lt;&lt; &quot;$template&quot;\r\n    \r\nSample Output\r\n\r\n    {\r\n      &quot;fields&quot;: {},\r\n      &quot;sections&quot;: [\r\n        {\r\n          &quot;fields&quot;: [\r\n            {\r\n              &quot;k&quot;: &quot;concealed&quot;,\r\n              &quot;n&quot;: &quot;abcd&quot;,\r\n              &quot;t&quot;: &quot;ROOT_USER_PASS&quot;,\r\n              &quot;v&quot;: &quot;efgh&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n[Try it online!][TIO-j9amoa79]\r\n\r\n[TIO-j9amoa79]: https://tio.run/##bVHBTsJAFLzvVzzWJrQJSOJR6MGDxotiqHIhDdm2D7pYt6X7qBLg2@tuEUSkh77uvMnszDQSOq3rq1YvkqoXmQNjV4Bf4qPIEAjNEITs8OG3NwyAzyRmiea3MAk79qwxJpmrBgHLsM8J64g1@LuBeJyrGEWGCe@c7pTdTYLgcToaDl@nb8H9aPoc/uWQ5fyuX@6C4C@huiAyDvkPZQch2793bRvWhoZKlFJEGWpgZ5f7XERxws/gsc9xNk@5FShWBFJRDgudK8ijhWkDPiWlsFgyI6x9x10sofsE1zAY3A8fmKnjQkhj2jkDba4LSf4zx5ztmJH2rCG9ijRJWhHuLYmyFOu9xeMf3RvqdkU5bzjWp1G1g0OblZisYgSXck0lio@txszEcjNUc0p9/8bzQGiYOEXHqUJwm243OzP6oJEKQanrFH05A6fa0rrAls@NklRzDpSiMlVgphGaCydGotdzKkCVeMxjbVPTwJg5mOWsrr8B &quot;Bash – Try It Online&quot;\r\n\r\n",
                "title": "Making multiple changes to one JSON template"
            },
            {
                "up_vote_count": 15,
                "is_accepted": false,
                "score": 15,
                "last_activity_date": 1509149522,
                "last_edit_date": 1509149522,
                "creation_date": 1509136159,
                "answer_id": 46982954,
                "question_id": 46981141,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Why not make your template an actual `jq` filter, rather than a JSON blob to modify?\r\n\r\nThe contents of `template.jq` would be\r\n\r\n    {\r\n      sections: [\r\n        { title: $t1 },\r\n        { title: $t2 },\r\n        { title: $t3 },\r\n        { title: $t4 },\r\n        { title: $t5 },\r\n        { title: $t6 },\r\n        { title: $t7 },\r\n        { title: $t8 }\r\n      ]\r\n    }\r\n\r\nThen your command would simply be\r\n\r\n\r\n    $ jq -n --arg t1 foo --arg t2 bar ... -f template.jq\r\n    {\r\n      &quot;sections&quot;: [\r\n        {\r\n          &quot;title&quot;: &quot;foo&quot;\r\n        },\r\n        {\r\n          &quot;title&quot;: &quot;bar&quot;\r\n        },\r\n        ...\r\n      ]\r\n    }\r\n\r\nOne benefit of doing it this way is that you can&#39;t accidentally forget a value; `jq` can only process the filter if you provide definitions for all 8 variables.",
                "title": "Making multiple changes to one JSON template"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1509267319,
                "last_edit_date": 1509267319,
                "creation_date": 1509166648,
                "answer_id": 46986402,
                "question_id": 46981141,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following approach to the problem is similar to @jq170727&#39;s (in particular, the jq program is agnostic both about the *number* of &quot;section_uuid&quot; variables, and the *names* of the template variables), but only one invocation of jq is required (rather than three).  \r\n\r\nThe other significant difference is that `reduce` is used to avoid the penalties associated with using `tostream`.  A minor difference is that `inputs` is used to avoid reading in the &quot;section_uuid&quot; variable values all at once.\r\n\r\n&gt;***Note: The `fillin` function defined below should be sufficient for basic templating.***\r\n\r\nIn the following, the &quot;template&quot; file is assumed to be named `template.json`.\r\n\r\n\r\n### template.jq\r\n\r\n    # input: a JSON entity defining a template;\r\n    # vars: a JSON object defining TEMPLATEVARIABLE-VALUE pairs\r\n    def fillin(vars):\r\n      reduce paths as $p (.;\r\n        getpath($p) as $v\r\n        | if $v|type == &quot;string&quot; and vars[$v] \r\n          then setpath($p; vars[$v])\r\n          else . \r\n          end);\r\n    \r\n    reduce inputs as $line ({i:0, value:$template};\r\n      (.value.sections[.i].title |= $line)\r\n      | .i +=1)\r\n    | .value\r\n    | fillin($vars)\r\n\r\n\r\n### The script\r\n\r\n    #!/bin/bash\r\n    \r\n    ### Set the bash variables - as many as needed\r\n    \r\n    section0_section_uuid=&quot;Section_0&quot;\r\n    section1_section_uuid=&quot;Section_1&quot;\r\n    \r\n    ROOT_USER_PASS=RUP\r\n    DEV_USER_PASS=DUP\r\n    \r\n    ### Preparations for calling jq\r\n    vars=$(cat&lt;&lt;EOF\r\n    {\r\n     &quot;ROOT_USER_PASS&quot;: &quot;$ROOT_USER_PASS&quot;,\r\n     &quot;DEV_USER_PASS&quot;: &quot;$DEV_USER_PASS&quot;\r\n    }\r\n    EOF\r\n    )\r\n    \r\n    cat &lt;&lt; EOF | jq -nR --argfile template template.json --argjson vars &quot;$vars&quot; -f template.jq\r\n    $section0_section_uuid\r\n    $section1_section_uuid\r\n    EOF\r\n\r\n### Output\r\n\r\nWith the (expanded) example template, the output is:\r\n\r\n    {\r\n      &quot;fields&quot;: [],\r\n      &quot;sections&quot;: [\r\n        {\r\n          &quot;fields&quot;: [\r\n            {\r\n              &quot;k&quot;: &quot;concealed&quot;,\r\n              &quot;n&quot;: &quot;[CHANGE_ME]&quot;,\r\n              &quot;t&quot;: &quot;RUP&quot;,\r\n              &quot;v&quot;: &quot;[CHANGE_ME]&quot;\r\n            },\r\n            {\r\n              &quot;k&quot;: &quot;concealed&quot;,\r\n              &quot;n&quot;: &quot;[CHANGE_ME]&quot;,\r\n              &quot;t&quot;: &quot;DUP&quot;,\r\n              &quot;v&quot;: &quot;[CHANGE_ME]&quot;\r\n            }\r\n          ],\r\n          &quot;name&quot;: &quot;Section_[CHANGE_ME]&quot;,\r\n          &quot;title&quot;: &quot;Section_0&quot;\r\n        },\r\n        {\r\n          &quot;fields&quot;: [\r\n            {\r\n              &quot;k&quot;: &quot;string&quot;,\r\n              &quot;n&quot;: &quot;[CHANGE_ME]&quot;,\r\n              &quot;t&quot;: &quot;placeholdertext&quot;,\r\n              &quot;v&quot;: &quot;[CHANGE_ME_LETTERS]&quot;\r\n            },\r\n            {\r\n              &quot;k&quot;: &quot;string&quot;,\r\n              &quot;n&quot;: &quot;[CHANGE_ME]&quot;,\r\n              &quot;t&quot;: &quot;placeholdertext&quot;,\r\n              &quot;v&quot;: &quot;[CHANGE_ME_LETTERS]&quot;\r\n            },\r\n            {\r\n              &quot;k&quot;: &quot;concealed&quot;,\r\n              &quot;n&quot;: &quot;[CHANGE_ME]&quot;,\r\n              &quot;t&quot;: &quot;placeholdertext&quot;,\r\n              &quot;v&quot;: &quot;[CHANGE_ME]&quot;\r\n            }\r\n          ],\r\n          &quot;name&quot;: &quot;Section_[CHANGE_ME]&quot;,\r\n          &quot;title&quot;: &quot;Section_1&quot;\r\n        }\r\n      ]\r\n    }\r\n",
                "title": "Making multiple changes to one JSON template"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1509267319,
        "creation_date": 1509127966,
        "last_edit_date": 1509245632,
        "question_id": 46981141,
        "body_markdown": "I&#39;m currently using `jq` with the 1pass CLI to try and create randomly generated passwords into a secure note. I&#39;m having an issue with setting the fields. \r\n\r\nThese are two of my variables. I have 8 total I need to set.\r\n\r\n    section0_section_uuid=&quot;Section_0&quot;\r\n\r\n    section1_section_uuid=&quot;Section_1&quot;\r\n\r\nAnd here are my commands to manipulate the template. I first read it in, change the first title,  then save it to `$template`. I then pass `$template` into `jq` \r\n\r\n    template=$(cat template.json | jq --arg uuid &quot;$section0_section_uuid&quot; &#39;.sections[0].title=$uuid&#39;)\r\n\r\n    template=$($template | jq --arg uuid &quot;$section1_section_uuid&quot; &#39;.sections[1].title=$uuid&#39;)\r\n\r\n    echo $template\r\n\r\nI get &quot;file name too long.&quot; I don&#39;t think I&#39;m passing the modified template variable in correctly. I need to do 7 more modifications to the `template.json` file.\r\n\r\nEdit:\r\n\r\nHere&#39;s the full template I&#39;m trying to manipulate. It&#39;s 12 total changes to the template I have to make. 10 of the 12 are random numbers that I will generate. The remaining 2 of the 12 will be a generated usernames.  \r\n\r\n    {\r\n      &quot;fields&quot;: [],\r\n      &quot;sections&quot;: [\r\n        {\r\n          &quot;fields&quot;: [\r\n            {\r\n              &quot;k&quot;: &quot;concealed&quot;,\r\n              &quot;n&quot;: &quot;[CHANGE_ME]&quot;,\r\n              &quot;t&quot;: &quot;ROOT_USER_PASS&quot;,\r\n              &quot;v&quot;: &quot;[CHANGE_ME]&quot;\r\n            },\r\n            {\r\n              &quot;k&quot;: &quot;concealed&quot;,\r\n              &quot;n&quot;: &quot;[CHANGE_ME]&quot;,\r\n              &quot;t&quot;: &quot;DEV_USER_PASS&quot;,\r\n              &quot;v&quot;: &quot;[CHANGE_ME]&quot;\r\n            }\r\n          ],\r\n          &quot;name&quot;: &quot;Section_[CHANGE_ME]&quot;,\r\n          &quot;title&quot;: &quot;Container SSH&quot;\r\n        },\r\n        {\r\n          &quot;fields&quot;: [\r\n            {\r\n              &quot;k&quot;: &quot;string&quot;,\r\n              &quot;n&quot;: &quot;[CHANGE_ME]&quot;,\r\n              &quot;t&quot;: &quot;placeholdertext&quot;,\r\n              &quot;v&quot;: &quot;[CHANGE_ME_LETTERS]&quot;\r\n            },\r\n            {\r\n              &quot;k&quot;: &quot;string&quot;,\r\n              &quot;n&quot;: &quot;[CHANGE_ME]&quot;,\r\n              &quot;t&quot;: &quot;placeholdertext&quot;,\r\n              &quot;v&quot;: &quot;[CHANGE_ME_LETTERS]&quot;\r\n            },\r\n            {\r\n              &quot;k&quot;: &quot;concealed&quot;,\r\n              &quot;n&quot;: &quot;[CHANGE_ME]&quot;,\r\n              &quot;t&quot;: &quot;placeholdertext&quot;,\r\n              &quot;v&quot;: &quot;[CHANGE_ME]&quot;\r\n            }\r\n          ],\r\n          &quot;name&quot;: &quot;Section_[CHANGE_ME]&quot;,\r\n          &quot;title&quot;: &quot;MySQL&quot;\r\n        }\r\n      ]\r\n    }",
        "link": "https://stackoverflow.com/questions/46981141/making-multiple-changes-to-one-json-template",
        "title": "Making multiple changes to one JSON template"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1509300938,
                "post_id": 47002191,
                "comment_id": 80953689,
                "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": 1509307073,
                "post_id": 47002191,
                "comment_id": 80955598,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1509312650,
                "post_id": 47002191,
                "comment_id": 80957370,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1509310474,
                "last_edit_date": 1509310474,
                "creation_date": 1509302821,
                "answer_id": 47003937,
                "question_id": 47002191,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution:\r\n\r\n    #!/bin/bash\r\n    \r\n    jq -M --argfile i input.json &#39;\r\n    \r\n        def VALUE_keys: keys[] | select(startswith(&quot;VALUE&quot;));\r\n        def TODAY_keys: keys[] | select(endswith(&quot;TODAY&quot;));\r\n        def TODAY_($k): &quot;\\($k)_TODAY&quot;;\r\n        def TOTAL_($k): &quot;\\($k)_TOTAL&quot;;\r\n    \r\n        def new_totals: \r\n            $i\r\n          | (map(VALUE_keys)|unique) as $attrs\r\n          | reduce (.[]|.DATE |= .[:10]) as $d ({}\r\n            ; reduce $attrs[] as $a (.\r\n              ; [$d.DATE, $a] as $p | setpath($p; getpath($p)+$d[$a])\r\n              )\r\n            )\r\n          | keys[] as $date \r\n          | [$date, .[$date]] ;\r\n    \r\n        def aggregate($k; $total):\r\n            .[TODAY_($k)] = $total\r\n          | if $k == &quot;VALUE_THREE&quot; \r\n            then .[TOTAL_($k)] += $total * 3\r\n            else .[TOTAL_($k)] += $total\r\n            end ;\r\n        \r\n        def next_day:\r\n            foreach new_totals as [$date, $totals] (\r\n               max_by(.DATE) \r\n             ; if .DATE == $date then empty else . end\r\n             | .DATE = $date\r\n             | .[TODAY_keys] = 0 \r\n             | reduce ($totals|keys[]) as $k (.; aggregate($k; $totals[$k]))\r\n           )\r\n        ;\r\n    \r\n        . + [next_day]\r\n\r\n    \r\n    &#39; consolidated.json | sponge consolidated.json\r\n\r\n`new_totals` computes the `input.json` sums returning the date and an array of values.  From the sample data it produces:\r\n\r\n    [\r\n      &quot;04.10.2017&quot;,\r\n      {\r\n        &quot;VALUE_ONE&quot;: 70,\r\n        &quot;VALUE_TWO&quot;: 10\r\n      }\r\n    ]\r\n\r\n`next_day` applies these values to the latest entry of `consolidated.json`\r\nreturning a value for the next day.  E.g.\r\n\r\n    {\r\n      &quot;DATE&quot;: &quot;04.10.2017&quot;,\r\n      &quot;VALUE_ONE_TODAY&quot;: 70,\r\n      &quot;VALUE_ONE_TOTAL&quot;: 960,\r\n      &quot;VALUE_THREE_TODAY&quot;: 0,\r\n      &quot;VALUE_THREE_TOTAL&quot;: 134,\r\n      &quot;VALUE_TWO_TODAY&quot;: 10,\r\n      &quot;VALUE_TWO_TOTAL&quot;: 10\r\n    }\r\n\r\nNote that the example output is inconsistent with the sample `input.json` so\r\nthe values differ.  \r\n\r\nThe script adds this to the input and uses `sponge` to update `consolidated.json` with the new data.  Note that the line\r\n\r\n    | if .DATE == $date then empty else . end\r\n\r\nprevents it from adding the data for a new day if that day is already present.  This is unnecessary if other safeguards are in place.\r\n\r\nNote also that `next_day` uses `foreach` to handle the situation where `input.json` contains data for more then one day.  For example if the first element of `input.json` were\r\n\r\n    {\r\n       &quot;DATE&quot;: &quot;03.12.2017 10:20&quot;,\r\n       &quot;ID&quot;:&quot;x&quot;,\r\n       &quot;VALUE_ONE&quot;: 20,\r\n       &quot;VALUE_TWO&quot;: 3\r\n    }\r\n\r\n`next_day` would generate two entries:\r\n\r\n    {\r\n      &quot;DATE&quot;: &quot;03.12.2017&quot;,\r\n      &quot;VALUE_ONE_TODAY&quot;: 20,\r\n      &quot;VALUE_ONE_TOTAL&quot;: 910,\r\n      &quot;VALUE_THREE_TODAY&quot;: 0,\r\n      &quot;VALUE_THREE_TOTAL&quot;: 134,\r\n      &quot;VALUE_TWO_TODAY&quot;: 3,\r\n      &quot;VALUE_TWO_TOTAL&quot;: 3\r\n    }\r\n    {\r\n      &quot;DATE&quot;: &quot;04.10.2017&quot;,\r\n      &quot;VALUE_ONE_TODAY&quot;: 50,\r\n      &quot;VALUE_ONE_TOTAL&quot;: 960,\r\n      &quot;VALUE_THREE_TODAY&quot;: 0,\r\n      &quot;VALUE_THREE_TOTAL&quot;: 134,\r\n      &quot;VALUE_TWO_TODAY&quot;: 7,\r\n      &quot;VALUE_TWO_TOTAL&quot;: 10\r\n    }\r\n\r\n[Try it online!](https://tio.run/##fVTbbtpAEH33V0wdS9gFHHNTEyMqIREpldIiVbRV5VpowQs4wNrxrhtQzLfT9a5vBKgfYLx75syZMwMzRFdHPF8FUHPe1NFw8qDaqtU1W5bZtlqfoGXZbUttqF9G/HzHg5/Dpx8P0/E3jmtb@evk11i1O4fGRYa23bvG0D1l6F1h6F7X0DplaB/cGnwGn4QxM59pQJSz3to5b5VoOhmPhr@rguThZPik2ndWWeTx@0MB7r0/FehWy6q20flfufuL5e4vl7u7XK7TlT3PA0KDje8hhj3R@vHmw@3MJ7czPmJFeX6B5ldoNlG0XPgbDH7FJKgpCvDHwwuQJdZ4T21IPx0XEqB4g@dMpwxFjL76bKVLKaph9ItMIfNKJiZeliebOc/TtbVhg/on/c46rkJ4r@8hafv9UjjBr1MWMLTh5cVh@mh@Fiagb1Gol90ZSUz8lxgbgChoiLGIFtAIe/Ecg246bmKmg4RkAKbDl82VcA/0t0NRpJ8nSBret6Dk@QUkBTmaJ8ga/E5CQmEQCxE3Rgv7sCxio655DocZFYYyNgqlmc9CEx88FBeOeG9w1SJwXahYhZbLCC/5MXeyD5pwzbALetMpR@LCIAMU1P4CtDUMBlBdR7X0nK0wERz5zFyo5yTwEToFEG8ovgYsQcQDuQiVSe/Y1EP7UvEiiDCaryo7kFqSeyAZqQt6xU3Yot10ttfFSIxSPR8Ub1BOnfcobRUt4W3I9pnoVFaZkuR4CT@5cMqfReqlBdXbfNEyhYkcp9yxNd@f/sVRUUdbu0axDjKQ4zWhDk7uj6sotfO/BbhJty4MyBJfuAR@PQ@2W0z4EQQxA@oTLpH5gRnFBLwAUyABgxX6izOa4/Ef &quot;Bash – Try It Online&quot;)",
                "title": "jq- Periodically add calculated values, based on exisiting values, to .json file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1509310967,
                "creation_date": 1509310967,
                "answer_id": 47005208,
                "question_id": 47002191,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a straightforward solution, which for simplicity of exposition makes the following (easy-to-work-around) assumptions:\r\n\r\n* The contents of input.json are as advertised, and in particular, that the date of objects in input.json does not yet occur in consolidated.json;\r\n* The last entry in the array in consolidated.json has the most recent date, and that it is prior to the date of the entries in input.json\r\n\r\n### consolidate.jq\r\n\r\n    def aggregate:\r\n      {DATE: (.[0]|.DATE|split(&quot; &quot;)[0]),\r\n       VALUE_ONE_TODAY: (map(.VALUE_ONE) | add),\r\n       VALUE_TWO_TODAY: (map(.VALUE_TWO) | add)}\r\n      ;\r\n    \r\n    .[-1] as $previous\r\n    | ($i | aggregate\r\n       | {DATE,\r\n          VALUE_ONE_TODAY,\r\n          VALUE_ONE_TOTAL : ($previous.VALUE_ONE_TOTAL + .VALUE_ONE_TODAY),\r\n          VALUE_THREE_TODAY : ($previous.VALUE_TWO_TOTAL + .VALUE_TWO_TODAY) }\r\n       |  .VALUE_THREE_TOTAL = ($previous.VALUE_THREE_TOTAL + 3 * .VALUE_THREE_TODAY) ) as $today\r\n    | . + [$today]\r\n\r\n\r\n### Invocation\r\n\r\n    jq -f consolidate.jq --argfile i input.json consolidated.json\r\n\r\nIf you are sure it is safe to do so, you could tack on: `| sponge consolidated.json`\r\n\r\n### Output\r\nThe added entry is as requested, namely:\r\n\r\n    {\r\n      &quot;DATE&quot;: &quot;04.10.2017&quot;,\r\n      &quot;VALUE_ONE_TODAY&quot;: 70,\r\n      &quot;VALUE_ONE_TOTAL&quot;: 960,\r\n      &quot;VALUE_THREE_TODAY&quot;: 10,\r\n      &quot;VALUE_THREE_TOTAL&quot;: 164\r\n    }",
                "title": "jq- Periodically add calculated values, based on exisiting values, to .json file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1509310967,
        "creation_date": 1509292353,
        "question_id": 47002191,
        "body_markdown": "\r\nThere is an input file which contains several objects connected to one specific day. (In this case it&#39;s 4th of October). Each Object however, represents another time of that day, with different VALUES. &quot;ID&quot; and day are always the same in the file:\r\n\r\nINPUT.json:\r\n\r\n    [\r\n      {\r\n        &quot;DATE&quot;: &quot;04.10.2017 10:20&quot;,\r\n        &quot;ID&quot;:&quot;x&quot;,\r\n        &quot;VALUE_ONE&quot;: 20,\r\n        &quot;VALUE_TWO&quot;: 3\r\n      },\r\n      {\r\n        &quot;DATE&quot;: &quot;04.10.2017 12:50&quot;,\r\n        &quot;ID&quot;:&quot;x&quot;,\r\n        &quot;VALUE_ONE&quot;: 40,\r\n        &quot;VALUE_TWO&quot;: 5\r\n      },\r\n      {\r\n        &quot;DATE&quot;: &quot;04.10.2017 14:20&quot;,\r\n        &quot;ID&quot;:&quot;x&quot;,\r\n        &quot;VALUE_ONE&quot;: 10,\r\n        &quot;VALUE_TWO&quot;: 2\r\n      }   \r\n    ]\r\n\r\nWhat I want to do now is calculate the day&#39;s total values and also do some math. (in this case either add or multiply by 3).\r\n\r\nThe results shall be added to the &#39;consolidated.json&#39; file, which should contain one object for each day. To ensure that, this process will be repeated daily.\r\n\r\nI have commented the calculation steps behind &#39;//&#39; :\r\n\r\nCONSOLIDATED.json:\r\n\r\n    [\r\n      {\r\n        &quot;DATE&quot;: &quot;02.10.2017&quot;,\r\n        &quot;VALUE_ONE_TODAY&quot;: 40,\r\n        &quot;VALUE_ONE_TOTAL&quot;: 800,\r\n        &quot;VALUE_THREE_TODAY&quot;: 5,\r\n        &quot;VALUE_THREE_TOTAL&quot;: 110\r\n      },\r\n      {\r\n        &quot;DATE&quot;: &quot;03.10.2017&quot;,\r\n        &quot;VALUE_ONE_TODAY&quot;: 90,\r\n        &quot;VALUE_ONE_TOTAL&quot;: 890, // =800+90\r\n        &quot;VALUE_THREE_TODAY&quot;: 8,\r\n        &quot;VALUE_THREE_TOTAL&quot;: 134 // = 110 + 3*8\r\n      },\r\n      {           //this object is new!\r\n        &quot;DATE&quot;: &quot;04.10.2017&quot;,\r\n        &quot;VALUE_ONE_TODAY&quot;: 70,\r\n        &quot;VALUE_ONE_TOTAL&quot;: 960, // =890+70\r\n        &quot;VALUE_THREE_TODAY&quot;: 10,\r\n        &quot;VALUE_THREE_TOTAL&quot;: 164 // =134 +3*10\r\n      }\r\n    ]\r\nI know I can get the totals of INPUT.json with \r\n\r\n    [.[]|.VALUE_ONE]|add\r\n\r\nand\r\n\r\n    [.[]|.VALUE_TWO*3]|add\r\n\r\nBut I am not sure how to get this into the desired structure and use last day&#39;s totals. \r\nThanks!",
        "link": "https://stackoverflow.com/questions/47002191/jq-periodically-add-calculated-values-based-on-exisiting-values-to-json-file",
        "title": "jq- Periodically add calculated values, based on exisiting values, to .json file"
    },
    {
        "tags": [
            "json",
            "path",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1509309782,
                "creation_date": 1509309782,
                "answer_id": 47005033,
                "question_id": 47004904,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "You could take advantage of how streams work by merging the path with their values. Streams will only emit `path, value` pairs for leaf values.  Just ignore the numbered indices.\r\n\r\n    $ jq --stream &#39;\r\n    select(length == 2) | [(.[0][] | select(strings)), .[1]] | join(&quot;/&quot;)\r\n    &#39; source-file\r\n\r\nreturns:\r\n\r\n    &quot;dir-1/file-1.1&quot;\r\n    &quot;dir-1/file-1.2&quot;\r\n    &quot;dir-1&quot;\r\n    &quot;dir-2/file-2.1&quot;\r\n\r\n",
                "title": "How to make paths to leafs of a JSON?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1509315918,
                "last_edit_date": 1509315918,
                "creation_date": 1509314651,
                "answer_id": 47005722,
                "question_id": 47004904,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution similar to [Jeff Mercado](https://stackoverflow.com/a/47005033/8379597)&#39;s which uses `tostream` and `flatten`\r\n\r\n    tostream | select(length==2) | .[0] |= map(strings) | flatten | join(&quot;/&quot;)\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/mrq5-WqKip)\r\n\r\nAnother way is to use a recursive function to walk the input such as\r\n\r\n    def slashpaths($p):\r\n      def concat($p;$k): if $p==&quot;&quot; then $k else &quot;\\($p)/\\($k)&quot; end;\r\n      if   type==&quot;array&quot;  then .[] | slashpaths($p)\r\n      elif type==&quot;object&quot; then\r\n           keys_unsorted[] as $k\r\n         | .[$k] | slashpaths(concat($p;$k))\r\n      else concat($p;.) end;\r\n    slashpaths(&quot;&quot;)\r\n\r\n[Try it online at tio.run!](https://tio.run/##XY/RToQwEEXf/YrJpA@SUAw8stkvQWIqDIGlaWtbYojsr4ujsKI7D02nc8/c28vbWn1gO3iZY1lhN2iSeZZjersWWF/TXZBuyuJXWbCyvtbLClwtdRC0Cr1TsQ@PwiXlA8Bt0ljTqMivJzEmJQwdCHc@I0LsyYAYgXQgwOdv7onPMUEg0572FawHiLMjZpT3akbYyKyqYbnz3RnSTO2Mfb1QEze3ffxTI83hZTLB@kgtr1KBsxyChfeL8c7h31cOM45/TLLkSP8HRUzW9dO6OFgTVinNpLUcjJsiN169SztFbr4A &quot;jq – Try It Online&quot;)",
                "title": "How to make paths to leafs of a JSON?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1509341643,
                "last_edit_date": 1509341643,
                "creation_date": 1509314845,
                "answer_id": 47005747,
                "question_id": 47004904,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using `--stream` is good but the following is perhaps less esoteric:\r\n\r\n    paths(scalars) as $p\r\n    | getpath($p) as $v\r\n    | ($p | map(strings) + [$v])\r\n    | join(&quot;/&quot;)\r\n\r\n(If using jq 1.4 or earlier, and if any of the leaves might be numeric or boolean or null, then `[$v]` above should be replaced by `[$v|tostring]`.)\r\n\r\nWhether the result should be regarded as &quot;paths to leaves&quot; is another matter...\r\n\r\n",
                "title": "How to make paths to leafs of a JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1509341643,
        "creation_date": 1509308881,
        "last_edit_date": 1509338228,
        "question_id": 47004904,
        "body_markdown": "Say we have the following JSON:\r\n\r\n    [\r\n      {\r\n        &quot;dir-1&quot;: [\r\n          &quot;file-1.1&quot;,\r\n          &quot;file-1.2&quot;\r\n        ]\r\n      },\r\n      &quot;dir-1&quot;,\r\n      {\r\n        &quot;dir-2&quot;: [\r\n          &quot;file-2.1&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\nAnd we want to get the next output:\r\n\r\n      &quot;dir-1/file-1.1&quot;\r\n      &quot;dir-1/file-1.2&quot;\r\n      &quot;dir-1&quot;\r\n      &quot;dir-2/file-2.1&quot;\r\n\r\ni.e. to get the paths to all leafs, joining items with `/`. Is there a way to do that on JQ?\r\n\r\n\r\nI tried something like this:\r\n\r\n    cat source-file | jq &#39;path(..) | [ .[] | tostring ] | join(&quot;/&quot;)&#39;\r\n\r\nBut it doesn&#39;t produce what I need even close.",
        "link": "https://stackoverflow.com/questions/47004904/how-to-make-paths-to-leafs-of-a-json",
        "title": "How to make paths to leafs of a JSON?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1509524947,
                "last_edit_date": 1509524947,
                "creation_date": 1509359667,
                "answer_id": 47013146,
                "question_id": 47012967,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The issue is in your notation `.[][]`. Your input is just an ***object*** but you are trying to present it as a &quot;container&quot; of &quot;containers&quot; `.[][]`.\r\n\r\nThe right way is:\r\n\r\n    jq &#39;.hosts[] | select(.hostname==&quot;h6&quot;)&#39; ddd.json\r\n    {\r\n      &quot;apt_update_last_success&quot;: &quot;1496049307&quot;,\r\n      &quot;architecture&quot;: &quot;amd64&quot;,\r\n      &quot;hostname&quot;: &quot;h6&quot;\r\n    }\r\n\r\n\r\n----------\r\nBesides, on *jq* **1.5** this `jq -r &#39;.[][] | select(.hostname==&quot;h6&quot;)&#39; ddd.json` doesn&#39;t return the expected object but only prints \r\n`jq: error (at jq1:36): Cannot iterate over string (&quot;DC&quot;)`\r\n",
                "title": "jq: error: Cannot iterate over string"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1666950511,
                "creation_date": 1666950511,
                "answer_id": 74233547,
                "question_id": 47012967,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I got this error when piping a log file with a list of individual JSON objects to JQ:\r\n\r\n```\r\n$ cat my_log_file.txt:\r\n{&quot;message&quot;: &quot;foo&quot;}\r\n{&quot;message&quot;: &quot;bar&quot;}\r\n\r\n$ cat my_log_file.txt | jq &#39;.message | unique&#39;\r\njq: error (at &lt;stdin&gt;:1): Cannot iterate over string (&quot;foo&quot;)\r\njq: error (at &lt;stdin&gt;:2): Cannot iterate over string (&quot;bar&quot;)\r\n```\r\n\r\nIn this case you need to use jq&#39;s command line option `-s` (slurp) so that you can operate on the file as a single array object.\r\n\r\n```\r\n$ cat my_log_file.txt | jq -s\r\n[\r\n  {\r\n    &quot;message&quot;: &quot;foo&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;bar&quot;\r\n  }\r\n]\r\n",
                "title": "jq: error: Cannot iterate over string"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 8,
        "last_activity_date": 1666950511,
        "creation_date": 1509359172,
        "question_id": 47012967,
        "body_markdown": "could someone please explain below warning?\r\n\r\ninput file is:\r\n\r\n    {\r\n     &quot;env&quot;: &quot;DC&quot;,\r\n     &quot;hosts&quot; :\r\n    [\r\n    {\r\n      &quot;apt_update_last_success&quot;: &quot;1495991703&quot;,\r\n      &quot;architecture&quot;: &quot;amd64&quot;,\r\n      &quot;hostname&quot;: &quot;h1&quot;\r\n    },\r\n    {\r\n      &quot;apt_update_last_success&quot;: &quot;1495991703&quot;,\r\n      &quot;architecture&quot;: &quot;amd64&quot;,\r\n      &quot;hostname&quot;: &quot;h2&quot;\r\n    },\r\n    {\r\n      &quot;apt_update_last_success&quot;: &quot;1496045706&quot;,\r\n      &quot;architecture&quot;: &quot;amd64&quot;,\r\n      &quot;hostname&quot;: &quot;h3&quot;\r\n    },\r\n    {\r\n      &quot;apt_update_last_success&quot;: &quot;1496045705&quot;,\r\n      &quot;architecture&quot;: &quot;amd64&quot;,\r\n      &quot;hostname&quot;: &quot;h4&quot;\r\n    },\r\n    {\r\n      &quot;apt_update_last_success&quot;: &quot;1496049305&quot;,\r\n      &quot;architecture&quot;: &quot;amd64&quot;,\r\n      &quot;hostname&quot;: &quot;h5&quot;\r\n    },\r\n    {\r\n      &quot;apt_update_last_success&quot;: &quot;1496049307&quot;,\r\n      &quot;architecture&quot;: &quot;amd64&quot;,\r\n      &quot;hostname&quot;: &quot;h6&quot;\r\n    }\r\n    ]\r\n    }\r\n\r\nthe jq command returns what expected but also prints the warning I dont know why:\r\n\r\n    $ jq -r &#39;.[][] | select(.hostname==&quot;h6&quot;)&#39; ddd.json\r\n    jq: error: Cannot iterate over string\r\n    {\r\n      &quot;apt_update_last_success&quot;: &quot;1496049307&quot;,\r\n      &quot;architecture&quot;: &quot;amd64&quot;,\r\n      &quot;hostname&quot;: &quot;h6&quot;\r\n    }\r\n\r\nplease tell me how to get rid of this.\r\n\r\nthank you.",
        "link": "https://stackoverflow.com/questions/47012967/jq-error-cannot-iterate-over-string",
        "title": "jq: error: Cannot iterate over string"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1509369836,
                "creation_date": 1509369836,
                "answer_id": 47016388,
                "question_id": 47016326,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Multiple filters in `jq` are separated by a comma. `. , .` duplicates the output because it means two times *the current context*.",
                "title": "What is special use of comma ( , ) operator while running &quot;Jq&quot; in command line?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1509370507,
                "creation_date": 1509370507,
                "answer_id": 47016630,
                "question_id": 47016326,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Take a look at the man page for jq by typing:\r\n\r\n    man jq\r\n\r\nThere is a paragraph on the use of the comma ,\r\n\r\n    ,\r\n\r\n    If two filters are separated by a comma, then the input  will  be  fed\r\n    into both and there will be multiple outputs: first, all of the outputs\r\n    produced by the left expression, and then all of the outputs produced\r\n    by the right. For instance, filter .foo, .bar, produces both the &quot;foo&quot;\r\n    fields and &quot;bar&quot; fields as separate outputs.\r\n\r\n:-)\r\n\r\n",
                "title": "What is special use of comma ( , ) operator while running &quot;Jq&quot; in command line?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1509370507,
        "creation_date": 1509369693,
        "question_id": 47016326,
        "body_markdown": "Here is the sample code,\r\n\r\n    echo &#39;{&quot;x&quot; : 1}&#39; | jq &#39;. , .&#39;\r\nThe output of the above command is this:\r\n{\r\n    &quot;x&quot; : 1\r\n}\r\n{\r\n    &quot;x&quot; : 1\r\n}\r\n\r\nI am beginner and didn&#39;t find much information about comma (, ) operator while  \r\nrunning with &quot;jq&quot;.",
        "link": "https://stackoverflow.com/questions/47016326/what-is-special-use-of-comma-operator-while-running-jq-in-command-line",
        "title": "What is special use of comma ( , ) operator while running &quot;Jq&quot; in command line?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1509377195,
                "post_id": 47018589,
                "comment_id": 80984296,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1509382013,
                "last_edit_date": 1509382013,
                "creation_date": 1509380717,
                "answer_id": 47019980,
                "question_id": 47018589,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "For me your filter produces the error\r\n\r\n    jq: error (at &lt;unknown&gt;): Cannot index array with string &quot;id&quot;\r\n\r\nI suspect this is because you wrote `$b` instead of `$b[]` and `$a.id` instead of `$passed.id`.  Here is my guess at what you intended to write:\r\n\r\n      $a[] \r\n    | reduce select(.status == &quot;passed&quot;) as $passed (.; \r\n       $b[] | select( $passed.id == .id and .status == &quot;failed&quot;)\r\n      )\r\n\r\nwhich produces the output\r\n\r\n    null\r\n    {\r\n      &quot;status&quot;: &quot;failed&quot;,\r\n      &quot;id&quot;: &quot;id2&quot;\r\n    }\r\n\r\nYou can filter away the `null` by adding `| values` e.g.\r\n\r\n      $a[] \r\n    | reduce select(.status == &quot;passed&quot;) as $passed (.; \r\n       $b[] | select( $passed.id == .id and .status == &quot;failed&quot;)\r\n      )\r\n    | values\r\n\r\nHowever you don&#39;t really need `reduce` here.  A simpler way is just:\r\n\r\n       $a[]\r\n     | select(.status == &quot;passed&quot;) as $passed\r\n     | $b[]\r\n     | select( $passed.id == .id and .status == &quot;failed&quot;)\r\n\r\n\r\nIf you intend to go further with this I would recommend a different approach: first construct an object combining `$a` and `$b` and then project what you want from it.  e.g.\r\n\r\n    reduce (($a[]|{(.id):{a:.status}}),($b[]|{(.id):{b:.status}})) as $v ({};.*$v)\r\n\r\nwill give you\r\n\r\n    {\r\n      &quot;id1&quot;: {\r\n        &quot;a&quot;: &quot;passed&quot;,\r\n        &quot;b&quot;: &quot;passed&quot;\r\n      },\r\n      &quot;id2&quot;: {\r\n        &quot;a&quot;: &quot;passed&quot;,\r\n        &quot;b&quot;: &quot;failed&quot;\r\n      }\r\n    }\r\n\r\nTo convert that back to the output you requested add\r\n \r\n     | keys[] as $id\r\n     | .[$id]\r\n     | select(.a == &quot;passed&quot; and .b == &quot;failed&quot;)\r\n     | {$id, status:.b}\r\n\r\nto obtain\r\n\r\n    {\r\n      &quot;id&quot;: &quot;id2&quot;,\r\n      &quot;status&quot;: &quot;failed&quot;\r\n    }",
                "title": "jq conditional processing on multiple files"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1509427452,
                "last_edit_date": 1509427452,
                "creation_date": 1509390629,
                "answer_id": 47022613,
                "question_id": 47018589,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following solutions to the problem are oriented primarily towards efficiency, but it turns out that they are quite straightforward and concise.  \r\n\r\nFor efficiency, we will construct a &quot;dictionary&quot; of ids of those who have passed in a.json to make the required lookup very fast. \r\n\r\nAlso, if you have a version of jq with `inputs`, it is easy to avoid &quot;slurping&quot; the contents of b.json.\r\n\r\n### Solution for jq 1.4 or higher\r\n\r\nHere is a generic solution which, however, slurps both files:\r\n\r\nInvocation (note the use of the -s option):\r\n\r\n    jq -s --slurpfile a a.json -f passed-and-failed.jq b.json\r\n\r\nProgram:\r\n\r\n    ([$a[] | select(.status==&quot;passed&quot;) | {(.id): true}] | add) as $passed\r\n    | .[] | select(.status == &quot;failed&quot; and $passed[.id])\r\n\r\nThat is, first construct the dictionary, and then emit the objects in b.json that satisfy the condition.\r\n\r\n### Solution for jq 1.5 or higher\r\n\r\nInvocation (note the use of the -n option):\r\n\r\n    jq -n --slurpfile a a.json -f passed-and-failed.jq b.json\r\n\r\n`INDEX/2` is currently available from the `master` branch, but is provided here in case your jq does not have it, in which case you might want to add its definition to `~/.jq`:\r\n\r\n    def INDEX(stream; idx_expr):\r\n      reduce stream as $row ({};\r\n        .[$row|idx_expr|\r\n          if type != &quot;string&quot; then tojson\r\n          else .\r\n          end] |= $row);\r\n\r\nThe solution now becomes a simple two-liner:\r\n\r\n    INDEX($a[] | select(.status == &quot;passed&quot;) | .id; .) as $passed\r\n    | inputs | select(.status == &quot;failed&quot; and $passed[.id])\r\n\r\n\r\n",
                "title": "jq conditional processing on multiple files"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1509427452,
        "creation_date": 1509376213,
        "last_edit_date": 1509380605,
        "question_id": 47018589,
        "body_markdown": "I have multiple json files:\r\n\r\n**a.json**\r\n\r\n    {\r\n      &quot;status&quot;: &quot;passed&quot;,\r\n      &quot;id&quot;: &quot;id1&quot;\r\n    }\r\n    {\r\n      &quot;status&quot;: &quot;passed&quot;,\r\n      &quot;id&quot;: &quot;id2&quot;\r\n    }\r\n\r\n**b.json**\r\n\r\n    {\r\n      &quot;status&quot;: &quot;passed&quot;,\r\n      &quot;id&quot;: &quot;id1&quot;\r\n    }\r\n    {\r\n      &quot;status&quot;: &quot;failed&quot;,\r\n      &quot;id&quot;: &quot;id2&quot;\r\n    }\r\n\r\nI want to know which id was passed in `a.json` and which is failed now in `b.json`.\r\n\r\n**expected.json**\r\n\r\n    {\r\n      &quot;status&quot;: &quot;failed&quot;,\r\n      &quot;id&quot;: &quot;id2&quot;\r\n    }\r\n\r\nI tried something like:\r\n\r\n    jq --slurpfile a a.json --slurpfile b b.json -n &#39;$a[] | reduce select(.status == &quot;passed&quot;) as $passed (.; $b | select($a.id == .id and  .status == &quot;failed&quot;))&#39;\r\n\r\n`$passed` is supposed to contain the list of passed entry in `a.json` and  `reduce` will merge all the objects for which the id matches and are `failed`.\r\n\r\nHowever it does not produce the expected result, and the documentation is kind of limited.\r\n\r\nHow to produce `expected.json` from `a.json` and `b.json` ?\r\n",
        "link": "https://stackoverflow.com/questions/47018589/jq-conditional-processing-on-multiple-files",
        "title": "jq conditional processing on multiple files"
    },
    {
        "tags": [
            "bash",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1633446354,
                "last_edit_date": 1633446354,
                "creation_date": 1509377721,
                "answer_id": 47019058,
                "question_id": 47018863,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Download and install `jq` which is like `sed` for `JSON` data. You can use it to slice and filter and map and transform structured data with the same ease that `sed`, `awk`, `grep` does for unstructured data. Remember to replace `&#39;...&#39;` with your actual `curl` arguments\r\n\r\n\r\n    curl &#39;...&#39; | jq --raw-output &#39;.AssetID&#39;\r\n\r\nand to store it in a variable use command-substitution syntax to run the command and return the result.\r\n\r\n    asset_ID=$( curl &#39;...&#39; | jq --raw-output &#39;.AssetID&#39; )\r\n\r\nIn the `curl` command, drop the `-i` flag to output only the `JSON` data without the header information.\r\n",
                "title": "Parsing and storing the json output of a curl command in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 8,
        "last_activity_date": 1633446354,
        "creation_date": 1509377105,
        "last_edit_date": 1602167957,
        "question_id": 47018863,
        "body_markdown": "I have five `cURL` statements that work fine by themselves and am trying to put them together in a bash script.  Each `cURL` statement relies on a variable generated from a `cuRL` statement executed before it.  I&#39;m trying to figure out the smartest way to go about this.  Here is the first cURL statement;\r\n\r\n    curl -i -k -b sessionid -X POST https://base/resource -H &quot;Content-Type: application/json&quot; -H &quot;Authorization: Authorization: PS-Auth key=keyString; runas=userName; pwd=[password]&quot; -d &quot;{\\&quot;AssetName\\&quot;:\\&quot;apiTest\\&quot;,\\&quot;DnsName\\&quot;:\\&quot;apiTest\\&quot;,\\&quot;DomainName\\&quot;:\\&quot;domainNameString\\&quot;,\\&quot;IPAddress\\&quot;:\\&quot;ipAddressHere\\&quot;,\\&quot;AssetType\\&quot;:\\&quot;apiTest\\&quot;}&quot;\r\n\r\nThis works fine, it produces this output;\r\n\r\n    {&quot;WorkgroupID&quot;:1,&quot;AssetID&quot;:57,&quot;AssetName&quot;:&quot;apiTest&quot;,&quot;AssetType&quot;:&quot;apiTest&quot;,&quot;DnsName&quot;:&quot;apiTest&quot;,&quot;DomainName&quot;:&quot;domainNameString&quot;,&quot;IPAddress&quot;:&quot;ipAddressHere&quot;,&quot;MacAddress&quot;:null,&quot;OperatingSystem&quot;:null,&quot;LastUpdateDate&quot;:&quot;2017-10-30T15:18:05.67-07:00&quot;}\r\n\r\nHowever, in the next `cURL` statement, I need to use the integer from `AssetID` in order to execute it.  In short, how can I take the `AssetID` value and store it to a variable to be used in the next statement?  In total, I&#39;ll be using 5 `cURL` statements and they rely on values generated in the preceeding statement to execute.  Any insight on how is appreciated.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/47018863/parsing-and-storing-the-json-output-of-a-curl-command-in-bash",
        "title": "Parsing and storing the json output of a curl command in bash"
    },
    {
        "tags": [
            "json",
            "file",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1509574584,
                "last_edit_date": 1509574584,
                "creation_date": 1509393673,
                "answer_id": 47023283,
                "question_id": 47022870,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses [Object Multiplication](https://stedolan.github.io/jq/manual/#Multiplication,division,modulo:%2A,/,and%).  Assuming your data is in `A.json` and `B.json`:\r\n\r\n    $ jq -M --argfile b B.json &#39;.[0].elements[0] *= $b[0].elements[0]&#39; A.json\r\n\r\nproduces\r\n\r\n    [\r\n      {\r\n        &quot;uri&quot;: &quot;https://someurl.com&quot;,\r\n        &quot;id&quot;: &quot;some-id&quot;,\r\n        &quot;keyword&quot;: &quot;SomeKeyword&quot;,\r\n        &quot;name&quot;: &quot;Some Name&quot;,\r\n        &quot;description&quot;: &quot;Some description for that test result&quot;,\r\n        &quot;line&quot;: 2,\r\n        &quot;tags&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;@sometag&quot;,\r\n            &quot;line&quot;: 1\r\n          }\r\n        ],\r\n        &quot;elements&quot;: [\r\n          {\r\n            &quot;a&quot;: 5,\r\n            &quot;b&quot;: 2\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nThis approach is easily generalized if your arrays contain more data but you&#39;ll need to understand how corresponding elements should be identified.\r\n\r\n___\r\n\r\nRegarding the revised question, here is a filter which updates objects of `A.json` with corresponding objects of `B.json` having the same `.id`:\r\n\r\n\r\n    def INDEX(stream; idx_expr):\r\n      reduce stream as $row ({};\r\n        .[$row|idx_expr| if type != &quot;string&quot; then tojson else . end] |= $row);\r\n\r\n    def merge_by_id(a;b):\r\n      if b then INDEX(a[];.id) * INDEX(b[];.id) | map(.) else a end;\r\n\r\n      INDEX($b[];.id) as $i\r\n    | map( .elements = merge_by_id(.elements; $i[.id].elements) )\r\n\r\nFor example if the above filter is in `filter.jq`, `A.json` contains the revised sample data and `B.json` contains\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;safety-tests&quot;,\r\n        &quot;elements&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;some-element-id&quot;,\r\n            &quot;description&quot;: &quot;updated description&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nThe command \r\n\r\n    $ jq -M --argfile b B.json -f filter.jq A.json\r\n\r\ngenerates the result \r\n\r\n    [\r\n      {\r\n        &quot;uri&quot;: &quot;some/url.feature&quot;,\r\n        &quot;id&quot;: &quot;safety-tests&quot;,                      &lt;------ top level .id\r\n        ...\r\n        &quot;elements&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;some-element-id&quot;,               &lt;------ element .id\r\n            &quot;keyword&quot;: &quot;Scenario Outline&quot;,\r\n            &quot;name&quot;: &quot;: Some scenario name&quot;,\r\n            &quot;description&quot;: &quot;updated description&quot;,  &lt;------ updated value\r\n            &quot;line&quot;: 46,\r\n            &quot;type&quot;: &quot;scenario&quot;,\r\n            ...\r\n\r\n___\r\n\r\nNote that the above solution assumes the `.id` of the elements in `A.json` are unique otherwise `merge_by_id` won&#39;t produce the desired output.  In that case the following filter should suffice:\r\n\r\n    def INDEX(stream; idx_expr):\r\n      reduce stream as $row ({};\r\n        .[$row|idx_expr| if type != &quot;string&quot; then tojson else . end] |= $row);\r\n\r\n      (INDEX($b[];.id) | map_values(INDEX(.elements[];.id))) as $i\r\n    | map( $i[.id] as $o | if $o then .elements |= map($o[.id]//.) else . end )\r\n\r\nThis filter only requires the `.id` of the objects in `B.json` to be unique.  If it&#39;s possible for there to be non-unique elements in both `A.json` and `B.json` then a more sophisticated mapping then this one will be required.\r\n\r\nHere is a version of the filter with comments:\r\n\r\n    def INDEX(stream; idx_expr):\r\n      reduce stream as $row ({};\r\n        .[$row|idx_expr| if type != &quot;string&quot; then tojson else . end] |= $row);\r\n\r\n      # first create a lookup table for elements from B.json\r\n      (                                         #       [{id:x, elements:[{id:y, ...}]}]\r\n          INDEX($b[];.id)                       # -&gt; {x: {id:x, elements:[{id:y, ...}]}..}\r\n        | map_values(INDEX(.elements[];.id))    # -&gt; {x: {y: {id:y, ...}}}\r\n      ) as $i\r\n\r\n      # update A.json objects\r\n    | map(                                      # for each object in A.json\r\n        $i[.id] as $o                           # do we have updated values from B.json ?\r\n      | if $o then .elements |= map($o[.id]//.) # if so then replace corresponding elements\r\n        else . end                              # otherwise leave object unchanged\r\n      )",
                "title": "overwrite a json file with objects from another json file using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1509399413,
                "last_edit_date": 1509399413,
                "creation_date": 1509393977,
                "answer_id": 47023357,
                "question_id": 47022870,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "There are two key insights required to solve your problem concisely:\r\n\r\n* if A and B are two objects, then you can combine them with priority being given to B by writing: A + B\r\n\r\n* To update an object &quot;in place&quot;, we can use |= or += as appropriate.\r\n\r\nIn your case, we can apply these insights by writing:\r\n\r\n    .[0].elements[0] += $B[0].elements[0]\r\n\r\nassuming an invocation along the following lines:\r\n\r\n    jq --argfile B B.json -f combine.jq A.json \r\n\r\n### Output\r\nWith your input, the output includes:\r\n\r\n    &quot;elements&quot;: [\r\n      {\r\n        &quot;a&quot;: 5,\r\n        &quot;b&quot;: 2\r\n      }\r\n    ]\r\n\r\nAs per the requirements.\r\n\r\n### Further notes\r\n\r\nTo overwrite A.json with the output produced by the above invocation of jq, you might want to use `sponge`, but please be aware of the risks.\r\n\r\nIf you don&#39;t want to use `--argfile` for whatever reason, you could use `--slurpfile` instead, but then you&#39;d have to write `$B[0][0]`\r\n\r\n",
                "title": "overwrite a json file with objects from another json file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1509574584,
        "creation_date": 1509391775,
        "last_edit_date": 1509453170,
        "question_id": 47022870,
        "body_markdown": "MODIFIED:\r\n\r\nHello I&#39;m having problems on merging 2 files basically I have 2 json files with this structure:\r\n\r\n    [\r\n      {\r\n        &quot;uri&quot;: &quot;some/url.feature&quot;,\r\n        &quot;id&quot;: &quot;safety-tests&quot;,\r\n        &quot;keyword&quot;: &quot;Feature&quot;,\r\n        &quot;name&quot;: &quot;Safety Tests&quot;,\r\n        &quot;description&quot;: &quot;Some description&quot;,\r\n        &quot;line&quot;: 2,\r\n        &quot;tags&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;@sometag&quot;,\r\n            &quot;line&quot;: 1\r\n          }\r\n        ],\r\n        &quot;elements&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;some-element-id&quot;,\r\n            &quot;keyword&quot;: &quot;Scenario Outline&quot;,\r\n            &quot;name&quot;: &quot;: Some scenario name&quot;,\r\n            &quot;description&quot;: &quot;&quot;,\r\n            &quot;line&quot;: 46,\r\n            &quot;type&quot;: &quot;scenario&quot;,\r\n            &quot;tags&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;@sometag&quot;,\r\n                &quot;line&quot;: 1\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;@someothertag&quot;,\r\n                &quot;line&quot;: 31\r\n              }\r\n            ],\r\n            &quot;before&quot;: [\r\n              {\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/test/file.rb:201&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 15000\r\n                }\r\n              },\r\n              {\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/file.rb:5&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 1722192000\r\n                }\r\n              }\r\n            ],\r\n            &quot;steps&quot;: [\r\n              {\r\n                &quot;keyword&quot;: &quot;Given &quot;,\r\n                &quot;name&quot;: &quot;Some step name&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;output&quot;: [\r\n                  &quot;Some output&quot;\r\n                ],\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:137&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 989158000\r\n                }\r\n              },\r\n              {\r\n                &quot;keyword&quot;: &quot;When &quot;,\r\n                &quot;name&quot;: &quot;some other step&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;output&quot;: [\r\n                  &quot;WARNING: static wait for 1 seconds.&quot;\r\n                ],\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:80&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 2700052000\r\n                }\r\n              },\r\n              {\r\n                &quot;keyword&quot;: &quot;And &quot;,\r\n                &quot;name&quot;: &quot;Some other name&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:38&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 954225000\r\n                }\r\n              },\r\n              {\r\n                &quot;keyword&quot;: &quot;Then &quot;,\r\n                &quot;name&quot;: &quot;Some other step name&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:2&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 38792000\r\n                }\r\n              },\r\n              {\r\n                &quot;keyword&quot;: &quot;And &quot;,\r\n                &quot;name&quot;: &quot;And again some other step name&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:2&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 39268000\r\n                }\r\n              },\r\n              {\r\n                &quot;keyword&quot;: &quot;And &quot;,\r\n                &quot;name&quot;: &quot;Some other step name&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:2&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 55637000\r\n                }\r\n              },\r\n              {\r\n                &quot;keyword&quot;: &quot;And &quot;,\r\n                &quot;name&quot;: &quot;Some other step name&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:2&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 38375000\r\n                }\r\n              },\r\n              {\r\n                &quot;keyword&quot;: &quot;When &quot;,\r\n                &quot;name&quot;: &quot;Some other step name&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:12&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 751416000\r\n                }\r\n              },\r\n              {\r\n                &quot;keyword&quot;: &quot;And &quot;,\r\n                &quot;name&quot;: &quot;Some other step name&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:2&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 28043000\r\n                }\r\n              },\r\n              {\r\n                &quot;keyword&quot;: &quot;Then &quot;,\r\n                &quot;name&quot;: &quot;Some other step name&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:20&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 5204000\r\n                }\r\n              }\r\n            ],\r\n            &quot;after&quot;: [\r\n              {\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:91&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 20000\r\n                }\r\n              },\r\n              {\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:52&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 5585000\r\n                }\r\n              },\r\n              {\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:27&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 168146000\r\n                }\r\n              },\r\n              {\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:428&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 62000\r\n                }\r\n              }\r\n            ]\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;some-element-id&quot;,\r\n            &quot;keyword&quot;: &quot;Scenario Outline&quot;,\r\n            &quot;name&quot;: &quot;: Some scenario name&quot;,\r\n            &quot;description&quot;: &quot;&quot;,\r\n            &quot;line&quot;: 46,\r\n            &quot;type&quot;: &quot;scenario&quot;,\r\n            &quot;tags&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;@sometag&quot;,\r\n                &quot;line&quot;: 1\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;@someothertag&quot;,\r\n                &quot;line&quot;: 31\r\n              }\r\n            ],\r\n            &quot;before&quot;: [\r\n              {\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/test/file.rb:201&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 15000\r\n                }\r\n              },\r\n              {\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/file.rb:5&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 1722192000\r\n                }\r\n              }\r\n            ],\r\n            &quot;steps&quot;: [\r\n              {\r\n                &quot;keyword&quot;: &quot;Given &quot;,\r\n                &quot;name&quot;: &quot;Some step name&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;output&quot;: [\r\n                  &quot;Some output&quot;\r\n                ],\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:137&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 989158000\r\n                }\r\n              },\r\n              {\r\n                &quot;keyword&quot;: &quot;When &quot;,\r\n                &quot;name&quot;: &quot;some other step&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;output&quot;: [\r\n                  &quot;WARNING: static wait for 1 seconds.&quot;\r\n                ],\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:80&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 2700052000\r\n                }\r\n              },\r\n              {\r\n                &quot;keyword&quot;: &quot;And &quot;,\r\n                &quot;name&quot;: &quot;Some other name&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:38&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 954225000\r\n                }\r\n              },\r\n              {\r\n                &quot;keyword&quot;: &quot;Then &quot;,\r\n                &quot;name&quot;: &quot;Some other step name&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:2&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 38792000\r\n                }\r\n              },\r\n              {\r\n                &quot;keyword&quot;: &quot;And &quot;,\r\n                &quot;name&quot;: &quot;And again some other step name&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:2&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 39268000\r\n                }\r\n              },\r\n              {\r\n                &quot;keyword&quot;: &quot;And &quot;,\r\n                &quot;name&quot;: &quot;Some other step name&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:2&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 55637000\r\n                }\r\n              },\r\n              {\r\n                &quot;keyword&quot;: &quot;And &quot;,\r\n                &quot;name&quot;: &quot;Some other step name&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:2&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 38375000\r\n                }\r\n              },\r\n              {\r\n                &quot;keyword&quot;: &quot;When &quot;,\r\n                &quot;name&quot;: &quot;Some other step name&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:12&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 751416000\r\n                }\r\n              },\r\n              {\r\n                &quot;keyword&quot;: &quot;And &quot;,\r\n                &quot;name&quot;: &quot;Some other step name&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:2&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 28043000\r\n                }\r\n              },\r\n              {\r\n                &quot;keyword&quot;: &quot;Then &quot;,\r\n                &quot;name&quot;: &quot;Some other step name&quot;,\r\n                &quot;line&quot;: 46,\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:20&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 5204000\r\n                }\r\n              }\r\n            ],\r\n            &quot;after&quot;: [\r\n              {\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:91&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 20000\r\n                }\r\n              },\r\n              {\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:52&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 5585000\r\n                }\r\n              },\r\n              {\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:27&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 168146000\r\n                }\r\n              },\r\n              {\r\n                &quot;match&quot;: {\r\n                  &quot;location&quot;: &quot;some/other/path/to/other/file.rb:428&quot;\r\n                },\r\n                &quot;result&quot;: {\r\n                  &quot;status&quot;: &quot;passed&quot;,\r\n                  &quot;duration&quot;: 62000\r\n                }\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nwhere `elements` can contain **any number of objects** on either file. These are test results from cucumber so usually file A contains more elements than file B since file B is a re-run of the failed tests in file A.\r\n\r\nFor example. If on the first pass we ran 100 tests, file A `elements` array will contain 100 objects of with the format described above. However if from those 100 tests 50 of them failed, file B `elements` array will contain 50 objects. What I want to do is to overwrite file A `elements` array with file B&#39;s just adding the elements that repeat in both. Something like \r\n\r\nif file A had\r\n\r\n    &quot;elements&quot;:[{a:1, b:2, c:3, d:2, e:9, f:4}]\r\n\r\nand file B had \r\n\r\n    &quot;elements&quot;:[{d:5}]\r\n\r\nI&#39;d like the new file to have \r\n\r\n    &quot;elements&quot;:[{a:1, b:2, c:3, d:5, e:9, f:4}]\r\n\r\nSo far I&#39;ve got \r\n\r\n    jq &#39;.[].elements&#39; path/to/file/b &gt; path/to/new/file\r\n    jq --argfile file path/to/new/file &#39;.[].elements += $file&#39; path/to/file/b\r\n\r\nThat puts together whatever file B contains in the `elements` array within the `elements` array in file A but doesn&#39;t remove the duplicated object inside of it. \r\n\r\nI tried to use `unique` but no clue on how to use it. Any ideas?\r\n\r\nAfter a few responses here I got \r\n\r\n    jq --argfile b ~/Desktop/cucumber-rerun.json &#39;.[0].elements[4] *= $b[0].elements[0]&#39; ~/Desktop/cucumber.json\r\n\r\nto works since, in my actual example, I knew the element 4 in file A is the one I want to overwrite with the 1 and only element in file B. However that doesn&#39;t work for me since both files are autogenerated and the order of the objects is unknown. \r\n\r\nI&#39;d like to have a command that sees both files compared them and autodetects repeated objects from A and B and overwrite those in A with those in B",
        "link": "https://stackoverflow.com/questions/47022870/overwrite-a-json-file-with-objects-from-another-json-file-using-jq",
        "title": "overwrite a json file with objects from another json file using jq"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 70,
                "is_accepted": true,
                "score": 70,
                "last_activity_date": 1687283551,
                "last_edit_date": 1687283551,
                "creation_date": 1509397118,
                "answer_id": 47024050,
                "question_id": 47023795,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the builtin function `del`:\r\n\r\n``` lang-bash\r\n$ jq &#39;del(.pages)&#39; myfile.json\r\n{\r\n  &quot;actions&quot;: {\r\n    &quot;pages&quot;: {\r\n      &quot;stuff&quot;: &quot;...&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/nwxNZ7LOY6)\r\n\r\nTo remove all pages everywhere, instead of just the outer level, you would use something like\r\n\r\n``` lang-bash\r\n$ jq &#39;del(.. | .pages?)&#39; myfile.json\r\n{\r\n  &quot;actions&quot;: {}\r\n}\r\n```\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/O76mi-VYRs)\r\n\r\n\r\n",
                "title": "Removing a key from parent object with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1509425824,
                "last_edit_date": 1509425824,
                "creation_date": 1509404905,
                "answer_id": 47025560,
                "question_id": 47023795,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since your input file is quite large, it might be worthwhile using jq 1.5&#39;s streaming parser:\r\n\r\n    jq -n --stream &#39;\r\n      fromstream(inputs|select((length == 2 and .[0][0] == &quot;pages&quot;)|not))\r\n    &#39; input.json\r\n",
                "title": "Removing a key from parent object with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 41,
        "last_activity_date": 1687283551,
        "creation_date": 1509395933,
        "last_edit_date": 1687283470,
        "question_id": 47023795,
        "body_markdown": "How to exclude some items using [JQ][1]? My JSON content has extra items I don&#39;t need (upwards of 500MB) and if I could trim those it reduces it to 1MB.\r\n\r\n    {\r\n      &quot;pages&quot;: {\r\n        &quot;elems&quot;: { ... stuff ... }\r\n      },\r\n      &quot;actions&quot;: {\r\n        &quot;pages&quot;: { ... stuff ... }\r\n      }\r\n    }\r\n\r\nI want to delete the 1st level `pages` entire object and key, but retain the lower level `pages` intact. Expected Output:\r\n\r\n    {\r\n      &quot;actions&quot;: {\r\n        &quot;pages&quot;: { ... stuff ... }\r\n      }\r\n    }\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/\r\n",
        "link": "https://stackoverflow.com/questions/47023795/removing-a-key-from-parent-object-with-jq",
        "title": "Removing a key from parent object with jq"
    },
    {
        "tags": [
            "json",
            "bioinformatics",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 390835,
                    "reputation": 1646,
                    "user_id": 751145,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/d7lKy.jpg?s=256",
                    "display_name": "Dat Nguyen",
                    "link": "https://stackoverflow.com/users/751145/dat-nguyen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1509421810,
                "post_id": 47027372,
                "comment_id": 81002253,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 4505119,
                    "reputation": 13,
                    "user_id": 3662691,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d58b46f9bd161a7164919f903ea856a4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Pramod",
                    "link": "https://stackoverflow.com/users/3662691/pramod"
                },
                "reply_to_user": {
                    "account_id": 390835,
                    "reputation": 1646,
                    "user_id": 751145,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/d7lKy.jpg?s=256",
                    "display_name": "Dat Nguyen",
                    "link": "https://stackoverflow.com/users/751145/dat-nguyen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1509461373,
                "post_id": 47027372,
                "comment_id": 81022990,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1509426726,
                "last_edit_date": 1509426726,
                "creation_date": 1509425298,
                "answer_id": 47028083,
                "question_id": 47027372,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Since the low-level requirements are clear enough, I&#39;ve assembled the following solution, which behaves exactly in accordance with the example.  However, the higher level requirements are rather sketchy so you may need to make some adjustments.\r\n\r\nThe low-level requirement (about converting the strings) can be implemented as follows:\r\n\r\n    # Input: a string\r\n    def gene2object:\r\n      split(&quot;;&quot;)\r\n      | [.[0], { chromosome: .[1], \r\n                 start: (.[2]|tonumber),\r\n                 end:   (.[3]|tonumber)} ];\r\n\r\nA solution can now be written quite simply as follows:\r\n\r\n    walk( if type == &quot;object&quot; and .metric == &quot;Exons&quot; \r\n          then .value |= (map(gene2object)|add) \r\n          else .\r\n          end )\r\n\r\n\r\nThe standard invocation (along the lines of: `jq -f program.jq input.json`) produces the output exactly as described, so I won&#39;t repeat it here.\r\n\r\nIf your jq does not have `walk/1`, then you can snarf its official definition from https://github.com/stedolan/jq/blob/master/src/builtin.jq\r\nThat is, search for: `def walk`\r\n\r\n       \r\n\r\n",
                "title": "Creating nested Json object using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1509461925,
        "creation_date": 1509420093,
        "last_edit_date": 1509461925,
        "question_id": 47027372,
        "body_markdown": "I need to get the values in Exon of the following Json input and split it by &quot;;&quot; and convert to a nested JSON as show below in the Expected ouput section\r\n\r\nSample Input\r\n------------\r\n\r\n      {  \r\n       &quot;regions&quot;:[  \r\n          {  \r\n             &quot;metric&quot;:&quot;GENE1&quot;,\r\n             &quot;value&quot;:[  \r\n                {  \r\n                   &quot;metric&quot;:&quot;Exons&quot;,\r\n                   &quot;value&quot;:[  \r\n                      &quot;GENE1;chr1;45656;5656667&quot;    \r\n                   ],\r\n                   &quot;type&quot;:&quot;set&quot;\r\n                },\r\n                {  \r\n                   &quot;metric&quot;:&quot;Precent_no_call&quot;,\r\n                   &quot;value&quot;:4.22623,\r\n                   &quot;type&quot;:&quot;simple&quot;\r\n                },\r\n                {  \r\n                   &quot;metric&quot;:&quot;Total_NoCall_bases&quot;,\r\n                   &quot;value&quot;:112533,\r\n                   &quot;type&quot;:&quot;simple&quot;\r\n                }\r\n             ],\r\n             &quot;type&quot;:&quot;metrics-set&quot;\r\n          },\r\n          {  \r\n             &quot;metric&quot;:&quot;GENE2&quot;,\r\n             &quot;value&quot;:[  \r\n                {  \r\n                   &quot;metric&quot;:&quot;Exons&quot;,\r\n                   &quot;value&quot;:[  \r\n                      &quot;GENE2_Exon5;chr1;45656;5656667&quot;,\r\n                      &quot;GENE2_Exon10;chr1;45656;5656667&quot;                 \r\n                   ],\r\n                   &quot;type&quot;:&quot;set&quot;\r\n                },\r\n                {  \r\n                   &quot;metric&quot;:&quot;Precent_no_call&quot;,\r\n                   &quot;value&quot;:0.746464,\r\n                   &quot;type&quot;:&quot;simple&quot;\r\n                },\r\n                {  \r\n                   &quot;metric&quot;:&quot;Total_NoCall_bases&quot;,\r\n                   &quot;value&quot;:16842,\r\n                   &quot;type&quot;:&quot;simple&quot;\r\n                }\r\n             ],\r\n             &quot;type&quot;:&quot;metrics-set&quot;\r\n          }\r\n       ]\r\n    }\r\n\r\n\r\n\r\n\r\n\r\nExpected Output\r\n--------\r\n\r\n    {  \r\n       &quot;regions&quot;:[  \r\n          {  \r\n             &quot;metric&quot;:&quot;GENE1&quot;,\r\n             &quot;value&quot;:[  \r\n                {  \r\n                   &quot;metric&quot;:&quot;Exons&quot;,\r\n                   &quot;value&quot;:[  \r\n                      &quot;GENE1&quot;,\r\n                      {  \r\n                         &quot;chromosome&quot;:&quot;chr1&quot;,\r\n                         &quot;start&quot;:45656,\r\n                         &quot;end&quot;:5656667\r\n                      }\r\n                   ],\r\n                   &quot;type&quot;:&quot;set&quot;\r\n                },\r\n                {  \r\n                   &quot;metric&quot;:&quot;Precent_no_call&quot;,\r\n                   &quot;value&quot;:4.22623,\r\n                   &quot;type&quot;:&quot;simple&quot;\r\n                },\r\n                {  \r\n                   &quot;metric&quot;:&quot;Total_NoCall_bases&quot;,\r\n                   &quot;value&quot;:112533,\r\n                   &quot;type&quot;:&quot;simple&quot;\r\n                }\r\n             ],\r\n             &quot;type&quot;:&quot;metrics-set&quot;\r\n          },\r\n          {  \r\n             &quot;metric&quot;:&quot;GENE2&quot;,\r\n             &quot;value&quot;:[  \r\n                {  \r\n                   &quot;metric&quot;:&quot;Exons&quot;,\r\n                   &quot;value&quot;:[  \r\n                      &quot;GENE2_Exon5&quot;,\r\n                      {  \r\n                         &quot;chromosome&quot;:&quot;chr1&quot;,\r\n                         &quot;start&quot;:45656,\r\n                         &quot;end&quot;:5656667\r\n                      },\r\n                      &quot;GENE2_Exon10&quot;,\r\n                      {  \r\n                         &quot;chromosome&quot;:&quot;chr1&quot;,\r\n                         &quot;start&quot;:45656,\r\n                         &quot;end&quot;:5656667\r\n                      }\r\n                   ],\r\n                   &quot;type&quot;:&quot;set&quot;\r\n                },\r\n                {  \r\n                   &quot;metric&quot;:&quot;Precent_no_call&quot;,\r\n                   &quot;value&quot;:0.746464,\r\n                   &quot;type&quot;:&quot;simple&quot;\r\n                },\r\n                {  \r\n                   &quot;metric&quot;:&quot;Total_NoCall_bases&quot;,\r\n                   &quot;value&quot;:16842,\r\n                   &quot;type&quot;:&quot;simple&quot;\r\n                }\r\n             ],\r\n             &quot;type&quot;:&quot;metrics-set&quot;\r\n          }\r\n       ]\r\n    }\r\n\r\nNOTE\r\n------\r\n\r\nAlso, this is related to the question here:-\r\n[Converting comma separated file to nested objects json in jq][1]\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/46632107/converting-comma-separated-file-to-nested-objects-json-in-jq\r\n\r\n\r\nThanks for your help in advance.\r\n\r\nSolution I tried from a comma separated input file(See in another question I posted)\r\n----------------\r\n\r\n    def parse:\r\n      [\r\n          inputs                     # read lines\r\n        | split(&quot;,&quot;)                 # split into columns\r\n        | select(length&gt;0)           # eliminate blanks\r\n        | .[:1] + [.[1:-3]] + .[-3:] # normalize columns\r\n        \r\n      ]\r\n    ;\r\n    def simple(n;v): {metric:n, value:v|tonumber, type:&quot;simple&quot;};\r\n    def set(n;v):    {metric:n, value:v,          type:&quot;set&quot;};\r\n    def chr(c;s;e):  {chromsome:c, start:s, end:e}; \r\n    def region:\r\n      set(.[0]; [\r\n          set(&quot;Exons&quot;;  (.[1] | tostring | split(&quot;;&quot;) |.[0]); \r\n          chr((.[1] | tostring | split(&quot;;&quot;) |.[1]),(.[1] | tostring | split(&quot;;&quot;) |.[2]),(.[1] | tostring | split(&quot;;&quot;) |.[3]))\r\n         ]\r\n         \r\n         ),\r\n          simple(&quot;Fraction of bases&quot;; .[5]),\r\n          simple(&quot;Total_bases&quot;; .[6])\r\n        ]\r\n      )\r\n    ;\r\n    {\r\n       &quot;Regions&quot;: parse | map(region)\r\n    }\r\n\r\nI was unable to loop it and read recursively. ",
        "link": "https://stackoverflow.com/questions/47027372/creating-nested-json-object-using-jq",
        "title": "Creating nested Json object using JQ"
    },
    {
        "tags": [
            "json",
            "linux",
            "ubuntu",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1509443550,
                "post_id": 47032224,
                "comment_id": 81011126,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6166906,
                    "reputation": 171,
                    "user_id": 4806488,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/d36ad8ab7499a77976f5789d9b0aa3b9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "venkat",
                    "link": "https://stackoverflow.com/users/4806488/venkat"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1509443662,
                "post_id": 47032224,
                "comment_id": 81011201,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1509444456,
                "last_edit_date": 1509444456,
                "creation_date": 1509443854,
                "answer_id": 47032457,
                "question_id": 47032224,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`“` and `”` are invalid quoting chars, the valid quoting char is `&quot;`.&lt;br&gt;The second moment is that the `echo` command arguments should be enclosed in single or double quotes (in conformity with argument content) to present a literal string:\r\n\r\n    echo &#39;{&quot;x&quot;:1}{&quot;y&quot;:1}&#39; | jq -s &#39;.&#39;\r\n    [\r\n      {\r\n        &quot;x&quot;: 1\r\n      },\r\n      {\r\n        &quot;y&quot;: 1\r\n      }\r\n    ]\r\n\r\n",
                "title": "How to convert objects of JSON file into an array of objects , by using Jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1509444456,
        "creation_date": 1509443118,
        "question_id": 47032224,
        "body_markdown": "I am just trying with this basic line, but I am not getting, here is the command.\r\n\r\n    echo {“x”:1} | jq &#39;[ . ]&#39;\r\nIt is showing the error as follows.\r\n\r\n    parse error: Invalid numeric literal at line 1, column 9\r\nThe expected output is :\r\n\r\n    [{&quot;x&quot;:1}]",
        "link": "https://stackoverflow.com/questions/47032224/how-to-convert-objects-of-json-file-into-an-array-of-objects-by-using-jq",
        "title": "How to convert objects of JSON file into an array of objects , by using Jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1509520561,
                "post_id": 47049316,
                "comment_id": 81046792,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1509522265,
                "creation_date": 1509522265,
                "answer_id": 47050324,
                "question_id": 47049316,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`glog` property within your input object contains JSON text representation, in &quot;*unparsed*&quot; form.\r\n\r\nTo parse JSON text representation into values use `fromjson` function:\r\n\r\n    jq -r &#39;&quot;id:\\(.id),QBOL-QUERY-SCHEMA:\\(.qlog | fromjson | .[&quot;QBOL-QUERY-SCHEMA&quot;] | keys[0])&quot;&#39; input.json\r\nThe output:\r\n\r\n    id:104909913,QBOL-QUERY-SCHEMA:/tmp/2017-10-31/5031/104909913.dir/000",
                "title": "error in parsing JSON value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1509525314,
                "creation_date": 1509525314,
                "answer_id": 47050929,
                "question_id": 47049316,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a more programmatic approach (that is, the jq program does not mention the &quot;QBOL-QUERY-SCHEMA&quot; key explicitly).  Whether this meets your actual needs, however, is unclear.\r\n\r\n    &quot;id:\\(.id),&quot; + \r\n      (.qlog | fromjson | to_entries[0] | .key + &quot;:&quot; +\r\n                (.value | to_entries[0] | .key) )\r\n\r\nWhen jq is invoked with the -r option, this yields:\r\n\r\n     id:104909913,QBOL-QUERY-SCHEMA:/tmp/2017-10-31/5031/104909913.dir/000\r\n\r\n\r\n\r\n  \r\n\r\n",
                "title": "error in parsing JSON value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1509525314,
        "creation_date": 1509517425,
        "last_edit_date": 1509519895,
        "question_id": 47049316,
        "body_markdown": "Somehow, I&#39;m not able to parse values for the below JSON.\r\n\r\n&gt; not able to get this qlog.QBOL-QUERY-SCHEMA value(getting string invalid \r\nerror)\r\n\r\nI was looking for something output like this: \r\n\r\n    id:104909913,QBOL-QUERY-SCHEMA:/tmp/2017-10-31/5031/104909913.dir/000\r\n\r\nJSON file:\r\n\r\n    {\r\n      &quot;id&quot;:104909913,\r\n      &quot;path&quot;:&quot;/tmp/2017-10-31/5031/104909913&quot;,\r\n      &quot;status&quot;:&quot;done&quot;,\r\n      &quot;created_at&quot;:&quot;2017-10-31T05:03:19Z&quot;,\r\n      &quot;updated_at&quot;:&quot;2017-10-31T05:10:24Z&quot;,\r\n      &quot;command_type&quot;:&quot;HiveCommand&quot;,\r\n      &quot;progress&quot;:100,\r\n      &quot;qbol_session_id&quot;:6527670,\r\n      &quot;qlog&quot;:&quot;{\\&quot;QBOL-QUERY-SCHEMA\\&quot;:{\\&quot;/tmp/2017-10-31/5031/104909913.dir/000\\&quot;:[{\\&quot;ColumnType\\&quot;:\\&quot;string\\&quot;,\\&quot;ColumnName\\&quot;:\\&quot;ts_date\\&quot;},{\\&quot;ColumnType\\&quot;:\\&quot;bigint\\&quot;,\\&quot;ColumnName\\&quot;:\\&quot;testing_requests\\&quot;},{\\&quot;ColumnType\\&quot;:\\&quot;bigint\\&quot;,\\&quot;ColumnName\\&quot;:\\&quot;testings_placed\\&quot;}]},\\&quot;EXECUTION_ENGINE\\&quot;:\\&quot;mr\\&quot;,\\&quot;QBOL-S3N-BYTES-READ\\&quot;:1258754351,\\&quot;QBOL-S3N-BYTES-WRITTEN\\&quot;:224,\\&quot;HIVE_VERSION\\&quot;:\\&quot;0.13\\&quot;}&quot;,\r\n      &quot;resolved_macros&quot;:null,\r\n      &quot;pid&quot;:27212,\r\n      &quot;template&quot;:&quot;generic&quot;,\r\n      &quot;submit_time&quot;:1509426199,\r\n      &quot;start_time&quot;:1509426202,\r\n      &quot;end_time&quot;:1509426624,\r\n      &quot;can_notify&quot;:false,\r\n      &quot;num_result_dir&quot;:1,\r\n      &quot;pool&quot;:null,\r\n      &quot;timeout&quot;:null,\r\n      &quot;name&quot;:null,\r\n      &quot;command_source&quot;:&quot;API&quot;,\r\n      &quot;account_id&quot;:5031,\r\n      &quot;saved_query_mutable_id&quot;:null,\r\n      &quot;user_id&quot;:12146,\r\n      &quot;label&quot;:&quot;default&quot;,\r\n      &quot;meta_data&quot;:{\r\n        &quot;results_resource&quot;:&quot;commands/104909913/results&quot;,\r\n        &quot;logs_resource&quot;:&quot;commands/104909913/logs&quot;\r\n      },\r\n      &quot;uid&quot;:5164,\r\n      &quot;perms&quot;:null,\r\n      &quot;command&quot;:{\r\n        &quot;query&quot;:&quot;select * from abc &quot;,\r\n        &quot;sample&quot;:false,\r\n        &quot;approx_mode&quot;:false,\r\n        &quot;approx_aggregations&quot;:false,\r\n        &quot;loader_table_name&quot;:null,\r\n        &quot;loader_stable&quot;:null,\r\n        &quot;md_cmd&quot;:false,\r\n        &quot;script_location&quot;:null\r\n      },\r\n      &quot;instance&quot;:null\r\n    }\r\n\r\nThanks for the help!",
        "link": "https://stackoverflow.com/questions/47049316/error-in-parsing-json-value",
        "title": "error in parsing JSON value"
    },
    {
        "tags": [
            "json",
            "bash",
            "sendgrid",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1509536942,
                "creation_date": 1509536942,
                "answer_id": 47054126,
                "question_id": 47053855,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With simple assignment:\r\n\r\n    jq &#39;.template_id=&quot;someID&quot; | .personalizations[0].subject=&quot;Some subject&quot;&#39; input.json\r\nThe output:\r\n\r\n    {\r\n      &quot;content&quot;: [],\r\n      &quot;from&quot;: {\r\n        &quot;email&quot;: &quot;someemail@gmail.com&quot;,\r\n        &quot;name&quot;: &quot;Some Name&quot;\r\n      },\r\n      &quot;reply_to&quot;: {\r\n        &quot;email&quot;: &quot;someemail@gmail.com&quot;,\r\n        &quot;name&quot;: &quot;Some Name&quot;\r\n      },\r\n      &quot;personalizations&quot;: [\r\n        {\r\n          &quot;to&quot;: [\r\n            {\r\n              &quot;email&quot;: &quot;someemail@gmail.com&quot;\r\n            },\r\n            {\r\n              &quot;email&quot;: &quot;someotheremail@gmail.com&quot;\r\n            }\r\n          ],\r\n          &quot;subject&quot;: &quot;Some subject&quot;\r\n        }\r\n      ],\r\n      &quot;template_id&quot;: &quot;someID&quot;\r\n    }\r\n\r\n",
                "title": "Add new array element to an existing JSON array using jq for sendgrid API"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1509536942,
        "creation_date": 1509535977,
        "question_id": 47053855,
        "body_markdown": "This question is related to a [previous][1] one. \r\n\r\n\r\nIn my case, I would like to simply add individual elements. I have the following input.json. \r\n\r\n    {\r\n      &quot;content&quot;: [\r\n      ],\r\n      &quot;from&quot;: {\r\n        &quot;email&quot;: &quot;someemail@gmail.com&quot;,\r\n        &quot;name&quot;: &quot;Some Name&quot;\r\n      },\r\n      &quot;reply_to&quot;: {\r\n        &quot;email&quot;: &quot;someemail@gmail.com&quot;,\r\n        &quot;name&quot;: &quot;Some Name&quot;\r\n        },\r\n      &quot;personalizations&quot;: [{\r\n        &quot;to&quot;: [{\r\n            &quot;email&quot;: &quot;someemail@gmail.com&quot;\r\n          },\r\n          {\r\n            &quot;email&quot;: &quot;someotheremail@gmail.com&quot;\r\n          }]\r\n        }]\r\n    }\r\n\r\nI would like to append the subject and template_id so that the output.json looks like below. \r\n\r\n    {\r\n      &quot;content&quot;: [\r\n      ],\r\n      &quot;from&quot;: {\r\n        &quot;email&quot;: &quot;someemail@gmail.com&quot;,\r\n        &quot;name&quot;: &quot;Some Name&quot;\r\n      },\r\n      &quot;reply_to&quot;: {\r\n        &quot;email&quot;: &quot;someemail@gmail.com&quot;,\r\n        &quot;name&quot;: &quot;Some Name&quot;\r\n        },\r\n      &quot;personalizations&quot;: [{\r\n        &quot;to&quot;: [{\r\n            &quot;email&quot;: &quot;someemail@gmail.com&quot;\r\n          },\r\n          {\r\n            &quot;email&quot;: &quot;someotheremail@gmail.com&quot;\r\n          }],\r\n        &quot;subject&quot;: &quot;Some subject&quot;\r\n        }],\r\n        &quot;template_id&quot;: &quot;someID&quot;\r\n    }\r\n  [1]: https://stackoverflow.com/questions/25414854/add-json-array-element-with-jq-cmdline\r\n\r\nHow would I do that with jq (including the syntax for input.json and output.json) in bash? ",
        "link": "https://stackoverflow.com/questions/47053855/add-new-array-element-to-an-existing-json-array-using-jq-for-sendgrid-api",
        "title": "Add new array element to an existing JSON array using jq for sendgrid API"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "unix",
            "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": 1,
                "creation_date": 1509564710,
                "post_id": 47061923,
                "comment_id": 81072596,
                "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": 1509565444,
                "post_id": 47061923,
                "comment_id": 81072994,
                "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": 1509565876,
                "post_id": 47061923,
                "comment_id": 81073246,
                "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": 1509566066,
                "post_id": 47061923,
                "comment_id": 81073356,
                "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": 1509567282,
                "post_id": 47061923,
                "comment_id": 81074028,
                "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": 1509567444,
                "post_id": 47061923,
                "comment_id": 81074102,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1509566050,
                "last_edit_date": 1509566050,
                "creation_date": 1509564019,
                "answer_id": 47062169,
                "question_id": 47061923,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    #!/bin/sh\r\n    \r\n    TMP=$(mktemp /tmp/$$.XXX)\r\n    \r\n    cat&lt;&lt;E_O_F &gt; $TMP\r\n    cat &lt;&lt;EOF\r\n    $(cat so-dollar-variables.json)\r\n    EOF\r\n    E_O_F\r\n    \r\n    . $TMP\r\n    \r\n    /bin/rm &quot;$TMP&quot;\r\n\r\n\r\n\r\n",
                "title": "How can I interpret variables on the fly in the shell script?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1509567872,
                "last_edit_date": 1509567872,
                "creation_date": 1509564071,
                "answer_id": 47062175,
                "question_id": 47061923,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using [env](https://stedolan.github.io/jq/manual/#$ENV,env)  and [gsub](https://stedolan.github.io/jq/manual/#gsub\\(regex;string\\),gsub\\(regex;string;flags\\)) to perform the replacement.\r\n\r\nNote that `env` requires the variables to be passed as environment variables as opposed to shell variables.\r\n\r\n\r\n    #!/bin/bash\r\n    \r\n    examplefile=&quot;../lib/example.json&quot;\r\n    HOST=ec2-..-...-...-...us-west-2.compute.amazonaws.com\r\n    PEMFILE=${HOME}/test.pem\r\n    \r\n    export HOST\r\n    export PEMFILE\r\n    installScript=$(jq -Mr &#39;\r\n       .script.install | gsub(&quot;(?&lt;x&gt;[$][{]?\\\\w+[}]?)&quot;; env[.x|gsub(&quot;[${}]+&quot;;&quot;&quot;)] )\r\n    &#39; $examplefile)\r\n    \r\n    echo $installScript\r\n\r\nSample Output\r\n\r\n    /home/runner/lib/install.sh ec2-..-...-...-...us-west-2.compute.amazonaws.com /home/runner/test.pem\r\n\r\n[Try it online!](https://tio.run/##ZZFNT4NAEIbv@yvGcRNKKkvk2EobD5iaSGpa44VyWMgqNHzJLraR8tsRWmqqJruTzTtPZt6ZDbiMWhFGOWg1yrCMC4WTGuNMKp4kOEFaL5au05hJHJiDymQEdLFcvwB9dtyHxycHb3AtVFX84WWv/aeBvt6vbo/RwqbRYAZiz9MiEWwr86y9vjKDODODzhohQ@YtToSNlxiSvqgtQstgrDs/t5LGTkhlWCzM06JSgvGUf@UZ38leIYML@@xUdTArRNr3KvJSQV/3/B5gMoy@Pm7IpqPtBxhuCRoBAHbaGxsYOMC7rIIRjuZ3@5lHfa/255vNbuw1/lzHKYjs02P7wwnyaN34Y5wi6j7oRAN6MbHeeer/hv5q37bf &quot;Bash – Try It Online&quot;)",
                "title": "How can I interpret variables on the fly in the shell script?"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1509566287,
                "last_edit_date": 1509566287,
                "creation_date": 1509564544,
                "answer_id": 47062299,
                "question_id": 47061923,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "It is easy using gnu utility [`envsubst`][1]:\r\n\r\n\r\n    installScript=$(jq -r &#39;.script.install&#39; &quot;$examplefile&quot; | envsubst)\r\n\r\n\r\n  [1]: https://www.gnu.org/software/gettext/manual/html_node/envsubst-Invocation.html",
                "title": "How can I interpret variables on the fly in the shell script?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1509586355,
                "last_edit_date": 1509586355,
                "creation_date": 1509565245,
                "answer_id": 47062478,
                "question_id": 47061923,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "## Specific solution\r\nHere&#39;s a jq solution to the stated problem, though it will only work for &quot;global&quot; environment variables. \r\n\r\n    def substitute:\r\n      gsub(&quot;\\\\${HOME}&quot;; env.HOME)\r\n      | gsub(&quot;\\\\$HOST&quot;; env.HOST)\r\n      | gsub(&quot;\\\\$PEMFILE&quot;; env.PEMFILE)\r\n      | gsub(&quot;\\\\$VAR1&quot;; env.VAR1)\r\n      | gsub(&quot;\\\\$VAR2&quot;; env.VAR2)\r\n      ;\r\n    \r\n    walk( if type==&quot;string&quot; then substitute else . end )\r\n\r\nIf your jq does not already have `walk/1`, then please either upgrade your jq or snarf the def from https://github.com/stedolan/jq/blob/master/src/builtin.jq\r\n\r\nThe solution above is a bit brittle but it could easily be robustified or generalized, as shown in the next section.\r\n\r\n### General solution\r\n\r\n    walk(if type == &quot;string&quot;\r\n         then gsub(&quot;\\\\$(?&lt;x&gt;[A-Za-z_][A-Za-z0-9_]+)&quot;; &quot;\\(env[.x])&quot;) \r\n              | gsub(&quot;\\\\${(?&lt;x&gt;[A-Za-z_][A-Za-z0-9_]+)}&quot;; &quot;\\(env[.x])&quot;) \r\n         else . end)\r\n\r\n",
                "title": "How can I interpret variables on the fly in the shell script?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1509570747,
                "creation_date": 1509570747,
                "answer_id": 47063740,
                "question_id": 47061923,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;ve been hitting this on and off for years. I think I&#39;ve finally got a decent pure-bash solution: uses regex matching and indirect parameter substitution\r\n\r\n\r\n\r\n\r\n    # read the file\r\n    json=$(&lt; file.json)\r\n    echo step 0\r\n    echo &quot;$json&quot;\r\n    \r\n    # set the relevant vars, just plain shell variables\r\n    HOST=_host_\r\n    PEMFILE=_pemfile_\r\n    VAR1=_var1_\r\n    VAR2=_var2_\r\n    \r\n    # replace &#39;$var&#39; forms\r\n    while [[ $json =~ (&quot;$&quot;([[:alnum:]_]+)) ]]; do \r\n        json=${json//${BASH_REMATCH[1]}/${!BASH_REMATCH[2]}}\r\n    done; \r\n    echo\r\n    echo step 1\r\n    echo &quot;$json&quot;\r\n    \r\n    # replace &#39;${var}&#39; forms\r\n    while [[ $json =~ (&quot;$&quot;&quot;{&quot;([[:alnum:]_]+)&quot;}&quot;) ]]; do \r\n        json=${json//${BASH_REMATCH[1]}/${!BASH_REMATCH[2]}}\r\n    done\r\n    echo\r\n    echo step 2\r\n    echo &quot;$json&quot;\r\n    \r\nOutput\r\n    \r\n    step 0\r\n    {\r\n        &quot;script&quot;: {\r\n        &quot;install&quot;: &quot;${HOME}/lib/install.sh $HOST $PEMFILE&quot;,\r\n        &quot;Setup&quot;: &quot;${HOME}/lib/setup.sh $HOST $PEMFILE $VAR1 $VAR2&quot;\r\n        }\r\n    \r\n    }\r\n    \r\n    step 1\r\n    {\r\n        &quot;script&quot;: {\r\n        &quot;install&quot;: &quot;${HOME}/lib/install.sh _host_ _pemfile_&quot;,\r\n        &quot;Setup&quot;: &quot;${HOME}/lib/setup.sh _host_ _pemfile_ _var1_ _var2_&quot;\r\n        }\r\n    \r\n    }\r\n    \r\n    step 2\r\n    {\r\n        &quot;script&quot;: {\r\n        &quot;install&quot;: &quot;/home/jackman/lib/install.sh _host_ _pemfile_&quot;,\r\n        &quot;Setup&quot;: &quot;/home/jackman/lib/setup.sh _host_ _pemfile_ _var1_ _var2_&quot;\r\n        }\r\n    \r\n    }\r\n\r\nThe magic is:\r\n\r\n1. the regular expression, where I capture both `$VAR` and `VAR`, and\r\n\r\n        [[ $json =~ (&quot;$&quot;([[:alnum:]_]+)) ]]\r\n        # ..........1   2             21\r\n\r\n1. the parameter substitution, where I search for the string `&quot;$VAR&quot;` and replace it with the indirect variable expansion `${!VAR}`\r\n\r\n        ${json//${BASH_REMATCH[1]}/${!BASH_REMATCH[2]}}",
                "title": "How can I interpret variables on the fly in the shell script?"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 2,
        "last_activity_date": 1509586355,
        "creation_date": 1509563019,
        "last_edit_date": 1509563591,
        "question_id": 47061923,
        "body_markdown": "I&#39;m reading JSON in a shell script using JQ. Here, I&#39;m unable to interpret the variables $HOME, $HOST, $PEMFILE in my shell script on the fly.\r\n\r\nJSON File:\r\n\r\n    {\r\n        &quot;script&quot;: {\r\n        &quot;install&quot;: &quot;${HOME}/lib/install.sh $HOST $PEMFILE&quot;,\r\n        &quot;Setup&quot;: &quot;${HOME}/lib/setup.sh $HOST $PEMFILE $VAR1 $VAR2&quot;\r\n        }\r\n    \r\n    }\r\n\r\nShell Script:\r\n\r\n    #!/bin/bash\r\n    examplefile=&quot;../lib/example.json&quot;\r\n    HOST=ec2-..-...-...-...us-west-2.compute.amazonaws.com\r\n    PEMFILE=${HOME}/test.pem\r\n    \r\n    installScript=($(jq &#39;.script.install&#39; $examplefile))\r\n    bash &quot;$installScript&quot;\r\n\r\n\r\nIs there a way I can interpret these variables on the fly without modifying the JSON?\r\n\r\nP.S I don&#39;t want to use eval.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/47061923/how-can-i-interpret-variables-on-the-fly-in-the-shell-script",
        "title": "How can I interpret variables on the fly in the shell script?"
    },
    {
        "tags": [
            "json",
            "count",
            "conditional-statements",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1509633619,
                "post_id": 47063311,
                "comment_id": 81104493,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1509647971,
                "post_id": 47063311,
                "comment_id": 81114108,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": false,
                "score": 11,
                "last_activity_date": 1525988695,
                "last_edit_date": 1525988695,
                "creation_date": 1509569170,
                "answer_id": 47063397,
                "question_id": 47063311,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[UPDATE: If the input is not an array, see the last section below.]\r\n\r\n### `count/1`\r\n\r\nI&#39;d recommend defining a `count` filter (and maybe putting it in your ~/.jq), perhaps as follows:\r\n\r\n     def count(s): reduce s as $_ (0;.+1);\r\n\r\nWith this, assuming the input is an array, you&#39;d write:\r\n\r\n     count(.[] | select(.sapm_score &gt; 40))\r\n\r\nor slightly more efficiently:\r\n\r\n     count(.[] | (.sapm_score &gt; 40) // empty)\r\n\r\nThis approach (counting items in a stream) is usually preferable to using `length` as it avoids the costs associated with constructing an array.\r\n\r\n### `count/2`\r\n\r\nHere&#39;s another definition of `count` that you might like to use (and perhaps add to ~/.jq as well):\r\n\r\n    def count(stream; cond): count(stream | cond // empty);\r\n    \r\nThis counts the elements of the stream for which `cond` is neither `false` nor `null`.\r\n\r\nNow, assuming the input consists of an array, you can simply write:\r\n\r\n    count(.[]; .sapm_score &gt; 40)\r\n\r\n### &quot;sapm_score&quot; vs &quot;spam_score&quot;\r\n\r\nIf the point is that you want to normalize &quot;sapm_score&quot; to &quot;spam_score&quot;, then (for example) you could use `count/2` as defined above, like so:\r\n\r\n     count(.[]; .spam_score &gt; 40 or .sapm_score &gt; 40)\r\n\r\nThis assumes all the items in the array are JSON objects. If that is not the case, then you might want to try adding &quot;?&quot; after the key names:\r\n\r\n    count(.[]; .spam_score? &gt; 40 or .sapm_score? &gt; 40)\r\n\r\nOf course all the above assumes the input is valid JSON. If that is not the case, then please see https://github.com/stedolan/jq/wiki/FAQ#processing-not-quite-valid-json\r\n\r\n### If the input is a stream of JSON objects ...\r\n\r\nThe revised question indicates the input consists of a stream of JSON objects (whereas originally the input was said to be an array of JSON objects).  If the input consists of a stream of JSON objects, then the above solutions can easily be adapted, depending on the version of jq that you have.  If your version of jq has `inputs` then (2) is recommended.\r\n\r\n(1) All versions: use the `-s` command-line option. \r\n\r\n(2) If your jq has `inputs`: use the `-n` command line option, and change `.[]` above to `inputs`, e.g.\r\n\r\n    count(inputs; .spam_score? &gt; 40 or .sapm_score? &gt; 40)",
                "title": "Using jq to count"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1509569172,
                "creation_date": 1509569172,
                "answer_id": 47063398,
                "question_id": 47063311,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Filter the items that satisfy the condition then get the length.\r\n\r\n    map(select(.sapm_score &gt; 40)) | length",
                "title": "Using jq to count"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1509633511,
                "last_edit_date": 1509633511,
                "creation_date": 1509569304,
                "answer_id": 47063428,
                "question_id": 47063311,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is one way:\r\n\r\n    reduce .[] as $s(0; if $s.spam_score &gt; 40 then .+1 else . end)\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/k747PBLh4T)\r\n\r\nIf instead of an array the input is a sequence of newline delimited objects [(jsonlines)](http://jsonlines.org/examples/) \r\n\r\n    reduce inputs as $s(0; if $s.spam_score &gt; 40 then .+1 else . end)\r\n\r\nwill work if jq is invoked with the `-n` flag.  Here is an example:\r\n\r\n    $ cat data.json\r\n    { &quot;spam_score&quot;:40.776 }\r\n    { &quot;spam_score&quot;:17.376 }\r\n\r\n    $ jq -Mn &#39;reduce inputs as $s(0; if $s.spam_score &gt; 40 then .+1 else . end)&#39; data.json\r\n    1\r\n\r\n[Try it online at tio.run](https://tio.run/##XY5BCsIwFAX3nuJRhCriJ8ViQEt3uhOPIDH50paa1v50JZ49FhcK7oaBgbkaqaI1AaUzwVAjnUdRHM7H2ROJ9OZ@EdsNnOxyRVpv8fr3mabNx09NbB5YnzzSgd1oGbXvxyAwgrks1B71bQL61SiRK4SKPWiVgVthENi7ZYrvToxv &quot;Bash – Try It Online&quot;)\r\n\r\n\r\n\r\n\r\n\r\n    ",
                "title": "Using jq to count"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1714748406,
                "last_edit_date": 1714748406,
                "creation_date": 1670124630,
                "answer_id": 74672645,
                "question_id": 47063311,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```bash\r\ncat input.json | jq -c &#39;. | select(.sapm_score &gt; 40)&#39; | wc -l\r\n```\r\n\r\nshould do it.\r\n\r\nThe `-c` option prints a one-liner compact json representation of each match, and `wc -l` counts the number of lines printed by jq.",
                "title": "Using jq to count"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 9,
        "last_activity_date": 1714748406,
        "creation_date": 1509568831,
        "last_edit_date": 1509631153,
        "question_id": 47063311,
        "body_markdown": "Using jq-1.5 if I have a file of JSON that looks like\r\n\r\n    [{... ,&quot;sapm_score&quot;:40.776, ...} {..., &quot;spam_score&quot;:17.376, ...} ...]\r\n\r\nHow would I get a count of the ones where `sapm_score &gt; 40`?\r\n\r\nThanks,\r\nDan\r\n\r\nUpdate:\r\n\r\nI looked at the input file and the format is actually\r\n\r\n    {... ,&quot;sapm_score&quot;:40.776, ...}\r\n    {..., &quot;spam_score&quot;:17.376, ...}\r\n    ...\r\n\r\nDoes this change how one needs to count?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/47063311/using-jq-to-count",
        "title": "Using jq to count"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1510058529,
                "last_edit_date": 1510058529,
                "creation_date": 1509714583,
                "answer_id": 47096567,
                "question_id": 47094953,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a general solution if the set of unit columns isn&#39;t known in advance:\r\n\r\n    def normalize: [            # convert input to array of flattened objects e.g. \r\n          inputs                # [{&quot;Action&quot;:&quot;A1&quot;,&quot;Group&quot;:&quot;10&quot;,&quot;Unit1&quot;:&quot;1&quot;}, ...]\r\n        | .Action as $a\r\n        | .Group[]\r\n        |   {Action:$a, Group:.Id}\r\n          + reduce .Units[] as $u ({};.[&quot;Unit\\($u)&quot;]=&quot;1&quot;)\r\n      ];\r\n    \r\n    def columns:                # compute column names\r\n      [ .[] | keys[] ] | unique ;\r\n    \r\n    def rows($names):           # generate row arrays\r\n        .[] | [ .[$names[]] ] | map( .//&quot;0&quot; );\r\n    \r\n    normalize | columns as $names | $names, rows($names) | join(&quot;|&quot;)\r\n\r\nSample Run (assumes filter in `filter.jq` and data in `data.json`)\r\n\r\n    $ jq -Mnr -f filter.jq data.json\r\n    Action|Group|Unit1|Unit2|Unit3\r\n    A1|10|1|0|0\r\n    A2|11|0|1|0\r\n    A2|20|0|0|0\r\n    A1|26|1|0|1\r\n\r\n[Try it online!](https://tio.run/##dVFNU8IwEL33V@wEDu1YAsUZD2U8cHL4AZ5qD7ENTLFNIB8yCP3r4jYpCoo5ZT/e27dv19tTyZdQiY01Og0ADmRemEoKkpJ5QmLypKTdkDQ7kEWJuWSCuWdRGY05kpC8zdsgvkJNb6CSS9QUUXFfmV7y3SC7IWH6cC0hJvdOxsxtIqRqWF198BQyuHgDKKR458r4XcFIYEqxPcglLGtmDBe8BPm65oXRwOmKQuCR3hv49QaQ/aPzx6OkC0gbA6U0d2xHoB4DTMOQnXMOmZ1b8Ai@KR2yGFwtpYuy7fXcgeKlLThQZ0KWOy4L4aGd0cwNfgmHNiL5I06PEJXPgqDzppC1bYRO/@5SyAaX5H0HCNZwjcAMKNIf4Y3vuznd14pqazn0jErudDh07VF6xbhCPxVDSmzxTmun3xN2xB6W5Z63YZsQ6HhMJgQiZA@@D4nFXrhb1KEw5z/xlQRMr2UlQnIk0en0KTedi/o0Gglb1yN3SAwU242kNRh8AQ &quot;jq – Try It Online&quot;)\r\n\r\nIn this specific problem the ordering done by `unique` matches the column output we want.  If that were not the case `columns` would be more complicated.\r\n\r\nMuch of the complexity comes from dealing with not knowing the final  set of Unit columns.  If the unit set is fixed and reasonably small (e.g. 1-5) a simpler filter can be used:\r\n\r\n      [&quot;\\(1+range(5))&quot;] as $units\r\n    | [&quot;Action&quot;, &quot;Group&quot;, &quot;Unit\\($units[])&quot;]\r\n    , ( inputs \r\n      | .Action as $a \r\n      | .Group[] \r\n      | [$a, .Id, (.Units[$units[]|[.]] | if .!=[] then &quot;1&quot; else &quot;0&quot; end) ]\r\n    ) | join(&quot;|&quot;)\r\n\r\nSample Run\r\n\r\n    $ jq -Mnr &#39;[&quot;\\(1+range(5))&quot;] as $units | [&quot;Action&quot;, &quot;Group&quot;, &quot;Unit\\($units[])&quot;], (inputs | .Action as $a | .Group[] | [$a, .Id, (.Units[$units[]|[.]] | if .!=[] then &quot;1&quot; else &quot;0&quot; end) ] ) | join(&quot;|&quot;)&#39; data.json\r\n    Action|Group|Unit1|Unit2|Unit3|Unit4|Unit5\r\n    A1|10|1|0|0|0|0\r\n    A2|11|0|1|0|0|0\r\n    A2|20|0|0|0|0|0\r\n    A1|26|1|0|1|0|0\r\n\r\n[Try it online at tio.run](https://tio.run/##bZCxbsMgFEV3f8XrUwZQsRW7agdHHTJV@YBOhMGqSerIAsc26hDn10ufsdsmkhkQXO49XDidfakPUJnG9V0eAVxw@9FX1mCO2xQFvrXWNZjLC@5K0tI1ae@m6jvSMEV1VddI3KWyhVR6m8ooJeaT7Ja3AFuokL3cVxD4FGpsPIxD4p6lj21hjpo9c44Kig5WbvTT82Agw4wXMKNpMfL2bLJJRanRK4DRPP0NRIE@QDKlA7X4VwNJqj9BrgoBya4kRhLKyl/4IBOlyFEdIHl4pUj/qQ3QQ0DXnQZc08KUHEIFTsaTrQzDAbn337YZL@98HBtX13HoRpu2@Iqt62nzAw &quot;jq – Try It Online&quot;) or at [jqplay.org](https://jqplay.org/s/WJ85t-ysS3)\r\n\r\n___\r\nTo handle the case where `Group` may be `null` the easiest way is to use a variation of [peak](https://stackoverflow.com/users/997358/peak)&#39;s suggestion.  E.g\r\n\r\n      [&quot;\\(1+range(5))&quot;] as $units\r\n    | [&quot;Action&quot;, &quot;Group&quot;, &quot;Unit\\($units[])&quot;]\r\n    , ( inputs \r\n      | .Action as $a \r\n      | ( .Group // [{Id:&quot;0&quot;, Units:[]}] )[]   # &lt;-- supply default group if null\r\n      | [$a, .Id, (.Units[$units[]|[.]] | if .!=[] then &quot;1&quot; else &quot;0&quot; end) ]\r\n    ) | join(&quot;|&quot;)\r\n\r\n[Try it online at tio.run](https://tio.run/##bZC/boMwEMb3PMX1lMFWjVOI2oGqQ6aKB@jkeEDFaYmQofxRB@DVS8@GtImEB8s@f9/P3935a8rMCXJbdW0TbwB6PLy3eWkxxkOIAl/rsqswVj0mGdXCB6q92bxtqIYh6lGPG3HjilZc4bUrIpdYXqJr3gpsJUL0dBtB4H4txv7fabuiGJ8ncEvhkYX3dWo/DHvkHDWkDWw7h6PuYSDBwhCw@OngvjuyWaY0uZxWAKN9Hh1sPH0AObs9Nf2rMulRsNuB6pMsRmobfA@@a670Ram2qQCZZASXXqAuvw5Kak2K/ATy7kVpaD@NBRoAmKIxQEgwNuPgUZyE5zK3DAfk0/RTVi5VMwWBG0bgQ9OlTr@Dsmvp8gs &quot;jq – Try It Online&quot;) or [jqplay.org](https://jqplay.org/s/59vZhMXYbe)",
                "title": "Converting JSON with arrays to CSV using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1510043848,
                "last_edit_date": 1510043848,
                "creation_date": 1509725925,
                "answer_id": 47100210,
                "question_id": 47094953,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is for the case where the number of &quot;Unit&quot; columns (n) is known beforehand.  It is just a variant of @jq170717&#39;s implementation.\r\n\r\nThe use of `max` is to ensure reasonable behavior if the given value of `n` is too small.  In that case, the number of columns in the output will vary.\r\n\r\nThe following has been tested with jq versions 1.5 and master; see below for the tweaks necessary for earlier versions of jq. \r\n\r\nInvocation: jq -nr -f tocsv.jq data.json\r\n\r\ntocsv.jq:\r\n\r\n    # n is the number of desired &quot;Unit&quot; columns\r\n    def tocsv(n):\r\n      def h: [&quot;Action&quot;, &quot;Group&quot;, &quot;Unit\\(range(1;n+1))&quot;];\r\n      def i(n): reduce .[] as $i ([range(0;n)|&quot;0&quot;]; .[$i]=&quot;1&quot;);\r\n      def p:\r\n        inputs \r\n        | .Action as $a \r\n        | .Group[] \r\n        | [$a, .Id] + (.Units | map(tonumber-1) | i(n));\r\n      h,p | join(&quot;,&quot;) ;\r\n    \r\n    tocsv(5)\r\n\r\nThe above has been written in a way that you can simply replace the call to `join` by a call to `@csv` or `@tsv` if you want all their benefits.  In that case, though, you might want to use `0` and `1` rather than `&quot;0&quot;` and `&quot;1&quot;` in the indicator function, `i`.\r\n\r\n\r\n### Verification\r\n\r\n    $ jq -nr -f tocsv.jq data.json\r\n    Action,Group,Unit1,Unit2,Unit3\r\n    A1,10,1,0,0\r\n    A2,11,0,1,0\r\n    A2,20,0,0,0\r\n    A1,26,1,0,1\r\n    \r\n\r\n### jq 1.3 or jq 1.4\r\nFor jq 1.3 or 1.4, change `inputs` to `.[]`, and use the following incantation:\r\n\r\n     jq -r -s -f tocsv.jq data.json\r\n\r\n### Update\r\nThe easiest way to handle the `&quot;Group&quot;:null` cases is probably to add the following line immediately before `| .Group[]`:\r\n\r\n    | .Group |= (. // [{Id:&quot;0&quot;, Units:[]}])\r\n\r\nThat way you can also easily change the &quot;default&quot; value of &quot;Id&quot;.\r\n",
                "title": "Converting JSON with arrays to CSV using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1510045119,
                "last_edit_date": 1510045119,
                "creation_date": 1509743485,
                "answer_id": 47104466,
                "question_id": 47094953,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This is for the case where the number of &quot;Unit&quot; columns (n) is unknown beforehand.  It avoids reading in the entire file at once, and proceeds in three main steps: the relevant information is collected in a compact form by &quot;synopsis&quot;; n is computed; and the full rows are formed.\r\n\r\nFor simplicity, the following is for jq version 1.5 or later, and uses `@csv`. Small tweaks might be needed if jq 1.4 is used, depending on detailed requirements regarding the output.\r\n\r\n### Invocation\r\n    jq -nr -f tocsv.jq input.json\r\n\r\n### tocsv.jq:\r\n\r\n    # Input: a stream of JSON objects.\r\n    # Output: a stream of arrays.\r\n    def synopsis:\r\n      inputs \r\n      | .Action as $a \r\n      | .Group[] \r\n      | [$a, .Id, (.Units|map(tonumber-1))];\r\n    \r\n    # Input: an array of arrays\r\n    # Output: a stream of arrays suitable for @csv\r\n    def stream:\r\n      def h(n): [&quot;Action&quot;, &quot;Group&quot;, &quot;Unit\\(range(1;n+1))&quot;];\r\n      def i(n): reduce .[] as $i ([range(0;n)|0]; .[$i]=1);\r\n      (map(.[2] | max) | max + 1) as $n\r\n      | h($n),\r\n        (.[] | .[0:2] + (.[2] | i($n)))\r\n      ;\r\n    \r\n    [synopsis] | stream | @csv\r\n\r\n### Output\r\n\r\n    &quot;Action&quot;,&quot;Group&quot;,&quot;Unit1&quot;,&quot;Unit2&quot;,&quot;Unit3&quot;\r\n    &quot;A1&quot;,&quot;10&quot;,1,0,0\r\n    &quot;A2&quot;,&quot;11&quot;,0,1,0\r\n    &quot;A2&quot;,&quot;20&quot;,0,0,0\r\n    &quot;A1&quot;,&quot;26&quot;,1,0,1\r\n\r\n### Update\r\n\r\nThe easiest way to handle the `&quot;Group&quot;:null` cases is probably to add the following line immediately before `| .Group[]`:\r\n\r\n    | .Group |= (. // [{Id:&quot;0&quot;, Units:[]}])\r\n\r\nThat way you can also easily change the &quot;default&quot; value of &quot;Id&quot;.",
                "title": "Converting JSON with arrays to CSV using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1510078152,
                "last_edit_date": 1510078152,
                "creation_date": 1510077737,
                "answer_id": 47164602,
                "question_id": 47094953,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution with minimal memory requirements for the case where the number of &quot;Unit&quot; columns (n) is unknown beforehand.  In the first pass, n is computed.\r\n\r\n### stream.jq\r\nThis is for the second pass:\r\n\r\n    # Output: a stream of arrays.\r\n    def synopsis:\r\n      inputs\r\n      | .Action as $a\r\n      | .Group |= (. // [{Id:0, Units:[]}])\r\n      | .Group[] \r\n      | [$a, .Id, (.Units|map(tonumber-1))];\r\n    \r\n    def h(n): [&quot;Action&quot;, &quot;Group&quot;, &quot;Unit\\(range(1;n+1))&quot;];\r\n    \r\n    # Output: an array suitable for @csv\r\n    def stream(n):\r\n      def i: reduce .[] as $i ([range(0;n)|0]; .[$i]=1);\r\n      .[0:2] + (.[2] | i) ;\r\n    \r\n    h($width), (synopsis | stream($width)) | @csv\r\n\r\n### Invocation\r\n\r\n    jq -rn --argjson width $(jq -n &#39;\r\n      [inputs|(.Group//[{Units:[]}])[]|.Units|map(tonumber)|max]|max\r\n      &#39; data.json) -f stream.jq data.json\r\n\r\n### Output\r\nThis is the output with the &quot;null&quot; record ({&quot;Action&quot;: &quot;A3&quot;,&quot;Group&quot;: null}) appended:\r\n\r\n    &quot;Action&quot;,&quot;Group&quot;,&quot;Unit1&quot;,&quot;Unit2&quot;,&quot;Unit3&quot;\r\n    &quot;A1&quot;,&quot;10&quot;,1,0,0\r\n    &quot;A2&quot;,&quot;11&quot;,0,1,0\r\n    &quot;A2&quot;,&quot;20&quot;,0,0,0\r\n    &quot;A1&quot;,&quot;26&quot;,1,0,1\r\n    &quot;A3&quot;,0,0,0,0",
                "title": "Converting JSON with arrays to CSV using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1510078152,
        "creation_date": 1509709267,
        "last_edit_date": 1510050609,
        "question_id": 47094953,
        "body_markdown": "I found myself in the world of JSON and I&#39;m trying to convert out of it using `jq`. I&#39;m trying to convert following structure to CSV:\r\n\r\n    {\r\n      &quot;Action&quot;: &quot;A1&quot;,\r\n      &quot;Group&quot;: [\r\n        {\r\n          &quot;Id&quot;: &quot;10&quot;,\r\n          &quot;Units&quot;: [\r\n            &quot;1&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;Action&quot;: &quot;A2&quot;,\r\n      &quot;Group&quot;: [\r\n        {\r\n          &quot;Id&quot;: &quot;11&quot;,\r\n          &quot;Units&quot;: [\r\n            &quot;2&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;Id&quot;: &quot;20&quot;,\r\n          &quot;Units&quot;: []\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;Action&quot;: &quot;A1&quot;,\r\n      &quot;Group&quot;: [\r\n        {\r\n          &quot;Id&quot;: &quot;26&quot;,\r\n          &quot;Units&quot;: [\r\n            &quot;1&quot;,\r\n            &quot;3&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;Action&quot;: &quot;A3&quot;,\r\n      &quot;Group&quot;: null\r\n    }\r\n\r\nwhere the Ids are between 10-99 and Units 1-5. Expected output would be (quoted or unquoted, comma separated or not, I used pipe separators for clarity):\r\n\r\n    Action|Group|Unit1|Unit2|Unit3|Unit4|Unit5\r\n    A1|10|1|0|0|0|0\r\n    A2|11|0|1|0|0|0\r\n    A2|20|0|0|0|0|0\r\n    A1|26|1|0|1|0|0\r\n    A3|0|0|0|0|0|0\r\n\r\nI&#39;ve played around with this for a while now (`history | grep jq | wc -l` says 107) but haven&#39;t made any real progress to combining the keys with eachother, I&#39;m basically just getting lists of keys (`jq` n00b).\r\n\r\n**Update:** \r\n\r\nTesting the solution (sorry, been a bit s l o w) I noticed that the data also has records with `&quot;Group&quot;: null`s, ie.:\r\n\r\n    {\r\n      &quot;Action&quot;: &quot;A3&quot;,\r\n      &quot;Group&quot;: null\r\n    }\r\n\r\n(above few lines added to the main test data set) which results in error: `jq: error (at file.json:61): Cannot iterate over null (null)`. Expected output would be:\r\n\r\n    A3|0|0|0|0\r\n\r\nIs there an easy way out of that one?",
        "link": "https://stackoverflow.com/questions/47094953/converting-json-with-arrays-to-csv-using-jq",
        "title": "Converting JSON with arrays to CSV using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "variables",
            "input",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 25,
                "is_accepted": false,
                "score": 25,
                "last_activity_date": 1509752802,
                "last_edit_date": 1509752802,
                "creation_date": 1509749996,
                "answer_id": 47105523,
                "question_id": 47105490,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Use the bash: `echo &quot;$json_data&quot; | jq &#39;.key&#39;`",
                "title": "Can I pass a string variable to jq rather than passing a file?"
            },
            {
                "up_vote_count": 12,
                "is_accepted": false,
                "score": 12,
                "last_activity_date": 1509749997,
                "creation_date": 1509749997,
                "answer_id": 47105524,
                "question_id": 47105490,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Absolutely. Just tell bash to &lt;a href=&quot;http://tldp.org/LDP/abs/html/process-sub.html&quot;&gt;give it a file instead&lt;/a&gt;.\r\n\r\n    jq &#39;.key&#39; &lt;(echo &quot;$json_data&quot;)\r\n\r\nAnd make sure you run it in bash, not sh.",
                "title": "Can I pass a string variable to jq rather than passing a file?"
            },
            {
                "up_vote_count": 205,
                "is_accepted": true,
                "score": 204,
                "last_activity_date": 1509752177,
                "creation_date": 1509752177,
                "answer_id": 47105805,
                "question_id": 47105490,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I would suggest using a bash [here string](https://linux.die.net/abs-guide/x15683.html).  e.g.\r\n\r\n    jq &#39;.key&#39; &lt;&lt;&lt; &quot;$json_data&quot;",
                "title": "Can I pass a string variable to jq rather than passing a file?"
            },
            {
                "up_vote_count": 43,
                "is_accepted": false,
                "score": 43,
                "last_activity_date": 1558711632,
                "last_edit_date": 1592644375,
                "creation_date": 1509755591,
                "answer_id": 47106137,
                "question_id": 47105490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The value of the variable &quot;json_data&quot; that was given in the original question was not valid JSON, so this response still covers both cases (nearly-valid and valid JSON).\n### Valid JSON\nIf &quot;$json_data&quot; does hold a valid JSON value, then here are two alternatives not mentioned elsewhere on this page.\n\n### `--argjson`\nFor example:\n\n     jq -n --argjson data &quot;$json_data&quot; &#39;$data.key&#39;\n\n### `env`\n\nIf the shell variable is not aleady an environment variable:\n\n    json_data=&quot;$json_data&quot; jq -n &#39;env.json_data | fromjson.key&#39;\n\n\n### Nearly-valid JSON\n\nIf indeed $json_data is **invalid** as JSON but valid as a jq expression, then you could adopt the tactic illustrated by the following transcript:\n\n    \n    $ json_data=&#39;{key:&quot;value&quot;}&#39;\n    $ jq -n &quot;$json_data&quot; | jq .key\n    &quot;value&quot;",
                "title": "Can I pass a string variable to jq rather than passing a file?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1528415065,
                "creation_date": 1528415065,
                "answer_id": 50751542,
                "question_id": 47105490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re trying to do this in a `.sh` file, this is what worked for me:\r\n\r\n\r\n    local json_data $(getJiraIssue &quot;$1&quot;)               # store JSON in var\r\n    echo `jq -n &quot;$json_data&quot; | jq &#39;.fields.summary&#39;`   # pass that JSON var to jq",
                "title": "Can I pass a string variable to jq rather than passing a file?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1547106614,
                "last_edit_date": 1547106614,
                "creation_date": 1547099515,
                "answer_id": 54122628,
                "question_id": 47105490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n#! /bin/bash\r\njson_data=&#39;{&quot;key&quot;:&quot;value&quot;}&#39;\r\necho $json_data | jq --raw-output &#39;.key&#39;\r\n```",
                "title": "Can I pass a string variable to jq rather than passing a file?"
            },
            {
                "up_vote_count": 10,
                "is_accepted": false,
                "score": 10,
                "last_activity_date": 1574911965,
                "creation_date": 1574911965,
                "answer_id": 59081352,
                "question_id": 47105490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to use inline command, I found this work on my Mac: \r\n\r\n    echo &#39;{&quot;key&quot;:&quot;value&quot;}&#39; | jq .key",
                "title": "Can I pass a string variable to jq rather than passing a file?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1650010989,
                "creation_date": 1650010989,
                "answer_id": 71881715,
                "question_id": 47105490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just do\r\n\r\n```\r\n$ jq &#39;.key&#39; &lt;&lt;&lt; $&#39;{&quot;key&quot;:&quot;value&quot;}&#39;\r\n&quot;value&quot;\r\n```",
                "title": "Can I pass a string variable to jq rather than passing a file?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1731522080,
                "creation_date": 1731522080,
                "answer_id": 79186214,
                "question_id": 47105490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes indeed it can be done.\r\n\r\nBelow snippet is part of the script which attempts to communicate to browserstack api to get the build status.\r\n\r\nSample response is like below\r\n\r\n    [\r\n        {\r\n            &quot;automation_build&quot;: {\r\n                &quot;name&quot;: &quot;Build #183: sample-app.apk v1.0&quot;,\r\n                &quot;hashed_id&quot;: &quot;13652db4394d39e59e2defafaa153e9da14827d&quot;,\r\n                &quot;duration&quot;: 1736,\r\n                &quot;status&quot;: &quot;failed&quot;,\r\n                &quot;build_tag&quot;: null,\r\n                &quot;public_url&quot;: null\r\n            }\r\n        }\r\n    ]\r\n\r\nAnd below script parses this response and gets the status of the build \r\n\r\n    BS_CREDENTIALS=&quot;${BS_CREDENTIALS:-}&quot;\r\n    BS_BUILD_STATUS_API=&#39;https://api.browserstack.com/app-automate/builds?limit=1&#39;\r\n    \r\n    #Get the curl response and store in response variable\r\n    response=`(curl  -u $BS_CREDENTIALS $BS_BUILD_STATUS_API)`\r\n    echo &quot;API response is `jq -n &quot;$response&quot;`&quot;\r\n    #Parse JSON response and get the status field from first element of array\r\n    buildStatus=$(jq -n &quot;$response&quot; | jq --raw-output &#39;.[0].automation_build.status&#39;)\r\n    buildId=$(jq -n &quot;$response&quot; | jq --raw-output &#39;.[0].automation_build.hashed_id&#39;)\r\n\r\n",
                "title": "Can I pass a string variable to jq rather than passing a file?"
            }
        ],
        "is_answered": true,
        "answer_count": 9,
        "score": 123,
        "last_activity_date": 1731522080,
        "creation_date": 1509749724,
        "last_edit_date": 1717498931,
        "question_id": 47105490,
        "body_markdown": "I want to convert JSON string into an array in bash.\r\nThe JSON string is passed to the bash script as an argument (it doesn&#39;t exist in a file).\r\n\r\nIs there a way of achieving it without using some temp files?\r\n\r\nSimilarly to this:\r\n\r\n    script.sh\r\n\r\n    #! /bin/bash\r\n    json_data=&#39;{&quot;key&quot;:&quot;value&quot;}&#39;\r\n    jq &#39;.key&#39; $json_data\r\n\r\n    jq: error: Could not open file {key:value}: No such file or directory",
        "link": "https://stackoverflow.com/questions/47105490/can-i-pass-a-string-variable-to-jq-rather-than-passing-a-file",
        "title": "Can I pass a string variable to jq rather than passing a file?"
    },
    {
        "tags": [
            "shell",
            "curl",
            "error-handling",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1509981030,
                "post_id": 47139605,
                "comment_id": 81229515,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2219968,
                    "reputation": 9,
                    "user_id": 1959609,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bf2416c359633519785fffa56e792a3b?s=256&d=identicon&r=PG",
                    "display_name": "user1959609",
                    "link": "https://stackoverflow.com/users/1959609/user1959609"
                },
                "reply_to_user": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1509981274,
                "post_id": 47139605,
                "comment_id": 81229687,
                "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": 1509983931,
                "post_id": 47139605,
                "comment_id": 81231631,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1509989425,
                "last_edit_date": 1509989425,
                "creation_date": 1509980162,
                "answer_id": 47139718,
                "question_id": 47139605,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Write the response into a variable:\r\n\r\n    # -f makes curl return an error in case of HTTP error.\r\n    # Check &quot;man curl&quot; on how reliable this is.\r\n    response=&quot;$(curl -f ...)&quot;\r\n    if [ $? -ne 0 ] ; then\r\n        echo &quot;Installing&quot;\r\n    else\r\n        jq FILTER &lt;&lt;&lt; &quot;${response}&quot;\r\n    fi\r\n    ",
                "title": "jq suppress parsing error for 404 json files"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1510244411,
        "creation_date": 1509979834,
        "last_edit_date": 1510244411,
        "question_id": 47139605,
        "body_markdown": "echo $(curl -s -u user:pwd &quot;http://site/file.json&quot; | jq -e -r &#39;.data[]? | select(.state == &quot;Active&quot;) | if  . == null then &quot;Installing&quot; elif . == &quot;Active&quot; then &quot;Active&quot; else &quot;Installing&quot; end&#39;)\r\n\r\nFollowing is the error:\r\n\r\nparse error: Invalid numeric literal at line 2, column 0\r\n\r\nIn a scenario when file.json doesn&#39;t exist 404 page is returned and jq is throwing a parsing error. In such case I want to return string &quot;Installing&quot;. Tried many things but nothing is working out, please help.\r\n",
        "link": "https://stackoverflow.com/questions/47139605/jq-suppress-parsing-error-for-404-json-files",
        "title": "jq suppress parsing error for 404 json files"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1510093901,
                "post_id": 47167963,
                "comment_id": 81286975,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1510094120,
                "creation_date": 1510094120,
                "answer_id": 47168543,
                "question_id": 47167963,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "First, that&#39;s not csv. The quotes would be interpreted as containing the single value. You have multiple sets of quotes per comma-separated value. But if that&#39;s what you want as output, you can definitely generate it, just know that it&#39;s not real csv.\r\n\r\n    $ jq -r &#39;to_entries | map(&quot;\\(.key|tojson):\\(.value|tojson)&quot;) | join(&quot;,&quot;)&#39; input.json",
                "title": "json to csv using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1510095733,
                "creation_date": 1510095733,
                "answer_id": 47168849,
                "question_id": 47167963,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a filter which generates the expected output (assuming data in `data.json`):\r\n\r\n    $ jq -Mr &#39;[keys[] as $k | {($k):.[$k]} | tojson[1:-1]] | join(&quot;,&quot;)&#39; data.json\r\n    &quot;Key1&quot;:&quot;Value1&quot;,&quot;Key2&quot;:&quot;Value2&quot;,&quot;Key3&quot;:&quot;Value3&quot;,&quot;key4&quot;:4,&quot;key5&quot;:5,&quot;key6&quot;:&quot;value6&quot;\r\n    &quot;Key1&quot;:&quot;Value1&quot;,&quot;Key2&quot;:&quot;Value2&quot;,&quot;Key3&quot;:&quot;Value3&quot;,&quot;key4&quot;:4,&quot;key5&quot;:5,&quot;key6&quot;:&quot;value6&quot;\r\n    &quot;Key1&quot;:&quot;Value1&quot;,&quot;Key2&quot;:&quot;Value2&quot;,&quot;Key3&quot;:&quot;Value3&quot;,&quot;key4&quot;:4,&quot;key5&quot;:5,&quot;key6&quot;:&quot;value6&quot;\r\n\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/UwHkeiH9NG)",
                "title": "json to csv using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1510095733,
        "creation_date": 1510091115,
        "question_id": 47167963,
        "body_markdown": "Looking to convert the following json example into csv using jq. The work is being performed on a centos 6.9, i am able to add tools to the box if need. The purpose of normalizing the json into csv is for a SIEM feed.\r\n\r\nJSON:\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      &quot;key4&quot;: 4,\r\n      &quot;key5&quot;: 5,\r\n      &quot;key6&quot;: &quot;value6&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      &quot;key4&quot;: 4,\r\n      &quot;key5&quot;: 5,\r\n      &quot;key6&quot;: &quot;value6&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      &quot;key4&quot;: 4,\r\n      &quot;key5&quot;: 5,\r\n      &quot;key6&quot;: &quot;value6&quot;\r\n    }\r\n\r\nOutput expecting:\r\n\r\n    &quot;key1&quot;:&quot;Value1&quot;,&quot;key2&quot;:&quot;Value2&quot;,&quot;key3&quot;:&quot;Value3&quot;,&quot;key4&quot;:4,&quot;key5&quot;:5,&quot;key6&quot;:&quot;Value6&quot;\r\n    &quot;key1&quot;:&quot;Value1&quot;,&quot;key2&quot;:&quot;Value2&quot;,&quot;key3&quot;:&quot;Value3&quot;,&quot;key4&quot;:4,&quot;key5&quot;:5,&quot;key6&quot;:&quot;Value6&quot;\r\n    &quot;key1&quot;:&quot;Value1&quot;,&quot;key2&quot;:&quot;Value2&quot;,&quot;key3&quot;:&quot;Value3&quot;,&quot;key4&quot;:4,&quot;key5&quot;:5,&quot;key6&quot;:&quot;Value6&quot;",
        "link": "https://stackoverflow.com/questions/47167963/json-to-csv-using-jq",
        "title": "json to csv using jq"
    },
    {
        "tags": [
            "shell",
            "variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1510136192,
                "last_edit_date": 1510136192,
                "creation_date": 1510131732,
                "answer_id": 47175421,
                "question_id": 47174988,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt;  am I doing something wrong?\r\n\r\nYes, within the jq program, you have quoted what you intended to be the jq variable, thus turning it into a JSON string. Simply remove the quotation marks to let the $-string be the $-variable.\r\n\r\np.s. You probably should avoid `contains`, which has weird semantics. Depending on your jq, alternatives to consider include `index` and `test`.",
                "title": "how to pass shell variable to jq filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1510169054,
        "creation_date": 1510130384,
        "last_edit_date": 1510169054,
        "question_id": 47174988,
        "body_markdown": "I try to pass a shell variable in that way:\r\n\r\n    jq -r --arg NEWGROUP &quot;$NEWGROUP&quot; &#39;.[] | select(.name | contains(&quot;$NEWGROUP&quot;) ) | .id&#39;\r\n\r\nbut it does not work.\r\n\r\nwhen I specify the group name explicitly in the contains() it works.\r\nam I doing something wrong?",
        "link": "https://stackoverflow.com/questions/47174988/how-to-pass-shell-variable-to-jq-filter",
        "title": "how to pass shell variable to jq filter"
    },
    {
        "tags": [
            "json",
            "object",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1510179902,
                "last_edit_date": 1510179902,
                "creation_date": 1510179404,
                "answer_id": 47190653,
                "question_id": 47190554,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "By passing in multiple input files, the contents of each file are streamed in. You&#39;d either have to slurp them in or combine the individual inputs.\r\n\r\n    $ jq -s &#39;add&#39; file1 file2\r\n\r\nor\r\n\r\n    $ jq -n &#39;reduce inputs as $i ({}; . + $i)&#39; file1 file2\r\n\r\nOr if you wanted to merge instead of add.\r\n\r\n    $ jq -n &#39;reduce inputs as $i ({}; . * $i)&#39; file1 file2",
                "title": "Merging two JSON objects with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1510179510,
                "creation_date": 1510179510,
                "answer_id": 47190679,
                "question_id": 47190554,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Alternative way with **jq** `--slurpfile` option:\r\n\r\n    jq --slurpfile f2 file2 &#39;. + $f2[0]&#39; file1\r\nThe output:\r\n\r\n    {\r\n      &quot;key1&quot;: &quot;valueA&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;,\r\n      &quot;key3&quot;: &quot;valueB&quot;\r\n    }\r\n\r\n",
                "title": "Merging two JSON objects with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1510186409,
                "creation_date": 1510186409,
                "answer_id": 47191884,
                "question_id": 47190554,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is another way (assumes sample data in `file1.json` and `file2.json`):\r\n\r\n    $ jq -Mn --argfile file1 file1.json --argfile file2 file2.json &#39;$file1 + $file2&#39;\r\n    {\r\n      &quot;key1&quot;: &quot;valueA&quot;,\r\n      &quot;key2&quot;: &quot;value2&quot;,\r\n      &quot;key3&quot;: &quot;valueB&quot;\r\n    }",
                "title": "Merging two JSON objects with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 7,
        "last_activity_date": 1510306878,
        "creation_date": 1510178971,
        "last_edit_date": 1510306878,
        "question_id": 47190554,
        "body_markdown": "I have two json files, each containing one simple object, for example:\r\n\r\n_file1_\r\n\r\n    {\r\n        &quot;key1&quot;: &quot;value1&quot;,\r\n        &quot;key2&quot;: &quot;value2&quot;\r\n    }\r\n\r\n_file2_\r\n\r\n    {\r\n        &quot;key1&quot;: &quot;valueA&quot;,\r\n        &quot;key3&quot;: &quot;valueB&quot;\r\n    }\r\n\r\nI need to combine these two using jq so that I end up with one object that contains all of the keys from both objects. If there are common keys, I need the values of from second object being used.\r\n\r\nI&#39;m struggling to get the right expression to use. I thought that something as simple as\r\n\r\n    jq &#39;. * .&#39; file1 file2\r\n\r\nshould give me what I want, however this results in a non-json output:\r\n\r\n    {\r\n        &quot;key1&quot;: &quot;value1&quot;,\r\n        &quot;key2&quot;: &quot;value2&quot;\r\n    }\r\n    {\r\n        &quot;key1&quot;: &quot;valueA&quot;,\r\n        &quot;key3&quot;: &quot;valueB&quot;\r\n    }\r\n\r\nThe same exact thing happens if I use `jq &#39;. + .&#39; file1 file2`.\r\n\r\nHow can I combine these two objects?",
        "link": "https://stackoverflow.com/questions/47190554/merging-two-json-objects-with-jq",
        "title": "Merging two JSON objects with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "sed",
            "jq",
            "recursive-datastructures"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1510243165,
                "last_edit_date": 1510243165,
                "creation_date": 1510241906,
                "answer_id": 47205871,
                "question_id": 47204952,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses [path](https://stedolan.github.io/jq/manual/#path\\(path_expression\\)) to find &quot;agent4&quot; and verify it appears within &quot;agents&quot; before removing it with [delpaths](https://stedolan.github.io/jq/manual/#delpaths\\(PATHS\\))\r\n\r\n    delpaths([ path(..|select(.==&quot;agent4&quot;)) | select(.[-2]==&quot;agents&quot;) ])\r\n\r\n\r\nSample Run (assumes data in `data.json`)\r\n\r\n    $ jq -M &#39;delpaths([ path(..|select(.==&quot;agent4&quot;)) | select(.[-2]==&quot;agents&quot;) ])&#39; data.json\r\n    {\r\n      &quot;environments&quot;: {\r\n        &quot;default&quot;: {\r\n          &quot;machines&quot;: {\r\n            &quot;dev-machine&quot;: {\r\n              &quot;agents&quot;: [\r\n                &quot;agent1&quot;,\r\n                &quot;agent2&quot;,\r\n                &quot;agent3&quot;\r\n              ]\r\n            }\r\n          }\r\n        }\r\n      },\r\n      &quot;environments2&quot;: {\r\n        &quot;agents&quot;: [\r\n          &quot;agent1&quot;,\r\n          &quot;agent2&quot;,\r\n          &quot;agent3&quot;\r\n        ]\r\n      }\r\n    }\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/-SlYr9tYjn)\r\n\r\nHere is another way using [reduce](https://stedolan.github.io/jq/manual/#Reduce), [leaf_paths](https://stedolan.github.io/jq/manual/#paths,paths\\(node_filter\\),leaf_paths), [getpath](https://stedolan.github.io/jq/manual/#getpath\\(PATHS\\)) and [delpaths](https://stedolan.github.io/jq/manual/#delpaths\\(PATHS\\)): \r\n\r\n    reduce leaf_paths as $p (.;\r\n      if $p[-2]==&quot;agents&quot; and getpath($p)==&quot;agent4&quot; then delpaths([$p]) else . end\r\n    )\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/gHGkdx8nJR)\r\n",
                "title": "jq recursively delete values that appear in array anywhere in schema"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1510242247,
                "creation_date": 1510242247,
                "answer_id": 47205996,
                "question_id": 47204952,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a solution using `walk`:\r\n\r\n    walk( if type == &quot;object&quot; and has(&quot;agents&quot;) \r\n          then .agents |= map(select(. != &quot;agent4&quot;))\r\n          else . end )\r\n\r\nIf you want to remove the value from all arrays, wherever they occur:\r\n\r\n    walk( if type == &quot;array&quot; then map(select(. != &quot;agent4&quot;)) else . end )\r\n\r\nIf you want a more flexible solution, you could, for example, replace `&quot;agent4&quot;` by `$value`, and then set `$value` on the command-line, e.g.  using `--arg value VALUE` if VALUE is a string, or `--argjson value VALUE` as appropriate.\r\n\r\nIf your jq does not have `walk`, simply prepend its definition, which is available (for example) from https://github.com/stedolan/jq/blob/master/src/builtin.jq\r\n\r\n",
                "title": "jq recursively delete values that appear in array anywhere in schema"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1510243615,
        "creation_date": 1510239334,
        "last_edit_date": 1510243615,
        "question_id": 47204952,
        "body_markdown": "I&#39;m trying to find out how to use jq to remove a certain value that occurs anywhere in the schema in an array. \r\n\r\nIn this case i&#39;m trying to remove agent4 from anywhere inside an array underneath the field labelled agents.\r\n\r\nThis is what I have so far \r\n\r\n    jq &#39;..|.agents? | select(. != null) |  map(select(. != &quot;agent4&quot;))&#39;\r\n\r\nBut that just creates the changed data and I don&#39;t know how to re-assign it to the path.\r\n\r\nI originally tried using sed for this but its definitely not the tool to use so I switched to jq.\r\n\r\n       {\r\n          &quot;environments&quot;: {\r\n            &quot;default&quot;: {\r\n              &quot;machines&quot;: {\r\n                &quot;dev-machine&quot;: {\r\n                  &quot;agents&quot;: [\r\n                    &quot;agent1&quot;,\r\n                    &quot;agent2&quot;,\r\n                    &quot;agent3&quot;,\r\n                    &quot;agent4&quot;\r\n                  ]\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;environments2&quot;: {         \r\n             &quot;agents&quot;: [\r\n                &quot;agent1&quot;,\r\n                &quot;agent2&quot;,\r\n                &quot;agent3&quot;,\r\n                &quot;agent4&quot;\r\n             ] \r\n          }\r\n        }\r\n\r\n\r\nHowever this just outputs\r\n\r\n    [\r\n      &quot;agent1&quot;,\r\n      &quot;agent2&quot;,\r\n      &quot;agent3&quot;\r\n    ]\r\n    [\r\n      &quot;agent1&quot;,\r\n      &quot;agent2&quot;,\r\n      &quot;agent3&quot;\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/47204952/jq-recursively-delete-values-that-appear-in-array-anywhere-in-schema",
        "title": "jq recursively delete values that appear in array anywhere in schema"
    },
    {
        "tags": [
            "json",
            "merge",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1510317015,
                "last_edit_date": 1510317015,
                "creation_date": 1510316614,
                "answer_id": 47222726,
                "question_id": 47221672,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution which uses [transpose](https://stedolan.github.io/jq/manual/#transpose) and [add](https://stedolan.github.io/jq/manual/#add).  Assuming the sample data is in `data.json`:\r\n\r\n    $ jq -M &#39;transpose|map(add)&#39; data.json\r\n    [\r\n      {\r\n        &quot;foo&quot;: 1,\r\n        &quot;bar&quot;: 12,\r\n        &quot;baz&quot;: 543\r\n      },\r\n      {\r\n        &quot;foo&quot;: 23,\r\n        &quot;bar&quot;: -1\r\n      }\r\n    ]\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/ger1zb3_xV)",
                "title": "Map over two arrays with jq and merge objects inside"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1510436709,
                "last_edit_date": 1510436709,
                "creation_date": 1510351544,
                "answer_id": 47231850,
                "question_id": 47221672,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a stream-oriented solution using `zips/2` defined as follows:\r\n\r\n    # Input: an array, padded as necessary with null.\r\n    # Output: a stream with |stream| items, `[$in[$i], $s$i] | f`, \r\n    # where $s$i is the $i-th item in the stream.\r\n    def zips(stream; f):\r\n      . as $in | foreach stream as $x (-1; .+=1; [$in[.], $x] | f);\r\n\r\nThis avoids the overhead of `transpose`, and would be especially appropriate if the two arrays had not already been combined, or if a stream output was acceptable.\r\n\r\nIn any case, `zips` could be used as follows to solve the problem at hand:\r\n\r\n    . as $in\r\n    | $in[0] | [zips( $in[1][]; add )]\r\n\r\nIf you don&#39;t require the result to be a single array, you can omit the square brackets around the call to `zips`. \r\n\r\n",
                "title": "Map over two arrays with jq and merge objects inside"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1510537098,
        "creation_date": 1510312954,
        "last_edit_date": 1510537098,
        "question_id": 47221672,
        "body_markdown": "I have two arrays of identical length with objects in them:\r\n\r\n    input: [[{foo: 1}, {foo: 23}], [{bar: 12, baz: 543}, {bar: -1}]]\r\n\r\nHow do I tell [jq](https://stedolan.github.io/jq/manual/) to merge them into one array like below?\r\n\r\n    output: [{foo: 1, bar: 12, baz: 543}, {foo: 23, bar: -1}]",
        "link": "https://stackoverflow.com/questions/47221672/map-over-two-arrays-with-jq-and-merge-objects-inside",
        "title": "Map over two arrays with jq and merge objects inside"
    },
    {
        "tags": [
            "json",
            "curl",
            "pipeline",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1510530648,
                "last_edit_date": 1510530648,
                "creation_date": 1510377740,
                "answer_id": 47234653,
                "question_id": 47234312,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I&#39;d suggest you start with:\r\n\r\n    jq &#39;select(.channels | index(&quot;58b8a25cf9f6e19cf671872f&quot;))&#39;\r\n\r\nIn fact, this might even be exactly the filter you want. If you want to remove the &quot;channels&quot; once you&#39;ve made the selection, you could augment the filter above as follows:\r\n\r\n    select(.channels | index(&quot;58b8a25cf9f6e19cf671872f&quot;)) | del(.channels)\r\n\r\nThe main thing to note is that one can create a pipeline WITHIN a single invocation of jq. So most likely you&#39;ll end up with: `curl ... | jq ...`\r\n\r\n### Btw\r\n\r\nThe jq expression `{&quot;id&quot;: .id}` can be abbreviated to `{id}`, so instead of: \r\n\r\n    {id.id, name: .name, channels: .channels, geofenceProfileId: .geofenceProfileId}\r\n\r\nyou could write:\r\n\r\n    {id, name, channels, geofenceProfileId}\r\n\r\n\r\n    ",
                "title": "How to properly chain multiple jq statements together when processing json in the shell such as with curl?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1661957085,
                "creation_date": 1661957085,
                "answer_id": 73557694,
                "question_id": 47234312,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Probably not related to your case but I managed to transform my command\r\n```\r\nnpm pkg get version -ws | jq &quot;select(to_entries | min_by(.value) | .value)&quot;\r\n```\r\n\r\nto \r\n```\r\nnpm pkg get version -ws | jq &quot;to_entries | min_by(.value) | .value&quot;\r\n```\r\n\r\nand result is same. May be it helps. SO the idea is to pipe inside jq statement\r\n",
                "title": "How to properly chain multiple jq statements together when processing json in the shell such as with curl?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 7,
        "last_activity_date": 1661957085,
        "creation_date": 1510374062,
        "last_edit_date": 1510529537,
        "question_id": 47234312,
        "body_markdown": "I am new to jq so if this is not a jq question or a json question please point me in the right direction.  I am not sure of the correct terminology so it is making it hard for me to properly articulate the problem.\r\n\r\nI am using to curl to pull some json that I want to filter out keys with specific values. Here is some of the sample json:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;593f468c81aaa30001960e16&quot;,\r\n      &quot;name&quot;: &quot;Name 1&quot;,\r\n      &quot;channels&quot;: [\r\n        &quot;593f38398481bc00019632e5&quot;\r\n      ],\r\n      &quot;geofenceProfileId&quot;: null\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;58e464585180ac000a748b57&quot;,\r\n      &quot;name&quot;: &quot;Name 2&quot;,\r\n      &quot;channels&quot;: [\r\n        &quot;58b480097f04f20007f3cdca&quot;,\r\n        &quot;580ea26616de060006000001&quot;\r\n      ],\r\n      &quot;geofenceProfileId&quot;: null\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;58b4d6db7f04f20007f3cdd2&quot;,\r\n      &quot;name&quot;: &quot;Name 3&quot;,\r\n      &quot;channels&quot;: [\r\n        &quot;58b8a25cf9f6e19cf671872f&quot;\r\n      ],\r\n      &quot;geofenceProfileId&quot;: &quot;57f53018271c810006000001&quot;\r\n    }\r\n\r\n\r\nWhen I run the following command:\r\n\r\n    curl -X GET -H &#39;authorization: Basic somestring=&#39; &quot;https://myserver/myjson&quot; |\r\n      jq &#39;.[] | {id: .id, name: .name, channels: .channels, geofenceProfileId: .geofenceProfileId}&#39; |\r\n      jq &#39;.[] | select(.channels == 58b8a25cf9f6e19cf671872f)&#39;\r\n\r\nI get the following error:\r\n\r\njq: error: syntax error, unexpected IDENT, expecting &#39;;&#39; or &#39;)&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.[] | select(.channels == 58b8a25cf9f6e19cf671872f)                            \r\njq: 1 compile error\r\n  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                 Dload  Upload   Total   Spent    Left  Speed\r\n100  351k    0  351k    0     0  1109k      0 --:--:-- --:--:-- --:--:-- 1110k\r\n\r\nIs this error because jq pretty prints the output of the first statement and the second statement is expecting it to be in one code block?  If so, how do I convert it back to non pretty print format or how can I use jq to run a new filter on the output? \r\n\r\nBasically I am trying to parse hundreds of records and filter out all of the records that are in a specific channel number or have a specific geofenceProfileId.",
        "link": "https://stackoverflow.com/questions/47234312/how-to-properly-chain-multiple-jq-statements-together-when-processing-json-in-th",
        "title": "How to properly chain multiple jq statements together when processing json in the shell such as with curl?"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "edit",
            "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": 1510597322,
                "post_id": 47270454,
                "comment_id": 81492834,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1510597957,
                "last_edit_date": 1510597957,
                "creation_date": 1510596349,
                "answer_id": 47270769,
                "question_id": 47270454,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Given:\r\n\r\n    res=&#39;[{&quot;fn&quot;: 22222,&quot;name&quot;:&quot;raimonds&quot;},{&quot;fn&quot;: 22222,&quot;name&quot;:&quot;john&quot;}]&#39;\r\n\r\nAs [@chepner][1] pointed out,\r\nyou could modify the object in a filter:\r\n\r\n    echo &quot;$res&quot; | jq &#39;.[].fn *= 2&#39;\r\n\r\nOutput:\r\n\r\n    [\r\n      {\r\n        &quot;fn&quot;: 44444,\r\n        &quot;name&quot;: &quot;raimonds&quot;\r\n      },\r\n      {\r\n        &quot;fn&quot;: 44444,\r\n        &quot;name&quot;: &quot;john&quot;\r\n      }\r\n    ]\r\n\r\nMy original suggestion was to construct objects with the modified property,\r\nwhich would quickly get tedious, and has no advantages whatsoever:\r\n\r\n    echo &quot;$res&quot; | jq &#39;[ .[] | {fn: (.fn * 2), name: .name} ]&#39;\r\n\r\n  [1]: https://stackoverflow.com/users/1126841/chepner",
                "title": "Change each json object key(fn) value with number multiplied with 2"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1510597578,
                "creation_date": 1510597578,
                "answer_id": 47271091,
                "question_id": 47270454,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "This filter multiplies the `.fn` member of each object within an array (or another object) by 2, leaving other members unchanged.\r\n\r\n    .[].fn *= 2\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/xFeICzxONW)",
                "title": "Change each json object key(fn) value with number multiplied with 2"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1510654166,
        "creation_date": 1510595214,
        "last_edit_date": 1510654166,
        "question_id": 47270454,
        "body_markdown": "Hello I want to change each json object key value. JSON - \r\n\r\n    abc=&#39;[{&quot;fn&quot;: 1,&quot;name&quot;:&quot;raimonds&quot;},{&quot;fn&quot;: 2,&quot;name&quot;:&quot;john&quot;}]&#39;\r\nNow using some filter in jq - \r\n\r\n    res=$(echo &quot;$abc&quot; | jq &#39;map(if .fn then . + {&quot;fn&quot;:22222} else . end)&#39;)\r\nNow if I&#39;m echoing $res it retuns -\r\n\r\n    &#39;[{&quot;fn&quot;: 22222,&quot;name&quot;:&quot;raimonds&quot;},{&quot;fn&quot;: 22222,&quot;name&quot;:&quot;john&quot;}]&#39;\r\nI want to multiply each fn by 2 and output it like this - \r\n\r\n    abc=&#39;[{&quot;fn&quot;: 22222,&quot;name&quot;:&quot;raimonds&quot;},{&quot;fn&quot;: 44444,&quot;name&quot;:&quot;john&quot;}]&#39;\r\nHow can i do that? Thank you!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/47270454/change-each-json-object-keyfn-value-with-number-multiplied-with-2",
        "title": "Change each json object key(fn) value with number multiplied with 2"
    },
    {
        "tags": [
            "arrays",
            "json",
            "grouping",
            "jq",
            "bucket"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1510610448,
                "last_edit_date": 1510610448,
                "creation_date": 1510609866,
                "answer_id": 47274152,
                "question_id": 47273693,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The following solution avoids `group_by` for two reasons:\r\n\r\n* efficiency\r\n* the `sort` used by `group_by` in jq version 1.5 might not be stable, which complicates things.\r\n\r\nInstead we use `bucketize` defined as follows:\r\n\r\n    def bucketize(f): reduce .[] as $x ({}; .[$x|f] += [$x] );\r\n\r\nTo keep things simple, we will also define the following helper function:\r\n\r\n    # compactify an array with a single ID\r\n    def compact:\r\n      . as $in\r\n      | reduce (.[0]|keys_unsorted[]) as $key ({};\r\n          . + {($key): $in|map(.[$key])})\r\n        + {&quot;ID&quot;: .[0].ID}\r\n        ;\r\n    \r\n### Solution\r\n\r\n    [bucketize(.ID)[] | compact]\r\n\r\nThis will ensure things are OK even if the set of dates differ across IDs, and even if the JSON objects are not grouped initially by date.\r\n\r\n(If you want to drop &quot;DATE&quot; altogether in the final results, then replace the call to `compact` by `compact | del(.DATE)` in the line above.)\r\n\r\n### Output\r\n\r\n   \r\n\r\n    [\r\n      {\r\n        &quot;DATE&quot;: [\r\n          &quot;10.10.2017 01:00&quot;,\r\n          &quot;10.10.2017 02:00&quot;,\r\n          &quot;10.10.2017 03:00&quot;\r\n        ],\r\n        &quot;ID&quot;: &quot;X&quot;,\r\n        &quot;VALUE_ONE&quot;: [\r\n          20,\r\n          30,\r\n          25\r\n        ],\r\n        &quot;VALUE_TWO&quot;: [\r\n          5,\r\n          7,\r\n          2\r\n        ]\r\n      },\r\n      {\r\n        &quot;DATE&quot;: [\r\n          &quot;10.10.2017 01:00&quot;,\r\n          &quot;10.10.2017 02:00&quot;,\r\n          &quot;10.10.2017 03:00&quot;\r\n        ],\r\n        &quot;ID&quot;: &quot;Y&quot;,\r\n        &quot;VALUE_ONE&quot;: [\r\n          10,\r\n          20,\r\n          50\r\n        ],\r\n        &quot;VALUE_TWO&quot;: [\r\n          9,\r\n          5,\r\n          5\r\n        ]\r\n      },\r\n      {\r\n        &quot;DATE&quot;: [\r\n          &quot;10.10.2017 01:00&quot;,\r\n          &quot;10.10.2017 02:00&quot;,\r\n          &quot;10.10.2017 03:00&quot;\r\n        ],\r\n        &quot;ID&quot;: &quot;Z&quot;,\r\n        &quot;VALUE_ONE&quot;: [\r\n          55,\r\n          60,\r\n          15\r\n        ],\r\n        &quot;VALUE_TWO&quot;: [\r\n          3,\r\n          7,\r\n          7\r\n        ]\r\n      }\r\n    ]\r\n\r\n",
                "title": "jq: Turn json object values into arrays"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1510612529,
                "creation_date": 1510612529,
                "answer_id": 47274693,
                "question_id": 47273693,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "With *2-step* reduce(it doesn&#39;t look beautiful but works):\r\n\r\n    jq &#39;reduce group_by(.ID)[] as $a ([]; . + [ reduce $a[] as $o \r\n       ({&quot;DATE&quot;:[],&quot;VALUE_ONE&quot;:[],&quot;VALUE_TWO&quot;:[]}; \r\n        .DATE |= .+ [$o.DATE] | .ID = $o.ID |.VALUE_ONE |= .+ [$o.VALUE_ONE] \r\n        | .VALUE_TWO |= .+ [$o.VALUE_TWO]) ] )&#39; input.json\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;DATE&quot;: [\r\n          &quot;10.10.2017 01:00&quot;,\r\n          &quot;10.10.2017 02:00&quot;,\r\n          &quot;10.10.2017 03:00&quot;\r\n        ],\r\n        &quot;VALUE_ONE&quot;: [\r\n          20,\r\n          30,\r\n          25\r\n        ],\r\n        &quot;VALUE_TWO&quot;: [\r\n          5,\r\n          7,\r\n          2\r\n        ],\r\n        &quot;ID&quot;: &quot;X&quot;\r\n      },\r\n      {\r\n        &quot;DATE&quot;: [\r\n          &quot;10.10.2017 01:00&quot;,\r\n          &quot;10.10.2017 02:00&quot;,\r\n          &quot;10.10.2017 03:00&quot;\r\n        ],\r\n        &quot;VALUE_ONE&quot;: [\r\n          10,\r\n          20,\r\n          50\r\n        ],\r\n        &quot;VALUE_TWO&quot;: [\r\n          9,\r\n          5,\r\n          5\r\n        ],\r\n        &quot;ID&quot;: &quot;Y&quot;\r\n      },\r\n      {\r\n        &quot;DATE&quot;: [\r\n          &quot;10.10.2017 01:00&quot;,\r\n          &quot;10.10.2017 02:00&quot;,\r\n          &quot;10.10.2017 03:00&quot;\r\n        ],\r\n        &quot;VALUE_ONE&quot;: [\r\n          55,\r\n          60,\r\n          15\r\n        ],\r\n        &quot;VALUE_TWO&quot;: [\r\n          3,\r\n          7,\r\n          7\r\n        ],\r\n        &quot;ID&quot;: &quot;Z&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "jq: Turn json object values into arrays"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1510616614,
                "creation_date": 1510616614,
                "answer_id": 47275371,
                "question_id": 47273693,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using [reduce](https://stedolan.github.io/jq/manual/#Reduce), [setpath](https://stedolan.github.io/jq/manual/#setpath\\(PATHS;VALUE\\)), [getpath](https://stedolan.github.io/jq/manual/#getpath\\(PATHS\\)), [del](https://stedolan.github.io/jq/manual/#del\\(path_expression\\)) and [symbolic variable destructuring](https://stedolan.github.io/jq/manual/#Variable/SymbolicBindingOperator:...as$identifier|...).  It will collect all the values for keys other than `ID` and `DATE` (eliminating the need to hardcode `VALUE_ONE`, etc.) in parallel arrays.\r\n\r\n    reduce (.[] | [.ID, .DATE, del(.ID,.DATE)]) as [$id,$date,$v] ({};\r\n        (getpath([$id, &quot;DATE&quot;])|length) as $idx\r\n      | setpath([$id, &quot;ID&quot;]; $id)\r\n      | setpath([$id, &quot;DATE&quot;, $idx]; $date)\r\n      | reduce ($v|keys[]) as $k (.; setpath([$id, $k, $idx]; $v[$k]))\r\n    )\r\n    | map(.)\r\n\r\n[Try it online!][TIO-j9ytqrh5]\r\n\r\n[jq]: https://stedolan.github.io/jq/\r\n[TIO-j9ytqrh5]: https://tio.run/##nZFda4MwGIXv@yteJBcGoviBK6tXBXtRGOtN99FJGDJD63TqanQbtX99NlrKqtThJrnw@J48npO8vlfuTnKmy5k0kXRNFcvQ9DFo@kTTJCLNHfH9UbzcT2/uZs@LW@EztJNcPiykibUnFwlGP8FsE8Y9BPOXDFaLYPQQzlus2gS9neF6QIvVv87B7CdYwwjnLZ46hPY5mANadAhXf7@LDkG3OgRaVlvm5y8MZNWlUIKrzh0Cao0l4LNIrnUjMcXgZeCiwCfI9zgjqKAg7/b2CMQjrxlPPb6RGwMcg1FcRixe802zVQw@hbeErG0VSaldT/GlaQMizebaVf/56DsFR0UZsq/MPeZDoahidyAo/AEULgopxiM8KuHNS2UVV9V3kvIgibNKUeI8ipQgTnMuxNb7UJKcC3EA &quot;jq – Try It Online&quot;",
                "title": "jq: Turn json object values into arrays"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1510618145,
                "creation_date": 1510618145,
                "answer_id": 47275605,
                "question_id": 47273693,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If your data set is small enough, you could just group them up by id and map to the desired results. It won&#39;t be super efficient compared to a streaming solution, but will be the simplest to implement using builtins.\r\n\r\n    group_by(.ID) | map({\r\n        DATE: map(.DATE),\r\n        ID: .[0].ID,\r\n        VALUE_ONE: map(.VALUE_ONE),\r\n        VALUE_TWO: map(.VALUE_TWO)\r\n    })",
                "title": "jq: Turn json object values into arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1510652701,
        "creation_date": 1510607795,
        "last_edit_date": 1510652701,
        "question_id": 47273693,
        "body_markdown": "I have got the following array of objects (this is just an excerpt, also the objects are bigger):\r\n\r\n    [{\r\n        &quot;DATE&quot;: &quot;10.10.2017 01:00&quot;,\r\n        &quot;ID&quot;: &quot;X&quot;,\r\n        &quot;VALUE_ONE&quot;: 20,\r\n        &quot;VALUE_TWO&quot;: 5\r\n      },\r\n      {\r\n        &quot;DATE&quot;: &quot;10.10.2017 02:00&quot;,\r\n        &quot;ID&quot;: &quot;X&quot;,\r\n        &quot;VALUE_ONE&quot;: 30,\r\n        &quot;VALUE_TWO&quot;: 7\r\n      },\r\n      {\r\n        &quot;DATE&quot;: &quot;10.10.2017 03:00&quot;,\r\n        &quot;ID&quot;: &quot;X&quot;,\r\n        &quot;VALUE_ONE&quot;: 25,\r\n        &quot;VALUE_TWO&quot;: 2\r\n      },\r\n    \r\n      {\r\n        &quot;DATE&quot;: &quot;10.10.2017 01:00&quot;,\r\n        &quot;ID&quot;: &quot;Y&quot;,\r\n        &quot;VALUE_ONE&quot;: 10,\r\n        &quot;VALUE_TWO&quot;: 9\r\n      },\r\n      {\r\n        &quot;DATE&quot;: &quot;10.10.2017 02:00&quot;,\r\n        &quot;ID&quot;: &quot;Y&quot;,\r\n        &quot;VALUE_ONE&quot;: 20,\r\n        &quot;VALUE_TWO&quot;: 5\r\n      },\r\n      {\r\n        &quot;DATE&quot;: &quot;10.10.2017 03:00&quot;,\r\n        &quot;ID&quot;: &quot;Y&quot;,\r\n        &quot;VALUE_ONE&quot;: 50,\r\n        &quot;VALUE_TWO&quot;: 5\r\n      },\r\n    \r\n      {\r\n        &quot;DATE&quot;: &quot;10.10.2017 01:00&quot;,\r\n        &quot;ID&quot;: &quot;Z&quot;,\r\n        &quot;VALUE_ONE&quot;: 55,\r\n        &quot;VALUE_TWO&quot;: 3\r\n      },\r\n      {\r\n        &quot;DATE&quot;: &quot;10.10.2017 02:00&quot;,\r\n        &quot;ID&quot;: &quot;Z&quot;,\r\n        &quot;VALUE_ONE&quot;: 60,\r\n        &quot;VALUE_TWO&quot;: 7\r\n      },\r\n      {\r\n        &quot;DATE&quot;: &quot;10.10.2017 03:00&quot;,\r\n        &quot;ID&quot;: &quot;Z&quot;,\r\n        &quot;VALUE_ONE&quot;: 15,\r\n        &quot;VALUE_TWO&quot;: 7\r\n      }\r\n    ]\r\n\r\n\r\nTo simplify this for a web application, and also to reduce file size, I would like to convert the `&quot;VALUE_ONE&quot;`,`&quot;VALUE_TWO&quot;` and `&quot;DATE&quot;` values to arrays for each &quot;ID&quot; just like this:\r\n\r\n    [{\r\n        &quot;DATE&quot;: [&quot;10.10.2017 01:00&quot;, &quot;10.10.2017 02:00&quot;, &quot;10.10.2017 03:00&quot;],\r\n        &quot;ID&quot;: &quot;X&quot;,\r\n        &quot;VALUE_ONE&quot;: [20, 30, 25],\r\n        &quot;VALUE_TWO&quot;: [5, 7, 2]\r\n      },\r\n      {\r\n        &quot;DATE&quot;: [&quot;10.10.2017 01:00&quot;, &quot;10.10.2017 02:00&quot;, &quot;10.10.2017 03:00&quot;],\r\n        &quot;ID&quot;: &quot;Y&quot;,\r\n        &quot;VALUE_ONE&quot;: [10, 20, 50],\r\n        &quot;VALUE_TWO&quot;: [9, 5, 5]\r\n      },\r\n      {\r\n        &quot;DATE&quot;: [&quot;10.10.2017 01:00&quot;, &quot;10.10.2017 02:00&quot;, &quot;10.10.2017 03:00&quot;],\r\n        &quot;ID&quot;: &quot;Z&quot;,\r\n        &quot;VALUE_ONE&quot;: [55, 60, 15],\r\n        &quot;VALUE_TWO&quot;: [3, 7, 7]\r\n      }\r\n    ]\r\n    \r\nHere it is important that you need to be able find the values that are linked to a certain time (date). As the input values for `&quot;DATE&quot;` are consecutive, you most probably do not need the `DATE` value anymore to find the requested `&quot;VALUE..&quot;` value. You can probably just use the index of the array for that (`index=0` is always `10.10.2017 01:00`, `index=1` is ... `02:00` etc.). \r\nIs it possible to do it like that? This would keep the file size even smaller.\r\nThanks!\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/47273693/jq-turn-json-object-values-into-arrays",
        "title": "jq: Turn json object values into arrays"
    },
    {
        "tags": [
            "json",
            "bash",
            "parameter-passing",
            "jq",
            "data-processing"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1510626112,
                "post_id": 47276532,
                "comment_id": 81504425,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3709136,
                    "reputation": 97,
                    "user_id": 3086917,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/f4ad43ab52be9ae071cbb785f5491de2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3086917",
                    "link": "https://stackoverflow.com/users/3086917/user3086917"
                },
                "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": 1510626619,
                "post_id": 47276532,
                "comment_id": 81504535,
                "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": 1510627006,
                "post_id": 47276532,
                "comment_id": 81504617,
                "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": 1510627176,
                "post_id": 47276532,
                "comment_id": 81504657,
                "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": 1510627328,
                "post_id": 47276532,
                "comment_id": 81504695,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 3709136,
                    "reputation": 97,
                    "user_id": 3086917,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://www.gravatar.com/avatar/f4ad43ab52be9ae071cbb785f5491de2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3086917",
                    "link": "https://stackoverflow.com/users/3086917/user3086917"
                },
                "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": 1510630198,
                "post_id": 47276532,
                "comment_id": 81505369,
                "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": 1510630572,
                "post_id": 47276532,
                "comment_id": 81505453,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1510631249,
                "last_edit_date": 1510631249,
                "creation_date": 1510630848,
                "answer_id": 47277265,
                "question_id": 47276532,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "1. jq does not support the evaluation of jq expressions in the\r\nway that would be required for your attempt to work.  You could do some\r\nkind of shell interpolation, but it would be better to use JSON paths,\r\ne.g. rather than `--arg value0 .host`, you could write `--arg value0 &quot;host&quot;`, etc.  In the following, I&#39;ve used `getpath/1`.\r\n\r\n2. There is no need to prepend the jq filter with &#39;. |&#39;\r\n\r\nAnyway, assuming the JSON contents of the pastebin are in pastebin.json, you could write:\r\n\r\n      jq \\\r\n       --arg key0        Host \\\r\n       --argjson value0  &#39;[&quot;http&quot;,&quot;host&quot;]&#39; \\\r\n       --arg key1        Vulnerability \\\r\n       --argjson value1  &#39;[&quot;opts&quot;, &quot;vulns&quot;, 0]&#39; \\\r\n       --arg key2        ISP \\\r\n       --argjson value2  &#39;[&quot;isp&quot;]&#39; \\\r\n       &#39;. as $in\r\n        | {}\r\n        | .[$key0] = ($in|getpath($value0))\r\n        | .[$key1] = ($in|getpath($value1))\r\n        | .[$key2] = ($in|getpath($value2))&#39; \\\r\n       pastebin.json\r\n\r\nThis would have the result:\r\n\r\n    {\r\n      &quot;Host&quot;: &quot;196.196.216.13&quot;,\r\n      &quot;Vulnerability&quot;: &quot;!CVE-2014-0160&quot;,\r\n      &quot;ISP&quot;: &quot;Fiber Grid Inc&quot;\r\n    }",
                "title": "Passing JSON objects to jq arguments"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1510643164,
                "last_edit_date": 1510643164,
                "creation_date": 1510641847,
                "answer_id": 47279255,
                "question_id": 47276532,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here&#39;s a variant solution using the approach suggested by @CharlesDuffy:\r\n\r\n    $ config=&#39;{&quot;Host&quot;: [&quot;http&quot;, &quot;host&quot;], \r\n               &quot;Vulnerability&quot;: [&quot;opts&quot;, &quot;vulns&quot;, 0], \r\n               &quot;ISP&quot;: [&quot;isp&quot;]}&#39;\r\n    $ jq --argjson config &quot;$config&quot; &#39;\r\n       . as $in\r\n       | $config\r\n       | map_values( . as $p | $in | getpath($p) )&#39; pastebin.json\r\n\r\nOutput:\r\n    \r\n    {\r\n      &quot;Host&quot;: &quot;196.196.216.13&quot;,\r\n      &quot;Vulnerability&quot;: &quot;!CVE-2014-0160&quot;,\r\n      &quot;ISP&quot;: &quot;Fiber Grid Inc&quot;\r\n    }\r\n\r\nThis incidentally highlights @chepner&#39;s point: the care and maintenance required for $config is no less than the care and maintenance required for the corresponding jq query, whereas the jq query language -- by design -- offers far more flexibility.\r\n",
                "title": "Passing JSON objects to jq arguments"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1510642951,
                "creation_date": 1510642951,
                "answer_id": 47279562,
                "question_id": 47276532,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In response to the supplementary question (&quot;to: chepner&quot;):\r\n\r\nThe pastebin data does not contain &quot;196.196.216.14&quot; so the supplementary question is unclear, but you will probably want to start with: \r\n\r\n    jq &#39;{(.ip_str): [.asn, .isp, .timestamp, opts.vulns[0] ]}&#39; pastebin.json\r\n\r\nThis produces:\r\n\r\n    {\r\n      &quot;196.196.216.13&quot;: [\r\n        &quot;AS63119&quot;,\r\n        &quot;Fiber Grid Inc&quot;,\r\n        &quot;2017-08-29T06:57:22.546423&quot;,\r\n        &quot;!CVE-2014-0160&quot;\r\n      ]\r\n    }\r\n\r\nThe key point here is the pair of parentheses around `.ip_str`.\r\n\r\nAs mentioned elsewhere, the jq query is again so simple and straightforward that it seems doubtful that a parameterized version will offer any advantage.  \r\n",
                "title": "Passing JSON objects to jq arguments"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1510643164,
        "creation_date": 1510625068,
        "last_edit_date": 1510627050,
        "question_id": 47276532,
        "body_markdown": "Data sample - **sample.json** (full sample: [https://pastebin.com/KFkVmc2M][1])\r\n\r\n        {\r\n          &quot;ip&quot;: 3301234701,\r\n          &quot;_shodan&quot;: {\r\n            &quot;options&quot;: {\r\n              &quot;referrer&quot;: &quot;7ae15507-f5cc-4353-b72e-5cc0b1c34c5e&quot;\r\n            },\r\n          },\r\n          &quot;hash&quot;: -1056085507,\r\n          &quot;os&quot;: null,\r\n          &quot;title&quot;: &quot;WHM Login&quot;,\r\n          &quot;opts&quot;: {\r\n            &quot;vulns&quot;: [&quot;!CVE-2014-0160&quot;],\r\n            &quot;heartbleed&quot;: &quot;2017/08/29 09:57:30 196.196.216.13:2087 - SAFE\\\r\n            }\r\n          },\r\n          &quot;isp&quot;: &quot;Fiber Grid Inc&quot;,\r\n          &quot;http&quot;: {\r\n            &quot;redirects&quot;: [],\r\n            &quot;title&quot;: &quot;WHM Login&quot;,\r\n            &quot;robots&quot;: null,\r\n            &quot;favicon&quot;: null,\r\n            &quot;host&quot;: &quot;196.196.216.13&quot;,\r\n            &quot;html&quot;:\r\n    }\r\n\r\nScript using jq which I hoped would work and haven&#39;t found a another solution yet.\r\n\r\n \r\n\r\n       cat sample.json | jq \\\r\n       --arg key0   &#39;Host&#39; \\\r\n       --arg value0 &#39;.host&#39; \\\r\n       --arg key1   &#39;Vulnerability&#39; \\\r\n       --arg value1 &#39;.opts.vulns[0]&#39; \\\r\n       --arg key2   &#39;ISP&#39; \\\r\n       --arg value2 &#39;.isp&#39; \\\r\n       &#39;. | .[$key0]= $value0 | .[$key1]=$value1 | .[$key2]=$value2&#39; \\\r\n       &lt;&lt;&lt;&#39;{}&#39;\r\n\r\n\r\nThe end result I hoped, but not getting:\r\n\r\n    {\r\n      &quot;Host&quot;: &quot;196.196.216.13&quot;,\r\n      &quot;Vulnerability&quot;: &quot;!CVE-2014-0160&quot;,\r\n      &quot;ISP&quot;: &quot;Fiber Grid Inc&quot;\r\n    }\r\n\r\nRight now it just returns the object as a string and I&#39;ve tried a lot of different ways to approach the problem. I am quite new to working with JSON and jq but based on what I&#39;ve read so far, the solution might not be as simple as I&#39;m wishing?\r\n\r\nSimply put, why isn&#39;t the object being returned as a value of the sample.json object and what do I have to do, to make it work? \r\n\r\nThanks!\r\n\r\nto: chepner\r\n\r\n    {\r\n      &quot;196.196.216.13&quot;:[\r\n      &quot;AS63119&quot;,\r\n      &quot;Fiber Grid Inc&quot;,\r\n      &quot;2017-08-29T06:57:22.546423&quot;,\r\n      &quot;!CVE-2014-0160&quot;\r\n    ],\r\n    &quot;196.196.216.14&quot;:[\r\n      &quot;AS63119&quot;,\r\n      &quot;Fiber Grid Inc&quot;,\r\n      &quot;2017-08-29T06:57:22.546423&quot;,\r\n      &quot;!CVE-2014-0160&quot;\r\n    ]\r\n    }\r\n\r\n  [1]: https://pastebin.com/KFkVmc2M",
        "link": "https://stackoverflow.com/questions/47276532/passing-json-objects-to-jq-arguments",
        "title": "Passing JSON objects to jq arguments"
    },
    {
        "tags": [
            "syntax-error",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2271,
                    "reputation": 28913,
                    "user_id": 3140,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/84dbc773c808111cc4ce138bff33f482?s=256&d=identicon&r=PG",
                    "display_name": "Jacob Krall",
                    "link": "https://stackoverflow.com/users/3140/jacob-krall"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1510883500,
                "post_id": 47342084,
                "comment_id": 81636332,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7369530,
                    "reputation": 345,
                    "user_id": 5610180,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/997a88b24cac41011e8582550f9a62b8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "spiderman",
                    "link": "https://stackoverflow.com/users/5610180/spiderman"
                },
                "reply_to_user": {
                    "account_id": 2271,
                    "reputation": 28913,
                    "user_id": 3140,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/84dbc773c808111cc4ce138bff33f482?s=256&d=identicon&r=PG",
                    "display_name": "Jacob Krall",
                    "link": "https://stackoverflow.com/users/3140/jacob-krall"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1510883671,
                "post_id": 47342084,
                "comment_id": 81636376,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1510883810,
                "last_edit_date": 1510883810,
                "creation_date": 1510883628,
                "answer_id": 47342113,
                "question_id": 47342084,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Object construction in `jq` uses syntax similar to JavaScript Object Notation (JSON).\r\n\r\n`{&quot;ParameterValue&quot; = &quot;jess-project&quot;}` is not valid in JSON. Did you mean `{&quot;ParameterValue&quot;: &quot;jess-project&quot;}`?",
                "title": "jq error syntax error, unexpected &#39;=&#39;, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1536808059,
                "creation_date": 1536808059,
                "answer_id": 52306090,
                "question_id": 47342084,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ran into this after reading [this here](http://engineering.monsanto.com/2015/05/22/jq-change-json/), and thought I add these notes, even if original post was so long ago. Hope it helps someone.\r\n\r\nAside from the incorrect use of `=` instead of `:` as pointed out above, I was also making the wrong assumption about the entire JSON object. So, make sure you&#39;re parsing that `test.json` correctly. For instance, if all ParameterKey/ParameterValues are in a list called `Parameters` and it looks something like this:\r\n\r\n    $ cat test.json\r\n    {\r\n      &quot;Parameters&quot;: [\r\n        {\r\n          &quot;ParameterKey&quot;: &quot;Project&quot;,\r\n          &quot;ParameterValue&quot;: &quot;jess-project&quot;\r\n        },\r\n        {\r\n          &quot;ParameterKey&quot;: &quot;NumberOfInstances&quot;,\r\n          &quot;ParameterValue&quot;: &quot;2&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nThen you have to take into account the `Parameters` list by doing:\r\n\r\n    $ jq &#39;.Parameters | map(if .ParameterKey == &quot;Project&quot; then . + {&quot;ParameterValue&quot;:&quot;my-project&quot;} else . end) | {&quot;Parameters&quot;:.}&#39; test.json\r\n    {\r\n      &quot;Parameters&quot;: [\r\n        {\r\n          &quot;ParameterKey&quot;: &quot;Project&quot;,\r\n          &quot;ParameterValue&quot;: &quot;my-project&quot;\r\n        },\r\n        {\r\n          &quot;ParameterKey&quot;: &quot;NumberOfInstances&quot;,\r\n          &quot;ParameterValue&quot;: &quot;2&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nNote that the list is added back at the end, by the last pipe.\r\n\r\nBy the way, here&#39;s another way to update a key&#39;s value:\r\n\r\n    $ jq &#39;.Parameters | map((select(.ParameterKey == &quot;Project&quot;) | .ParameterValue) |= &quot;my-project&quot;) | {&quot;Parameters&quot;:.}&#39; test.json\r\n    {\r\n      &quot;Parameters&quot;: [\r\n        {\r\n          &quot;ParameterKey&quot;: &quot;Project&quot;,\r\n          &quot;ParameterValue&quot;: &quot;my-project&quot;\r\n        },\r\n        {\r\n          &quot;ParameterKey&quot;: &quot;NumberOfInstances&quot;,\r\n          &quot;ParameterValue&quot;: &quot;2&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nAnd if you want to specify a shell variable, you can even do this:\r\n\r\n    PRJ=my-project\r\n    jq --arg prj &quot;$PRJ&quot; &#39;.Parameters | map((select(.ParameterKey == &quot;Project&quot;) | .ParameterValue) |= $prj) | {&quot;Parameters&quot;:.}&#39; test.json &gt; test-updated.json\r\n\r\nIn above example we&#39;re redirecting the modifications to new file `test-updated.json`, because invariably you&#39;ll most likely want to do that anyway since `jq` just doesn&#39;t have a replace-in-place option like `sed -i`.\r\n\r\n\r\n\r\n\r\n",
                "title": "jq error syntax error, unexpected &#39;=&#39;, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1536808059,
        "creation_date": 1510883376,
        "last_edit_date": 1510950869,
        "question_id": 47342084,
        "body_markdown": "    cat test.json | jq &#39;map(if ParameterKey == &quot;Project&quot;           then . + {&quot;ParameterValue&quot; = &quot;jess-project&quot;}             else .             end           )&#39;\r\n\r\n    jq: error: syntax error, unexpected &#39;=&#39;, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    map(if ParameterKey == &quot;Project&quot;           then . + {&quot;ParameterValue&quot; = &quot;jess-project&quot;}             else .             end           )                                                                      \r\n    jq: 1 compile error\r\n\r\n",
        "link": "https://stackoverflow.com/questions/47342084/jq-error-syntax-error-unexpected-expecting-unix-shell-quoting-issues",
        "title": "jq error syntax error, unexpected &#39;=&#39;, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1510924294,
                "last_edit_date": 1510924294,
                "creation_date": 1510923960,
                "answer_id": 47351362,
                "question_id": 47350099,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "To extract all `name`s, but only the *first name* in case the `name` is an array:\r\n\r\n    jq &#39;.[].name | if type==&quot;array&quot; then first else . end&#39; &lt;file\r\n\r\nFor your sample input, the [output](https://jqplay.org/s/S6jNSL0dN9) is:\r\n\r\n    &quot;aaa&quot;\r\n    &quot;bbb&quot;\r\n    &quot;fff&quot;",
                "title": "jq: how to select elements with different structure"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1511066342,
        "creation_date": 1510919695,
        "last_edit_date": 1511066342,
        "question_id": 47350099,
        "body_markdown": "I&#39;m sure this is very simple, but I do not know how to do it with jq.\r\n\r\nI have a JSON like [this one][1]\r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;109&quot;,\r\n        &quot;name&quot;: &quot;aaa&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;1098&quot;,\r\n        &quot;name&quot;: [\r\n          &quot;bbb&quot;,\r\n          &quot;ccc&quot;\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;2000&quot;,\r\n        &quot;name&quot;: [\r\n          &quot;fff&quot;,\r\n          &quot;ddd&quot;\r\n        ]\r\n      }\r\n    ]\r\n\r\n\r\nAnd I would like to extract the `.name`. When `name` is an array, I would like to take always the first element.\r\n\r\nDo I must create an `if` clause, or is there some more direct mode?\r\n\r\nAs output I would like to have `&quot;aaa&quot; &quot;bbb&quot; &quot;fff&quot;`, but I have `&quot;aaa&quot; &quot;bbb&quot; &quot;fff&quot; &quot;bbb&quot; &quot;fff&quot;`.\r\n\r\nHere is what I have so far:\r\n\r\n&lt;!-- language: lang-jq --&gt;\r\n\r\n    if .[].name|type == &quot;array&quot; then .[].name[0]?  else first(.[].name) end\r\n\r\nOutput:\r\n\r\n    &quot;aaa&quot;\r\n    &quot;bbb&quot;\r\n    &quot;fff&quot;\r\n    &quot;bbb&quot;\r\n    &quot;fff&quot;\r\n\r\nInteractive example https://jqplay.org/s/fOBuwdj6WS\r\n\r\n  [1]: https://jqplay.org/s/dck56xKk8C\r\n",
        "link": "https://stackoverflow.com/questions/47350099/jq-how-to-select-elements-with-different-structure",
        "title": "jq: how to select elements with different structure"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 73,
                "is_accepted": false,
                "score": 72,
                "last_activity_date": 1537436464,
                "last_edit_date": 1537436464,
                "creation_date": 1510938995,
                "answer_id": 47356030,
                "question_id": 47355901,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Simply change the comma to a pipe character and you’re done:\r\n\r\n    .two=&quot;newval&quot; | .three=&quot;newval&quot;\r\n\r\n&quot;,&quot; is for concatenating streams: `A,B` will emit A followed by B.",
                "title": "jq: Change multiple values"
            },
            {
                "up_vote_count": 16,
                "is_accepted": true,
                "score": 16,
                "last_activity_date": 1510946923,
                "creation_date": 1510946923,
                "answer_id": 47357956,
                "question_id": 47355901,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a method which uses [+ object addition](https://stedolan.github.io/jq/manual/#Addition:+) to update multiple members.\r\n\r\n    . + {two:&quot;newtwo&quot;, three:&quot;newthree&quot;}\r\n\r\nSample Run (assumes data in `data.json`)\r\n\r\n    $ jq -M &#39;. + {two:&quot;newtwo&quot;, three:&quot;newthree&quot;}&#39; data.json\r\n    {\r\n      &quot;one&quot;: {\r\n        &quot;val&quot;: 1\r\n      },\r\n      &quot;two&quot;: &quot;newtwo&quot;,\r\n      &quot;three&quot;: &quot;newthree&quot;,\r\n      &quot;four&quot;: &quot;val&quot;\r\n    }\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/X5MI2D4YrH)",
                "title": "jq: Change multiple values"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1674604258,
                "creation_date": 1674604258,
                "answer_id": 75228454,
                "question_id": 47355901,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This old question is popular on Google and I had a similar need that led to a more concise solution (which I&#39;m not sure if existed at the time of ask). In my case, I needed to assign the same value to multiple keys which fits the example OP gave but it bears warning that this won&#39;t work for assigning different values.\r\n#### Solving OP&#39;s problem\r\nKeep the comma operator and pass the combined stream to the assignment:\r\n```lang-shell\r\n$ jq &#39;(.two, .three) = &quot;newval&quot;&#39; data.json\r\n```\r\n```lang-json\r\n{\r\n  &quot;one&quot;: {\r\n    &quot;val&quot;: 1\r\n  },\r\n  &quot;two&quot;: &quot;newval&quot;,\r\n  &quot;three&quot;: &quot;newval&quot;,\r\n  &quot;four&quot;: &quot;val&quot;\r\n}\r\n```\r\njqPlay example: https://jqplay.org/s/Jx7m-pnl_OQ\r\n\r\n#### My extended problem\r\n----------\r\nI needed to mask sensitive (secret) values in Kubernetes manifests that looked like this:\r\n```lang-json\r\n{\r\n  &quot;apiVersion&quot;: &quot;v1&quot;,\r\n  &quot;kind&quot;: &quot;Secret&quot;,\r\n  &quot;metadata&quot;: {\r\n    &quot;name&quot;: &quot;test&quot;\r\n  },\r\n  &quot;data&quot;: {\r\n    &quot;foo&quot;: &quot;czAwcGVyczNrcml0Cg==&quot;\r\n  },\r\n  &quot;stringData&quot;: {\r\n    &quot;baz&quot;: &quot;s00pers3krit&quot;\r\n  }\r\n}\r\n```\r\nWith a few additional complicating factors:\r\n 1. The `foo` and `baz` sub-keys were arbitrary and unknown ahead of time\r\n 1. One or both of the `data` and `stringData` keys could be present\r\n 1. There may be multiple documents in the input stream and only `.kind == &quot;Secret&quot;` should be masked\r\n\r\n#### My solution\r\n----------\r\n```lang-shell\r\n$ helm template helm/ | yq &#39;( select(.kind == &quot;Secret&quot;)  | (.data[]?, .stringData[]?) ) = &quot;[Masked]&quot;&#39;\r\n```\r\n```lang-json\r\n{\r\n  &quot;apiVersion&quot;: &quot;v1&quot;,\r\n  &quot;kind&quot;: &quot;Secret&quot;,\r\n  &quot;metadata&quot;: {\r\n    &quot;name&quot;: &quot;secret1&quot;\r\n  },\r\n  &quot;type&quot;: &quot;kubernetes.io/dockerconfigjson&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;.dockerconfigjson&quot;: &quot;[Masked]&quot;\r\n  },\r\n  &quot;stringData&quot;: {\r\n    &quot;.dockerconfigjson&quot;: &quot;[Masked]&quot;\r\n  }\r\n}\r\n{\r\n  &quot;apiVersion&quot;: &quot;v1&quot;,\r\n  &quot;kind&quot;: &quot;Secret&quot;,\r\n  &quot;metadata&quot;: {\r\n    &quot;name&quot;: &quot;secret2&quot;\r\n  },\r\n  &quot;type&quot;: &quot;kubernetes.io/dockerconfigjson&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;baz&quot;: &quot;[Masked]&quot;\r\n  },\r\n  &quot;stringData&quot;: {\r\n    &quot;quux`&quot;: &quot;[Masked]&quot;\r\n  }\r\n}\r\n{\r\n  &quot;apiVersion&quot;: &quot;v1&quot;,\r\n  &quot;kind&quot;: &quot;ConfigMap&quot;,\r\n  &quot;metadata&quot;: {\r\n    &quot;name&quot;: &quot;configmap1&quot;\r\n  },\r\n  &quot;type&quot;: &quot;kubernetes.io/dockerconfigjson&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;foo&quot;: &quot;czAwcGVyczNrcml0Cg==&quot;,\r\n    &quot;snuffle&quot;: &quot;fuzzy&quot;\r\n  }\r\n}\r\n```\r\n\r\n 1. Use a subselect to assign the static value `[Masked]` to the selected keys:\r\n    ```\r\n    () = &quot;[Masked]&quot;\r\n    ```\r\n 1. Select only `.kind == &quot;Secret&quot;` for reassignment:\r\n    ```\r\n    ( select(.kind == &quot;Secret&quot;) ) = &quot;[Masked]&quot;\r\n    ```\r\n 1. Pipe the selected objects in a stream generator to produce multiple fields to be assigned:\r\n    ```\r\n    ( select(.kind == &quot;Secret&quot;) | (., .) ) = &quot;[Masked]&quot;\r\n    ```\r\n 1. But only the `data` and `stringData` of those objects:\r\n    ```\r\n    ( select(.kind == &quot;Secret&quot;) | (.data, .stringData) ) = &quot;[Masked]&quot;\r\n    ```\r\n 1. And really only the subkeys of those (keep `.data` but modify all its child key):\r\n    ```\r\n    ( select(.kind == &quot;Secret&quot;) | (.data[], .stringData[]) ) = &quot;[Masked]&quot;\r\n    ```\r\n 1. And finally only if those sub keys actually exist:\r\n    ```\r\n    ( select(.kind == &quot;Secret&quot;) | (.data[]?, .stringData[]?) ) = &quot;[Masked]&quot;\r\n    ```\r\njqPlay: https://jqplay.org/s/8SqKgeP1BzN",
                "title": "jq: Change multiple values"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 32,
        "last_activity_date": 1674604258,
        "creation_date": 1510938572,
        "last_edit_date": 1587966848,
        "question_id": 47355901,
        "body_markdown": "I&#39;m trying to change multiple json values with this line\r\n\r\n     jq &#39;.two=&quot;newval&quot;, .three=&quot;newval&quot;&#39; my.json \r\n\r\nwith this is the input\r\n\r\n    {\r\n      &quot;one&quot;: {\r\n        &quot;val&quot;: 1\r\n      },\r\n      &quot;two&quot;: &quot;val&quot;,\r\n      &quot;three&quot;: &quot;val&quot;,\r\n      &quot;four&quot;: &quot;val&quot;\r\n    }\r\n\r\nbut the output is 2 jsons:\r\n\r\n    {\r\n      &quot;one&quot;: {\r\n        &quot;val&quot;: 1\r\n      },\r\n      &quot;two&quot;: &quot;newval&quot;,\r\n      &quot;three&quot;: &quot;val&quot;,\r\n      &quot;four&quot;: &quot;val&quot;\r\n    }\r\n    {\r\n      &quot;one&quot;: {\r\n        &quot;val&quot;: 1\r\n      },\r\n      &quot;two&quot;: &quot;val&quot;,\r\n      &quot;three&quot;: &quot;newval&quot;,\r\n      &quot;four&quot;: &quot;val&quot;\r\n    }\r\n\r\nHow can I change multiple values and output in one item?",
        "link": "https://stackoverflow.com/questions/47355901/jq-change-multiple-values",
        "title": "jq: Change multiple values"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1511024467,
                "last_edit_date": 1511024467,
                "creation_date": 1511014369,
                "answer_id": 47367029,
                "question_id": 47366958,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Change the rather weird-looking `.””` to `[]`\r\n\r\nThis has been verified to work with jq 1.3, 1.4, 1.5 and the current &quot;master&quot; version, e.g.\r\n\r\n    jq1.3 &#39;.products[] | select(.productFamily==&quot;Compute Instance&quot;) | .sku&#39; sku.json\r\n    &quot;HYZTQKMNAKH6FG9C&quot;\r\n\r\n",
                "title": "Need to find product ID based on sku"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1511015333,
                "creation_date": 1511015333,
                "answer_id": 47367154,
                "question_id": 47366958,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "    jq --raw-output &#39;.products | map(select(.productFamily==&quot;Compute Instance&quot;)) | .[].sku&#39;\r\n\r\n\r\n",
                "title": "Need to find product ID based on sku"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1511024467,
        "creation_date": 1511013837,
        "last_edit_date": 1511014545,
        "question_id": 47366958,
        "body_markdown": "I&#39;ve the below json object in place-\r\n\r\n    {\r\n      &quot;formatVersion&quot;: &quot;v1.0&quot;,\r\n      &quot;publicationDate&quot;: &quot;2017-11-17T19:00:39Z&quot;,\r\n      &quot;products&quot;: {\r\n        &quot;HYZTQKMNAKH6FG9C&quot;: {\r\n          &quot;sku&quot;: &quot;HYZTQKMNAKH6FG9C&quot;,\r\n          &quot;productFamily&quot;: &quot;Compute Instance&quot;\r\n        },\r\n        &quot;2BEAK4F883TCCQMS&quot;: {\r\n          &quot;sku&quot;: &quot;2BEAK4F883TCCQMS&quot;,\r\n          &quot;productFamily&quot;: &quot;Compute2 Instance&quot;\r\n        },\r\n        &quot;7QJJXQX9QWC5GEPD&quot;: {\r\n          &quot;sku&quot;: &quot;7QJJXQX9QWC5GEPD&quot;,\r\n          &quot;productFamily&quot;: &quot;Compute3 Instance&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nWith the help of jq, i&#39;d need to find out all the sku based on a particular keyword search like `.productFamily == &quot;Compute Instance&quot;`.\r\n\r\nI&#39;ve the below jq filter, but its not getting me any output-\r\n\r\n    jq --raw-output &#39;.products.&quot;&quot;| select(.productFamily==&quot;Compute Instance&quot;) | .sku&#39;\r\n\r\nCan anybody help me on this? Thanks in advance.",
        "link": "https://stackoverflow.com/questions/47366958/need-to-find-product-id-based-on-sku",
        "title": "Need to find product ID based on sku"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1511091326,
                "post_id": 47371280,
                "comment_id": 81704867,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 28,
                "is_accepted": true,
                "score": 28,
                "last_activity_date": 1511044702,
                "last_edit_date": 1511044702,
                "creation_date": 1511044253,
                "answer_id": 47371754,
                "question_id": 47371280,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your problem is when `type == &quot;array&quot;` is true `.` will be an array so `.userGroupAccesses` won&#39;t work.  What you want to do is focus on the case when `.` is an object.  In your call to `walk` you only need to check for `type == &quot;object&quot;` and then remove the members you don&#39;t want.  e.g.\r\n\r\n    walk(if type == &quot;object&quot; then del(.publicAccess, .userGroupAccesses) else . end)\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/qpx5knqiPt)\r\n\r\nYou can also solve this without `walk` by using [Recursive Descent `..`](https://stedolan.github.io/jq/manual/#RecursiveDescent:..)  e.g.\r\n\r\n    del(.. | .publicAccess?, .userGroupAccesses?)\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/5BJsU3pyPM)\r\n",
                "title": "Delete objects and arrays with jq which match a key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 17,
        "last_activity_date": 1537521245,
        "creation_date": 1511040641,
        "last_edit_date": 1537521245,
        "question_id": 47371280,
        "body_markdown": "I have a JSON with the following content:\r\n\r\n    {\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Test&quot;,\r\n          &quot;program&quot;: {\r\n            &quot;publicAccess&quot;: &quot;--------&quot;,\r\n            &quot;externalAccess&quot;: false,\r\n            &quot;userGroupAccesses&quot;: [\r\n              {\r\n                &quot;access&quot;: &quot;r-------&quot;\r\n              },\r\n              {\r\n                &quot;access&quot;: &quot;rw------&quot;\r\n              }\r\n            ],\r\n            &quot;id&quot;: &quot;MmBqeMLIC2r&quot;\r\n          },\r\n          &quot;publicAccess&quot;: &quot;rw------&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nAnd I want to delete all keys (recursively) which match `publicAccess` or `userGroupAccesses`, so that my JSON looks like this:\r\n\r\n    {\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Test&quot;,\r\n          &quot;program&quot;: {\r\n            &quot;externalAccess&quot;: false,\r\n            &quot;id&quot;: &quot;MmBqeMLIC2r&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nI&#39;ve copied `jq`&#39;s builtin `walk` function from [source][1].\r\n\r\n    # Apply f to composite entities recursively, and to atoms\r\n    def walk(f):\r\n      . as $in\r\n      | if type == &quot;object&quot; then\r\n          reduce keys[] as $key\r\n            ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\r\n      elif type == &quot;array&quot; then map( walk(f) ) | f\r\n      else f\r\n      end;\r\n    \r\n    # My Code\r\n    walk(if (type == &quot;object&quot; and .publicAccess)\r\n            then del(.publicAccess)\r\n         elif (type == &quot;array&quot; and .userGroupAccesses)\r\n            then del(.userGroupAccesses)\r\n         else\r\n           .\r\n    end )\r\n\r\nGives me `jq: error (at &lt;stdin&gt;:2622): Cannot index array with string &quot;userGroupAccesses&quot;`. Also if I use `.userGroupAccesses[]` - How do I get the result?\r\n\r\nSnippet on jqplay: https://jqplay.org/s/1m7wAeHMTu\r\n\r\n  [1]: https://github.com/stedolan/jq/blob/master/src/builtin.jq#L284",
        "link": "https://stackoverflow.com/questions/47371280/delete-objects-and-arrays-with-jq-which-match-a-key",
        "title": "Delete objects and arrays with jq which match a key"
    },
    {
        "tags": [
            "json",
            "variables",
            "jq",
            "string-literals",
            "string-interpolation"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1511079934,
                "creation_date": 1511079934,
                "answer_id": 47374963,
                "question_id": 47374719,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "shell variables in *jq* scripts should be interpolated or passed as arguments via `--arg name value`:\r\n\r\n    jq --arg inp1 &quot;$input1&quot; --arg inp2 &quot;$input2&quot; \\\r\n    &#39;map(if .ParameterKey == &quot;Project&quot; \r\n        then . + {&quot;ParameterValue&quot; : ($inp1 + &quot;/solution/&quot; + $inp2 + &quot;.result&quot;) } \r\n    else . end)&#39; test.json\r\n\r\nThe output:\r\n\r\n    [\r\n      {\r\n        &quot;ParameterKey&quot;: &quot;Project&quot;,\r\n        &quot;ParameterValue&quot;: &quot;test1/solution/test2.result&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "jq not replacing json value with parameter"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1511080585,
                "creation_date": 1511080585,
                "answer_id": 47375032,
                "question_id": 47374719,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "In your jq program, you have quoted &quot;$input1/solution/$input2.result&quot;, and therefore it is a JSON string literal, whereas you evidently want string interpolation; you also need to distinguish between the shell variables ($input1 and $input2) on the one hand, and the corresponding jq dollar-variables (which may or may not have the same name) on the other.\r\n\r\nSince your shell variables are strings, you could pass them in using the `--arg` command-line option (e.g. `--arg input1 &quot;$input1&quot;` if you chose to name the variables in the same way).\r\n\r\nYou can read up on string interpolation in the jq manual (see https://stedolan.github.io/jq/manual, but note the links at the top for different versions of jq).  \r\n\r\nThere are other ways to achieve the desired results too, but using string interpolation with same-named variables, you&#39;d write: \r\n\r\n    &quot;\\($input1)/solution/\\($input2).result&quot; \r\n\r\nNotice that the above string is NOT itself literally a JSON string. Only after string interpolation does it become so.\r\n\r\n",
                "title": "jq not replacing json value with parameter"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1511080768,
        "creation_date": 1511077618,
        "last_edit_date": 1511080768,
        "question_id": 47374719,
        "body_markdown": "test.sh is not replacing test.json parameter values ($input1 and $input2). result.json has same ParameterValue &quot;$input1/solution/$input2.result&quot;\r\n\r\n     [\r\n        {\r\n          &quot;ParameterKey&quot;: &quot;Project&quot;,\r\n          &quot;ParameterValue&quot;: [ &quot;$input1/solution/$input2.result&quot; ]\r\n         }\r\n        ]\r\n\r\ntest.sh\r\n-------\r\n\r\n    #!/bin/bash\r\n    input1=&quot;test1&quot;\r\n    input2=&quot;test2&quot;\r\n    echo $input1\r\n    echo $input2\r\n    cat test.json | jq &#39;map(if .ParameterKey == &quot;Project&quot;           then . + {&quot;ParameterValue&quot; : &quot;$input1/solution/$input2.result&quot; }             else .             end           )&#39; &gt; result.json\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/47374719/jq-not-replacing-json-value-with-parameter",
        "title": "jq not replacing json value with parameter"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1511131612,
                "post_id": 47382724,
                "comment_id": 81718367,
                "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": 1511131679,
                "post_id": 47382724,
                "comment_id": 81718389,
                "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": 1511131716,
                "post_id": 47382724,
                "comment_id": 81718404,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 6296997,
                    "reputation": 129,
                    "user_id": 4892880,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/38e9302fefc31817159c0c0bff3e3995?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "catchkarthik",
                    "link": "https://stackoverflow.com/users/4892880/catchkarthik"
                },
                "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": 1511131946,
                "post_id": 47382724,
                "comment_id": 81718472,
                "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": 1511132015,
                "post_id": 47382724,
                "comment_id": 81718493,
                "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": 1511132035,
                "post_id": 47382724,
                "comment_id": 81718500,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1511131809,
                "creation_date": 1511131809,
                "answer_id": 47382866,
                "question_id": 47382724,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your `jq` script correctly works (giving output of `{&quot;numbers&quot;: &quot;2&quot;}`), if written as follows:\r\n\r\n    {\r\n       numbers: (.numbers | if type==&quot;array&quot; then .[2] else . end)\r\n    }\r\n\r\n",
                "title": "jq: using type in the format file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1511136072,
                "last_edit_date": 1511136072,
                "creation_date": 1511132100,
                "answer_id": 47382897,
                "question_id": 47382724,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "&gt; If it is an array, I would like to get the 2nd element in the array and if it is not, just return the element available.\r\n\r\n1. If by &quot;2nd element&quot; you mean the second element, you would use 1 as the array index, since jq has a 0 as its &quot;index origin&quot;.  \r\n\r\n2. Both of your two examples (Format_1 and Format_2) have arrays as the value of `.numbers`, but if your requirement is as stated, with the interpretation of &quot;2nd&quot; as &quot;second&quot;, a suitable jq filter would seem to be:\r\n\r\n    .numbers | if type == &quot;array&quot; then .[1] else . end\r\n\r\nYour program is so short that you could simply run it as follows:\r\n\r\n    jq -c &#39;.numbers | if type == &quot;array&quot; then .[1] else . end&#39; Format_{1,2}\r\n\r\n\r\n3.  If you want to place your jq program in a file, then it is good practice to use a filetype of &quot;jq&quot; (i.e. name the file so that it ends with &quot;.jq&quot;). Using `Format_file.jq` as the file name, you could use the following invocation:\r\n\r\n    jq -f Format_file.jq -c Format_1 Format_2\r\n\r\nNote the avoidance of `cat`.\r\n\r\n4. In none of your examples is it necessary or wise to use a pipeline with more than one invocation of jq.\r\n   \r\nIf you want the output to look like the input but with the value of the &quot;numbers&quot; key to be altered as per the above, you could simply replace &#39;=` by `|=`: \r\n\r\n     .numbers |= if type == &quot;array&quot; then .[1] else . end",
                "title": "jq: using type in the format file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1511136072,
        "creation_date": 1511130764,
        "question_id": 47382724,
        "body_markdown": "I got multiple json files with different format.\r\n\r\n    **Format_1**:\r\n    \r\n    {\r\n      &quot;numbers&quot;:[\r\n       &quot;0&quot;,\r\n       &quot;1&quot;,\r\n       &quot;2&quot;\r\n      ]\r\n    }\r\n\r\n    **Format_2**:\r\n    \r\n    {\r\n      &quot;numbers&quot;:[\r\n       &quot;0&quot;\r\n      ]\r\n    }\r\n\r\nIf it is an array, I would like to get the 2nd element in the array and if it is not, just return the element available. \r\n\r\n    cat Format_1 | jq &#39;.numbers&#39; | jq &#39;if type==&quot;array&quot; then &#39;.[2]&#39; else &#39;.&#39; end&#39;\r\n\r\nThe above command works fine and give me the **output** 1\r\n\r\n    cat Format_2 | jq &#39;.numbers&#39; | jq &#39;if type==&quot;array&quot; then &#39;.[2]&#39; else &#39;.&#39; end&#39;\r\n\r\nThe above command give me the **output 0**.\r\n\r\nWhen I try to put the above in a format file and pass it to jq, i get syntax error\r\n\r\n    **Format_File**:\r\n    \r\n    {\r\n       numbers : .numbers | &#39;if type==&quot;array&quot; then &#39;.[2]&#39; else &#39;.&#39; end&#39;\r\n    }\r\n\r\n**command**:\r\n\r\n    cat Format_1 | jq -f Format_file -c\r\n\r\n***jq: error: syntax error, unexpected end (Unix shell quoting issues?) at &lt;top-level&gt;, line 11:\r\n        numbers  : .numbers | &#39;if type==&quot;array&quot; then &#39;.[2]&#39; else &#39;.&#39; end&#39;,***\r\n\r\nCan someone help me with the syntax of the format file with IF Statement please? \r\n\r\n           \r\n\r\n \r\n\r\n \r\n",
        "link": "https://stackoverflow.com/questions/47382724/jq-using-type-in-the-format-file",
        "title": "jq: using type in the format file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1511197455,
                "last_edit_date": 1511197455,
                "creation_date": 1511146144,
                "answer_id": 47384397,
                "question_id": 47384026,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Although the precise error isn&#39;t given, running the command generates\r\n\r\n    jq: error: Could not open file map(if .ParameterValue == &quot;&lt;ans2&gt;&quot; \r\n    then . + {&quot;ParameterValue&quot;: &quot;input2&quot;} else . end): No such file or directory\r\n\r\nThe `No such file or directory` message indicates jq is trying to open a file \r\nnamed &quot;**`map(if .ParameterValue == &quot;&lt;ans2&gt;&quot; then . + {&quot;ParameterValue&quot;: &quot;input2&quot;} else . end)`**&quot; which is happening because that string appears where jq expects the name of an input file.  \r\n\r\nTo correct this you can combine the two filter strings into one string with `|` and pass `test.json` as the input file, e.g.\r\n\r\n    jq &#39;\r\n       map(if .ParameterKey == &quot;&lt;ans1&gt;&quot; then . + {&quot;ParameterKey&quot;: &quot;input1&quot;} else . end)\r\n     | map(if .ParameterValue == &quot;&lt;ans2&gt;&quot; then . + {&quot;ParameterValue&quot;: &quot;input2&quot;} else . end)\r\n    &#39; test.json &gt; result.json\r\n\r\nor keep your basic structure and add a second explicit jq invocation e.g.\r\n\r\n    cat test.json | \\\r\n    jq &#39;map(if .ParameterKey == &quot;&lt;ans1&gt;&quot; then . + {&quot;ParameterKey&quot;: &quot;input1&quot;} else . end)&#39; | \\\r\n    jq &#39;map(if .ParameterValue == &quot;&lt;ans2&gt;&quot; then . + {&quot;ParameterValue&quot;: &quot;input2&quot;} else . end)&#39; \\\r\n    &gt; result.json\r\n\r\nIn this particular case either will work but the first way is more efficient.  [Peak&#39;s suggestion](https://stackoverflow.com/a/47385320/8379597) which uses only a single `map()` is better still.\r\n\r\n",
                "title": "jq compilation error for two maps - not replacing json value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1511153922,
                "creation_date": 1511153922,
                "answer_id": 47385320,
                "question_id": 47384026,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here are two solutions - one that is both simple and brief, and one that scales well. Notice that in both cases, `map` is only needed once.\r\n\r\n\r\n### Simple and brief\r\n    map( if .ParameterKey   == &quot;&lt;ans1&gt;&quot; then . + {&quot;ParameterKey&quot;:   &quot;input1&quot;} else . end\r\n       | if .ParameterValue == &quot;&lt;ans2&gt;&quot; then . + {&quot;ParameterValue&quot;: &quot;input2&quot;} else . end)\r\n\r\n### With a helper function\r\n    def maybe_update($key; $old; $new):\r\n      if .[$key] == $old then .[$key] = $new else . end;\r\n   \r\n    map( maybe_update(&quot;ParameterKey&quot;;   &quot;&lt;ans1&gt;&quot;; &quot;input1&quot;)\r\n       | maybe_update(&quot;ParameterValue&quot;; &quot;&lt;ans2&gt;&quot;; &quot;input2&quot;) )\r\n\r\n\r\n ",
                "title": "jq compilation error for two maps - not replacing json value"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1511197743,
        "creation_date": 1511142612,
        "last_edit_date": 1511197743,
        "question_id": 47384026,
        "body_markdown": "I am observing an error with the following data when using two jq maps within a shell script.\r\n\r\n## test.json\r\n\r\n    [\r\n      {\r\n         &quot;ParameterKey&quot;: &quot;&lt;ans1&gt;&quot;,\r\n         &quot;ParameterValue&quot;: &quot;&lt;ans2&gt;&quot;\r\n      }\r\n    ]\r\n\r\nMy script is\r\n\r\n    cat test.json | \\\r\n    jq &#39;map(if .ParameterKey == &quot;&lt;ans1&gt;&quot; then . + {&quot;ParameterKey&quot; : &quot;input1&quot; } else . end )&#39; \\\r\n       &#39;map(if .ParameterValue == &quot;&lt;ans2&gt;&quot; then . + {&quot;ParameterValue&quot; : &quot;input2&quot; } else . end)&#39; \\ \r\n    &gt; result.json",
        "link": "https://stackoverflow.com/questions/47384026/jq-compilation-error-for-two-maps-not-replacing-json-value",
        "title": "jq compilation error for two maps - not replacing json value"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1511197855,
                "last_edit_date": 1511197855,
                "creation_date": 1511196295,
                "answer_id": 47396980,
                "question_id": 47396243,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The reason you&#39;re seeing that message is that the [`map()`](https://stedolan.github.io/jq/manual/#map\\(x\\),map_values\\(x\\)) expression is enumerating the values of your object (&quot;`Project`&quot; and &quot;`&lt;check&gt;`&quot;) invoking the `if .ParameterKey ...` expression on each of them. Unfortunately those are strings and the `.ParameterKey` part of your `if` condition won&#39;t work with string values so jq gives you the error `Cannot index string with string “ParameterKey”`.\r\n\r\nYou probably only want the `map()` if your `test.json` contains an array of objects. If your `test.json` contains an object at the top level such as `{&quot;ParameterKey&quot;: &quot;Project&quot;, &quot;ParameterValue&quot;: &quot;&lt;check&gt;&quot;}` then you should remove the `map()`.  e.g.\r\n\r\n    $ cat test.json | \\\r\n      jq &#39;if .ParameterKey == &quot;Project&quot; then . + {&quot;ParameterValue&quot; : &quot;val&quot; }  else . end&#39;\r\n    {\r\n      &quot;ParameterKey&quot;: &quot;Project&quot;,\r\n      &quot;ParameterValue&quot;: &quot;val&quot;\r\n    }\r\n",
                "title": "jq: error (at &lt;stdin&gt;:4): Cannot index string with string &quot;ParameterKey&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1511197855,
        "creation_date": 1511194036,
        "question_id": 47396243,
        "body_markdown": "test.sh is not replacing test.json parameter value &lt;check&gt; and gives jq compilation error.\r\n\r\ntest.json\r\n---------\r\n\r\n    {\r\n      &quot;ParameterKey&quot;: &quot;Project&quot;,\r\n      &quot;ParameterValue&quot;: &quot;&lt;check&gt;&quot;\r\n     }\r\n\r\n\r\ntest.sh\r\n-------\r\n\r\n    cat test.json | jq \\\r\n    &#39;map(if .ParameterKey == &quot;Project&quot; \r\n        then . + {&quot;ParameterValue&quot; : &quot;val&quot; } \r\n    else . end)&#39; &gt; result.json\r\n\r\n",
        "link": "https://stackoverflow.com/questions/47396243/jq-error-at-stdin4-cannot-index-string-with-string-parameterkey",
        "title": "jq: error (at &lt;stdin&gt;:4): Cannot index string with string &quot;ParameterKey&quot;"
    },
    {
        "tags": [
            "jq",
            "jqtransform"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1511282702,
                "creation_date": 1511282702,
                "answer_id": 47418336,
                "question_id": 47397088,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I believe this is because jq can only represent legal JSON data and the number you&#39;ve given is outside the range that can be represented without loss of precision.  See also\r\n\r\n* [What is JavaScript&#39;s highest integer value that a number can go to without losing precision?](https://stackoverflow.com/questions/307179/what-is-javascripts-highest-integer-value-that-a-number-can-go-to-without-losin#307200)\r\n\r\nIf you need to work with larger numbers as strings in jq you may want to try this library:\r\n\r\n* [jq-bigint](https://github.com/joelpurra/jq-bigint)&lt;br/&gt;A big integer library for working with possibly-signed arbitrarily long decimal strings. Written by Peter Koppstein (@pkoppstein) and released under the MIT license.",
                "title": "is JQ Transform modifying numbers? How can I get past it?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1511282702,
        "creation_date": 1511196652,
        "last_edit_date": 1511280427,
        "question_id": 47397088,
        "body_markdown": "Why this (&quot;Filter&quot; in jqplay.org):\r\n{&quot;key&quot;:633447818234478180}\r\n\r\nreturns this (&quot;Result&quot; in jqplay.org):\r\n{&quot;key&quot;: 633447818234478200}\r\n\r\nOriginal JSON doesn&#39;t matter.\r\n\r\nWhy is it changing 180 into 200? How can I overcome this? Is this a bug? A number too big?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/47397088/is-jq-transform-modifying-numbers-how-can-i-get-past-it",
        "title": "is JQ Transform modifying numbers? How can I get past it?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1511271548,
                "creation_date": 1511271548,
                "answer_id": 47414530,
                "question_id": 47412818,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Assuming you have the same condition on the unit columns [as in your earlier question](https://stackoverflow.com/questions/47094953/converting-json-with-arrays-to-csv-using-jq), the following filter should produce the desired output:\r\n\r\n      [&quot;\\(1+range(5))&quot;] as $units\r\n    | [&quot;date&quot;, &quot;value1&quot;, &quot;value2&quot;, &quot;group&quot;, &quot;unit\\($units[])&quot;]\r\n    , (\r\n          inputs\r\n        | .Date.Value as $date\r\n        | .Groups[]?\r\n        | .Id as $group\r\n        | .RequiredObject // {}\r\n        | keys[] as $k\r\n        | .[$k]\r\n        | .Value1 as $value1\r\n        | .Value2 as $value2\r\n        | [ $date, $value1, $value2, $group, (.Units[$units[]|[.]] | if .!=[] then &quot;1&quot; else &quot;0&quot; end) ]\r\n      )\r\n    | join(&quot;|&quot;)\r\n\r\nSample Run (assumes filter in `filter.jq` and data in `data.json`)\r\n\r\n    $ jq -Mnr -f filter.jq data.json\r\n    date|value1|value2|group|unit1|unit2|unit3|unit4|unit5\r\n    2017-11-17T00:00:00|2|3|11|1|0|0|0|1\r\n    2017-11-17T00:00:00|1|9|12|0|1|0|0|0\r\n\r\n[Try it online!](https://tio.run/##lVLBbptAEL37K6ajHEAFwm4URXVVVZEaWTk0luykF8KBhnW8NlkcWFpZNr8eOrsEe6PmkhVCMzvvvXnMsHrucrEAqTaNrscjgB3@yLTA8Q5/ZUVDAfKYXYSMheziNo7H9sE2wNulrKeKAIusqEUbjD7O1FUjApxUZbOpDY/F5n2dE5XCAOflk7hTSjyIus6q7fT3SjzonkYyjB3RjNAz8dzISuQDbIfzK/Ek1aTYzi5v8unPuZ7Jm8nBIDMOiWcTTskZJXdKavKSoFE8x7RtTSd@7MTf7XSppnp5VZ1x9kaeufJfXHlupdv2awf2JHjvsc9Vph6Fd@77mEJWw0lj4CNT3xMiN@MNAP/08kPETfRohmgCQ7n3emaSkpClB@CN4HD6bR8u9hCZzUXWqe1rOrnlfkVJ@t29vM4t1nZ2799OB05PYdc69bXYkpKlrl1acrJO3bwfosX1H/xfkR@L3Ckmvf9g4A0BD17N0jAiu4hkGNM@idKUqHIB0adv5E4vhQJaHwj6twFjClTuw2DQf93JqpTKwz36XfdSbrQsVd2FoWqKIrQzpqTK/oZloyn5Bw &quot;jq – Try It Online&quot;)",
                "title": "Converting yet another JSON to CSV with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1511271548,
        "creation_date": 1511266203,
        "last_edit_date": 1511269930,
        "question_id": 47412818,
        "body_markdown": "I&#39;m trying to convert a JSON with nested objects and arrays to a CSV file. The structure is:\r\n\r\n    {\r\n      &quot;Date&quot;: {\r\n        &quot;Value&quot;: &quot;2017-11-17T00:00:00&quot;\r\n      },\r\n      &quot;ThisOne&quot;: false\r\n    }\r\n    {\r\n      &quot;Date&quot;: {\r\n        &quot;Value&quot;: &quot;2017-11-17T00:00:00&quot;\r\n      },\r\n      &quot;ThisOne&quot;: true,\r\n      &quot;Groups&quot;: {\r\n        &quot;10&quot;: {\r\n          &quot;Id&quot;: &quot;10&quot;,\r\n          &quot;SomeUnnecessaryObject&quot;: true\r\n        },\r\n        &quot;11&quot;: {\r\n          &quot;Id&quot;: &quot;11&quot;,\r\n          &quot;RequiredObject&quot;: {\r\n            &quot;SEeminGlyRANdOMStRiNG&quot;: {\r\n              &quot;Value1&quot;: &quot;2&quot;,\r\n              &quot;Value2&quot;: &quot;3&quot;,\r\n              &quot;Units&quot;: [\r\n                &quot;1&quot;,\r\n                &quot;5&quot;\r\n              ]\r\n            }\r\n          }\r\n        },\r\n        &quot;12&quot;: {\r\n          &quot;Id&quot;: &quot;12&quot;,\r\n          &quot;RequiredObject&quot;: {\r\n            &quot;AnOthEr321&quot;: {\r\n              &quot;Value1&quot;: &quot;1&quot;,\r\n              &quot;Value2&quot;: &quot;9&quot;,\r\n              &quot;Units&quot;: [\r\n                &quot;2&quot;\r\n              ]\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n(hope I got the parentheses right) and I&#39;m trying to convert it to csv:\r\n\r\n    date|value1|value2|group|unit1|unit2|unit3|unit4|unit5\r\n    2017-11-17T00:00:00|2|3|11|1|0|0|0|1\r\n    2017-11-17T00:00:00|1|9|12|0|1|0|0|0\r\n\r\nThe groups run from 10 to 99 and units from 1 to 5. The `SEeminGlyRANdOMStRiNG` is a seemingly random string. The objects I want have `RequiredObject` but there are top level objects that don&#39;t have it. I&#39;ve been pruning objects with `select(.ThisOne==true)` because I don&#39;t understand how to reference from `.Group ... RequiredObject ... Value1` with changing values in the path. There might be top-level object that have `ThisOne==true` but lack the `RequiredObject`s.\r\n",
        "link": "https://stackoverflow.com/questions/47412818/converting-yet-another-json-to-csv-with-jq",
        "title": "Converting yet another JSON to CSV with jq"
    },
    {
        "tags": [
            "python",
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2686715,
                    "reputation": 8666,
                    "user_id": 2320961,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AdwXN.png?s=256",
                    "display_name": "Nic3500",
                    "link": "https://stackoverflow.com/users/2320961/nic3500"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1511267995,
                "post_id": 47413270,
                "comment_id": 81779957,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7538821,
                    "reputation": 449,
                    "user_id": 5724244,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://lh6.googleusercontent.com/-bJua7QXi05c/AAAAAAAAAAI/AAAAAAAAAII/YS5zcgD_xQk/s256-rj/photo.jpg",
                    "display_name": "frp farhan",
                    "link": "https://stackoverflow.com/users/5724244/frp-farhan"
                },
                "reply_to_user": {
                    "account_id": 2686715,
                    "reputation": 8666,
                    "user_id": 2320961,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AdwXN.png?s=256",
                    "display_name": "Nic3500",
                    "link": "https://stackoverflow.com/users/2320961/nic3500"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1511268053,
                "post_id": 47413270,
                "comment_id": 81779990,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2686715,
                    "reputation": 8666,
                    "user_id": 2320961,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AdwXN.png?s=256",
                    "display_name": "Nic3500",
                    "link": "https://stackoverflow.com/users/2320961/nic3500"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1511268113,
                "post_id": 47413270,
                "comment_id": 81780029,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7538821,
                    "reputation": 449,
                    "user_id": 5724244,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://lh6.googleusercontent.com/-bJua7QXi05c/AAAAAAAAAAI/AAAAAAAAAII/YS5zcgD_xQk/s256-rj/photo.jpg",
                    "display_name": "frp farhan",
                    "link": "https://stackoverflow.com/users/5724244/frp-farhan"
                },
                "reply_to_user": {
                    "account_id": 2686715,
                    "reputation": 8666,
                    "user_id": 2320961,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AdwXN.png?s=256",
                    "display_name": "Nic3500",
                    "link": "https://stackoverflow.com/users/2320961/nic3500"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1511268170,
                "post_id": 47413270,
                "comment_id": 81780060,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2686715,
                    "reputation": 8666,
                    "user_id": 2320961,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AdwXN.png?s=256",
                    "display_name": "Nic3500",
                    "link": "https://stackoverflow.com/users/2320961/nic3500"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1511268254,
                "post_id": 47413270,
                "comment_id": 81780107,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7538821,
                    "reputation": 449,
                    "user_id": 5724244,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://lh6.googleusercontent.com/-bJua7QXi05c/AAAAAAAAAAI/AAAAAAAAAII/YS5zcgD_xQk/s256-rj/photo.jpg",
                    "display_name": "frp farhan",
                    "link": "https://stackoverflow.com/users/5724244/frp-farhan"
                },
                "reply_to_user": {
                    "account_id": 2686715,
                    "reputation": 8666,
                    "user_id": 2320961,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AdwXN.png?s=256",
                    "display_name": "Nic3500",
                    "link": "https://stackoverflow.com/users/2320961/nic3500"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1511268306,
                "post_id": 47413270,
                "comment_id": 81780154,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 2686715,
                    "reputation": 8666,
                    "user_id": 2320961,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AdwXN.png?s=256",
                    "display_name": "Nic3500",
                    "link": "https://stackoverflow.com/users/2320961/nic3500"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1511268348,
                "post_id": 47413270,
                "comment_id": 81780186,
                "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": 1511268697,
                "post_id": 47413270,
                "comment_id": 81780409,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 7538821,
                    "reputation": 449,
                    "user_id": 5724244,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://lh6.googleusercontent.com/-bJua7QXi05c/AAAAAAAAAAI/AAAAAAAAAII/YS5zcgD_xQk/s256-rj/photo.jpg",
                    "display_name": "frp farhan",
                    "link": "https://stackoverflow.com/users/5724244/frp-farhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1511268916,
                "post_id": 47413270,
                "comment_id": 81780536,
                "content_license": "CC BY-SA 3.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1511302800,
                "last_edit_date": 1511302800,
                "creation_date": 1511269252,
                "answer_id": 47413770,
                "question_id": 47413270,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If the first file is array.json and the second object.json, then ignoring the various ssh/rsync/sponge options, the basic jq invocation would be along the lines:\r\n\r\n    jq —-argfile object object.json ‘. + [$object]’ array.json\r\n\r\n\r\nThere are several quite reasonable alternatives, depending on your version of jq. \r\n\r\nLet&#39;s suppose that the object to be added is not conveniently available as a FILE or STDIN; presumably it can at least be made available as a shell variable.  In that case you could tweak the above incantation along the following lines:\r\n\r\n    jq —-argjson object &quot;$object&quot; ‘. + [$object]’ array.json\r\n\r\nPlease consult the [jq manual][1] for further variations.\r\n    \r\nAs for the remote/local stuff, assuming jq is available locally, maybe you&#39;d be best off using rsync to fetch the remote file to local, perform the update, and then rsync back to remote.  There are countless variations, but I&#39;d put everything in a script so that you can easily add refinements to deal with unexpected situations, etc.\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/",
                "title": "how to add an element in json file which is located on remote machine"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1511270408,
                "last_edit_date": 1511270408,
                "creation_date": 1511270059,
                "answer_id": 47414016,
                "question_id": 47413270,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you can figure out how to edit a file programmatically, doing it over SSH is not any more complicated, just two steps instead of one.\r\n\r\n    import json\r\n\r\n    newdata = {\r\n        &quot;kind&quot;: &quot;PilotService&quot;,\r\n        &quot;apiVersion&quot;: &quot;rbac.newDevops.com/v1&quot;,\r\n        &quot;type&quot;: &quot;attribute-based&quot;,\r\n        &quot;metadata&quot;: {\r\n                &quot;name&quot;: &quot;apache&quot;,\r\n                &quot;description&quot;: &quot;apache service as a process&quot;\r\n            },\r\n        &quot;spec&quot;: {\r\n                &quot;addresses&quot;: [\r\n                    &quot;172.22.0.7/24:80&quot;\r\n                ]\r\n        }\r\n\r\n    with open(&#39;services.json&#39;) as jdata:\r\n        data = json.load(jdata)\r\n    data.append(newdata)\r\n    with open(&#39;services.json&#39;, &#39;w&#39;) as writable:\r\n        writable.write(json.dump(data))\r\n\r\nIf you can save this script on the remote host, all you need is\r\n\r\n    ssh remote python script.py\r\n\r\nbut you might want to look into using Fabric or Paramiko to encapsulate the entire process.\r\n\r\nIf the file is big, you might want to avoid the open file for reading, read into memory, close, open for writing, write pattern, but that&#39;s usually the most straightforward way to do it. (You can open for reading and writing, and rewind when you are done reading, but that doesn&#39;t really help against race conditions if you might have several processes writing to the same file.)",
                "title": "how to add an element in json file which is located on remote machine"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1511271168,
                "creation_date": 1511271168,
                "answer_id": 47414390,
                "question_id": 47413270,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Using bash and process substitution (`&lt;(command)`):\r\n\r\n    $ jq -s &#39;.&#39; &lt;(jq &#39;.[]&#39; file1) file2\r\n    [\r\n      {\r\n        &quot;kind&quot;: &quot;SpecialService&quot;,\r\n        &quot;type&quot;: &quot;attribute&quot;,\r\n        &quot;spec&quot;: {\r\n          &quot;addresses&quot;: [\r\n            &quot;172.21.3.196:6379&quot;\r\n          ]\r\n        },\r\n        &quot;apiVersion&quot;: &quot;rbac.newDevops.com/v1&quot;,\r\n        &quot;metadata&quot;: {\r\n          &quot;name&quot;: &quot;redis&quot;,\r\n          &quot;description&quot;: &quot;autogenerated by superagent.py script&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;kind&quot;: &quot;PilotService&quot;,\r\n        &quot;apiVersion&quot;: &quot;rbac.newDevops.com/v1&quot;,\r\n        &quot;type&quot;: &quot;attribute-based&quot;,\r\n        &quot;metadata&quot;: {\r\n          &quot;name&quot;: &quot;apache&quot;,\r\n          &quot;description&quot;: &quot;apache service as a process&quot;\r\n        },\r\n        &quot;spec&quot;: {\r\n          &quot;addresses&quot;: [\r\n            &quot;172.22.0.7/24:80&quot;\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n\r\nYou could use this as the substitution for `file1`: `&lt;(ssh user@remote jq &#39;.[]&#39; file1)` you just need to setup ssh keys to omit password querying. There are plenty of guides on doing that.",
                "title": "how to add an element in json file which is located on remote machine"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1511367543,
                "last_edit_date": 1511367543,
                "creation_date": 1511333139,
                "answer_id": 47428379,
                "question_id": 47413270,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "So finally by trying multiple answers I thought to post the actual solution to the problem.\r\n\r\nfile1.json:\r\n\r\n    \r\n  \r\n\r\n    {\r\n                    &quot;kind&quot;: &quot;PilotService&quot;,\r\n                    &quot;apiVersion&quot;: &quot;rbac.newDevops.com/v1&quot;,\r\n                    &quot;type&quot;: &quot;attribute-based&quot;,\r\n                    &quot;metadata&quot;: {\r\n                        &quot;name&quot;: &quot;apache&quot;,\r\n                        &quot;description&quot;: &quot;apache service as a process&quot;\r\n                    },\r\n                    &quot;spec&quot;: {\r\n                        &quot;addresses&quot;: [\r\n                            &quot;172.22.0.7/24:80&quot;\r\n                        ]\r\n                    }\r\n    }\r\n\r\n\r\n\r\nfile2.json:\r\n\r\n    [\r\n      {\r\n        &quot;kind&quot;: &quot;SpecialService&quot;,\r\n        &quot;type&quot;: &quot;attribute&quot;,\r\n        &quot;spec&quot;: {\r\n          &quot;addresses&quot;: [\r\n            &quot;172.21.3.196:6379&quot;\r\n          ]\r\n        },\r\n        &quot;apiVersion&quot;: &quot;rbac.newDevops.com/v1&quot;,\r\n        &quot;metadata&quot;: {\r\n          &quot;name&quot;: &quot;redis&quot;,\r\n          &quot;description&quot;: &quot;autogenerated by superagent.py script&quot;\r\n        }\r\n      },\r\n    ]\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\non the shell terminal:\r\n\r\n    object=`cat file2.json`\r\n\r\n    jq --argjson object &quot;$object&quot; &quot;. + [$object]&quot; file1.json &gt; beta.json\r\n\r\n\r\n\r\n",
                "title": "how to add an element in json file which is located on remote machine"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": -1,
        "last_activity_date": 1511367543,
        "creation_date": 1511267725,
        "last_edit_date": 1511270116,
        "question_id": 47413270,
        "body_markdown": "I have a file `services.json` which is located on remote machine,\r\n\r\n    [\r\n      {\r\n        &quot;kind&quot;: &quot;SpecialService&quot;,\r\n        &quot;type&quot;: &quot;attribute&quot;,\r\n        &quot;spec&quot;: {\r\n          &quot;addresses&quot;: [\r\n            &quot;172.21.3.196:6379&quot;\r\n          ]\r\n        },\r\n        &quot;apiVersion&quot;: &quot;rbac.newDevops.com/v1&quot;,\r\n        &quot;metadata&quot;: {\r\n          &quot;name&quot;: &quot;redis&quot;,\r\n          &quot;description&quot;: &quot;autogenerated by superagent.py script&quot;\r\n        }\r\n      },\r\n    ]\r\n\r\nNow, the task is to append the above file with the following element in json.\r\n\r\n\r\n    {\r\n                &quot;kind&quot;: &quot;PilotService&quot;,\r\n                &quot;apiVersion&quot;: &quot;rbac.newDevops.com/v1&quot;,\r\n                &quot;type&quot;: &quot;attribute-based&quot;,\r\n                &quot;metadata&quot;: {\r\n                    &quot;name&quot;: &quot;apache&quot;,\r\n                    &quot;description&quot;: &quot;apache service as a process&quot;\r\n                },\r\n                &quot;spec&quot;: {\r\n                    &quot;addresses&quot;: [\r\n                        &quot;172.22.0.7/24:80&quot;\r\n                    ]\r\n                }\r\n    }\r\n\r\nOnce we add the content into the json file we need to close the array of the existing json. (The file content starts with an array.)\r\n\r\nI tried using python to perform ssh to the remote machine but I&#39;m failing in editing json on remote machine using `jq` or with `open` of python\r\n\r\nAny guidance on this like how do we edit json files on remote machine?",
        "link": "https://stackoverflow.com/questions/47413270/how-to-add-an-element-in-json-file-which-is-located-on-remote-machine",
        "title": "how to add an element in json file which is located on remote machine"
    },
    {
        "tags": [
            "jq",
            "jqtransform"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1511286082,
                "last_edit_date": 1511286082,
                "creation_date": 1511283687,
                "answer_id": 47418651,
                "question_id": 47418378,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "I think you are very close.  You just need to use `.output.text[]` and take advantage of how [Object Construction](https://stedolan.github.io/jq/manual/#ObjectConstruction:{}) behaves when a member expression returns multiple results. Try this:\r\n\r\n    {\r\n     &quot;localDB&quot; : [{\r\n       &quot;tableName&quot;: &quot;Default&quot;,\r\n       &quot;mode&quot;: &quot;append&quot;,\r\n       &quot;data&quot;: [\r\n         {&quot;time&quot; : now|tostring, &quot;message&quot; : .input.text,   &quot;from&quot; : &quot;me&quot;},\r\n         {&quot;time&quot; : now|tostring, &quot;message&quot; :.output.text[], &quot;from&quot; : &quot;bot&quot;}\r\n      ]\r\n     }]\r\n    }\r\n\r\nSample Output\r\n\r\n    {\r\n      &quot;localDB&quot;: [\r\n        {\r\n          &quot;tableName&quot;: &quot;Default&quot;,\r\n          &quot;mode&quot;: &quot;append&quot;,\r\n          &quot;data&quot;: [\r\n            {\r\n              &quot;time&quot;: &quot;1511283566.11608&quot;,\r\n              &quot;message&quot;: &quot;HI&quot;,\r\n              &quot;from&quot;: &quot;me&quot;\r\n            },\r\n            {\r\n              &quot;time&quot;: &quot;1511283566.116094&quot;,\r\n              &quot;message&quot;: &quot;OK1&quot;,\r\n              &quot;from&quot;: &quot;bot&quot;\r\n            },\r\n            {\r\n              &quot;time&quot;: &quot;1511283566.116094&quot;,\r\n              &quot;message&quot;: &quot;TWO&quot;,\r\n              &quot;from&quot;: &quot;bot&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n[Try it online!](https://tio.run/##lY9Bi8IwEIXv/oow57TgtUfxsIugF8FD6WHcRqmkmdpOUaj562anqYoezSGPvBe@mXc6hwEq1/QM2QBsrqLw8wteA/X8YeewWc1Bw3a3gcL72S0oOcNsvBVY@kO7XIDKVP7wxGXcW7PG2kCmYGkO2FsG/YprKmOCTWNc@RaUyChB/jRkDnAlGME7utyYOm4rd9TCMF2Hx5iksUg6rqtHyqGlevTljxT6ipVO7SMrL/Qba08M/sEqJvWT@hDu1HBFrgtJ4nprk7iQPFq8JBPxHw &quot;jq – Try It Online&quot;)\r\n\r\n---\r\n\r\nHere is a filter which uses a `settime` function to assign different times to the rows:\r\n\r\n    def settime: reduce range(length) as $i (.; .[$i].time = (now + $i|tostring));\r\n    {\r\n     &quot;localDB&quot; : [{\r\n       &quot;tableName&quot;: &quot;Default&quot;,\r\n       &quot;mode&quot;: &quot;append&quot;,\r\n       &quot;data&quot;: [\r\n         {&quot;message&quot; : .input.text,   &quot;from&quot; : &quot;me&quot;},\r\n         {&quot;message&quot; :.output.text[], &quot;from&quot; : &quot;bot&quot;}\r\n       ] | settime\r\n     }]\r\n    }\r\n\r\nSample Output\r\n\r\n    {\r\n      &quot;localDB&quot;: [\r\n        {\r\n          &quot;tableName&quot;: &quot;Default&quot;,\r\n          &quot;mode&quot;: &quot;append&quot;,\r\n          &quot;data&quot;: [\r\n            {\r\n              &quot;message&quot;: &quot;HI&quot;,\r\n              &quot;from&quot;: &quot;me&quot;,\r\n              &quot;time&quot;: &quot;1511285948.684203&quot;\r\n            },\r\n            {\r\n              &quot;message&quot;: &quot;OK1&quot;,\r\n              &quot;from&quot;: &quot;bot&quot;,\r\n              &quot;time&quot;: &quot;1511285949.684243&quot;\r\n            },\r\n            {\r\n              &quot;message&quot;: &quot;TWO&quot;,\r\n              &quot;from&quot;: &quot;bot&quot;,\r\n              &quot;time&quot;: &quot;1511285950.684261&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n[Try it online!](https://tio.run/##bVBNa4QwEL3vrxiGPSjVQK8uvZQ9tBS6l0IP4iG7ztqUmFgzsgXNX6@NWssWmkOGeR8zyXv/GHtUpukYsx6ZPkPFh0f0CdqO/8A5Hp5uMcGX1wMW3m@GEcIp6QyOmFVNGbRUdieCVpqKIk2m4rcYpIOtgkjsQORbVYhJCncQGXuBm0ANbB23ylRxvNtMI/v5BtT2JPX@HiGD/AcLKMujpmdZE2aAezrLTjMmv3Rty5mRTUOmvCJKyTIQ@QqEPViTc7KiaYOYQxDTV5NJfm5tPeFBE8L43ySWiGZTXiRXpqNl9KupgGGNaIF8MVc/jl@2YWWNG9PUdFqn8yNC08pLugz/Bg &quot;jq – Try It Online&quot;)",
                "title": "How can I JQ transform array into a different array, joint with other data?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1511286082,
        "creation_date": 1511282827,
        "question_id": 47418378,
        "body_markdown": "I need to transform this:\r\n\r\n    {&quot;input&quot;:{&quot;text&quot;:&quot;HI&quot;},&quot;output&quot;:{&quot;text&quot;:[&quot;OK1&quot;,&quot;TWO&quot;]}}\r\n\r\nInto this:\r\n\r\n    {\r\n      &quot;localDB&quot;: [\r\n        {\r\n          &quot;tableName&quot;: &quot;Default&quot;,\r\n          &quot;mode&quot;: &quot;append&quot;,\r\n          &quot;data&quot;: [\r\n            {\r\n              &quot;time&quot;: &quot;1511281401.991815&quot;,\r\n              &quot;message&quot;: &quot;HI&quot;,\r\n              &quot;from&quot;: &quot;me&quot;\r\n            },\r\n            {\r\n              &quot;time&quot;: &quot;1511281401.991837&quot;,\r\n              &quot;message&quot;: &quot;OK1&quot;\r\n              &quot;from&quot;: &quot;bot&quot;\r\n            }\r\n            {\r\n              &quot;time&quot;: &quot;1511281401.991847&quot;,\r\n              &quot;message&quot;: &quot;TWO&quot;\r\n              &quot;from&quot;: &quot;bot&quot;\r\n    }\r\n    ]}]}\r\n\r\nIs it possible at all?\r\n\r\nKey issue here is that number of &quot;records&quot; in the localDB &lt;b&gt;should vary depending on&lt;/b&gt; the number of entries in .output.text node. There could be just one text, or three or more.\r\n\r\nI tried with this, but it is not quite working:\r\n\r\n    {\r\n     &quot;localDB&quot; : [{\r\n       &quot;tableName&quot;: &quot;Default&quot;,\r\n       &quot;mode&quot;: &quot;append&quot;,\r\n       &quot;data&quot;: [\r\n         {&quot;time&quot; : now|tostring, &quot;message&quot; : .input.text, &quot;from&quot; : &quot;me&quot;},\r\n         {&quot;time&quot; : now|tostring, &quot;message&quot; :.output.text, &quot;from&quot; : &quot;bot&quot;}\r\n      ]\r\n     }]\r\n    }",
        "link": "https://stackoverflow.com/questions/47418378/how-can-i-jq-transform-array-into-a-different-array-joint-with-other-data",
        "title": "How can I JQ transform array into a different array, joint with other data?"
    },
    {
        "tags": [
            "json",
            "bash",
            "terminal",
            "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": 1511289659,
                "post_id": 47419750,
                "comment_id": 81794909,
                "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": 1511308970,
                "post_id": 47419750,
                "comment_id": 81804381,
                "content_license": "CC BY-SA 3.0"
            },
            {
                "owner": {
                    "account_id": 412243,
                    "reputation": 3776,
                    "user_id": 785213,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4afc5a37218ad4f1d104492e4b4d3657?s=256&d=identicon&r=PG",
                    "display_name": "Kevin E",
                    "link": "https://stackoverflow.com/users/785213/kevin-e"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1716384973,
                "post_id": 47419750,
                "comment_id": 138422921,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1511291209,
                "creation_date": 1511291209,
                "answer_id": 47420819,
                "question_id": 47419750,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "`jq` doesn&#39;t fetch pages. You need to fetch pages with multiple `curl` calls, and then combine the JSON outputs.\r\nFor example you could get a JSON array of the combined `.item` properties:\r\n\r\n    url=https://mywebsite.com/api/cars.json\r\n    jq -s &#39;.[0].items + .[1].items&#39; &lt;(curl &quot;$url&amp;page=1&quot; | jq .) &lt;(curl &quot;$url&amp;page=2&quot; | jq .)\r\n\r\nIf you don&#39;t know in advance the number of pages you&#39;ll need,\r\nthen you&#39;ll need to work a bit harder, but it&#39;s of course possible.\r\n\r\nGet the total entries from the first page:\r\n\r\n    total=$(curl &quot;$url&amp;page=1&quot; | jq .total_entries)\r\n\r\nCompute the number of pages:\r\n\r\n    ((pages = total / 100))\r\n    \r\n    if ((total % 100 &gt; 0)); then\r\n        ((pages++))\r\n    else\r\n\r\nAnd then you can write a loop to download the results page by page,\r\ngenerate the `jq` command `.[0].items + ... + .[n].items` and call `jq` with it to get the combined JSON array.",
                "title": "Fetch multiple pages of json with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1671419110,
                "creation_date": 1671419110,
                "answer_id": 74845954,
                "question_id": 47419750,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you can download all of the pages and create an array of all of the entries (much like @janos answer above), then you need not computationally generate the `jq` command.  Instead you can use `flatten` as in\r\n`jq &#39;[.[].items] | flatten&#39;` ",
                "title": "Fetch multiple pages of json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1671419110,
        "creation_date": 1511287355,
        "question_id": 47419750,
        "body_markdown": "When calling an API, I am returned a json that can be pretty printed with \r\n\r\n    curl &quot;https://mywebsite.com/api/cars.json&amp;page=1&quot; |  jq &#39;.&#39; \r\n\r\nBelow is a sample output.  Seeing as there are two pages of records (112 total entries and only 100 entries showing per page), what command can I use in `jq` to immediately fetch both pages of data?\r\n\r\n\r\n    {\r\n      &quot;current_page&quot;: 1,\r\n      &quot;per_page&quot;: 100,\r\n      &quot;total_entries&quot;: 112,\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;id&quot;: 1,\r\n          &quot;name&quot;: &quot;vehicleA&quot;,\r\n          &quot;state&quot;: &quot;available&quot;,\r\n          &quot;charge&quot;: 100\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;name&quot;: &quot;vehicleB&quot;,\r\n          &quot;state&quot;: &quot;available&quot;,\r\n          &quot;charge&quot;: 75\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;name&quot;: &quot;vehicleB&quot;,\r\n          &quot;state&quot;: &quot;available&quot;,\r\n          &quot;charge&quot;: 50\r\n        }...\r\n\r\n\r\n   ",
        "link": "https://stackoverflow.com/questions/47419750/fetch-multiple-pages-of-json-with-jq",
        "title": "Fetch multiple pages of json with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "count",
            "jq",
            "missing-data"
        ],
        "answers": [
            {
                "up_vote_count": 17,
                "is_accepted": true,
                "score": 17,
                "last_activity_date": 1511293314,
                "last_edit_date": 1511293314,
                "creation_date": 1511292030,
                "answer_id": 47421029,
                "question_id": 47420833,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution using [`map`](https://stedolan.github.io/jq/manual/#map\\(x\\),map_values\\(x\\)) and [`length`](https://stedolan.github.io/jq/manual/#length):\r\n\r\n    .items | map(select(.charge == null)) | length\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/1KIqTcoRWt)\r\n\r\nHere is a more efficient solution using [`reduce`](https://stedolan.github.io/jq/manual/#Reduce):\r\n\r\n    reduce (.items[] | select(.charge == null)) as $i (0;.+=1)\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/5Uc6-Lkxpv)\r\n\r\nSample Run (assuming corrected JSON data in `data.json`)\r\n\r\n    $ jq -M &#39;reduce (.items[] | select(.charge == null)) as $i (0;.+=1)&#39; data.json\r\n    1\r\n\r\nNote that each of the above takes a minor shortcut assuming that the items won&#39;t have a `&quot;charge&quot;:null` member.  If some items could have a `null` charge then the test for `== null` won&#39;t distinguish between those items and items without the `charge` key.  If this is a concern the following forms of the above filters which use [`has`](https://stedolan.github.io/jq/manual/#has\\(key\\)) are better:\r\n\r\n    .items | map(select(has(&quot;charge&quot;)|not)) | length\r\n\r\n    reduce (.items[] | select(has(&quot;charge&quot;)|not)) as $i (0;.+=1)\r\n",
                "title": "Count records with missing keys using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1511338264,
                "last_edit_date": 1511338264,
                "creation_date": 1511308075,
                "answer_id": 47424638,
                "question_id": 47420833,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Here is a solution that uses a simple but powerful utility function worthy perhaps of your standard library:\r\n\r\n    def sigma(stream): reduce stream as $s (null; . + $s);\r\n\r\nThe filter you&#39;d use with this would be:\r\n\r\n    sigma(.items[] | select(has(&quot;charge&quot;) == false) | 1)\r\n\r\nThis is very efficient as no intermediate array is required, and no useless additions of 0 are involved. Also, as mentioned elsewhere, using `has` is more robust than making assumptions about the value of `.charge`.\r\n\r\n### Startup file\r\n\r\nIf you have no plans to use jq&#39;s module system, you can simply add the above definition of `sigma` to the file ~/.jq and invoke jq like so:\r\n\r\n    jq &#39;sigma(.items[] | select(has(&quot;charge&quot;) == false) | 1)&#39;\r\n\r\nBetter yet, if you also add `def count(s): sigma(s|1);` to the file, the invocation would simply be:\r\n\r\n    jq &#39;count(.items[] | select(has(&quot;charge&quot;) | not))&#39;\r\n\r\n### Standard Library\r\n\r\nIf for example ~/.jq/jq/jq.jq is your standard library, then assuming `count/1` is included in this file, you could invoke jq like so:\r\n\r\n    jq &#39;include &quot;jq&quot;; count(.items[] | select(has(&quot;charge&quot;) == false))&#39;\r\n\r\n",
                "title": "Count records with missing keys using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 8,
        "last_activity_date": 1511338264,
        "creation_date": 1511291252,
        "last_edit_date": 1511308189,
        "question_id": 47420833,
        "body_markdown": "\r\nBelow is a sample output that is returned when calling an API:\r\n\r\n    curl &quot;https://mywebsite.com/api/cars.json&amp;page=1&quot; |  jq &#39;.&#39; \r\n\r\nUsing `jq`, how would one count the number or records where the `charge` key is missing?  I understand that the first bit of code would include `jq &#39;. | length&#39;` but how would one filter out objects that contain or don&#39;t contain a certain key value ?\r\n\r\nIf applied to the sample below, the output would be `1`\r\n\r\n\r\n    {\r\n      &quot;current_page&quot;: 1,\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;id&quot;: 1,\r\n          &quot;name&quot;: &quot;vehicleA&quot;,\r\n          &quot;state&quot;: &quot;available&quot;,\r\n          &quot;charge&quot;: 100\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;name&quot;: &quot;vehicleB&quot;,\r\n          &quot;state&quot;: &quot;available&quot;,\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;name&quot;: &quot;vehicleB&quot;,\r\n          &quot;state&quot;: &quot;available&quot;,\r\n          &quot;charge&quot;: 50\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n\r\n   ",
        "link": "https://stackoverflow.com/questions/47420833/count-records-with-missing-keys-using-jq",
        "title": "Count records with missing keys using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1511295936,
                "creation_date": 1511295936,
                "answer_id": 47422063,
                "question_id": 47421993,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "Your question is not exactly accurate:\r\n\r\n- The example JSON is invalid, because the last property of the second object has a trailing comma, which should raise a parsing error\r\n- The output of `map(select(.charge == null))` is not an object as in the example, but an array of a single object\r\n\r\nIn any case, you can extract the `.id` from the result of `map` like this:\r\n\r\n    jq -M &#39;map(select(.charge == null)) | .[].id&#39; file.json",
                "title": "Get specific key value pairs with jq"
            },
            {
                "up_vote_count": 6,
                "is_accepted": false,
                "score": 6,
                "last_activity_date": 1511296019,
                "creation_date": 1511296019,
                "answer_id": 47422094,
                "question_id": 47421993,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "If you would like an array of ids for items without a charge you could use this filter:\r\n\r\n    .items | map(select(.charge == null) | .id)\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/K_-O_YrxD5)\r\n\r\nIf you want the values enumerated instead of being collected into an array this is better:\r\n\r\n    .items[] | select(.charge == null) | .id\r\n\r\n[Try it online at jqplay.org](https://jqplay.org/s/L-Rnd1C6yv)\r\n",
                "title": "Get specific key value pairs with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1511296019,
        "creation_date": 1511295602,
        "question_id": 47421993,
        "body_markdown": "In my sample json below,  I can filter records where charge is null with `jq -M &#39; map(select(.charge == null)) &#39;` \r\n\r\n      [\r\n        {\r\n          &quot;id&quot;: 1,\r\n          &quot;name&quot;: &quot;vehicleA&quot;,\r\n          &quot;state&quot;: &quot;available&quot;,\r\n          &quot;charge&quot;: 100\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;name&quot;: &quot;vehicleB&quot;,\r\n          &quot;state&quot;: &quot;available&quot;,\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;name&quot;: &quot;vehicleB&quot;,\r\n          &quot;state&quot;: &quot;available&quot;,\r\n          &quot;charge&quot;: 50\r\n        }\r\n      ]\r\n\r\nwhich returns:\r\n\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;name&quot;: &quot;vehicleB&quot;,\r\n      &quot;state&quot;: &quot;available&quot;,\r\n    }\r\n\r\nHow would one only get `id` and the value associated with `id` of the filtered records so that adding this step to the above query would return `2`?  \r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/47421993/get-specific-key-value-pairs-with-jq",
        "title": "Get specific key value pairs with jq"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "jq",
            "lookup-tables"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1511363911,
                "creation_date": 1511363911,
                "answer_id": 47438214,
                "question_id": 47437773,
                "content_license": "CC BY-SA 3.0",
                "body_markdown": "The key to a good answer here is:\r\n\r\n    .Customer.City |= $codes[.]\r\n\r\n",
                "title": "Replacing values in JSON using values from another file with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1596729636,
                "last_edit_date": 1596729636,
                "creation_date": 1596728504,
                "answer_id": 63287157,
                "question_id": 47437773,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n\r\n    jq --argfile codes codes.json &#39;select(.Customer?)|{(.Customer.City):$codes[.Customer.City]}&#39; data.json | jq -n &#39;[inputs] | add&#39;",
                "title": "Replacing values in JSON using values from another file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1596729636,
        "creation_date": 1511362686,
        "last_edit_date": 1511368553,
        "question_id": 47437773,
        "body_markdown": "I have a json file with city names in it and I would like to replace them with particular city codes from another file. The `data.json` is roughly:\r\n\r\n    {\r\n      &quot;Customer&quot;: {\r\n        &quot;CustomerName&quot;: &quot;Customer1&quot;,\r\n        &quot;City&quot;: &quot;Cityname1&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;RelevantObject&quot;: false\r\n    }\r\n    {\r\n      &quot;Customer&quot;: {\r\n        &quot;CustomerName&quot;: &quot;Customer2&quot;,\r\n        &quot;City&quot;: &quot;Cityname2&quot;\r\n      }\r\n    }\r\n    # {...\r\n\r\nThe code list can be anything that is the easiest to feed to jq, I&#39;ve been trying with `codes.json`:\r\n\r\n    {\r\n      &quot;Cityname1&quot;: &quot;Code1&quot;,\r\n      &quot;Cityname2&quot;: &quot;Code2&quot; \r\n    }\r\n\r\nbut like I said, any format is fine. The hoped result:\r\n\r\n    {\r\n      &quot;Customer&quot;: {\r\n        &quot;CustomerName&quot;: &quot;Customer1&quot;,\r\n        &quot;City&quot;: &quot;Code1&quot;\r\n      }\r\n    }\r\n    {\r\n      &quot;RelevantObject&quot;: false\r\n    }\r\n    {\r\n      &quot;Customer&quot;: {\r\n        &quot;CustomerName&quot;: &quot;Customer2&quot;,\r\n        &quot;City&quot;: &quot;Code2&quot;\r\n      }\r\n    }\r\n\r\nI&#39;ve been trying to read the file in with `jq --argfile codes codes.json` but I&#39;ve had a hard time of referring to the `$codes` in the `jq`:  `.Customer.City=$codes.?`?\r\n",
        "link": "https://stackoverflow.com/questions/47437773/replacing-values-in-json-using-values-from-another-file-with-jq",
        "title": "Replacing values in JSON using values from another file with jq"
    }
]